hexo-theme-redefine-x 2.8.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (319) hide show
  1. package/.github/ISSUE_TEMPLATE/bug-chinese.yml +115 -0
  2. package/.github/ISSUE_TEMPLATE/bug-english.yml +106 -0
  3. package/.github/ISSUE_TEMPLATE/enhancement-chinese.yml +55 -0
  4. package/.github/ISSUE_TEMPLATE/enhancement-english.yml +55 -0
  5. package/.github/workflows/build-and-commit.yml +49 -0
  6. package/.github/workflows/npm-publish.yml +34 -0
  7. package/.github/workflows/stale-issues.yml +20 -0
  8. package/CHANGELOG_REDEFINE_X.md +236 -0
  9. package/CODE_OF_CONDUCT.md +128 -0
  10. package/CONTRIBUTING.md +51 -0
  11. package/DONATION.md +82 -0
  12. package/LICENSE +674 -0
  13. package/README.md +135 -0
  14. package/README_zh-CN.md +138 -0
  15. package/README_zh-TW.md +137 -0
  16. package/TODO.md +215 -0
  17. package/_config.yml +489 -0
  18. package/languages/en.yml +93 -0
  19. package/languages/es.yml +92 -0
  20. package/languages/fr.yml +92 -0
  21. package/languages/ja.yml +92 -0
  22. package/languages/zh-CN.yml +95 -0
  23. package/languages/zh-TW.yml +94 -0
  24. package/layout/404.ejs +1 -0
  25. package/layout/archive.ejs +1 -0
  26. package/layout/category.ejs +1 -0
  27. package/layout/components/comments/comment.ejs +22 -0
  28. package/layout/components/comments/giscus.ejs +42 -0
  29. package/layout/components/comments/gitalk.ejs +47 -0
  30. package/layout/components/comments/twikoo.ejs +50 -0
  31. package/layout/components/comments/waline.ejs +34 -0
  32. package/layout/components/footer/footer.ejs +99 -0
  33. package/layout/components/header/head.ejs +222 -0
  34. package/layout/components/header/navbar.ejs +163 -0
  35. package/layout/components/header/preloader.ejs +148 -0
  36. package/layout/components/header/progress-bar.ejs +12 -0
  37. package/layout/components/plugins/aplayer.ejs +3 -0
  38. package/layout/components/scripts.ejs +90 -0
  39. package/layout/components/sidebar/author.ejs +6 -0
  40. package/layout/components/sidebar/avatar.ejs +3 -0
  41. package/layout/components/sidebar/statistics.ejs +14 -0
  42. package/layout/components/swup.ejs +27 -0
  43. package/layout/index.ejs +1 -0
  44. package/layout/layout.ejs +13 -0
  45. package/layout/page.ejs +57 -0
  46. package/layout/pages/archive/archive.ejs +3 -0
  47. package/layout/pages/bookmarks/bookmarks.ejs +68 -0
  48. package/layout/pages/category/categories.ejs +11 -0
  49. package/layout/pages/category/category-detail.ejs +6 -0
  50. package/layout/pages/friends/friends-link.ejs +59 -0
  51. package/layout/pages/home/home-article.ejs +52 -0
  52. package/layout/pages/home/home-background.ejs +33 -0
  53. package/layout/pages/home/home-banner.ejs +234 -0
  54. package/layout/pages/home/home-content.ejs +62 -0
  55. package/layout/pages/home/home-sidebar.ejs +78 -0
  56. package/layout/pages/masonry/masonry.ejs +28 -0
  57. package/layout/pages/notfound/notfound.ejs +8 -0
  58. package/layout/pages/page-template.ejs +23 -0
  59. package/layout/pages/post/article-content.ejs +153 -0
  60. package/layout/pages/post/article-copyright.ejs +69 -0
  61. package/layout/pages/post/article-info.ejs +78 -0
  62. package/layout/pages/post/post-tools.ejs +17 -0
  63. package/layout/pages/post/toc.ejs +15 -0
  64. package/layout/pages/shuoshuo/essays.ejs +23 -0
  65. package/layout/pages/tag/tag-detail.ejs +6 -0
  66. package/layout/pages/tag/tags.ejs +24 -0
  67. package/layout/post.ejs +1 -0
  68. package/layout/tag.ejs +1 -0
  69. package/layout/tags.ejs +1 -0
  70. package/layout/utils/image-viewer.ejs +3 -0
  71. package/layout/utils/local-search.ejs +20 -0
  72. package/layout/utils/paginator.ejs +8 -0
  73. package/layout/utils/posts-list.ejs +28 -0
  74. package/layout/utils/side-tools.ejs +51 -0
  75. package/package.json +45 -0
  76. package/scripts/config-export.js +66 -0
  77. package/scripts/data-handle.js +37 -0
  78. package/scripts/events/404.js +16 -0
  79. package/scripts/events/welcome.js +141 -0
  80. package/scripts/filters/delete-mask-handle.js +27 -0
  81. package/scripts/filters/encrypt.js +202 -0
  82. package/scripts/filters/img-handle.js +9 -0
  83. package/scripts/filters/lazyload-handle.js +350 -0
  84. package/scripts/filters/lib/hbe.default.js +15 -0
  85. package/scripts/filters/link-handle.js +42 -0
  86. package/scripts/filters/stylus-handle.js +9 -0
  87. package/scripts/filters/table-handle.js +11 -0
  88. package/scripts/helpers/meta-helpers.js +38 -0
  89. package/scripts/helpers/page-helpers.js +153 -0
  90. package/scripts/helpers/recommendation-helpers.js +367 -0
  91. package/scripts/helpers/theme-helpers.js +251 -0
  92. package/scripts/helpers/waline-helpers.js +33 -0
  93. package/scripts/modules/btn.js +85 -0
  94. package/scripts/modules/btns.js +71 -0
  95. package/scripts/modules/folding.js +34 -0
  96. package/scripts/modules/note-large.js +72 -0
  97. package/scripts/modules/note.js +64 -0
  98. package/scripts/modules/tabs.js +99 -0
  99. package/source/assets/hbe.style.css +220 -0
  100. package/source/assets/odometer-theme-minimal.css +81 -0
  101. package/source/css/build/tailwind.css +2 -0
  102. package/source/css/common/animated.styl +71 -0
  103. package/source/css/common/basic.styl +239 -0
  104. package/source/css/common/codeblock/code-block.styl +158 -0
  105. package/source/css/common/codeblock/code-theme.styl +82 -0
  106. package/source/css/common/codeblock/highlight.styl +189 -0
  107. package/source/css/common/codeblock/hljs-themes/dark/a11y-dark.styl +18 -0
  108. package/source/css/common/codeblock/hljs-themes/dark/agate.styl +18 -0
  109. package/source/css/common/codeblock/hljs-themes/dark/atom-one-dark.styl +18 -0
  110. package/source/css/common/codeblock/hljs-themes/dark/github-dark.styl +18 -0
  111. package/source/css/common/codeblock/hljs-themes/dark/monokai-sublime.styl +18 -0
  112. package/source/css/common/codeblock/hljs-themes/dark/night-owl.styl +18 -0
  113. package/source/css/common/codeblock/hljs-themes/dark/nord.styl +18 -0
  114. package/source/css/common/codeblock/hljs-themes/dark/tokyo-night-dark.styl +18 -0
  115. package/source/css/common/codeblock/hljs-themes/dark/vs2015.styl +18 -0
  116. package/source/css/common/codeblock/hljs-themes/light/atom-one-light.styl +18 -0
  117. package/source/css/common/codeblock/hljs-themes/light/default.styl +18 -0
  118. package/source/css/common/codeblock/hljs-themes/light/github.styl +18 -0
  119. package/source/css/common/colors.styl +112 -0
  120. package/source/css/common/markdown.styl +337 -0
  121. package/source/css/common/redefine-theme.styl +65 -0
  122. package/source/css/common/theme.styl +72 -0
  123. package/source/css/common/variables.styl +145 -0
  124. package/source/css/layout/_modules/aplayer.styl +799 -0
  125. package/source/css/layout/_modules/buttons.styl +42 -0
  126. package/source/css/layout/_modules/folding.styl +180 -0
  127. package/source/css/layout/_modules/notes.styl +181 -0
  128. package/source/css/layout/_modules/tabs.styl +105 -0
  129. package/source/css/layout/_partials/404.styl +14 -0
  130. package/source/css/layout/_partials/archive-list.styl +49 -0
  131. package/source/css/layout/_partials/article-copyright-info.styl +27 -0
  132. package/source/css/layout/_partials/article-meta-info.styl +62 -0
  133. package/source/css/layout/_partials/comments/comment.styl +11 -0
  134. package/source/css/layout/_partials/comments/gitalk.styl +529 -0
  135. package/source/css/layout/_partials/comments/twikoo.styl +62 -0
  136. package/source/css/layout/_partials/comments/waline.styl +1151 -0
  137. package/source/css/layout/_partials/footer.styl +59 -0
  138. package/source/css/layout/_partials/home-banner.styl +48 -0
  139. package/source/css/layout/_partials/image-viewer.styl +37 -0
  140. package/source/css/layout/_partials/local-search.styl +137 -0
  141. package/source/css/layout/_partials/navbar.styl +309 -0
  142. package/source/css/layout/_partials/page-template.styl +147 -0
  143. package/source/css/layout/_partials/paginator.styl +65 -0
  144. package/source/css/layout/_partials/post-tools.styl +43 -0
  145. package/source/css/layout/_partials/progress-bar.styl +33 -0
  146. package/source/css/layout/_partials/side-tools.styl +87 -0
  147. package/source/css/layout/_partials/tagcloud.styl +136 -0
  148. package/source/css/layout/_partials/toc.styl +105 -0
  149. package/source/css/layout/animations.styl +42 -0
  150. package/source/css/layout/archive-content.styl +8 -0
  151. package/source/css/layout/article-content.styl +257 -0
  152. package/source/css/layout/bookmarks.styl +8 -0
  153. package/source/css/layout/category-content.styl +21 -0
  154. package/source/css/layout/category-list.styl +119 -0
  155. package/source/css/layout/home-content.styl +114 -0
  156. package/source/css/layout/home-sidebar.styl +126 -0
  157. package/source/css/layout/page.styl +144 -0
  158. package/source/css/layout/tag-content.styl +30 -0
  159. package/source/css/style.styl +26 -0
  160. package/source/css/tailwind.source.css +236 -0
  161. package/source/fontawesome/all.min.css +6 -0
  162. package/source/fontawesome/brands.min.css +6 -0
  163. package/source/fontawesome/duotone.min.css +6 -0
  164. package/source/fontawesome/fontawesome.min.css +6 -0
  165. package/source/fontawesome/light.min.css +6 -0
  166. package/source/fontawesome/regular.min.css +6 -0
  167. package/source/fontawesome/sharp-solid.min.css +6 -0
  168. package/source/fontawesome/solid.min.css +6 -0
  169. package/source/fontawesome/svg-with-js.min.css +6 -0
  170. package/source/fontawesome/thin.min.css +6 -0
  171. package/source/fontawesome/v4-font-face.min.css +6 -0
  172. package/source/fontawesome/v4-shims.min.css +6 -0
  173. package/source/fontawesome/v5-font-face.min.css +6 -0
  174. package/source/fonts/Chillax/Chillax-Variable.eot +0 -0
  175. package/source/fonts/Chillax/Chillax-Variable.ttf +0 -0
  176. package/source/fonts/Chillax/Chillax-Variable.woff +0 -0
  177. package/source/fonts/Chillax/Chillax-Variable.woff2 +0 -0
  178. package/source/fonts/Chillax/chillax.css +39 -0
  179. package/source/fonts/Geist/GeistVF.ttf +0 -0
  180. package/source/fonts/Geist/GeistVF.woff +0 -0
  181. package/source/fonts/Geist/GeistVF.woff2 +0 -0
  182. package/source/fonts/Geist/geist.css +16 -0
  183. package/source/fonts/GeistMono/GeistMonoVF.ttf +0 -0
  184. package/source/fonts/GeistMono/GeistMonoVF.woff +0 -0
  185. package/source/fonts/GeistMono/GeistMonoVF.woff2 +0 -0
  186. package/source/fonts/GeistMono/geist-mono.css +16 -0
  187. package/source/images/bookmark-placeholder.svg +9 -0
  188. package/source/images/loading.svg +5 -0
  189. package/source/images/redefine-avatar.svg +1 -0
  190. package/source/images/redefine-favicon.svg +1 -0
  191. package/source/images/redefine-logo.svg +1 -0
  192. package/source/images/redefine-logo.webp +0 -0
  193. package/source/images/redefine-og.webp +0 -0
  194. package/source/images/wallhaven-wqery6-dark.webp +0 -0
  195. package/source/images/wallhaven-wqery6-light.webp +0 -0
  196. package/source/js/build/layouts/bookmarkNav.js +2 -0
  197. package/source/js/build/layouts/bookmarkNav.js.map +1 -0
  198. package/source/js/build/layouts/categoryList.js +2 -0
  199. package/source/js/build/layouts/categoryList.js.map +1 -0
  200. package/source/js/build/layouts/essays.js +2 -0
  201. package/source/js/build/layouts/essays.js.map +1 -0
  202. package/source/js/build/layouts/lazyload.js +2 -0
  203. package/source/js/build/layouts/lazyload.js.map +1 -0
  204. package/source/js/build/layouts/navbarShrink.js +2 -0
  205. package/source/js/build/layouts/navbarShrink.js.map +1 -0
  206. package/source/js/build/layouts/toc.js +2 -0
  207. package/source/js/build/layouts/toc.js.map +1 -0
  208. package/source/js/build/libs/APlayer.min.js +2 -0
  209. package/source/js/build/libs/Swup.min.js +2 -0
  210. package/source/js/build/libs/SwupPreloadPlugin.min.js +1 -0
  211. package/source/js/build/libs/SwupProgressPlugin.min.js +1 -0
  212. package/source/js/build/libs/SwupScriptsPlugin.min.js +1 -0
  213. package/source/js/build/libs/SwupScrollPlugin.min.js +1 -0
  214. package/source/js/build/libs/SwupSlideTheme.min.js +1 -0
  215. package/source/js/build/libs/Typed.min.js +10 -0
  216. package/source/js/build/libs/anime.min.js +8 -0
  217. package/source/js/build/libs/mermaid.min.js +2314 -0
  218. package/source/js/build/libs/minimasonry.min.js +1 -0
  219. package/source/js/build/libs/moment-with-locales.min.js +2 -0
  220. package/source/js/build/libs/moment.min.js +2 -0
  221. package/source/js/build/libs/odometer.min.js +2 -0
  222. package/source/js/build/libs/pangu.min.js +9 -0
  223. package/source/js/build/libs/pjax.min.js +1 -0
  224. package/source/js/build/libs/waline.js +84 -0
  225. package/source/js/build/main.js +2 -0
  226. package/source/js/build/main.js.map +1 -0
  227. package/source/js/build/plugins/aplayer.js +2 -0
  228. package/source/js/build/plugins/aplayer.js.map +1 -0
  229. package/source/js/build/plugins/hbe.js +2 -0
  230. package/source/js/build/plugins/hbe.js.map +1 -0
  231. package/source/js/build/plugins/masonry.js +2 -0
  232. package/source/js/build/plugins/masonry.js.map +1 -0
  233. package/source/js/build/plugins/mermaid.js +2 -0
  234. package/source/js/build/plugins/mermaid.js.map +1 -0
  235. package/source/js/build/plugins/pangu.js +2 -0
  236. package/source/js/build/plugins/pangu.js.map +1 -0
  237. package/source/js/build/plugins/tabs.js +2 -0
  238. package/source/js/build/plugins/tabs.js.map +1 -0
  239. package/source/js/build/plugins/typed.js +2 -0
  240. package/source/js/build/plugins/typed.js.map +1 -0
  241. package/source/js/build/tools/codeBlock.js +2 -0
  242. package/source/js/build/tools/codeBlock.js.map +1 -0
  243. package/source/js/build/tools/imageViewer.js +2 -0
  244. package/source/js/build/tools/imageViewer.js.map +1 -0
  245. package/source/js/build/tools/lightDarkSwitch.js +2 -0
  246. package/source/js/build/tools/lightDarkSwitch.js.map +1 -0
  247. package/source/js/build/tools/localSearch.js +2 -0
  248. package/source/js/build/tools/localSearch.js.map +1 -0
  249. package/source/js/build/tools/runtime.js +2 -0
  250. package/source/js/build/tools/runtime.js.map +1 -0
  251. package/source/js/build/tools/scrollTopBottom.js +2 -0
  252. package/source/js/build/tools/scrollTopBottom.js.map +1 -0
  253. package/source/js/build/tools/tocToggle.js +2 -0
  254. package/source/js/build/tools/tocToggle.js.map +1 -0
  255. package/source/js/build/utils.js +2 -0
  256. package/source/js/build/utils.js.map +1 -0
  257. package/source/js/build.js +148 -0
  258. package/source/js/layouts/bookmarkNav.js +65 -0
  259. package/source/js/layouts/categoryList.js +53 -0
  260. package/source/js/layouts/essays.js +25 -0
  261. package/source/js/layouts/lazyload.js +199 -0
  262. package/source/js/layouts/navbarShrink.js +135 -0
  263. package/source/js/layouts/toc.js +115 -0
  264. package/source/js/libs/APlayer.min.js +2 -0
  265. package/source/js/libs/APlayer.min.js.map +1 -0
  266. package/source/js/libs/Swup.min.js +2 -0
  267. package/source/js/libs/Swup.min.js.map +1 -0
  268. package/source/js/libs/SwupPreloadPlugin.min.js +1 -0
  269. package/source/js/libs/SwupPreloadPlugin.min.js.map +1 -0
  270. package/source/js/libs/SwupProgressPlugin.min.js +1 -0
  271. package/source/js/libs/SwupScriptsPlugin.min.js +1 -0
  272. package/source/js/libs/SwupScrollPlugin.min.js +1 -0
  273. package/source/js/libs/SwupScrollPlugin.min.js.map +1 -0
  274. package/source/js/libs/SwupSlideTheme.min.js +1 -0
  275. package/source/js/libs/Typed.min.js +10 -0
  276. package/source/js/libs/anime.min.js +8 -0
  277. package/source/js/libs/mermaid.min.js +2314 -0
  278. package/source/js/libs/mermaid.min.js.map +7 -0
  279. package/source/js/libs/minimasonry.min.js +1 -0
  280. package/source/js/libs/moment-with-locales.min.js +2 -0
  281. package/source/js/libs/moment.min.js +2 -0
  282. package/source/js/libs/odometer.min.js +2 -0
  283. package/source/js/libs/pangu.min.js +9 -0
  284. package/source/js/libs/pjax.min.js +1 -0
  285. package/source/js/libs/waline.js +84 -0
  286. package/source/js/libs/waline.js.map +1 -0
  287. package/source/js/main.js +95 -0
  288. package/source/js/plugins/aplayer.js +33 -0
  289. package/source/js/plugins/hbe.js +350 -0
  290. package/source/js/plugins/masonry.js +115 -0
  291. package/source/js/plugins/mermaid.js +7 -0
  292. package/source/js/plugins/pangu.js +12 -0
  293. package/source/js/plugins/tabs.js +29 -0
  294. package/source/js/plugins/typed.js +62 -0
  295. package/source/js/tools/codeBlock.js +48 -0
  296. package/source/js/tools/imageViewer.js +194 -0
  297. package/source/js/tools/lightDarkSwitch.js +165 -0
  298. package/source/js/tools/localSearch.js +327 -0
  299. package/source/js/tools/runtime.js +28 -0
  300. package/source/js/tools/scrollTopBottom.js +34 -0
  301. package/source/js/tools/tocToggle.js +58 -0
  302. package/source/js/utils.js +383 -0
  303. package/source/webfonts/fa-brands-400.ttf +0 -0
  304. package/source/webfonts/fa-brands-400.woff2 +0 -0
  305. package/source/webfonts/fa-duotone-900.ttf +0 -0
  306. package/source/webfonts/fa-duotone-900.woff2 +0 -0
  307. package/source/webfonts/fa-light-300.ttf +0 -0
  308. package/source/webfonts/fa-light-300.woff2 +0 -0
  309. package/source/webfonts/fa-regular-400.ttf +0 -0
  310. package/source/webfonts/fa-regular-400.woff2 +0 -0
  311. package/source/webfonts/fa-sharp-solid-900.ttf +0 -0
  312. package/source/webfonts/fa-sharp-solid-900.woff2 +0 -0
  313. package/source/webfonts/fa-solid-900.ttf +0 -0
  314. package/source/webfonts/fa-solid-900.woff2 +0 -0
  315. package/source/webfonts/fa-thin-100.ttf +0 -0
  316. package/source/webfonts/fa-thin-100.woff2 +0 -0
  317. package/source/webfonts/fa-v4compatibility.ttf +0 -0
  318. package/source/webfonts/fa-v4compatibility.woff2 +0 -0
  319. package/vercel.json +7 -0
