markopress 0.0.2 → 0.0.4

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 (288) hide show
  1. package/dist/build/index.d.ts +0 -1
  2. package/dist/build/index.js +1 -1627
  3. package/dist/build/types.d.ts +0 -1
  4. package/dist/build/types.js +1 -5
  5. package/dist/build/vite-markdown-plugin.d.ts +0 -1
  6. package/dist/build/vite-markdown-plugin.js +1 -147
  7. package/dist/cli/index.d.ts +0 -1
  8. package/dist/cli/index.js +1 -74
  9. package/dist/config/app-root.d.ts +0 -1
  10. package/dist/config/app-root.js +1 -24
  11. package/dist/config/index.d.ts +0 -1
  12. package/dist/config/index.js +1 -6
  13. package/dist/config/loader.d.ts +0 -1
  14. package/dist/config/loader.js +1 -188
  15. package/dist/config/types.d.ts +0 -1
  16. package/dist/config/types.js +1 -5
  17. package/dist/config/validation.d.ts +0 -1
  18. package/dist/config/validation.js +1 -139
  19. package/dist/content/index.d.ts +0 -1
  20. package/dist/content/index.js +1 -6
  21. package/dist/content/registry.d.ts +0 -1
  22. package/dist/content/registry.js +1 -45
  23. package/dist/content/types.d.ts +0 -1
  24. package/dist/content/types.js +1 -5
  25. package/dist/dev/index.d.ts +0 -1
  26. package/dist/dev/index.js +1 -93
  27. package/dist/index.d.ts +0 -1
  28. package/dist/index.js +1 -17
  29. package/dist/markdown/base-path-plugin.d.ts +16 -0
  30. package/dist/markdown/base-path-plugin.js +1 -0
  31. package/dist/markdown/code.d.ts +0 -1
  32. package/dist/markdown/code.js +1 -305
  33. package/dist/markdown/containers.d.ts +0 -1
  34. package/dist/markdown/containers.js +1 -143
  35. package/dist/markdown/includes.d.ts +0 -1
  36. package/dist/markdown/includes.js +1 -9
  37. package/dist/markdown/index.d.ts +0 -1
  38. package/dist/markdown/index.js +1 -8
  39. package/dist/markdown/loader.d.ts +0 -1
  40. package/dist/markdown/loader.js +1 -325
  41. package/dist/markdown/md-link-plugin.d.ts +14 -0
  42. package/dist/markdown/md-link-plugin.js +1 -0
  43. package/dist/markdown/preserve-tags.d.ts +0 -1
  44. package/dist/markdown/preserve-tags.js +1 -233
  45. package/dist/markdown/renderer.d.ts +0 -1
  46. package/dist/markdown/renderer.js +1 -146
  47. package/dist/markdown/tag-validator.d.ts +0 -1
  48. package/dist/markdown/tag-validator.js +1 -118
  49. package/dist/markdown/types.d.ts +2 -1
  50. package/dist/markdown/types.js +1 -5
  51. package/dist/plugin/compat.d.ts +0 -1
  52. package/dist/plugin/compat.js +1 -78
  53. package/dist/plugin/context.d.ts +0 -1
  54. package/dist/plugin/context.js +1 -103
  55. package/dist/plugin/index.d.ts +0 -1
  56. package/dist/plugin/index.js +1 -6
  57. package/dist/plugin/manager.d.ts +0 -1
  58. package/dist/plugin/manager.js +1 -385
  59. package/dist/plugin/types.d.ts +1 -1
  60. package/dist/plugin/types.js +1 -5
  61. package/dist/plugins/blog-index/index.d.ts +0 -1
  62. package/dist/plugins/blog-index/index.js +1 -158
  63. package/dist/plugins/sidenav/index.d.ts +0 -1
  64. package/dist/plugins/sidenav/index.js +1 -86
  65. package/dist/plugins/toc/index.d.ts +0 -1
  66. package/dist/plugins/toc/index.js +1 -79
  67. package/dist/preview/index.d.ts +0 -1
  68. package/dist/preview/index.js +1 -25
  69. package/dist/theme/default/design-systems/default.d.ts +0 -1
  70. package/dist/theme/default/design-systems/default.js +1 -289
  71. package/dist/theme/default/design-systems/docusaurus.d.ts +0 -1
  72. package/dist/theme/default/design-systems/docusaurus.js +1 -299
  73. package/dist/theme/default/design-systems/index.d.ts +0 -1
  74. package/dist/theme/default/design-systems/index.js +1 -54
  75. package/dist/theme/default/design-systems/rspress.d.ts +0 -1
  76. package/dist/theme/default/design-systems/rspress.js +1 -299
  77. package/dist/theme/default/design-systems/types.d.ts +0 -1
  78. package/dist/theme/default/design-systems/types.js +1 -6
  79. package/dist/theme/default/design-systems/vitepress.d.ts +0 -1
  80. package/dist/theme/default/design-systems/vitepress.js +1 -299
  81. package/dist/theme/default/index.d.ts +0 -1
  82. package/dist/theme/default/index.js +1 -44
  83. package/dist/theme/default/theme.d.ts +0 -1
  84. package/dist/theme/default/theme.js +1 -58
  85. package/dist/theme/index.d.ts +0 -1
  86. package/dist/theme/index.js +1 -6
  87. package/dist/theme/loader.d.ts +0 -1
  88. package/dist/theme/loader.js +1 -125
  89. package/dist/theme/types.d.ts +1 -1
  90. package/dist/theme/types.js +1 -5
  91. package/dist/vite/index.d.ts +0 -1
  92. package/dist/vite/index.js +1 -6
  93. package/dist/vite/markdownPlugin.d.ts +0 -1
  94. package/dist/vite/markdownPlugin.js +1 -111
  95. package/dist/vite/plugin.d.ts +0 -1
  96. package/dist/vite/plugin.js +1 -94
  97. package/package.json +3 -2
  98. package/src/theme/default/layouts/blog.marko +1 -1
  99. package/src/theme/default/layouts/default.marko +5 -5
  100. package/src/theme/default/layouts/docs.marko +6 -6
  101. package/src/theme/default/layouts/page.marko +1 -1
  102. package/templates/catch-all-handler.js.template +2 -17
  103. package/dist/build/index.d.ts.map +0 -1
  104. package/dist/build/index.js.map +0 -1
  105. package/dist/build/manifest-generator.d.ts +0 -34
  106. package/dist/build/manifest-generator.d.ts.map +0 -1
  107. package/dist/build/manifest-generator.js +0 -86
  108. package/dist/build/manifest-generator.js.map +0 -1
  109. package/dist/build/security.test.d.ts +0 -6
  110. package/dist/build/security.test.d.ts.map +0 -1
  111. package/dist/build/security.test.js +0 -88
  112. package/dist/build/security.test.js.map +0 -1
  113. package/dist/build/types.d.ts.map +0 -1
  114. package/dist/build/types.js.map +0 -1
  115. package/dist/build/vite-config.test.d.ts +0 -2
  116. package/dist/build/vite-config.test.d.ts.map +0 -1
  117. package/dist/build/vite-config.test.js +0 -53
  118. package/dist/build/vite-config.test.js.map +0 -1
  119. package/dist/build/vite-markdown-plugin.d.ts.map +0 -1
  120. package/dist/build/vite-markdown-plugin.js.map +0 -1
  121. package/dist/build/vite-markdown-plugin.test.d.ts +0 -2
  122. package/dist/build/vite-markdown-plugin.test.d.ts.map +0 -1
  123. package/dist/build/vite-markdown-plugin.test.js +0 -41
  124. package/dist/build/vite-markdown-plugin.test.js.map +0 -1
  125. package/dist/cli/index.d.ts.map +0 -1
  126. package/dist/cli/index.js.map +0 -1
  127. package/dist/config/app-root.d.ts.map +0 -1
  128. package/dist/config/app-root.js.map +0 -1
  129. package/dist/config/app-root.test.d.ts +0 -2
  130. package/dist/config/app-root.test.d.ts.map +0 -1
  131. package/dist/config/app-root.test.js +0 -71
  132. package/dist/config/app-root.test.js.map +0 -1
  133. package/dist/config/index.d.ts.map +0 -1
  134. package/dist/config/index.js.map +0 -1
  135. package/dist/config/loader.d.ts.map +0 -1
  136. package/dist/config/loader.js.map +0 -1
  137. package/dist/config/loader.test.d.ts +0 -2
  138. package/dist/config/loader.test.d.ts.map +0 -1
  139. package/dist/config/loader.test.js +0 -24
  140. package/dist/config/loader.test.js.map +0 -1
  141. package/dist/config/types.d.ts.map +0 -1
  142. package/dist/config/types.js.map +0 -1
  143. package/dist/config/validation.d.ts.map +0 -1
  144. package/dist/config/validation.js.map +0 -1
  145. package/dist/content/index.d.ts.map +0 -1
  146. package/dist/content/index.js.map +0 -1
  147. package/dist/content/registry.d.ts.map +0 -1
  148. package/dist/content/registry.js.map +0 -1
  149. package/dist/content/scanner.d.ts +0 -9
  150. package/dist/content/scanner.d.ts.map +0 -1
  151. package/dist/content/scanner.js +0 -115
  152. package/dist/content/scanner.js.map +0 -1
  153. package/dist/content/types.d.ts.map +0 -1
  154. package/dist/content/types.js.map +0 -1
  155. package/dist/dev/index.d.ts.map +0 -1
  156. package/dist/dev/index.js.map +0 -1
  157. package/dist/index.d.ts.map +0 -1
  158. package/dist/index.js.map +0 -1
  159. package/dist/markdown/code.d.ts.map +0 -1
  160. package/dist/markdown/code.js.map +0 -1
  161. package/dist/markdown/containers.d.ts.map +0 -1
  162. package/dist/markdown/containers.js.map +0 -1
  163. package/dist/markdown/includes.d.ts.map +0 -1
  164. package/dist/markdown/includes.js.map +0 -1
  165. package/dist/markdown/index.d.ts.map +0 -1
  166. package/dist/markdown/index.js.map +0 -1
  167. package/dist/markdown/loader.d.ts.map +0 -1
  168. package/dist/markdown/loader.js.map +0 -1
  169. package/dist/markdown/preserve-tags.d.ts.map +0 -1
  170. package/dist/markdown/preserve-tags.js.map +0 -1
  171. package/dist/markdown/renderer.d.ts.map +0 -1
  172. package/dist/markdown/renderer.js.map +0 -1
  173. package/dist/markdown/tag-validator.d.ts.map +0 -1
  174. package/dist/markdown/tag-validator.js.map +0 -1
  175. package/dist/markdown/types.d.ts.map +0 -1
  176. package/dist/markdown/types.js.map +0 -1
  177. package/dist/plugin/compat.d.ts.map +0 -1
  178. package/dist/plugin/compat.js.map +0 -1
  179. package/dist/plugin/context.d.ts.map +0 -1
  180. package/dist/plugin/context.js.map +0 -1
  181. package/dist/plugin/index.d.ts.map +0 -1
  182. package/dist/plugin/index.js.map +0 -1
  183. package/dist/plugin/manager.d.ts.map +0 -1
  184. package/dist/plugin/manager.js.map +0 -1
  185. package/dist/plugin/types.d.ts.map +0 -1
  186. package/dist/plugin/types.js.map +0 -1
  187. package/dist/plugins/blog-index/index.d.ts.map +0 -1
  188. package/dist/plugins/blog-index/index.js.map +0 -1
  189. package/dist/plugins/sidenav/index.d.ts.map +0 -1
  190. package/dist/plugins/sidenav/index.js.map +0 -1
  191. package/dist/plugins/toc/index.d.ts.map +0 -1
  192. package/dist/plugins/toc/index.js.map +0 -1
  193. package/dist/preview/index.d.ts.map +0 -1
  194. package/dist/preview/index.js.map +0 -1
  195. package/dist/theme/default/build/generate-all.d.ts +0 -9
  196. package/dist/theme/default/build/generate-all.d.ts.map +0 -1
  197. package/dist/theme/default/build/generate-all.js +0 -85
  198. package/dist/theme/default/build/generate-all.js.map +0 -1
  199. package/dist/theme/default/build/generate-css.d.ts +0 -19
  200. package/dist/theme/default/build/generate-css.d.ts.map +0 -1
  201. package/dist/theme/default/build/generate-css.js +0 -199
  202. package/dist/theme/default/build/generate-css.js.map +0 -1
  203. package/dist/theme/default/build/index.d.ts +0 -5
  204. package/dist/theme/default/build/index.d.ts.map +0 -1
  205. package/dist/theme/default/build/index.js +0 -5
  206. package/dist/theme/default/build/index.js.map +0 -1
  207. package/dist/theme/default/design-systems/default.d.ts.map +0 -1
  208. package/dist/theme/default/design-systems/default.js.map +0 -1
  209. package/dist/theme/default/design-systems/docusaurus.d.ts.map +0 -1
  210. package/dist/theme/default/design-systems/docusaurus.js.map +0 -1
  211. package/dist/theme/default/design-systems/index.d.ts.map +0 -1
  212. package/dist/theme/default/design-systems/index.js.map +0 -1
  213. package/dist/theme/default/design-systems/rspress.d.ts.map +0 -1
  214. package/dist/theme/default/design-systems/rspress.js.map +0 -1
  215. package/dist/theme/default/design-systems/types.d.ts.map +0 -1
  216. package/dist/theme/default/design-systems/types.js.map +0 -1
  217. package/dist/theme/default/design-systems/vitepress.d.ts.map +0 -1
  218. package/dist/theme/default/design-systems/vitepress.js.map +0 -1
  219. package/dist/theme/default/index.d.ts.map +0 -1
  220. package/dist/theme/default/index.js.map +0 -1
  221. package/dist/theme/default/theme.d.ts.map +0 -1
  222. package/dist/theme/default/theme.js.map +0 -1
  223. package/dist/theme/index.d.ts.map +0 -1
  224. package/dist/theme/index.js.map +0 -1
  225. package/dist/theme/loader.d.ts.map +0 -1
  226. package/dist/theme/loader.js.map +0 -1
  227. package/dist/theme/types.d.ts.map +0 -1
  228. package/dist/theme/types.js.map +0 -1
  229. package/dist/vite/index.d.ts.map +0 -1
  230. package/dist/vite/index.js.map +0 -1
  231. package/dist/vite/markdownPlugin.d.ts.map +0 -1
  232. package/dist/vite/markdownPlugin.js.map +0 -1
  233. package/dist/vite/plugin.d.ts.map +0 -1
  234. package/dist/vite/plugin.js.map +0 -1
  235. package/src/theme/default/build/generate-all.ts +0 -99
  236. package/src/theme/default/build/generate-css.ts +0 -234
  237. package/src/theme/default/build/index.ts +0 -5
  238. package/src/theme/default/components/doc-footer.marko +0 -180
  239. package/src/theme/default/components/footer.marko +0 -32
  240. package/src/theme/default/components/header.marko +0 -49
  241. package/src/theme/default/components/nav-bar.marko +0 -191
  242. package/src/theme/default/components/page-header.marko +0 -20
  243. package/src/theme/default/components/reading-progress.marko +0 -36
  244. package/src/theme/default/components/search.marko +0 -239
  245. package/src/theme/default/components/sidebar.marko +0 -211
  246. package/src/theme/default/components/site-footer.marko +0 -211
  247. package/src/theme/default/components/skip-link.marko +0 -49
  248. package/src/theme/default/components/theme/theme-aside-bottom.marko +0 -1
  249. package/src/theme/default/components/theme/theme-aside-top.marko +0 -1
  250. package/src/theme/default/components/theme/theme-body-bottom.marko +0 -1
  251. package/src/theme/default/components/theme/theme-body-top.marko +0 -1
  252. package/src/theme/default/components/theme/theme-doc-bottom.marko +0 -1
  253. package/src/theme/default/components/theme/theme-doc-footer-after.marko +0 -1
  254. package/src/theme/default/components/theme/theme-doc-footer-before.marko +0 -1
  255. package/src/theme/default/components/theme/theme-doc-top.marko +0 -1
  256. package/src/theme/default/components/theme/theme-head-bottom.marko +0 -1
  257. package/src/theme/default/components/theme/theme-head-top.marko +0 -1
  258. package/src/theme/default/components/theme/theme-home-features-after.marko +0 -1
  259. package/src/theme/default/components/theme/theme-home-hero-after.marko +0 -1
  260. package/src/theme/default/components/theme/theme-home-hero-before.marko +0 -1
  261. package/src/theme/default/components/theme/theme-navbar-center.marko +0 -5
  262. package/src/theme/default/components/theme/theme-navbar-end.marko +0 -30
  263. package/src/theme/default/components/theme/theme-navbar-start.marko +0 -1
  264. package/src/theme/default/components/theme/theme-page-bottom.marko +0 -1
  265. package/src/theme/default/components/theme/theme-page-top.marko +0 -1
  266. package/src/theme/default/components/theme/theme-sidebar-bottom.marko +0 -1
  267. package/src/theme/default/components/theme/theme-sidebar-top.marko +0 -1
  268. package/src/theme/default/components/theme/theme-toc-item.marko +0 -1
  269. package/src/theme/default/components/theme-toggle.marko +0 -122
  270. package/src/theme/default/components/toc.marko +0 -140
  271. package/src/theme/default/design-systems/default.ts +0 -331
  272. package/src/theme/default/design-systems/docusaurus.ts +0 -341
  273. package/src/theme/default/design-systems/index.ts +0 -67
  274. package/src/theme/default/design-systems/rspress.ts +0 -341
  275. package/src/theme/default/design-systems/types.ts +0 -296
  276. package/src/theme/default/design-systems/vitepress.ts +0 -341
  277. package/src/theme/default/index.ts +0 -107
  278. package/src/theme/default/theme.ts +0 -83
  279. package/templates/example-tags/README.md +0 -212
  280. package/templates/example-tags/alert-box.marko +0 -98
  281. package/templates/example-tags/button-primary.marko +0 -28
  282. package/templates/example-tags/button-secondary.marko +0 -28
  283. package/templates/example-tags/button.marko +0 -6
  284. package/templates/example-tags/card-body.marko +0 -8
  285. package/templates/example-tags/card-footer.marko +0 -7
  286. package/templates/example-tags/card-header.marko +0 -7
  287. package/templates/example-tags/card.marko +0 -20
  288. package/templates/example-tags/icon.marko +0 -149
