hooks.js 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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 history, dispatchEvent, CustomEvent, document, HTMLDocument */
  24. this.hooks = this.hooks || (() => {
  25. if (document instanceof HTMLDocument) {
  26. const scriptElement = document.createElement("script");
  27. scriptElement.textContent = `(${hookPushState.toString()})()`;
  28. (document.documentElement || document).appendChild(scriptElement);
  29. scriptElement.remove();
  30. }
  31. return true;
  32. function hookPushState() {
  33. const pushState = history.pushState;
  34. let warningDisplayed;
  35. history.pushState = function (state, title, url) {
  36. if (!warningDisplayed) {
  37. warningDisplayed = true;
  38. console.warn("SingleFile is hooking the history.pushState API to detect navigation."); // eslint-disable-line no-console
  39. }
  40. dispatchEvent(new CustomEvent("single-file-push-state", { detail: { state, title, url } }));
  41. pushState.call(history, state, title, url);
  42. };
  43. }
  44. })();