content-hooks-frames.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /*
  2. * Copyright 2010-2019 Gildas Lormeau
  3. * contact : gildas.lormeau <at> gmail.com
  4. *
  5. * This file is part of SingleFile.
  6. *
  7. * The code in this file is free software: you can redistribute it and/or
  8. * modify it under the terms of the GNU Affero General Public License
  9. * (GNU AGPL) as published by the Free Software Foundation, either version 3
  10. * of the License, or (at your option) any later version.
  11. *
  12. * The code in this file is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero
  15. * General Public License for more details.
  16. *
  17. * As additional permission under GNU AGPL version 3 section 7, you may
  18. * distribute UNMODIFIED VERSIONS OF THIS file without the copy of the GNU
  19. * AGPL normally required by section 4, provided you include this license
  20. * notice and a URL through which recipients can access the Corresponding
  21. * Source.
  22. */
  23. /* global window */
  24. this.singlefile.lib.hooks.content.frames = this.singlefile.lib.hooks.content.frames || (() => {
  25. const LOAD_DEFERRED_IMAGES_START_EVENT = "single-file-load-deferred-images-start";
  26. const LOAD_DEFERRED_IMAGES_END_EVENT = "single-file-load-deferred-images-end";
  27. const BLOCK_COOKIES_START_EVENT = "single-file-block-cookies-start";
  28. const BLOCK_COOKIES_END_EVENT = "single-file-block-cookies-end";
  29. const BLOCK_STORAGE_START_EVENT = "single-file-block-storage-start";
  30. const BLOCK_STORAGE_END_EVENT = "single-file-block-storage-end";
  31. const LOAD_IMAGE_EVENT = "single-file-load-image";
  32. const IMAGE_LOADED_EVENT = "single-file-image-loaded";
  33. const NEW_FONT_FACE_EVENT = "single-file-new-font-face";
  34. const browser = this.browser;
  35. const addEventListener = window.addEventListener;
  36. const dispatchEvent = window.dispatchEvent;
  37. const CustomEvent = window.CustomEvent;
  38. const document = window.document;
  39. const HTMLDocument = window.HTMLDocument;
  40. const fontFaces = [];
  41. if (document instanceof HTMLDocument) {
  42. let scriptElement = document.createElement("script");
  43. if (browser && browser.runtime && browser.runtime.getURL) {
  44. scriptElement.src = browser.runtime.getURL("/lib/hooks/content/content-hooks-frames-web.js");
  45. scriptElement.async = false;
  46. } else if (this.singlefile.lib.getFileContent) {
  47. scriptElement.textContent = this.singlefile.lib.getFileContent("/lib/hooks/content/content-hooks-frames-web.js");
  48. }
  49. (document.documentElement || document).appendChild(scriptElement);
  50. scriptElement.remove();
  51. addEventListener.call(window, NEW_FONT_FACE_EVENT, event => fontFaces.push(event.detail));
  52. }
  53. return {
  54. getFontsData: () => fontFaces,
  55. loadDeferredImagesStart: options => {
  56. if (options.loadDeferredImagesBlockCookies) {
  57. dispatchEvent.call(window, new CustomEvent(BLOCK_COOKIES_START_EVENT));
  58. }
  59. if (options.loadDeferredImagesBlockStorage) {
  60. dispatchEvent.call(window, new CustomEvent(BLOCK_STORAGE_START_EVENT));
  61. }
  62. dispatchEvent.call(window, new CustomEvent(LOAD_DEFERRED_IMAGES_START_EVENT));
  63. },
  64. loadDeferredImagesEnd: options => {
  65. if (options.loadDeferredImagesBlockCookies) {
  66. dispatchEvent.call(window, new CustomEvent(BLOCK_COOKIES_END_EVENT));
  67. }
  68. if (options.loadDeferredImagesBlockStorage) {
  69. dispatchEvent.call(window, new CustomEvent(BLOCK_STORAGE_END_EVENT));
  70. }
  71. dispatchEvent.call(window, new CustomEvent(LOAD_DEFERRED_IMAGES_END_EVENT));
  72. },
  73. LOAD_IMAGE_EVENT,
  74. IMAGE_LOADED_EVENT
  75. };
  76. })();