content-hooks-frames.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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 LOAD_IMAGE_EVENT = "single-file-load-image";
  30. const IMAGE_LOADED_EVENT = "single-file-image-loaded";
  31. const NEW_FONT_FACE_EVENT = "single-file-new-font-face";
  32. const fontFaces = [];
  33. if (document instanceof HTMLDocument) {
  34. let scriptElement = document.createElement("script");
  35. if (this.browser && browser.runtime && browser.runtime.getURL) {
  36. scriptElement.src = browser.runtime.getURL("/lib/hooks/content/content-hooks-frames-web.js");
  37. scriptElement.async = false;
  38. } else if (this.singlefile.lib.getFileContent) {
  39. scriptElement.textContent = this.singlefile.lib.getFileContent("/lib/hooks/content/content-hooks-frames-web.js");
  40. }
  41. (document.documentElement || document).appendChild(scriptElement);
  42. scriptElement.remove();
  43. addEventListener(NEW_FONT_FACE_EVENT, event => fontFaces.push(event.detail));
  44. }
  45. return {
  46. getFontsData: () => fontFaces,
  47. loadDeferredImagesStart: options => {
  48. if (options.loadDeferredImagesBlockCookies) {
  49. dispatchEvent(new CustomEvent(BLOCK_COOKIES_START_EVENT));
  50. }
  51. dispatchEvent(new CustomEvent(LOAD_DEFERRED_IMAGES_START_EVENT));
  52. },
  53. loadDeferredImagesEnd: options => {
  54. if (options.loadDeferredImagesBlockCookies) {
  55. dispatchEvent(new CustomEvent(BLOCK_COOKIES_END_EVENT));
  56. }
  57. dispatchEvent(new CustomEvent(LOAD_DEFERRED_IMAGES_END_EVENT));
  58. },
  59. LOAD_IMAGE_EVENT,
  60. IMAGE_LOADED_EVENT
  61. };
  62. })();