@@ -0,0 +1,48 @@
1
+ const initCopyCode = () => {
2
+ HTMLElement.prototype.wrap = function (wrapper) {
3
+ this.parentNode.insertBefore(wrapper, this);
4
+ this.parentNode.removeChild(this);
5
+ wrapper.appendChild(this);
6
+ };
7
+
8
+ document.querySelectorAll("figure.highlight").forEach((element) => {
9
+ const container = document.createElement("div");
10
+ element.wrap(container);
11
+ container.classList.add("highlight-container");
12
+ container.insertAdjacentHTML(
13
+ "beforeend",
14
+ '<div class="copy-button"><i class="fa-regular fa-copy"></i></div>',
15
+ );
16
+ container.insertAdjacentHTML(
17
+ "beforeend",
18
+ '<div class="fold-button"><i class="fa-solid fa-chevron-down"></i></div>',
19
+ );
20
+ const copyButton = container.querySelector(".copy-button");
21
+ const foldButton = container.querySelector(".fold-button");
22
+ copyButton.addEventListener("click", () => {
23
+ const codeLines = [...container.querySelectorAll(".code .line")];
24
+ const code = codeLines.map((line) => line.innerText).join("\n");
25
+
26
+ // Copy code to clipboard
27
+ navigator.clipboard.writeText(code);
28
+
29
+ // Display 'copied' icon
30
+ copyButton.querySelector("i").className = "fa-regular fa-check";
31
+
32
+ // Reset icon after a while
33
+ setTimeout(() => {
34
+ copyButton.querySelector("i").className = "fa-regular fa-copy";
35
+ }, 1000);
36
+ });
37
+ foldButton.addEventListener("click", () => {
38
+ container.classList.toggle("folded");
39
+ foldButton.querySelector("i").className = container.classList.contains(
40
+ "folded",
41
+ )
42
+ ? "fa-solid fa-chevron-up"
43
+ : "fa-solid fa-chevron-down";
44
+ });
45
+ });
46
+ };
47
+
48
+ export default initCopyCode;
@@ -0,0 +1,194 @@
1
+ export default function imageViewer() {
2
+ let isBigImage = false;
3
+ let scale = 1;
4
+ let isMouseDown = false;
5
+ let dragged = false;
6
+ let currentImgIndex = 0;
7
+ let lastMouseX = 0;
8
+ let lastMouseY = 0;
9
+ let translateX = 0;
10
+ let translateY = 0;
11
+
12
+ const maskDom = document.querySelector(".image-viewer-container");
13
+ if (!maskDom) {
14
+ console.warn(
15
+ "Image viewer container not found. Exiting imageViewer function.",
16
+ );
17
+ return;
18
+ }
19
+
20
+ const targetImg = maskDom.querySelector("img");
21
+ if (!targetImg) {
22
+ console.warn(
23
+ "Target image not found in image viewer container. Exiting imageViewer function.",
24
+ );
25
+ return;
26
+ }
27
+
28
+ const showHandle = (isShow) => {
29
+ document.body.style.overflow = isShow ? "hidden" : "auto";
30
+ isShow
31
+ ? maskDom.classList.add("active")
32
+ : maskDom.classList.remove("active");
33
+ };
34
+
35
+ const zoomHandle = (event) => {
36
+ event.preventDefault();
37
+ const rect = targetImg.getBoundingClientRect();
38
+ const offsetX = event.clientX - rect.left;
39
+ const offsetY = event.clientY - rect.top;
40
+ const dx = offsetX - rect.width / 2;
41
+ const dy = offsetY - rect.height / 2;
42
+ const oldScale = scale;
43
+ scale += event.deltaY * -0.001;
44
+ scale = Math.min(Math.max(0.8, scale), 4);
45
+
46
+ if (oldScale < scale) {
47
+ // Zooming in
48
+ translateX -= dx * (scale - oldScale);
49
+ translateY -= dy * (scale - oldScale);
50
+ } else {
51
+ // Zooming out
52
+ translateX = 0;
53
+ translateY = 0;
54
+ }
55
+
56
+ targetImg.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;
57
+ };
58
+
59
+ const dragStartHandle = (event) => {
60
+ event.preventDefault();
61
+ isMouseDown = true;
62
+ lastMouseX = event.clientX;
63
+ lastMouseY = event.clientY;
64
+ targetImg.style.cursor = "grabbing";
65
+ };
66
+
67
+ let lastTime = 0;
68
+ const throttle = 100;
69
+
70
+ const dragHandle = (event) => {
71
+ if (isMouseDown) {
72
+ const currentTime = new Date().getTime();
73
+ if (currentTime - lastTime < throttle) {
74
+ return;
75
+ }
76
+ lastTime = currentTime;
77
+ const deltaX = event.clientX - lastMouseX;
78
+ const deltaY = event.clientY - lastMouseY;
79
+ translateX += deltaX;
80
+ translateY += deltaY;
81
+ lastMouseX = event.clientX;
82
+ lastMouseY = event.clientY;
83
+ targetImg.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;
84
+ dragged = true;
85
+ }
86
+ };
87
+
88
+ const dragEndHandle = (event) => {
89
+ if (isMouseDown) {
90
+ event.stopPropagation();
91
+ }
92
+ isMouseDown = false;
93
+ targetImg.style.cursor = "grab";
94
+ };
95
+
96
+ targetImg.addEventListener("wheel", zoomHandle, { passive: false });
97
+ targetImg.addEventListener("mousedown", dragStartHandle, { passive: false });
98
+ targetImg.addEventListener("mousemove", dragHandle, { passive: false });
99
+ targetImg.addEventListener("mouseup", dragEndHandle, { passive: false });
100
+ targetImg.addEventListener("mouseleave", dragEndHandle, { passive: false });
101
+
102
+ maskDom.addEventListener("click", (event) => {
103
+ if (!dragged) {
104
+ isBigImage = false;
105
+ showHandle(isBigImage);
106
+ scale = 1;
107
+ translateX = 0;
108
+ translateY = 0;
109
+ targetImg.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;
110
+ }
111
+ dragged = false;
112
+ });
113
+
114
+ const imgDoms = document.querySelectorAll(
115
+ ".markdown-body img:not(.img-preloader-loaded), .masonry-item img:not(.img-preloader-loaded), #shuoshuo-content img:not(.img-preloader-loaded)",
116
+ );
117
+
118
+ const allViewableElements = [];
119
+
120
+ imgDoms.forEach((img) => {
121
+ allViewableElements.push({
122
+ element: img,
123
+ getSrc: () => img.dataset.originalSrc || img.src,
124
+ });
125
+ });
126
+
127
+ const escapeKeyListener = (event) => {
128
+ if (event.key === "Escape" && isBigImage) {
129
+ isBigImage = false;
130
+ showHandle(isBigImage);
131
+ scale = 1;
132
+ translateX = 0;
133
+ translateY = 0;
134
+ targetImg.style.transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;
135
+ document.removeEventListener("keydown", escapeKeyListener);
136
+ }
137
+ };
138
+
139
+ const observeNewImages = () => {
140
+ const newImgs = document.querySelectorAll(
141
+ ".markdown-body .img-preloader-loaded, .masonry-item .img-preloader-loaded, #shuoshuo-content .img-preloader-loaded"
142
+ );
143
+
144
+ newImgs.forEach((img) => {
145
+ if (!allViewableElements.some(item => item.element === img)) {
146
+ const index = allViewableElements.length;
147
+ allViewableElements.push({
148
+ element: img,
149
+ getSrc: () => img.dataset.originalSrc || img.src,
150
+ });
151
+
152
+ img.addEventListener("click", () => {
153
+ currentImgIndex = index;
154
+ isBigImage = true;
155
+ showHandle(isBigImage);
156
+ targetImg.src = img.dataset.originalSrc || img.src;
157
+ document.addEventListener("keydown", escapeKeyListener);
158
+ });
159
+ }
160
+ });
161
+ };
162
+
163
+ if (allViewableElements.length > 0 || document.querySelector(".img-preloader")) {
164
+ allViewableElements.forEach((item, index) => {
165
+ item.element.addEventListener("click", () => {
166
+ currentImgIndex = index;
167
+ isBigImage = true;
168
+ showHandle(isBigImage);
169
+ targetImg.src = item.getSrc();
170
+ document.addEventListener("keydown", escapeKeyListener);
171
+ });
172
+ });
173
+
174
+ const handleArrowKeys = (event) => {
175
+ if (!isBigImage) return;
176
+
177
+ if (event.key === "ArrowUp" || event.key === "ArrowLeft") {
178
+ currentImgIndex = (currentImgIndex - 1 + allViewableElements.length) % allViewableElements.length;
179
+ } else if (event.key === "ArrowDown" || event.key === "ArrowRight") {
180
+ currentImgIndex = (currentImgIndex + 1) % allViewableElements.length;
181
+ } else {
182
+ return;
183
+ }
184
+
185
+ targetImg.src = allViewableElements[currentImgIndex].getSrc();
186
+ };
187
+
188
+ document.addEventListener("keydown", handleArrowKeys);
189
+
190
+ const imgObserver = new MutationObserver(observeNewImages);
191
+ imgObserver.observe(document.body, { childList: true, subtree: true });
192
+ setInterval(observeNewImages, 1000);
193
+ }
194
+ }
@@ -0,0 +1,165 @@
1
+ import { main } from "../main.js";
2
+
3
+ const elementCode = ".mermaid";
4
+
5
+ const saveOriginalData = function () {
6
+ return new Promise((resolve, reject) => {
7
+ try {
8
+ var els = document.querySelectorAll(elementCode),
9
+ count = els.length;
10
+ els.forEach((element) => {
11
+ element.setAttribute("data-original-code", element.innerHTML);
12
+ count--;
13
+ if (count == 0) {
14
+ resolve();
15
+ }
16
+ });
17
+ } catch (error) {
18
+ reject(error);
19
+ }
20
+ });
21
+ };
22
+
23
+ const resetProcessed = function () {
24
+ return new Promise((resolve, reject) => {
25
+ try {
26
+ var els = document.querySelectorAll(elementCode),
27
+ count = els.length;
28
+ els.forEach((element) => {
29
+ if (element.getAttribute("data-original-code") != null) {
30
+ element.removeAttribute("data-processed");
31
+ element.innerHTML = element.getAttribute("data-original-code");
32
+ }
33
+ count--;
34
+ if (count == 0) {
35
+ resolve();
36
+ }
37
+ });
38
+ } catch (error) {
39
+ reject(error);
40
+ }
41
+ });
42
+ };
43
+ export const ModeToggle = {
44
+ modeToggleButton_dom: null,
45
+ iconDom: null,
46
+ mermaidLightTheme: null,
47
+ mermaidDarkTheme: null,
48
+
49
+ async mermaidInit(theme) {
50
+ if (window.mermaid) {
51
+ await resetProcessed();
52
+ mermaid.initialize({ theme });
53
+ mermaid.init({ theme }, document.querySelectorAll(elementCode));
54
+ }
55
+ },
56
+
57
+ enableLightMode() {
58
+ document.body.classList.remove("dark-mode");
59
+ document.documentElement.classList.remove("dark");
60
+ document.body.classList.add("light-mode");
61
+ document.documentElement.classList.add("light");
62
+ this.iconDom.className = "fa-regular fa-moon";
63
+ main.styleStatus.isDark = false;
64
+ main.setStyleStatus();
65
+ this.mermaidInit(this.mermaidLightTheme);
66
+ this.setGiscusTheme();
67
+ },
68
+
69
+ enableDarkMode() {
70
+ document.body.classList.remove("light-mode");
71
+ document.documentElement.classList.remove("light");
72
+ document.body.classList.add("dark-mode");
73
+ document.documentElement.classList.add("dark");
74
+ this.iconDom.className = "fa-regular fa-brightness";
75
+ main.styleStatus.isDark = true;
76
+ main.setStyleStatus();
77
+ this.mermaidInit(this.mermaidDarkTheme);
78
+ this.setGiscusTheme();
79
+ },
80
+
81
+ async setGiscusTheme(theme) {
82
+ if (document.querySelector("#giscus-container")) {
83
+ let giscusFrame = document.querySelector("iframe.giscus-frame");
84
+ while (!giscusFrame) {
85
+ await new Promise((r) => setTimeout(r, 1000));
86
+ giscusFrame = document.querySelector("iframe.giscus-frame");
87
+ }
88
+ while (giscusFrame.classList.contains("giscus-frame--loading"))
89
+ await new Promise((r) => setTimeout(r, 1000));
90
+ theme ??= main.styleStatus.isDark ? "dark" : "light";
91
+ giscusFrame.contentWindow.postMessage(
92
+ {
93
+ giscus: {
94
+ setConfig: {
95
+ theme: theme,
96
+ },
97
+ },
98
+ },
99
+ "https://giscus.app",
100
+ );
101
+ }
102
+ },
103
+
104
+ isDarkPrefersColorScheme() {
105
+ return (
106
+ window.matchMedia && window.matchMedia("(prefers-color-scheme: dark)")
107
+ );
108
+ },
109
+
110
+ initModeStatus() {
111
+ const styleStatus = main.getStyleStatus();
112
+
113
+ if (styleStatus) {
114
+ styleStatus.isDark ? this.enableDarkMode() : this.enableLightMode();
115
+ } else {
116
+ this.isDarkPrefersColorScheme().matches
117
+ ? this.enableDarkMode()
118
+ : this.enableLightMode();
119
+ }
120
+ },
121
+
122
+ initModeToggleButton() {
123
+ this.modeToggleButton_dom.addEventListener("click", () => {
124
+ const isDark = document.body.classList.contains("dark-mode");
125
+ isDark ? this.enableLightMode() : this.enableDarkMode();
126
+ });
127
+ },
128
+
129
+ initModeAutoTrigger() {
130
+ const isDarkMode = this.isDarkPrefersColorScheme();
131
+ isDarkMode.addEventListener("change", (e) => {
132
+ e.matches ? this.enableDarkMode() : this.enableLightMode();
133
+ });
134
+ },
135
+
136
+ async init() {
137
+ this.modeToggleButton_dom = document.querySelector(
138
+ ".tool-dark-light-toggle",
139
+ );
140
+ this.iconDom = document.querySelector(".tool-dark-light-toggle i");
141
+ this.mermaidLightTheme =
142
+ typeof theme.mermaid !== "undefined" &&
143
+ typeof theme.mermaid.style !== "undefined" &&
144
+ typeof theme.mermaid.style.light !== "undefined"
145
+ ? theme.mermaid.style.light
146
+ : "default";
147
+ this.mermaidDarkTheme =
148
+ typeof theme.mermaid !== "undefined" &&
149
+ typeof theme.mermaid.style !== "undefined" &&
150
+ typeof theme.mermaid.style.dark !== "undefined"
151
+ ? theme.mermaid.style.dark
152
+ : "dark";
153
+ this.initModeStatus();
154
+ this.initModeToggleButton();
155
+ this.initModeAutoTrigger();
156
+ try {
157
+ await saveOriginalData().catch(console.error);
158
+ } catch (error) {}
159
+ },
160
+ };
161
+
162
+ // Exported function
163
+ export default function initModeToggle() {
164
+ ModeToggle.init();
165
+ }