options.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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 browser, document */
  21. (async () => {
  22. const bgPage = await browser.runtime.getBackgroundPage();
  23. const removeHiddenElementsInput = document.getElementById("removeHiddenElementsInput");
  24. const removeUnusedStylesInput = document.getElementById("removeUnusedStylesInput");
  25. const removeFramesInput = document.getElementById("removeFramesInput");
  26. const removeImportsInput = document.getElementById("removeImportsInput");
  27. const removeScriptsInput = document.getElementById("removeScriptsInput");
  28. const saveRawPageInput = document.getElementById("saveRawPageInput");
  29. const compressHTMLInput = document.getElementById("compressHTMLInput");
  30. const compressCSSInput = document.getElementById("compressCSSInput");
  31. const lazyLoadImagesInput = document.getElementById("lazyLoadImagesInput");
  32. const contextMenuEnabledInput = document.getElementById("contextMenuEnabledInput");
  33. const appendSaveDateInput = document.getElementById("appendSaveDateInput");
  34. const shadowEnabledInput = document.getElementById("shadowEnabledInput");
  35. const maxResourceSizeInput = document.getElementById("maxResourceSizeInput");
  36. const maxResourceSizeEnabledInput = document.getElementById("maxResourceSizeEnabledInput");
  37. const confirmFilenameInput = document.getElementById("confirmFilenameInput");
  38. const removeAudioSrcInput = document.getElementById("removeAudioSrcInput");
  39. const removeVideoSrcInput = document.getElementById("removeVideoSrcInput");
  40. const displayInfobarInput = document.getElementById("displayInfobarInput");
  41. const displayStatsInput = document.getElementById("displayStatsInput");
  42. const backgroundSaveInput = document.getElementById("backgroundSaveInput");
  43. const autoSaveDelayInput = document.getElementById("autoSaveDelayInput");
  44. const autoSaveLoadInput = document.getElementById("autoSaveLoadInput");
  45. const autoSaveUnloadInput = document.getElementById("autoSaveUnloadInput");
  46. const autoSaveLoadOrUnloadInput = document.getElementById("autoSaveLoadOrUnloadInput");
  47. const removeAlternativeFontsInput = document.getElementById("removeAlternativeFontsInput");
  48. const removeSrcSetInput = document.getElementById("removeSrcSetInput");
  49. const removeAlternativeMediasInput = document.getElementById("removeAlternativeMediasInput");
  50. let pendingSave = Promise.resolve();
  51. document.getElementById("resetButton").addEventListener("click", async () => {
  52. await bgPage.singlefile.config.reset();
  53. await refresh();
  54. await update();
  55. }, false);
  56. maxResourceSizeEnabledInput.addEventListener("click", () => maxResourceSizeInput.disabled = !maxResourceSizeEnabledInput.checked, false);
  57. autoSaveUnloadInput.addEventListener("click", async () => {
  58. autoSaveDelayInput.disabled = autoSaveUnloadInput.checked;
  59. await bgPage.singlefile.ui.autosave.refresh();
  60. }, false);
  61. autoSaveLoadOrUnloadInput.addEventListener("click", async () => {
  62. autoSaveUnloadInput.disabled = autoSaveLoadInput.disabled = autoSaveLoadOrUnloadInput.checked;
  63. if (autoSaveLoadOrUnloadInput.checked) {
  64. autoSaveUnloadInput.checked = autoSaveLoadInput.checked = false;
  65. } else {
  66. autoSaveUnloadInput.checked = false;
  67. autoSaveLoadInput.checked = true;
  68. }
  69. await bgPage.singlefile.ui.autosave.refresh();
  70. }, false);
  71. document.body.onchange = update;
  72. refresh();
  73. async function refresh() {
  74. const config = await bgPage.singlefile.config.get();
  75. removeHiddenElementsInput.checked = config.removeHiddenElements;
  76. removeUnusedStylesInput.checked = config.removeUnusedStyles;
  77. removeFramesInput.checked = config.removeFrames;
  78. removeImportsInput.checked = config.removeImports;
  79. removeScriptsInput.checked = config.removeScripts;
  80. saveRawPageInput.checked = config.saveRawPage;
  81. compressHTMLInput.checked = config.compressHTML;
  82. compressCSSInput.checked = config.compressCSS;
  83. lazyLoadImagesInput.checked = config.lazyLoadImages;
  84. contextMenuEnabledInput.checked = config.contextMenuEnabled;
  85. appendSaveDateInput.checked = config.appendSaveDate;
  86. shadowEnabledInput.checked = config.shadowEnabled;
  87. maxResourceSizeEnabledInput.checked = config.maxResourceSizeEnabled;
  88. maxResourceSizeInput.value = config.maxResourceSize;
  89. maxResourceSizeInput.disabled = !config.maxResourceSizeEnabled;
  90. confirmFilenameInput.checked = config.confirmFilename;
  91. removeAudioSrcInput.checked = config.removeAudioSrc;
  92. removeVideoSrcInput.checked = config.removeVideoSrc;
  93. displayInfobarInput.checked = config.displayInfobar;
  94. displayStatsInput.checked = config.displayStats;
  95. backgroundSaveInput.checked = config.backgroundSave;
  96. autoSaveDelayInput.value = config.autoSaveDelay;
  97. autoSaveDelayInput.disabled = config.autoSaveUnload;
  98. autoSaveLoadInput.checked = !config.autoSaveLoadOrUnload && config.autoSaveLoad;
  99. autoSaveLoadOrUnloadInput.checked = config.autoSaveLoadOrUnload;
  100. autoSaveUnloadInput.checked = !config.autoSaveLoadOrUnload && config.autoSaveUnload;
  101. autoSaveLoadInput.disabled = config.autoSaveLoadOrUnload;
  102. autoSaveUnloadInput.disabled = config.autoSaveLoadOrUnload;
  103. removeAlternativeFontsInput.checked = config.removeAlternativeFonts;
  104. removeSrcSetInput.checked = config.removeSrcSet;
  105. removeAlternativeMediasInput.checked = config.removeAlternativeMedias;
  106. }
  107. async function update() {
  108. await pendingSave;
  109. pendingSave = bgPage.singlefile.config.set({
  110. removeHiddenElements: removeHiddenElementsInput.checked,
  111. removeUnusedStyles: removeUnusedStylesInput.checked,
  112. removeFrames: removeFramesInput.checked,
  113. removeImports: removeImportsInput.checked,
  114. removeScripts: removeScriptsInput.checked,
  115. saveRawPage: saveRawPageInput.checked,
  116. compressHTML: compressHTMLInput.checked,
  117. compressCSS: compressCSSInput.checked,
  118. lazyLoadImages: lazyLoadImagesInput.checked,
  119. contextMenuEnabled: contextMenuEnabledInput.checked,
  120. appendSaveDate: appendSaveDateInput.checked,
  121. shadowEnabled: shadowEnabledInput.checked,
  122. maxResourceSizeEnabled: maxResourceSizeEnabledInput.checked,
  123. maxResourceSize: maxResourceSizeInput.value,
  124. confirmFilename: confirmFilenameInput.checked,
  125. removeAudioSrc: removeAudioSrcInput.checked,
  126. removeVideoSrc: removeVideoSrcInput.checked,
  127. displayInfobar: displayInfobarInput.checked,
  128. displayStats: displayStatsInput.checked,
  129. backgroundSave: backgroundSaveInput.checked,
  130. autoSaveDelay: autoSaveDelayInput.value,
  131. autoSaveLoad: autoSaveLoadInput.checked,
  132. autoSaveUnload: autoSaveUnloadInput.checked,
  133. autoSaveLoadOrUnload: autoSaveLoadOrUnloadInput.checked,
  134. removeAlternativeFonts: removeAlternativeFontsInput.checked,
  135. removeSrcSet: removeSrcSetInput.checked,
  136. removeAlternativeMedias: removeAlternativeMediasInput.checked
  137. });
  138. await pendingSave;
  139. await bgPage.singlefile.ui.menu.refresh();
  140. }
  141. })();