ui.js 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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 = this.singlefile.ui || (() => {
  22. const MASK_TAGNAME = "singlefile-mask";
  23. const PROGRESS_BAR_TAGNAME = "singlefile-progress-var";
  24. return {
  25. init() {
  26. let maskElement = document.querySelector(MASK_TAGNAME);
  27. if (!maskElement) {
  28. maskElement = document.createElement(MASK_TAGNAME);
  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. maskElement.offsetWidth;
  40. maskElement.style.opacity = .3;
  41. const progressBarElement = document.createElement(PROGRESS_BAR_TAGNAME);
  42. progressBarElement.style.all = "unset";
  43. progressBarElement.style.position = "fixed";
  44. progressBarElement.style.top = "0px";
  45. progressBarElement.style.left = "0px";
  46. progressBarElement.style.height = "8px";
  47. progressBarElement.style.width = "0%";
  48. progressBarElement.style.backgroundColor = "white";
  49. progressBarElement.style.transition = "width 50ms";
  50. document.body.appendChild(maskElement);
  51. maskElement.appendChild(progressBarElement);
  52. }
  53. },
  54. onprogress(event) {
  55. const progressBarElement = document.querySelector(PROGRESS_BAR_TAGNAME);
  56. if (progressBarElement) {
  57. const width = Math.floor((event.details.index / event.details.max) * 100) + "%";
  58. if (progressBarElement.style.width != width) {
  59. progressBarElement.style.width = Math.floor((event.details.index / event.details.max) * 100) + "%";
  60. }
  61. }
  62. },
  63. end() {
  64. const maskElement = document.querySelector(MASK_TAGNAME);
  65. if (maskElement) {
  66. maskElement.remove();
  67. }
  68. }
  69. };
  70. })();