content-hooks-frames.js 2.4 KB

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