From a7e4901f728ac3069d9ae6a185b44971178a10a0 Mon Sep 17 00:00:00 2001 From: toasted-nutbread Date: Sun, 1 Dec 2019 15:19:21 -0500 Subject: Move PageExitPrevention to its own file --- ext/bg/js/page-exit-prevention.js | 60 +++++++++++++++++++++++++++++++++++++++ ext/bg/js/settings.js | 46 ------------------------------ ext/bg/settings.html | 1 + 3 files changed, 61 insertions(+), 46 deletions(-) create mode 100644 ext/bg/js/page-exit-prevention.js diff --git a/ext/bg/js/page-exit-prevention.js b/ext/bg/js/page-exit-prevention.js new file mode 100644 index 00000000..aee4e3c2 --- /dev/null +++ b/ext/bg/js/page-exit-prevention.js @@ -0,0 +1,60 @@ +/* + * Copyright (C) 2019 Alex Yatskov + * Author: Alex Yatskov + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + + +class PageExitPrevention { + constructor() { + } + + start() { + PageExitPrevention._addInstance(this); + } + + end() { + PageExitPrevention._removeInstance(this); + } + + static _addInstance(instance) { + const size = PageExitPrevention._instances.size; + PageExitPrevention._instances.set(instance, true); + if (size === 0) { + window.addEventListener('beforeunload', PageExitPrevention._onBeforeUnload); + } + } + + static _removeInstance(instance) { + if ( + PageExitPrevention._instances.delete(instance) && + PageExitPrevention._instances.size === 0 + ) { + window.removeEventListener('beforeunload', PageExitPrevention._onBeforeUnload); + } + } + + static _onBeforeUnload(e) { + if (PageExitPrevention._instances.size === 0) { + return; + } + + e.preventDefault(); + e.returnValue = ''; + return ''; + } +} + +PageExitPrevention._instances = new Map(); diff --git a/ext/bg/js/settings.js b/ext/bg/js/settings.js index abe6f389..9e9604e2 100644 --- a/ext/bg/js/settings.js +++ b/ext/bg/js/settings.js @@ -222,52 +222,6 @@ async function onReady() { $(document).ready(() => onReady()); -/* - * Page exit prevention - */ - -class PageExitPrevention { - constructor() { - } - - start() { - PageExitPrevention._addInstance(this); - } - - end() { - PageExitPrevention._removeInstance(this); - } - - static _addInstance(instance) { - const size = PageExitPrevention._instances.size; - PageExitPrevention._instances.set(instance, true); - if (size === 0) { - window.addEventListener('beforeunload', PageExitPrevention._onBeforeUnload); - } - } - - static _removeInstance(instance) { - if ( - PageExitPrevention._instances.delete(instance) && - PageExitPrevention._instances.size === 0 - ) { - window.removeEventListener('beforeunload', PageExitPrevention._onBeforeUnload); - } - } - - static _onBeforeUnload(e) { - if (PageExitPrevention._instances.size === 0) { - return; - } - - e.preventDefault(); - e.returnValue = ''; - return ''; - } -} -PageExitPrevention._instances = new Map(); - - /* * Appearance */ diff --git a/ext/bg/settings.html b/ext/bg/settings.html index 908c618c..9edb48e5 100644 --- a/ext/bg/settings.html +++ b/ext/bg/settings.html @@ -876,6 +876,7 @@ + -- cgit v1.2.3