content-hooks-frames.js 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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 browser, addEventListener, dispatchEvent, CustomEvent, document, HTMLDocument */
  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 fontFaces = [];
  35. if (document instanceof HTMLDocument) {
  36. let scriptElement = document.createElement("script");
  37. if (this.browser && browser.runtime && browser.runtime.getURL) {
  38. scriptElement.src = browser.runtime.getURL("/lib/hooks/content/content-hooks-frames-web.js");
  39. scriptElement.async = false;
  40. } else if (this.singlefile.lib.getFileContent) {
  41. scriptElement.textContent = this.singlefile.lib.getFileContent("/lib/hooks/content/content-hooks-frames-web.js");
  42. }
  43. (document.documentElement || document).appendChild(scriptElement);
  44. scriptElement.remove();
  45. addEventListener(NEW_FONT_FACE_EVENT, event => fontFaces.push(event.detail));
  46. }
  47. return {
  48. getFontsData: () => fontFaces,
  49. loadDeferredImagesStart: options => {
  50. if (options.loadDeferredImagesBlockCookies) {
  51. dispatchEvent(new CustomEvent(BLOCK_COOKIES_START_EVENT));
  52. }
  53. if (options.loadDeferredImagesBlockStorage) {
  54. dispatchEvent(new CustomEvent(BLOCK_STORAGE_START_EVENT));
  55. }
  56. dispatchEvent(new CustomEvent(LOAD_DEFERRED_IMAGES_START_EVENT));
  57. },
  58. loadDeferredImagesEnd: options => {
  59. if (options.loadDeferredImagesBlockCookies) {
  60. dispatchEvent(new CustomEvent(BLOCK_COOKIES_END_EVENT));
  61. }
  62. if (options.loadDeferredImagesBlockStorage) {
  63. dispatchEvent(new CustomEvent(BLOCK_STORAGE_END_EVENT));
  64. }
  65. dispatchEvent(new CustomEvent(LOAD_DEFERRED_IMAGES_END_EVENT));
  66. },
  67. LOAD_IMAGE_EVENT,
  68. IMAGE_LOADED_EVENT
  69. };
  70. })();