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,20 +0,0 @@
1
- /*!
2
- * Header Component
3
- * Displays site title, description, and statistics
4
- */
5
-
6
- <div class="header">
7
- <h1>🚀 ${input.title || 'MarkoPress'}</h1>
8
- <p>${input.description || 'A general-purpose static site generator using Marko.js v6'}</p>
9
-
10
- <if=input.stats>
11
- <div class="stats stats-container">
12
- <for|stat| of=input.stats>
13
- <div class="stat">
14
- <div class="stat-value">${stat.value}</div>
15
- <div class="stat-label">${stat.label}</div>
16
- </div>
17
- </for>
18
- </div>
19
- </if>
20
- </div>
@@ -1,36 +0,0 @@
1
- /*!
2
- * Reading Progress Indicator Component
3
- * Subtle progress bar at top of page showing scroll progress
4
- */
5
-
6
- <let/progress=0/>
7
-
8
- <style/styles>
9
- .container {
10
- position: fixed;
11
- top: 0;
12
- left: 0;
13
- right: 0;
14
- height: 2px;
15
- background: transparent;
16
- z-index: 9999;
17
- pointer-events: none;
18
- }
19
-
20
- .bar {
21
- height: 100%;
22
- background: var(--color-primary-2, rgba(100, 108, 255, 0.3));
23
- transition: width 100ms linear;
24
- }
25
-
26
- /* Reduced motion support */
27
- @media (prefers-reduced-motion: reduce) {
28
- .bar {
29
- transition: none;
30
- }
31
- }
32
- </style>
33
-
34
- <div class=styles.container>
35
- <div class=styles.bar style="width: ${progress}%"></>
36
- </div>
@@ -1,239 +0,0 @@
1
- /*!
2
- * Search Component
3
- * Search placeholder with keyboard shortcut (Ctrl+K / Cmd+K) and modal overlay
4
- * Functional search to be implemented later
5
- */
6
-
7
- <let/isOpen=false/>
8
-
9
- <button
10
- class="search-trigger"
11
- aria-label="Search"
12
- onClick(e) {
13
- isOpen = true;
14
- }>
15
- <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
16
- <circle cx="11" cy="11" r="8"></circle>
17
- <line x1="21" y1="21" x2="16.65" y2="16.65"></line>
18
- </svg>
19
- <span class="search-label">Search</span>
20
- <kbd class="search-shortcut">
21
- <if=(typeof navigator !== 'undefined' && /Mac|iPod|iPhone|iPad/.test(navigator.platform))>
22
- ⌘K
23
- </if>
24
- <else>
25
- Ctrl K
26
- </else>
27
- </kbd>
28
- </button>
29
-
30
- <if=isOpen>
31
- <div
32
- class="search-modal"
33
- onClick(e) {
34
- isOpen = false;
35
- }>
36
- <div
37
- class="search-modal-content"
38
- onClick(e) {
39
- e.stopPropagation();
40
- }>
41
- <div class="search-input-wrapper">
42
- <svg class="search-icon" xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
43
- <circle cx="11" cy="11" r="8"></circle>
44
- <line x1="21" y1="21" x2="16.65" y2="16.65"></line>
45
- </svg>
46
- <input
47
- type="text"
48
- class="search-input"
49
- placeholder="Search documentation..."
50
- disabled
51
- />
52
- <kbd class="search-shortcut-small">ESC</kbd>
53
- </div>
54
- <div class="search-placeholder">
55
- <svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" class="search-placeholder-icon">
56
- <circle cx="11" cy="11" r="8"></circle>
57
- <line x1="21" y1="21" x2="16.65" y2="16.65"></line>
58
- </svg>
59
- <p class="search-placeholder-text">Search is coming soon!</p>
60
- <p class="search-placeholder-hint">Press <kbd>ESC</kbd> to close</p>
61
- </div>
62
- </div>
63
- </div>
64
- </if>
65
-
66
- <style>
67
- .search-trigger {
68
- display: inline-flex;
69
- align-items: center;
70
- gap: var(--space-xs);
71
- padding: var(--space-sm) var(--space-md);
72
- border: 1px solid var(--border-default);
73
- background: var(--bg-alt);
74
- color: var(--text-2);
75
- font-size: var(--font-size-sm);
76
- border-radius: var(--radius-md, 8px);
77
- cursor: pointer;
78
- transition: all var(--transition-fast);
79
- }
80
-
81
- .search-trigger:hover {
82
- border-color: var(--color-primary-2, #3a5ccc);
83
- background: var(--bg-soft);
84
- color: var(--text-1);
85
- }
86
-
87
- .search-trigger:focus-visible {
88
- outline: 2px solid var(--color-primary-2, #3a5ccc);
89
- outline-offset: 2px;
90
- }
91
-
92
- .search-label {
93
- display: none;
94
- }
95
-
96
- @media (min-width: 768px) {
97
- .search-label {
98
- display: inline;
99
- }
100
- }
101
-
102
- .search-shortcut,
103
- .search-shortcut-small {
104
- padding: 2px 6px;
105
- font-size: 11px;
106
- font-family: var(--font-mono);
107
- background: var(--bg-default);
108
- border: 1px solid var(--border-default);
109
- border-radius: var(--radius-sm, 4px);
110
- color: var(--text-3);
111
- }
112
-
113
- .search-shortcut {
114
- display: none;
115
- }
116
-
117
- @media (min-width: 768px) {
118
- .search-shortcut {
119
- display: inline-block;
120
- }
121
- }
122
-
123
- /* Search Modal */
124
- .search-modal {
125
- position: fixed;
126
- top: 0;
127
- left: 0;
128
- right: 0;
129
- bottom: 0;
130
- background: rgba(0, 0, 0, 0.5);
131
- display: flex;
132
- align-items: flex-start;
133
- justify-content: center;
134
- padding-top: calc(var(--navbar-height, 64px) + var(--space-xl));
135
- z-index: 100;
136
- animation: fade-in 0.2s ease-out;
137
- }
138
-
139
- @keyframes fade-in {
140
- from {
141
- opacity: 0;
142
- }
143
- to {
144
- opacity: 1;
145
- }
146
- }
147
-
148
- .search-modal-content {
149
- width: 90%;
150
- max-width: 640px;
151
- background: var(--bg-default);
152
- border: 1px solid var(--border-default);
153
- border-radius: var(--radius-lg, 12px);
154
- box-shadow: var(--shadow-5);
155
- overflow: hidden;
156
- animation: slide-down 0.2s ease-out;
157
- }
158
-
159
- @keyframes slide-down {
160
- from {
161
- opacity: 0;
162
- transform: translateY(-10px);
163
- }
164
- to {
165
- opacity: 1;
166
- transform: translateY(0);
167
- }
168
- }
169
-
170
- .search-input-wrapper {
171
- display: flex;
172
- align-items: center;
173
- gap: var(--space-md);
174
- padding: var(--space-md) var(--space-lg);
175
- border-bottom: 1px solid var(--border-default);
176
- }
177
-
178
- .search-icon {
179
- flex-shrink: 0;
180
- color: var(--text-3);
181
- }
182
-
183
- .search-input {
184
- flex: 1;
185
- border: none;
186
- background: transparent;
187
- font-size: var(--font-size-base);
188
- color: var(--text-1);
189
- outline: none;
190
- }
191
-
192
- .search-input::placeholder {
193
- color: var(--text-3);
194
- }
195
-
196
- .search-input:disabled {
197
- cursor: not-allowed;
198
- }
199
-
200
- .search-shortcut-small {
201
- flex-shrink: 0;
202
- }
203
-
204
- .search-placeholder {
205
- display: flex;
206
- flex-direction: column;
207
- align-items: center;
208
- justify-content: center;
209
- padding: var(--space-3xl);
210
- text-align: center;
211
- }
212
-
213
- .search-placeholder-icon {
214
- margin-bottom: var(--space-md);
215
- color: var(--text-3);
216
- opacity: 0.5;
217
- }
218
-
219
- .search-placeholder-text {
220
- font-size: var(--font-size-base);
221
- font-weight: var(--font-weight-medium);
222
- color: var(--text-1);
223
- margin-bottom: var(--space-sm);
224
- }
225
-
226
- .search-placeholder-hint {
227
- font-size: var(--font-size-sm);
228
- color: var(--text-3);
229
- }
230
-
231
- .search-placeholder-hint kbd {
232
- padding: 2px 6px;
233
- font-size: 11px;
234
- font-family: var(--font-mono);
235
- background: var(--bg-alt);
236
- border: 1px solid var(--border-default);
237
- border-radius: var(--radius-sm, 4px);
238
- }
239
- </style>
@@ -1,211 +0,0 @@
1
- /*!
2
- * Sidebar Component
3
- * Hierarchical navigation with collapsible groups
4
- */
5
-
6
- <let/openGroups=new Set((input.initialOpenGroups || []))/>
7
- <let/currentPath=(typeof window !== "undefined" && window.location && window.location.pathname) || ""/>
8
-
9
- <style/styles>
10
- .content {
11
- display: flex;
12
- flex-direction: column;
13
- gap: var(--space-lg);
14
- }
15
-
16
- .section {
17
- display: flex;
18
- flex-direction: column;
19
- gap: var(--space-md);
20
- }
21
-
22
- .sectionHeader {
23
- padding: var(--sidebar-category-padding, var(--space-sm) 0);
24
- font-size: var(--sidebar-category-font-size, 0.75rem);
25
- font-weight: var(--sidebar-category-font-weight, 600);
26
- text-transform: var(--sidebar-category-text-transform, uppercase);
27
- color: var(--text-2, #6b7280);
28
- letter-spacing: 0.05em;
29
- }
30
-
31
- .nav {
32
- list-style: none;
33
- display: flex;
34
- flex-direction: column;
35
- gap: var(--sidebar-item-gap, var(--space-xs));
36
- }
37
-
38
- .item {
39
- list-style: none;
40
- }
41
-
42
- .link {
43
- display: flex;
44
- align-items: center;
45
- gap: var(--space-sm);
46
- padding: var(--sidebar-item-padding, var(--space-sm) var(--space-md));
47
- font-size: var(--sidebar-item-font-size, 0.875rem);
48
- font-weight: var(--sidebar-item-font-weight, 400);
49
- color: var(--text-2, #6b7280);
50
- text-decoration: none;
51
- border-radius: var(--sidebar-item-border-radius, 4px);
52
- transition: all var(--transition-fast, 0.15s);
53
- line-height: var(--sidebar-item-height, 1.4);
54
- height: var(--sidebar-item-height, auto);
55
- }
56
-
57
- .link:hover {
58
- color: var(--text-1, #1f2937);
59
- background: var(--sidebar-hover-background, rgba(0, 0, 0, 0.05));
60
- }
61
-
62
- .link.active {
63
- color: var(--color-primary-1, #3a5ccc);
64
- background: var(--sidebar-active-background, rgba(100, 108, 255, 0.14));
65
- font-weight: var(--sidebar-item-font-weight, 500);
66
- border-left: var(--sidebar-active-border, 2px solid #3451b2);
67
- }
68
-
69
- .icon {
70
- flex-shrink: 0;
71
- font-size: 1rem;
72
- }
73
-
74
- .text {
75
- flex: 1;
76
- }
77
-
78
- .group {
79
- display: flex;
80
- flex-direction: column;
81
- }
82
-
83
- .groupHeader {
84
- display: flex;
85
- align-items: center;
86
- justify-content: space-between;
87
- padding: var(--sidebar-item-padding, var(--space-sm) var(--space-md));
88
- font-size: var(--sidebar-item-font-size, 0.875rem);
89
- font-weight: 500;
90
- color: var(--text-1, #1f2937);
91
- cursor: pointer;
92
- border-radius: var(--sidebar-item-border-radius, 4px);
93
- transition: background-color var(--transition-fast, 0.15s);
94
- user-select: none;
95
- height: var(--sidebar-item-height, auto);
96
- }
97
-
98
- .groupHeader:hover {
99
- background: var(--sidebar-hover-background, rgba(0, 0, 0, 0.05));
100
- }
101
-
102
- .groupTitle {
103
- flex: 1;
104
- }
105
-
106
- .groupIcon {
107
- flex-shrink: 0;
108
- transition: transform var(--transition-fast, 0.15s);
109
- }
110
-
111
- .groupIcon.rotated {
112
- transform: rotate(90deg);
113
- }
114
-
115
- .groupItems {
116
- list-style: none;
117
- padding-left: var(--space-lg);
118
- margin-top: var(--space-xs);
119
- display: flex;
120
- flex-direction: column;
121
- gap: var(--sidebar-item-gap, var(--space-xs));
122
- border-left: 1px solid var(--border-divider, #e5e7eb);
123
- }
124
-
125
- .groupItems .link {
126
- font-size: var(--sidebar-item-font-size, 0.875rem);
127
- color: var(--text-2, #6b7280);
128
- }
129
- </style>
130
-
131
- <div class=styles.content role="navigation" aria-label="Sidebar navigation">
132
- <!-- Sidebar Sections -->
133
- <for|section| of=(input.sections || [])>
134
- <div class=styles.section>
135
- <!-- Section Header -->
136
- <if=section.text>
137
- <div class=styles.sectionHeader>${section.text}</div>
138
- </if>
139
-
140
- <!-- Section Items -->
141
- <ul class=styles.nav>
142
- <for|item| of=section.items>
143
- <if=item.items && item.items.length>
144
- <!-- Item with children (collapsible group) -->
145
- <li class=styles.group>
146
- <div
147
- class=styles.groupHeader
148
- onClick(e) {
149
- if (openGroups.has(item.text)) {
150
- openGroups.delete(item.text);
151
- } else {
152
- openGroups.add(item.text);
153
- }
154
- }
155
- role="button"
156
- tabindex="0"
157
- aria-expanded=openGroups.has(item.text)>
158
- <span class=styles.groupTitle>${item.text}</span>
159
- <let/rotatedClass=openGroups.has(item.text) ? styles.groupIcon + ' ' + styles.rotated : styles.groupIcon/>
160
- <svg
161
- class=rotatedClass
162
- xmlns="http://www.w3.org/2000/svg"
163
- width="16"
164
- height="16"
165
- viewBox="0 0 24 24"
166
- fill="none"
167
- stroke="currentColor"
168
- stroke-width="2">
169
- <polyline points="9 18 15 12 9 6"></polyline>
170
- </svg>
171
- </div>
172
-
173
- <if=openGroups.has(item.text)>
174
- <ul class=styles.groupItems>
175
- <for|subitem| of=item.items>
176
- <let/subitemClass=currentPath === subitem.link ? styles.link + ' ' + styles.active : styles.link/>
177
- <li class=styles.item>
178
- <a
179
- class=subitemClass
180
- href=subitem.link>
181
- <if=subitem.icon>
182
- <span class=styles.icon>${subitem.icon}</span>
183
- </if>
184
- <span class=styles.text>${subitem.text}</span>
185
- </a>
186
- </li>
187
- </for>
188
- </ul>
189
- </if>
190
- </li>
191
- </if>
192
-
193
- <if=!item.items || item.items.length === 0>
194
- <!-- Regular item (no children) -->
195
- <let/itemClass=currentPath === item.link ? styles.link + ' ' + styles.active : styles.link/>
196
- <li class=styles.item>
197
- <a
198
- class=itemClass
199
- href=item.link>
200
- <if=item.icon>
201
- <span class=styles.icon>${item.icon}</span>
202
- </if>
203
- <span class=styles.text>${item.text}</span>
204
- </a>
205
- </li>
206
- </if>
207
- </for>
208
- </ul>
209
- </div>
210
- </for>
211
- </div>
@@ -1,211 +0,0 @@
1
- /*!
2
- * Footer Component
3
- * Site footer with navigation, copyright, and social links
4
- */
5
-
6
- <footer class="site-footer">
7
- <div class="footer-container">
8
- <!-- Main Footer Content -->
9
- <div class="footer-main">
10
- <!-- Logo/Brand -->
11
- <if=input.logo || input.siteName>
12
- <div class="footer-brand">
13
- <if=input.logo>
14
- <img src=input.logo alt="Logo" class="footer-logo">
15
- </if>
16
- <if=input.siteName>
17
- <div class="footer-site-name">${input.siteName}</div>
18
- </if>
19
- <if=input.tagline>
20
- <p class="footer-tagline">${input.tagline}</p>
21
- </if>
22
- </div>
23
- </if>
24
-
25
- <!-- Footer Links Columns -->
26
- <div class="footer-columns">
27
- <for|column| of=(input.columns || [])>
28
- <div class="footer-column">
29
- <h3 class="footer-column-title">${column.title}</h3>
30
- <ul class="footer-column-links">
31
- <for|link| of=column.links>
32
- <li>
33
- <a href=link.url class="footer-link">
34
- ${link.text}
35
- </a>
36
- </li>
37
- </for>
38
- </ul>
39
- </div>
40
- </for>
41
- </div>
42
- </div>
43
-
44
- <!-- Footer Bottom -->
45
- <div class="footer-bottom">
46
- <!-- Copyright -->
47
- <div class="footer-copyright">
48
- <p>© ${new Date().getFullYear()} ${input.siteName || 'MarkoPress'}. All rights reserved.</p>
49
- <if=input.license>
50
- <p class="footer-license">${input.license}</p>
51
- </if>
52
- </div>
53
-
54
- <!-- Social Links -->
55
- <if=input.social>
56
- <div class="footer-social">
57
- <for|social| of=input.social>
58
- <a
59
- href=social.url
60
- class="footer-social-link"
61
- target="_blank"
62
- rel="noopener noreferrer"
63
- aria-label=social.label>
64
- <span>${social.icon || social.label}</span>
65
- </a>
66
- </for>
67
- </div>
68
- </if>
69
- </div>
70
- </div>
71
- </footer>
72
-
73
- <style>
74
- .site-footer {
75
- background: var(--bg-secondary);
76
- border-top: 1px solid var(--border-color);
77
- }
78
-
79
- .footer-container {
80
- max-width: var(--container-max-width);
81
- margin: 0 auto;
82
- padding: var(--space-3xl) var(--space-lg) var(--space-lg);
83
- }
84
-
85
- /* Main Footer Content */
86
- .footer-main {
87
- display: grid;
88
- grid-template-columns: 1fr;
89
- gap: var(--space-2xl);
90
- margin-bottom: var(--space-2xl);
91
- }
92
-
93
- @media (min-width: 768px) {
94
- .footer-main {
95
- grid-template-columns: 2fr 3fr;
96
- }
97
- }
98
-
99
- /* Brand Section */
100
- .footer-brand {
101
- display: flex;
102
- flex-direction: column;
103
- gap: var(--space-md);
104
- }
105
-
106
- .footer-logo {
107
- width: 40px;
108
- height: 40px;
109
- }
110
-
111
- .footer-site-name {
112
- font-size: var(--text-xl);
113
- font-weight: var(--font-semibold);
114
- color: var(--text-primary);
115
- }
116
-
117
- .footer-tagline {
118
- font-size: var(--text-sm);
119
- color: var(--text-secondary);
120
- line-height: var(--leading-relaxed);
121
- }
122
-
123
- /* Footer Columns */
124
- .footer-columns {
125
- display: grid;
126
- grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
127
- gap: var(--space-lg);
128
- }
129
-
130
- .footer-column-title {
131
- font-size: var(--text-sm);
132
- font-weight: var(--font-semibold);
133
- color: var(--text-primary);
134
- margin-bottom: var(--space-md);
135
- text-transform: uppercase;
136
- letter-spacing: 0.05em;
137
- }
138
-
139
- .footer-column-links {
140
- list-style: none;
141
- padding: 0;
142
- margin: 0;
143
- display: flex;
144
- flex-direction: column;
145
- gap: var(--space-sm);
146
- }
147
-
148
- .footer-link {
149
- font-size: var(--text-sm);
150
- color: var(--text-secondary);
151
- text-decoration: none;
152
- transition: color var(--transition-fast);
153
- }
154
-
155
- .footer-link:hover {
156
- color: var(--accent-primary);
157
- }
158
-
159
- /* Footer Bottom */
160
- .footer-bottom {
161
- display: flex;
162
- flex-direction: column;
163
- gap: var(--space-md);
164
- padding-top: var(--space-lg);
165
- border-top: 1px solid var(--border-color);
166
- }
167
-
168
- @media (min-width: 768px) {
169
- .footer-bottom {
170
- flex-direction: row;
171
- justify-content: space-between;
172
- align-items: center;
173
- }
174
- }
175
-
176
- .footer-copyright {
177
- font-size: var(--text-sm);
178
- color: var(--text-tertiary);
179
- }
180
-
181
- .footer-copyright p {
182
- margin: 0;
183
- }
184
-
185
- .footer-license {
186
- margin-top: var(--space-xs);
187
- }
188
-
189
- /* Social Links */
190
- .footer-social {
191
- display: flex;
192
- gap: var(--space-md);
193
- }
194
-
195
- .footer-social-link {
196
- display: flex;
197
- align-items: center;
198
- justify-content: center;
199
- width: 36px;
200
- height: 36px;
201
- color: var(--text-secondary);
202
- background: var(--bg-tertiary);
203
- border-radius: var(--radius-md);
204
- transition: all var(--transition-fast);
205
- }
206
-
207
- .footer-social-link:hover {
208
- color: var(--accent-primary);
209
- background: var(--accent-bg);
210
- }
211
- </style>