ui.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  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 document */
  21. this.singlefile.ui = (() => {
  22. const MASK_TAGNAME = "singlefile-mask";
  23. return {
  24. init() {
  25. let maskElement = document.querySelector(MASK_TAGNAME);
  26. if (!maskElement) {
  27. maskElement = document.createElement(MASK_TAGNAME);
  28. maskElement.style.all = "unset";
  29. maskElement.style.position = "fixed";
  30. maskElement.style.top = "0px";
  31. maskElement.style.left = "0px";
  32. maskElement.style.height = "100%";
  33. maskElement.style.width = "100%";
  34. maskElement.style.backgroundColor = "black";
  35. maskElement.style.zIndex = 2147483647;
  36. maskElement.style.opacity = 0;
  37. maskElement.style.transition = "opacity 250ms";
  38. document.body.appendChild(maskElement);
  39. maskElement.offsetWidth;
  40. maskElement.style.opacity = .3;
  41. }
  42. },
  43. end() {
  44. const maskElement = document.querySelector(MASK_TAGNAME);
  45. if (maskElement) {
  46. maskElement.remove();
  47. }
  48. }
  49. };
  50. })();