| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- /*
- * Copyright 2018 Gildas Lormeau
- * contact : gildas.lormeau <at> gmail.com
- *
- * This file is part of SingleFile.
- *
- * SingleFile is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * SingleFile 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 Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with SingleFile. If not, see <http://www.gnu.org/licenses/>.
- */
- /* global browser, document, timeout, MutationObserver */
- this.lazyLoader = this.lazyLoader || (() => {
- const LAZY_LOADING_TIMEOUT = 1000;
- const IDLE_LAZY_LOADING_TIMEOUT = 3000;
- const MAX_LAZY_LOADING_TIMEOUT = 30000;
- return { process };
- async function process() {
- const scriptURL = browser.runtime.getURL("lib/lazy/web-lazy-loader-before.js");
- const scriptBeforeElement = document.createElement("script");
- scriptBeforeElement.src = scriptURL;
- document.body.appendChild(scriptBeforeElement);
- let timeoutId, maxTimeoutId, idleTimeoutId;
- const promise = new Promise(resolve => {
- let srcAttributeChanged;
- scriptBeforeElement.onload = () => scriptBeforeElement.remove();
- const observer = new MutationObserver(() => {
- srcAttributeChanged = true;
- timeoutId = deferLazyLoadEnd(timeoutId, maxTimeoutId, idleTimeoutId, observer, resolve);
- });
- observer.observe(document, { attributeFilter: ["src", "srcset"], subtree: true });
- idleTimeoutId = timeout.set(() => {
- if (!srcAttributeChanged) {
- timeout.clear(timeoutId);
- lazyLoadEnd(maxTimeoutId, idleTimeoutId, observer, resolve);
- }
- }, IDLE_LAZY_LOADING_TIMEOUT);
- maxTimeoutId = timeout.set(() => {
- timeout.clear(timeoutId);
- lazyLoadEnd(maxTimeoutId, idleTimeoutId, observer, resolve);
- }, MAX_LAZY_LOADING_TIMEOUT);
- });
- return promise;
- }
- function deferLazyLoadEnd(timeoutId, maxTimeoutId, idleTimeoutId, observer, resolve) {
- timeout.clear(timeoutId);
- return timeout.set(() => lazyLoadEnd(maxTimeoutId, idleTimeoutId, observer, resolve), LAZY_LOADING_TIMEOUT);
- }
- function lazyLoadEnd(maxTimeoutId, idleTimeoutId, observer, resolve) {
- timeout.clear(maxTimeoutId);
- timeout.clear(idleTimeoutId);
- timeout.set(resolve, LAZY_LOADING_TIMEOUT);
- const scriptURL = browser.runtime.getURL("lib/lazy/web-lazy-loader-after.js");
- const scriptAfterElement = document.createElement("script");
- scriptAfterElement.src = scriptURL;
- document.body.appendChild(scriptAfterElement);
- scriptAfterElement.onload = () => scriptAfterElement.remove();
- observer.disconnect();
- }
- })();
|