ui.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright 2018 Gildas Lormeau
  3. * contact : gildas.lormeau <at> gmail.com
  4. *
  5. * This file is part of SingleFile.
  6. *
  7. * SingleFile is free software: you can redistribute it and/or modify
  8. * it under the terms of the GNU Lesser General Public License as published by
  9. * the Free Software Foundation, either version 3 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * SingleFile 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
  15. * GNU Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public License
  18. * along with SingleFile. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. /* global singlefile, document */
  21. singlefile.ui = (() => {
  22. const MASK_ID = "__SingleFile_mask__";
  23. return {
  24. processStart() {
  25. let maskElement = document.getElementById(MASK_ID);
  26. if (!maskElement) {
  27. maskElement = document.createElement("singlefile-mask");
  28. maskElement.id = "__SingleFile_mask__";
  29. maskElement.style.all = "unset";
  30. maskElement.style.position = "fixed";
  31. maskElement.style.top = "0px";
  32. maskElement.style.left = "0px";
  33. maskElement.style.height = "100%";
  34. maskElement.style.width = "100%";
  35. maskElement.style.backgroundColor = "black";
  36. maskElement.style.zIndex = 2147483647;
  37. maskElement.style.opacity = 0;
  38. maskElement.style.transition = "opacity 250ms";
  39. document.body.appendChild(maskElement);
  40. maskElement.offsetWidth;
  41. maskElement.style.opacity = .3;
  42. }
  43. },
  44. processEnd() {
  45. const maskElement = document.getElementById(MASK_ID);
  46. if (maskElement) {
  47. maskElement.remove();
  48. }
  49. }
  50. };
  51. })();