From 3e6a88d31d4a9569f6fc93ffb826edb12caf20d0 Mon Sep 17 00:00:00 2001 From: Danny Coates Date: Mon, 12 Mar 2018 10:15:11 -0700 Subject: [PATCH] render header and footer only once. fixes #788 --- app/fileManager.js | 37 +++++++++++++++--------------- app/templates/footer/index.js | 9 +++++++- app/templates/header/index.js | 42 +++++++++++++++++++++-------------- 3 files changed, 52 insertions(+), 36 deletions(-) diff --git a/app/fileManager.js b/app/fileManager.js index 897dda4f..786f99f8 100644 --- a/app/fileManager.js +++ b/app/fileManager.js @@ -110,21 +110,21 @@ export default function(state, emitter) { } await delay(1000); await fadeOut('.page'); - openLinksInNewTab(links, false); emitter.emit('pushState', `/share/${ownedFile.id}`); } catch (err) { - // eslint-disable-next-line no-console - console.error(err); - if (err.message === '0') { //cancelled. do nothing metrics.cancelledUpload({ size, type }); - return render(); + render(); + } else { + // eslint-disable-next-line no-console + console.error(err); + state.raven.captureException(err); + metrics.stoppedUpload({ size, type, err }); + emitter.emit('pushState', '/error'); } - state.raven.captureException(err); - metrics.stoppedUpload({ size, type, err }); - emitter.emit('pushState', '/error'); } finally { + openLinksInNewTab(links, false); state.uploading = false; state.transfer = null; } @@ -188,17 +188,18 @@ export default function(state, emitter) { if (err.message === '0') { // download cancelled state.transfer.reset(); - return render(); + render(); + } else { + // eslint-disable-next-line no-console + console.error(err); + state.transfer = null; + const location = err.message === '404' ? '/404' : '/error'; + if (location === '/error') { + state.raven.captureException(err); + metrics.stoppedDownload({ size, err }); + } + emitter.emit('pushState', location); } - // eslint-disable-next-line no-console - console.error(err); - state.transfer = null; - const location = err.message === '404' ? '/404' : '/error'; - if (location === '/error') { - state.raven.captureException(err); - metrics.stoppedDownload({ size, err }); - } - emitter.emit('pushState', location); } finally { openLinksInNewTab(links, false); } diff --git a/app/templates/footer/index.js b/app/templates/footer/index.js index e81d5b3d..a0ad4de5 100644 --- a/app/templates/footer/index.js +++ b/app/templates/footer/index.js @@ -2,7 +2,7 @@ const html = require('choo/html'); const assets = require('../../../common/assets'); module.exports = function(state) { - return html`