@@ -1,49 +0,0 @@
1
- /*!
2
- * Skip Link Component
3
- * Accessibility skip link that allows keyboard users to jump to main content
4
- * Hidden until focused
5
- */
6
-
7
- <a
8
- href="#main-content"
9
- class="skip-link"
10
- aria-label="Skip to main content">
11
- Skip to main content
12
- </a>
13
-
14
- <style>
15
- .skip-link {
16
- position: absolute;
17
- top: -40px;
18
- left: 0;
19
- padding: var(--space-sm) var(--space-md);
20
- background: var(--color-primary-2, #3a5ccc);
21
- color: var(--bg-default, #ffffff);
22
- text-decoration: none;
23
- font-weight: var(--font-weight-medium);
24
- z-index: 9999;
25
- transition: top var(--transition-fast);
26
- border-radius: 0 var(--radius-sm, 4px) var(--radius-sm, 4px) 0;
27
- }
28
-
29
- .skip-link:focus {
30
- top: 0;
31
- outline: 2px solid var(--color-primary-1, #3451b2);
32
- outline-offset: -2px;
33
- }
34
-
35
- /* Ensure high contrast for accessibility */
36
- @media (prefers-contrast: high) {
37
- .skip-link {
38
- background: var(--color-primary-1, #3451b2);
39
- border: 2px solid var(--text-1, #111827);
40
- }
41
- }
42
-
43
- /* Reduced motion support */
44
- @media (prefers-reduced-motion: reduce) {
45
- .skip-link {
46
- transition: none;
47
- }
48
- }
49
- </style>
@@ -1 +0,0 @@
1
- <!-- Extension point: theme aside bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme aside top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme body bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme body top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme doc bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme doc footer after -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme doc footer before -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme doc top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme head bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme head top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme home features after -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme home hero after -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme home hero before -->
@@ -1,5 +0,0 @@
1
- <nav class="navbar-nav">
2
- <if=input.items>
3
- <nav-bar items=input.items/>
4
- </if>
5
- </nav>
@@ -1,30 +0,0 @@
1
- <div class="navbar-actions">
2
- <!-- Search Component with Keyboard Shortcut -->
3
- <search/>
4
-
5
- <!-- Theme Toggle (Dark Mode) -->
6
- <theme-toggle/>
7
-
8
- <!-- Mobile Menu Toggle -->
9
- <button class="btn-icon mobile-menu-toggle" aria-label="Toggle menu" onClick() {
10
- if (input.setMobileMenuOpen) {
11
- input.setMobileMenuOpen(!input.mobileMenuOpen);
12
- }
13
- }>
14
- <if=input.mobileMenuOpen>
15
- <!-- Close Icon -->
16
- <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
17
- <line x1=18 y1=6 x2=6 y2=18/>
18
- <line x1=6 y1=6 x2=18 y2=18/>
19
- </svg>
20
- </if>
21
- <else>
22
- <!-- Menu Icon -->
23
- <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
24
- <line x1=3 y1=12 x2=21 y2=12/>
25
- <line x1=3 y1=6 x2=21 y2=6/>
26
- <line x1=3 y1=18 x2=21 y2=18/>
27
- </svg>
28
- </else>
29
- </button>
30
- </div>
@@ -1 +0,0 @@
1
- <!-- Extension point: theme navbar start -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme page bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme page top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme sidebar bottom -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme sidebar top -->
@@ -1 +0,0 @@
1
- <!-- Extension point: theme toc item -->
@@ -1,122 +0,0 @@
1
- /*!
2
- * Theme Toggle Component
3
- * Dark mode toggle with sun/moon icons and localStorage persistence
4
- */
5
-
6
- <let/isDark=false/>
7
-
8
- <style/styles>
9
- .toggle {
10
- display: inline-flex;
11
- align-items: center;
12
- justify-content: center;
13
- width: 40px;
14
- height: 40px;
15
- padding: 0;
16
- border: none;
17
- background: transparent;
18
- color: var(--text-2);
19
- cursor: pointer;
20
- border-radius: var(--radius-md, 8px);
21
- transition: background-color var(--transition-fast), color var(--transition-fast);
22
- }
23
-
24
- .toggle:hover {
25
- background: var(--bg-soft);
26
- color: var(--text-1);
27
- }
28
-
29
- .toggle:focus-visible {
30
- outline: 2px solid var(--color-primary-2, #3a5ccc);
31
- outline-offset: 2px;
32
- }
33
-
34
- .icon {
35
- transition: opacity var(--transition-fast), transform var(--transition-fast);
36
- }
37
-
38
- .icon.moon {
39
- animation: moon-rise 0.3s ease-out;
40
- }
41
-
42
- .icon.sun {
43
- animation: sun-rise 0.3s ease-out;
44
- }
45
-
46
- @keyframes moon-rise {
47
- from {
48
- opacity: 0;
49
- transform: rotate(-90deg) scale(0.5);
50
- }
51
- to {
52
- opacity: 1;
53
- transform: rotate(0) scale(1);
54
- }
55
- }
56
-
57
- @keyframes sun-rise {
58
- from {
59
- opacity: 0;
60
- transform: rotate(90deg) scale(0.5);
61
- }
62
- to {
63
- opacity: 1;
64
- transform: rotate(0) scale(1);
65
- }
66
- }
67
- </style>
68
-
69
- <button
70
- class=styles.toggle
71
- aria-label="Toggle dark mode"
72
- onClick(e) {
73
- isDark = !isDark;
74
- if (typeof document !== 'undefined') {
75
- const html = document.documentElement;
76
- if (isDark) {
77
- html.classList.add('dark');
78
- } else {
79
- html.classList.remove('dark');
80
- }
81
- localStorage.setItem('theme', isDark ? 'dark' : 'light');
82
- }
83
- }>
84
- <if=isDark>
85
- <svg
86
- class=styles.icon.sun
87
- xmlns="http://www.w3.org/2000/svg"
88
- width="20"
89
- height="20"
90
- viewBox="0 0 24 24"
91
- fill="none"
92
- stroke="currentColor"
93
- stroke-width="2"
94
- stroke-linecap="round"
95
- stroke-linejoin="round">
96
- <circle cx="12" cy="12" r="5"></circle>
97
- <line x1="12" y1="1" x2="12" y2="3"></line>
98
- <line x1="12" y1="21" x2="12" y2="23"></line>
99
- <line x1="4.22" y1="4.22" x2="5.64" y2="5.64"></line>
100
- <line x1="18.36" y1="18.36" x2="19.78" y2="19.78"></line>
101
- <line x1="1" y1="12" x2="3" y2="12"></line>
102
- <line x1="21" y1="12" x2="23" y2="12"></line>
103
- <line x1="4.22" y1="19.78" x2="5.64" y2="18.36"></line>
104
- <line x1="18.36" y1="5.64" x2="19.78" y2="4.22"></line>
105
- </svg>
106
- </if>
107
- <else>
108
- <svg
109
- class=styles.icon.moon
110
- xmlns="http://www.w3.org/2000/svg"
111
- width="20"
112
- height="20"
113
- viewBox="0 0 24 24"
114
- fill="none"
115
- stroke="currentColor"
116
- stroke-width="2"
117
- stroke-linecap="round"
118
- stroke-linejoin="round">
119
- <path d="M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z"></path>
120
- </svg>
121
- </else>
122
- </button>
@@ -1,140 +0,0 @@
1
- <let/hasHeaders=(input.headers && input.headers.length > 0)/>
2
-
3
- <if=hasHeaders>
4
- <nav class="toc">
5
- <div class="toc-header">On This Page</div>
6
- <ul class="toc-list">
7
- <for|header| of=input.headers>
8
- <li class="toc-item">
9
- <a href="#" + header.slug class="toc-link toc-link--level-2">
10
- <span class="toc-text">${header.title}</span>
11
- </a>
12
-
13
- <if=(header.children && header.children.length > 0)>
14
- <ul class="toc-list toc-list--nested">
15
- <for|child| of=header.children>
16
- <li class="toc-item">
17
- <a href="#" + child.slug class="toc-link toc-link--level-3">
18
- <span class="toc-text">${child.title}</span>
19
- </a>
20
- </li>
21
- </for>
22
- </ul>
23
- </if>
24
- </li>
25
- </for>
26
- </ul>
27
- </nav>
28
- </if>
29
-
30
- <style>
31
- .toc {
32
- position: sticky;
33
- top: var(--navbar-height, 60px);
34
- width: var(--toc-width, 220px);
35
- flex-shrink: 0;
36
- align-self: flex-start;
37
- max-height: calc(100vh - 80px);
38
- overflow-y: auto;
39
- padding-left: var(--space-md, 1rem);
40
- border-left: 1px solid var(--border-color, #e5e7eb);
41
- }
42
-
43
- .toc-header {
44
- font-size: var(--text-xs, 0.75rem);
45
- font-weight: var(--font-semibold, 600);
46
- color: var(--text-tertiary, #6b7280);
47
- text-transform: uppercase;
48
- letter-spacing: 0.05em;
49
- margin-bottom: var(--space-sm, 0.75rem);
50
- padding-left: var(--space-xs, 0.5rem);
51
- }
52
-
53
- .toc-list {
54
- list-style: none;
55
- padding: 0;
56
- margin: 0;
57
- display: flex;
58
- flex-direction: column;
59
- gap: 2px;
60
- }
61
-
62
- .toc-list--nested {
63
- gap: 1px;
64
- margin-top: 2px;
65
- padding-left: 0;
66
- }
67
-
68
- .toc-item {
69
- list-style: none;
70
- }
71
-
72
- .toc-link {
73
- display: flex;
74
- align-items: center;
75
- padding: 6px var(--space-sm, 0.75rem);
76
- font-size: var(--text-sm, 0.875rem);
77
- color: var(--text-secondary, #64748b);
78
- text-decoration: none;
79
- border-radius: 4px;
80
- transition: all 0.15s ease;
81
- line-height: 1.5;
82
- }
83
-
84
- .toc-link:hover {
85
- color: var(--text-primary, #334155);
86
- background-color: var(--c-gray-100, #f1f5f9);
87
- }
88
-
89
- .toc-link.toc-link--level-3 {
90
- font-size: var(--text-xs, 0.75rem);
91
- padding: 4px var(--space-sm, 0.75rem) 4px 24px;
92
- color: var(--text-tertiary, #94a3b8);
93
- }
94
-
95
- .toc-link.toc-link--level-3:hover {
96
- color: var(--text-secondary, #475569);
97
- background-color: var(--c-gray-50, #f8fafc);
98
- }
99
-
100
- .toc-link.active {
101
- color: var(--c-brand, #3b82f6);
102
- background-color: var(--accent-bg, rgba(59, 130, 246, 0.1));
103
- font-weight: var(--font-medium, 500);
104
- }
105
-
106
- .toc-link.toc-link--level-3.active {
107
- color: var(--c-brand, #3b82f6);
108
- background-color: var(--accent-bg, rgba(59, 130, 246, 0.1));
109
- }
110
-
111
- /* Scrollbar styling for TOC */
112
- .toc::-webkit-scrollbar {
113
- width: 4px;
114
- }
115
-
116
- .toc::-webkit-scrollbar-track {
117
- background: transparent;
118
- }
119
-
120
- .toc::-webkit-scrollbar-thumb {
121
- background: var(--c-gray-300, #d1d5db);
122
- border-radius: 2px;
123
- }
124
-
125
- .toc::-webkit-scrollbar-thumb:hover {
126
- background: var(--c-gray-400, #9ca3af);
127
- }
128
-
129
- @media (max-width: 1280px) {
130
- .toc {
131
- width: 180px;
132
- }
133
- }
134
-
135
- @media (max-width: 1024px) {
136
- .toc {
137
- display: none;
138
- }
139
- }
140
- </style>