const choo = require('choo'); const html = require('choo/html'); const nanotiming = require('nanotiming'); const download = require('./download'); const footer = require('../templates/footer'); const fxPromo = require('../templates/fxPromo'); const signupPromo = require('../templates/signupPromo'); const activeBackground = require('../templates/activeBackground'); const fileList = require('../templates/fileList'); const profile = require('../templates/userAccount'); const modal = require('../templates/modal'); nanotiming.disabled = true; const app = choo(); function banner(state, emit) { if (state.promo && !state.route.startsWith('/unsupported/')) { return fxPromo(state, emit); } } function modalDialog(state, emit) { if (state.modal) { return modal(state, emit); } } function body(template) { return function(state, emit) { const b = html` ${modalDialog(state, emit)} ${banner(state, emit)}
${signupPromo(state)}
${profile(state, emit)} ${template(state, emit)}
${fileList(state)}
${footer(state)} `; if (state.layout) { // server side only return state.layout(state, b); } return b; }; } app.route('/', body(require('../pages/welcome'))); app.route('/share/:id', body(require('../pages/share'))); app.route('/download/:id', body(download)); app.route('/download/:id/:key', body(download)); app.route('/unsupported/:reason', body(require('../pages/unsupported'))); app.route('/legal', body(require('../pages/legal'))); app.route('/error', body(require('../pages/error'))); app.route('/blank', body(require('../pages/blank'))); app.route('/signin', body(require('../pages/signin'))); app.route('/api/fxa/oauth', function(state, emit) { emit('replaceState', '/'); setTimeout(() => emit('render')); }); app.route('*', body(require('../pages/notFound'))); module.exports = app;