ui.js 2.7 KB

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