@fuzdev/fuz_ui 0.169.0

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 (323) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +93 -0
  3. package/dist/Alert.svelte +108 -0
  4. package/dist/Alert.svelte.d.ts +16 -0
  5. package/dist/Alert.svelte.d.ts.map +1 -0
  6. package/dist/ApiDeclarationList.svelte +35 -0
  7. package/dist/ApiDeclarationList.svelte.d.ts +9 -0
  8. package/dist/ApiDeclarationList.svelte.d.ts.map +1 -0
  9. package/dist/ApiIndex.svelte +65 -0
  10. package/dist/ApiIndex.svelte.d.ts +23 -0
  11. package/dist/ApiIndex.svelte.d.ts.map +1 -0
  12. package/dist/ApiModule.svelte +124 -0
  13. package/dist/ApiModule.svelte.d.ts +22 -0
  14. package/dist/ApiModule.svelte.d.ts.map +1 -0
  15. package/dist/Breadcrumb.svelte +83 -0
  16. package/dist/Breadcrumb.svelte.d.ts +23 -0
  17. package/dist/Breadcrumb.svelte.d.ts.map +1 -0
  18. package/dist/Card.svelte +157 -0
  19. package/dist/Card.svelte.d.ts +13 -0
  20. package/dist/Card.svelte.d.ts.map +1 -0
  21. package/dist/ColorSchemeInput.svelte +65 -0
  22. package/dist/ColorSchemeInput.svelte.d.ts +11 -0
  23. package/dist/ColorSchemeInput.svelte.d.ts.map +1 -0
  24. package/dist/Contextmenu.svelte +30 -0
  25. package/dist/Contextmenu.svelte.d.ts +32 -0
  26. package/dist/Contextmenu.svelte.d.ts.map +1 -0
  27. package/dist/ContextmenuEntry.svelte +74 -0
  28. package/dist/ContextmenuEntry.svelte.d.ts +12 -0
  29. package/dist/ContextmenuEntry.svelte.d.ts.map +1 -0
  30. package/dist/ContextmenuLinkEntry.svelte +112 -0
  31. package/dist/ContextmenuLinkEntry.svelte.d.ts +12 -0
  32. package/dist/ContextmenuLinkEntry.svelte.d.ts.map +1 -0
  33. package/dist/ContextmenuRoot.svelte +372 -0
  34. package/dist/ContextmenuRoot.svelte.d.ts +71 -0
  35. package/dist/ContextmenuRoot.svelte.d.ts.map +1 -0
  36. package/dist/ContextmenuRootForSafariCompatibility.svelte +541 -0
  37. package/dist/ContextmenuRootForSafariCompatibility.svelte.d.ts +79 -0
  38. package/dist/ContextmenuRootForSafariCompatibility.svelte.d.ts.map +1 -0
  39. package/dist/ContextmenuSeparator.svelte +16 -0
  40. package/dist/ContextmenuSeparator.svelte.d.ts +4 -0
  41. package/dist/ContextmenuSeparator.svelte.d.ts.map +1 -0
  42. package/dist/ContextmenuSubmenu.svelte +116 -0
  43. package/dist/ContextmenuSubmenu.svelte.d.ts +10 -0
  44. package/dist/ContextmenuSubmenu.svelte.d.ts.map +1 -0
  45. package/dist/ContextmenuTextEntry.svelte +21 -0
  46. package/dist/ContextmenuTextEntry.svelte.d.ts +10 -0
  47. package/dist/ContextmenuTextEntry.svelte.d.ts.map +1 -0
  48. package/dist/CopyToClipboard.svelte +81 -0
  49. package/dist/CopyToClipboard.svelte.d.ts +18 -0
  50. package/dist/CopyToClipboard.svelte.d.ts.map +1 -0
  51. package/dist/DeclarationDetail.svelte +340 -0
  52. package/dist/DeclarationDetail.svelte.d.ts +8 -0
  53. package/dist/DeclarationDetail.svelte.d.ts.map +1 -0
  54. package/dist/DeclarationLink.svelte +50 -0
  55. package/dist/DeclarationLink.svelte.d.ts +8 -0
  56. package/dist/DeclarationLink.svelte.d.ts.map +1 -0
  57. package/dist/Details.svelte +51 -0
  58. package/dist/Details.svelte.d.ts +20 -0
  59. package/dist/Details.svelte.d.ts.map +1 -0
  60. package/dist/Dialog.svelte +217 -0
  61. package/dist/Dialog.svelte.d.ts +30 -0
  62. package/dist/Dialog.svelte.d.ts.map +1 -0
  63. package/dist/Dialogs.svelte +28 -0
  64. package/dist/Dialogs.svelte.d.ts +11 -0
  65. package/dist/Dialogs.svelte.d.ts.map +1 -0
  66. package/dist/Docs.svelte +179 -0
  67. package/dist/Docs.svelte.d.ts +13 -0
  68. package/dist/Docs.svelte.d.ts.map +1 -0
  69. package/dist/DocsContent.svelte +40 -0
  70. package/dist/DocsContent.svelte.d.ts +14 -0
  71. package/dist/DocsContent.svelte.d.ts.map +1 -0
  72. package/dist/DocsFooter.svelte +64 -0
  73. package/dist/DocsFooter.svelte.d.ts +15 -0
  74. package/dist/DocsFooter.svelte.d.ts.map +1 -0
  75. package/dist/DocsLink.svelte +41 -0
  76. package/dist/DocsLink.svelte.d.ts +12 -0
  77. package/dist/DocsLink.svelte.d.ts.map +1 -0
  78. package/dist/DocsList.svelte +44 -0
  79. package/dist/DocsList.svelte.d.ts +11 -0
  80. package/dist/DocsList.svelte.d.ts.map +1 -0
  81. package/dist/DocsMenu.svelte +55 -0
  82. package/dist/DocsMenu.svelte.d.ts +11 -0
  83. package/dist/DocsMenu.svelte.d.ts.map +1 -0
  84. package/dist/DocsMenuHeader.svelte +15 -0
  85. package/dist/DocsMenuHeader.svelte.d.ts +9 -0
  86. package/dist/DocsMenuHeader.svelte.d.ts.map +1 -0
  87. package/dist/DocsModulesList.svelte +32 -0
  88. package/dist/DocsModulesList.svelte.d.ts +7 -0
  89. package/dist/DocsModulesList.svelte.d.ts.map +1 -0
  90. package/dist/DocsPageLinks.svelte +61 -0
  91. package/dist/DocsPageLinks.svelte.d.ts +8 -0
  92. package/dist/DocsPageLinks.svelte.d.ts.map +1 -0
  93. package/dist/DocsPrimaryNav.svelte +93 -0
  94. package/dist/DocsPrimaryNav.svelte.d.ts +11 -0
  95. package/dist/DocsPrimaryNav.svelte.d.ts.map +1 -0
  96. package/dist/DocsSearch.svelte +48 -0
  97. package/dist/DocsSearch.svelte.d.ts +11 -0
  98. package/dist/DocsSearch.svelte.d.ts.map +1 -0
  99. package/dist/DocsSecondaryNav.svelte +63 -0
  100. package/dist/DocsSecondaryNav.svelte.d.ts +9 -0
  101. package/dist/DocsSecondaryNav.svelte.d.ts.map +1 -0
  102. package/dist/DocsTertiaryNav.svelte +118 -0
  103. package/dist/DocsTertiaryNav.svelte.d.ts +10 -0
  104. package/dist/DocsTertiaryNav.svelte.d.ts.map +1 -0
  105. package/dist/EcosystemLinks.svelte +53 -0
  106. package/dist/EcosystemLinks.svelte.d.ts +7 -0
  107. package/dist/EcosystemLinks.svelte.d.ts.map +1 -0
  108. package/dist/EcosystemLinksPanel.svelte +22 -0
  109. package/dist/EcosystemLinksPanel.svelte.d.ts +8 -0
  110. package/dist/EcosystemLinksPanel.svelte.d.ts.map +1 -0
  111. package/dist/GithubLink.svelte +75 -0
  112. package/dist/GithubLink.svelte.d.ts +14 -0
  113. package/dist/GithubLink.svelte.d.ts.map +1 -0
  114. package/dist/Glyph.svelte +28 -0
  115. package/dist/Glyph.svelte.d.ts +9 -0
  116. package/dist/Glyph.svelte.d.ts.map +1 -0
  117. package/dist/Hashlink.svelte +41 -0
  118. package/dist/Hashlink.svelte.d.ts +8 -0
  119. package/dist/Hashlink.svelte.d.ts.map +1 -0
  120. package/dist/HiddenPersonalLinks.svelte +6 -0
  121. package/dist/HiddenPersonalLinks.svelte.d.ts +27 -0
  122. package/dist/HiddenPersonalLinks.svelte.d.ts.map +1 -0
  123. package/dist/HueInput.svelte +127 -0
  124. package/dist/HueInput.svelte.d.ts +11 -0
  125. package/dist/HueInput.svelte.d.ts.map +1 -0
  126. package/dist/ImgOrSvg.svelte +58 -0
  127. package/dist/ImgOrSvg.svelte.d.ts +25 -0
  128. package/dist/ImgOrSvg.svelte.d.ts.map +1 -0
  129. package/dist/LibraryDetail.svelte +297 -0
  130. package/dist/LibraryDetail.svelte.d.ts +15 -0
  131. package/dist/LibraryDetail.svelte.d.ts.map +1 -0
  132. package/dist/LibrarySummary.svelte +151 -0
  133. package/dist/LibrarySummary.svelte.d.ts +16 -0
  134. package/dist/LibrarySummary.svelte.d.ts.map +1 -0
  135. package/dist/MdnLink.svelte +40 -0
  136. package/dist/MdnLink.svelte.d.ts +8 -0
  137. package/dist/MdnLink.svelte.d.ts.map +1 -0
  138. package/dist/Mdz.svelte +30 -0
  139. package/dist/Mdz.svelte.d.ts +10 -0
  140. package/dist/Mdz.svelte.d.ts.map +1 -0
  141. package/dist/MdzNodeView.svelte +93 -0
  142. package/dist/MdzNodeView.svelte.d.ts +9 -0
  143. package/dist/MdzNodeView.svelte.d.ts.map +1 -0
  144. package/dist/ModuleLink.svelte +48 -0
  145. package/dist/ModuleLink.svelte.d.ts +8 -0
  146. package/dist/ModuleLink.svelte.d.ts.map +1 -0
  147. package/dist/PasteFromClipboard.svelte +35 -0
  148. package/dist/PasteFromClipboard.svelte.d.ts +9 -0
  149. package/dist/PasteFromClipboard.svelte.d.ts.map +1 -0
  150. package/dist/PendingAnimation.svelte +62 -0
  151. package/dist/PendingAnimation.svelte.d.ts +13 -0
  152. package/dist/PendingAnimation.svelte.d.ts.map +1 -0
  153. package/dist/PendingButton.svelte +75 -0
  154. package/dist/PendingButton.svelte.d.ts +17 -0
  155. package/dist/PendingButton.svelte.d.ts.map +1 -0
  156. package/dist/ProjectLinks.svelte +54 -0
  157. package/dist/ProjectLinks.svelte.d.ts +19 -0
  158. package/dist/ProjectLinks.svelte.d.ts.map +1 -0
  159. package/dist/Redirect.svelte +44 -0
  160. package/dist/Redirect.svelte.d.ts +23 -0
  161. package/dist/Redirect.svelte.d.ts.map +1 -0
  162. package/dist/Spiders.svelte +57 -0
  163. package/dist/Spiders.svelte.d.ts +9 -0
  164. package/dist/Spiders.svelte.d.ts.map +1 -0
  165. package/dist/Svg.svelte +99 -0
  166. package/dist/Svg.svelte.d.ts +54 -0
  167. package/dist/Svg.svelte.d.ts.map +1 -0
  168. package/dist/Teleport.svelte +48 -0
  169. package/dist/Teleport.svelte.d.ts +15 -0
  170. package/dist/Teleport.svelte.d.ts.map +1 -0
  171. package/dist/ThemeInput.svelte +75 -0
  172. package/dist/ThemeInput.svelte.d.ts +15 -0
  173. package/dist/ThemeInput.svelte.d.ts.map +1 -0
  174. package/dist/Themed.svelte +101 -0
  175. package/dist/Themed.svelte.d.ts +24 -0
  176. package/dist/Themed.svelte.d.ts.map +1 -0
  177. package/dist/TomeContent.svelte +67 -0
  178. package/dist/TomeContent.svelte.d.ts +12 -0
  179. package/dist/TomeContent.svelte.d.ts.map +1 -0
  180. package/dist/TomeHeader.svelte +56 -0
  181. package/dist/TomeHeader.svelte.d.ts +4 -0
  182. package/dist/TomeHeader.svelte.d.ts.map +1 -0
  183. package/dist/TomeLink.svelte +29 -0
  184. package/dist/TomeLink.svelte.d.ts +10 -0
  185. package/dist/TomeLink.svelte.d.ts.map +1 -0
  186. package/dist/TomeSection.svelte +65 -0
  187. package/dist/TomeSection.svelte.d.ts +24 -0
  188. package/dist/TomeSection.svelte.d.ts.map +1 -0
  189. package/dist/TomeSectionHeader.svelte +90 -0
  190. package/dist/TomeSectionHeader.svelte.d.ts +13 -0
  191. package/dist/TomeSectionHeader.svelte.d.ts.map +1 -0
  192. package/dist/TypeLink.svelte +19 -0
  193. package/dist/TypeLink.svelte.d.ts +7 -0
  194. package/dist/TypeLink.svelte.d.ts.map +1 -0
  195. package/dist/alert.d.ts +7 -0
  196. package/dist/alert.d.ts.map +1 -0
  197. package/dist/alert.js +6 -0
  198. package/dist/api_search.svelte.d.ts +16 -0
  199. package/dist/api_search.svelte.d.ts.map +1 -0
  200. package/dist/api_search.svelte.js +61 -0
  201. package/dist/constants.d.ts +2 -0
  202. package/dist/constants.d.ts.map +1 -0
  203. package/dist/constants.js +3 -0
  204. package/dist/context_helpers.d.ts +17 -0
  205. package/dist/context_helpers.d.ts.map +1 -0
  206. package/dist/context_helpers.js +19 -0
  207. package/dist/contextmenu_helpers.d.ts +16 -0
  208. package/dist/contextmenu_helpers.d.ts.map +1 -0
  209. package/dist/contextmenu_helpers.js +39 -0
  210. package/dist/contextmenu_state.svelte.d.ts +152 -0
  211. package/dist/contextmenu_state.svelte.d.ts.map +1 -0
  212. package/dist/contextmenu_state.svelte.js +424 -0
  213. package/dist/csp.d.ts +160 -0
  214. package/dist/csp.d.ts.map +1 -0
  215. package/dist/csp.js +354 -0
  216. package/dist/csp_of_ryanatkn.d.ts +6 -0
  217. package/dist/csp_of_ryanatkn.d.ts.map +1 -0
  218. package/dist/csp_of_ryanatkn.js +14 -0
  219. package/dist/declaration.svelte.d.ts +84 -0
  220. package/dist/declaration.svelte.d.ts.map +1 -0
  221. package/dist/declaration.svelte.js +66 -0
  222. package/dist/declaration_contextmenu.d.ts +4 -0
  223. package/dist/declaration_contextmenu.d.ts.map +1 -0
  224. package/dist/declaration_contextmenu.js +14 -0
  225. package/dist/dialog.d.ts +24 -0
  226. package/dist/dialog.d.ts.map +1 -0
  227. package/dist/dialog.js +12 -0
  228. package/dist/dimensions.svelte.d.ts +5 -0
  229. package/dist/dimensions.svelte.d.ts.map +1 -0
  230. package/dist/dimensions.svelte.js +4 -0
  231. package/dist/docs_helpers.svelte.d.ts +48 -0
  232. package/dist/docs_helpers.svelte.d.ts.map +1 -0
  233. package/dist/docs_helpers.svelte.js +99 -0
  234. package/dist/helpers.d.ts +2 -0
  235. package/dist/helpers.d.ts.map +1 -0
  236. package/dist/helpers.js +16 -0
  237. package/dist/intersect.svelte.d.ts +47 -0
  238. package/dist/intersect.svelte.d.ts.map +1 -0
  239. package/dist/intersect.svelte.js +92 -0
  240. package/dist/library.svelte.d.ts +197 -0
  241. package/dist/library.svelte.d.ts.map +1 -0
  242. package/dist/library.svelte.js +130 -0
  243. package/dist/library_gen.d.ts +34 -0
  244. package/dist/library_gen.d.ts.map +1 -0
  245. package/dist/library_gen.js +123 -0
  246. package/dist/library_gen_helpers.d.ts +85 -0
  247. package/dist/library_gen_helpers.d.ts.map +1 -0
  248. package/dist/library_gen_helpers.js +188 -0
  249. package/dist/library_helpers.d.ts +54 -0
  250. package/dist/library_helpers.d.ts.map +1 -0
  251. package/dist/library_helpers.js +102 -0
  252. package/dist/logos.d.ts +134 -0
  253. package/dist/logos.d.ts.map +1 -0
  254. package/dist/logos.js +281 -0
  255. package/dist/mdz.d.ts +106 -0
  256. package/dist/mdz.d.ts.map +1 -0
  257. package/dist/mdz.js +1481 -0
  258. package/dist/mdz_components.d.ts +37 -0
  259. package/dist/mdz_components.d.ts.map +1 -0
  260. package/dist/mdz_components.js +12 -0
  261. package/dist/module.svelte.d.ts +47 -0
  262. package/dist/module.svelte.d.ts.map +1 -0
  263. package/dist/module.svelte.js +56 -0
  264. package/dist/module_contextmenu.d.ts +4 -0
  265. package/dist/module_contextmenu.d.ts.map +1 -0
  266. package/dist/module_contextmenu.js +14 -0
  267. package/dist/module_helpers.d.ts +69 -0
  268. package/dist/module_helpers.d.ts.map +1 -0
  269. package/dist/module_helpers.js +87 -0
  270. package/dist/rune_helpers.svelte.d.ts +6 -0
  271. package/dist/rune_helpers.svelte.d.ts.map +1 -0
  272. package/dist/rune_helpers.svelte.js +10 -0
  273. package/dist/storage.d.ts +13 -0
  274. package/dist/storage.d.ts.map +1 -0
  275. package/dist/storage.js +43 -0
  276. package/dist/svelte_helpers.d.ts +37 -0
  277. package/dist/svelte_helpers.d.ts.map +1 -0
  278. package/dist/svelte_helpers.js +245 -0
  279. package/dist/themer.svelte.d.ts +24 -0
  280. package/dist/themer.svelte.d.ts.map +1 -0
  281. package/dist/themer.svelte.js +43 -0
  282. package/dist/tome.d.ts +80 -0
  283. package/dist/tome.d.ts.map +1 -0
  284. package/dist/tome.js +27 -0
  285. package/dist/ts_helpers.d.ts +110 -0
  286. package/dist/ts_helpers.d.ts.map +1 -0
  287. package/dist/ts_helpers.js +533 -0
  288. package/dist/tsdoc_helpers.d.ts +98 -0
  289. package/dist/tsdoc_helpers.d.ts.map +1 -0
  290. package/dist/tsdoc_helpers.js +221 -0
  291. package/package.json +128 -0
  292. package/src/lib/alert.ts +14 -0
  293. package/src/lib/api_search.svelte.ts +85 -0
  294. package/src/lib/constants.ts +3 -0
  295. package/src/lib/context_helpers.ts +47 -0
  296. package/src/lib/contextmenu_helpers.ts +63 -0
  297. package/src/lib/contextmenu_state.svelte.ts +515 -0
  298. package/src/lib/csp.ts +576 -0
  299. package/src/lib/csp_of_ryanatkn.ts +16 -0
  300. package/src/lib/declaration.svelte.ts +102 -0
  301. package/src/lib/declaration_contextmenu.ts +22 -0
  302. package/src/lib/dialog.ts +35 -0
  303. package/src/lib/dimensions.svelte.ts +4 -0
  304. package/src/lib/docs_helpers.svelte.ts +149 -0
  305. package/src/lib/helpers.ts +10 -0
  306. package/src/lib/intersect.svelte.ts +152 -0
  307. package/src/lib/library.svelte.ts +162 -0
  308. package/src/lib/library_gen.ts +160 -0
  309. package/src/lib/library_gen_helpers.ts +262 -0
  310. package/src/lib/library_helpers.ts +123 -0
  311. package/src/lib/logos.ts +302 -0
  312. package/src/lib/mdz.ts +1819 -0
  313. package/src/lib/mdz_components.ts +34 -0
  314. package/src/lib/module.svelte.ts +78 -0
  315. package/src/lib/module_contextmenu.ts +20 -0
  316. package/src/lib/module_helpers.ts +113 -0
  317. package/src/lib/rune_helpers.svelte.ts +10 -0
  318. package/src/lib/storage.ts +48 -0
  319. package/src/lib/svelte_helpers.ts +303 -0
  320. package/src/lib/themer.svelte.ts +68 -0
  321. package/src/lib/tome.ts +38 -0
  322. package/src/lib/ts_helpers.ts +662 -0
  323. package/src/lib/tsdoc_helpers.ts +259 -0
@@ -0,0 +1,64 @@
1
+ <script lang="ts">
2
+ import {format_url, type Url} from '@fuzdev/fuz_util/url.js';
3
+ import type {Snippet} from 'svelte';
4
+
5
+ import type {Library} from './library.svelte.js';
6
+ import Svg from './Svg.svelte';
7
+ import {github_logo} from './logos.js';
8
+
9
+ const {
10
+ library,
11
+ root_url = null,
12
+ logo,
13
+ logo_header,
14
+ logo_footer,
15
+ children,
16
+ }: {
17
+ library: Library;
18
+ root_url?: Url | null;
19
+ logo?: Snippet;
20
+ logo_header?: Snippet;
21
+ logo_footer?: Snippet;
22
+ children?: Snippet;
23
+ } = $props();
24
+ </script>
25
+
26
+ <footer class="box">
27
+ {@render children?.()}
28
+ <div class="logo box panel p_lg shadow_inset_xs">
29
+ {@render logo_header?.()}
30
+ <!-- eslint-disable-next-line svelte/no-navigation-without-resolve -->
31
+ <a href={library.repo_url} rel="me" title="source code on GitHub"
32
+ >{#if logo}{@render logo()}{:else}<Svg
33
+ data={github_logo}
34
+ size="var(--icon_size_lg)"
35
+ />{/if}</a
36
+ >
37
+ {@render logo_footer?.()}
38
+ </div>
39
+ {#if root_url}
40
+ <div class="root_url">
41
+ <!-- eslint-disable-next-line svelte/no-navigation-without-resolve -->
42
+ <a href={root_url}>{format_url(root_url)}</a>
43
+ </div>
44
+ {/if}
45
+ </footer>
46
+
47
+ <style>
48
+ /* TODO probably extract */
49
+ .logo a {
50
+ --border_width: var(--border_width_4);
51
+ --border_color: transparent;
52
+ text-decoration: none;
53
+ display: flex;
54
+ border-radius: 50%;
55
+ border: var(--border_width) double var(--border_color);
56
+ }
57
+ .logo a:hover {
58
+ --border_color: var(--color_a_5);
59
+ }
60
+ .root_url {
61
+ /* TODO messy */
62
+ margin-top: var(--space_md);
63
+ }
64
+ </style>
@@ -0,0 +1,15 @@
1
+ import { type Url } from '@fuzdev/fuz_util/url.js';
2
+ import type { Snippet } from 'svelte';
3
+ import type { Library } from './library.svelte.js';
4
+ type $$ComponentProps = {
5
+ library: Library;
6
+ root_url?: Url | null;
7
+ logo?: Snippet;
8
+ logo_header?: Snippet;
9
+ logo_footer?: Snippet;
10
+ children?: Snippet;
11
+ };
12
+ declare const DocsFooter: import("svelte").Component<$$ComponentProps, {}, "">;
13
+ type DocsFooter = ReturnType<typeof DocsFooter>;
14
+ export default DocsFooter;
15
+ //# sourceMappingURL=DocsFooter.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsFooter.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsFooter.svelte"],"names":[],"mappings":"AAGA,OAAO,EAAa,KAAK,GAAG,EAAC,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAEpC,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAIhD,KAAK,gBAAgB,GAAI;IACxB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IACtB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAuCH,QAAA,MAAM,UAAU,sDAAwC,CAAC;AACzD,KAAK,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;AAChD,eAAe,UAAU,CAAC"}
@@ -0,0 +1,41 @@
1
+ <script lang="ts">
2
+ import type {Snippet} from 'svelte';
3
+
4
+ import ModuleLink from './ModuleLink.svelte';
5
+ import DeclarationLink from './DeclarationLink.svelte';
6
+ import {library_context} from './library.svelte.js';
7
+ import type {Declaration} from './declaration.svelte.js';
8
+ import type {Module} from './module.svelte.js';
9
+
10
+ const {
11
+ reference,
12
+ display_text,
13
+ children: children_prop,
14
+ }: {
15
+ reference: string;
16
+ display_text?: string | null;
17
+ children?: Snippet<[Declaration | undefined, Module | undefined]>;
18
+ } = $props();
19
+ const library = library_context.get();
20
+
21
+ // Try to find as declaration first, then module
22
+ const declaration = $derived(library.lookup_declaration(reference));
23
+ const module = $derived(declaration ? declaration.module : library.lookup_module(reference));
24
+ </script>
25
+
26
+ {#if declaration}
27
+ <DeclarationLink name={reference}>
28
+ {@render children()}
29
+ </DeclarationLink>
30
+ {:else if module}
31
+ <ModuleLink module_path={module.path}>
32
+ {@render children()}
33
+ </ModuleLink>
34
+ {:else}
35
+ <code>{@render children()}</code>
36
+ {/if}
37
+
38
+ {#snippet children()}{#if children_prop}{@render children_prop(
39
+ declaration,
40
+ module,
41
+ )}{:else}{display_text ?? reference}{/if}{/snippet}
@@ -0,0 +1,12 @@
1
+ import type { Snippet } from 'svelte';
2
+ import type { Declaration } from './declaration.svelte.js';
3
+ import type { Module } from './module.svelte.js';
4
+ type $$ComponentProps = {
5
+ reference: string;
6
+ display_text?: string | null;
7
+ children?: Snippet<[Declaration | undefined, Module | undefined]>;
8
+ };
9
+ declare const DocsLink: import("svelte").Component<$$ComponentProps, {}, "">;
10
+ type DocsLink = ReturnType<typeof DocsLink>;
11
+ export default DocsLink;
12
+ //# sourceMappingURL=DocsLink.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsLink.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsLink.svelte"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAKpC,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACzD,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,oBAAoB,CAAC;AAE9C,KAAK,gBAAgB,GAAI;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC,WAAW,GAAG,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;CAClE,CAAC;AAyCH,QAAA,MAAM,QAAQ,sDAAwC,CAAC;AACvD,KAAK,QAAQ,GAAG,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC;AAC5C,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,44 @@
1
+ <script lang="ts">
2
+ import type {Snippet} from 'svelte';
3
+
4
+ const {
5
+ expand_width = false,
6
+ margin = true,
7
+ class: class_prop,
8
+ children,
9
+ }: {
10
+ expand_width?: boolean;
11
+ margin?: boolean;
12
+ class?: string;
13
+ children: Snippet;
14
+ } = $props();
15
+ </script>
16
+
17
+ <div class="docs_list {class_prop}" class:expand_width class:margin>
18
+ {@render children()}
19
+ </div>
20
+
21
+ <style>
22
+ .docs_list {
23
+ width: var(--docs_menu_width);
24
+ min-width: var(--docs_menu_width);
25
+ }
26
+ .docs_list.expand_width {
27
+ width: 100%;
28
+ max-width: var(--distance_md);
29
+ }
30
+ .docs_list.margin {
31
+ margin: var(--space_xl6) 0;
32
+ }
33
+
34
+ /* TODO should be fixed upstream in moss */
35
+ .docs_list :global(a.highlighted) {
36
+ background-color: var(--bg_4);
37
+ }
38
+ .docs_list :global(a:hover) {
39
+ background-color: var(--bg_5);
40
+ }
41
+ .docs_list :global(a:is(:active, .selected)) {
42
+ background-color: var(--bg_7);
43
+ }
44
+ </style>
@@ -0,0 +1,11 @@
1
+ import type { Snippet } from 'svelte';
2
+ type $$ComponentProps = {
3
+ expand_width?: boolean;
4
+ margin?: boolean;
5
+ class?: string;
6
+ children: Snippet;
7
+ };
8
+ declare const DocsList: import("svelte").Component<$$ComponentProps, {}, "">;
9
+ type DocsList = ReturnType<typeof DocsList>;
10
+ export default DocsList;
11
+ //# sourceMappingURL=DocsList.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsList.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsList.svelte"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAEnC,KAAK,gBAAgB,GAAI;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;CAClB,CAAC;AAoBH,QAAA,MAAM,QAAQ,sDAAwC,CAAC;AACvD,KAAK,QAAQ,GAAG,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC;AAC5C,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,55 @@
1
+ <script lang="ts">
2
+ import {page} from '$app/state';
3
+ import {slide} from 'svelte/transition';
4
+ import type {Snippet} from 'svelte';
5
+
6
+ import DocsList from './DocsList.svelte';
7
+ import {to_tome_pathname, type Tome} from './tome.js';
8
+ import DocsMenuHeader from './DocsMenuHeader.svelte';
9
+
10
+ const {
11
+ tomes,
12
+ children,
13
+ expand_width = false,
14
+ }: {
15
+ tomes: Array<Tome>;
16
+ children?: Snippet<[category: string]>;
17
+ expand_width?: boolean;
18
+ } = $props();
19
+
20
+ const tomes_by_category = $derived(
21
+ tomes.reduce<Record<string, Array<Tome>>>((result, c) => {
22
+ (result[c.category] ??= []).push(c);
23
+ return result;
24
+ }, {}),
25
+ );
26
+ </script>
27
+
28
+ <!-- eslint-disable svelte/no-navigation-without-resolve -->
29
+
30
+ <DocsList {expand_width} margin={false} class="docs_menu">
31
+ <ul class="unstyled">
32
+ {#each Object.entries(tomes_by_category) as [category, tomes] (category)}
33
+ <li class="category">
34
+ {#if children}{@render children(category)}{:else}<DocsMenuHeader>{category}</DocsMenuHeader
35
+ >{/if}
36
+ <ul class="unstyled">
37
+ {#each tomes as item (item)}
38
+ {@const pathname = to_tome_pathname(item)}
39
+ <li role="none" transition:slide>
40
+ <a class="menu_item" href={pathname} class:selected={pathname === page.url.pathname}
41
+ ><div class="ellipsis">{item.name}</div></a
42
+ >
43
+ </li>
44
+ {/each}
45
+ </ul>
46
+ </li>
47
+ {/each}
48
+ </ul>
49
+ </DocsList>
50
+
51
+ <style>
52
+ .category {
53
+ margin: var(--space_xl6) 0;
54
+ }
55
+ </style>
@@ -0,0 +1,11 @@
1
+ import type { Snippet } from 'svelte';
2
+ import { type Tome } from './tome.js';
3
+ type $$ComponentProps = {
4
+ tomes: Array<Tome>;
5
+ children?: Snippet<[category: string]>;
6
+ expand_width?: boolean;
7
+ };
8
+ declare const DocsMenu: import("svelte").Component<$$ComponentProps, {}, "">;
9
+ type DocsMenu = ReturnType<typeof DocsMenu>;
10
+ export default DocsMenu;
11
+ //# sourceMappingURL=DocsMenu.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsMenu.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsMenu.svelte"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAGpC,OAAO,EAAmB,KAAK,IAAI,EAAC,MAAM,WAAW,CAAC;AAGrD,KAAK,gBAAgB,GAAI;IACxB,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC;IACvC,YAAY,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAgDH,QAAA,MAAM,QAAQ,sDAAwC,CAAC;AACvD,KAAK,QAAQ,GAAG,UAAU,CAAC,OAAO,QAAQ,CAAC,CAAC;AAC5C,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,15 @@
1
+ <script lang="ts">
2
+ import type {Snippet} from 'svelte';
3
+ import type {SvelteHTMLElements} from 'svelte/elements';
4
+
5
+ const {
6
+ class: class_prop,
7
+ children,
8
+ ...rest
9
+ }: SvelteHTMLElements['h4'] & {
10
+ // TODO maybe add an optional `selected` status? if any children are selected
11
+ children: Snippet;
12
+ } = $props();
13
+ </script>
14
+
15
+ <h4 {...rest} class="mb_sm {class_prop}">{@render children()}</h4>
@@ -0,0 +1,9 @@
1
+ import type { Snippet } from 'svelte';
2
+ import type { SvelteHTMLElements } from 'svelte/elements';
3
+ type $$ComponentProps = SvelteHTMLElements['h4'] & {
4
+ children: Snippet;
5
+ };
6
+ declare const DocsMenuHeader: import("svelte").Component<$$ComponentProps, {}, "">;
7
+ type DocsMenuHeader = ReturnType<typeof DocsMenuHeader>;
8
+ export default DocsMenuHeader;
9
+ //# sourceMappingURL=DocsMenuHeader.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsMenuHeader.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsMenuHeader.svelte"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AACpC,OAAO,KAAK,EAAC,kBAAkB,EAAC,MAAM,iBAAiB,CAAC;AAEvD,KAAK,gBAAgB,GAAI,kBAAkB,CAAC,IAAI,CAAC,GAAG;IAEnD,QAAQ,EAAE,OAAO,CAAC;CAClB,CAAC;AAgBH,QAAA,MAAM,cAAc,sDAAwC,CAAC;AAC7D,KAAK,cAAc,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AACxD,eAAe,cAAc,CAAC"}
@@ -0,0 +1,32 @@
1
+ <script lang="ts">
2
+ import {page} from '$app/state';
3
+
4
+ import DocsList from './DocsList.svelte';
5
+ import {library_context} from './library.svelte.js';
6
+
7
+ const {
8
+ expand_width = false,
9
+ }: {
10
+ expand_width?: boolean;
11
+ } = $props();
12
+
13
+ const library = library_context.get();
14
+ </script>
15
+
16
+ <DocsList {expand_width} class="modules_list">
17
+ <h4 class="mb_sm">modules</h4>
18
+ <ul class="unstyled">
19
+ {#each library.modules_sorted as module (module.path)}
20
+ <li>
21
+ <!-- eslint-disable svelte/no-navigation-without-resolve -->
22
+ <a
23
+ class="menu_item"
24
+ href={module.url_api}
25
+ class:selected={module.url_api === page.url.pathname}
26
+ >
27
+ <div class="ellipsis">{module.path}</div>
28
+ </a>
29
+ </li>
30
+ {/each}
31
+ </ul>
32
+ </DocsList>
@@ -0,0 +1,7 @@
1
+ type $$ComponentProps = {
2
+ expand_width?: boolean;
3
+ };
4
+ declare const DocsModulesList: import("svelte").Component<$$ComponentProps, {}, "">;
5
+ type DocsModulesList = ReturnType<typeof DocsModulesList>;
6
+ export default DocsModulesList;
7
+ //# sourceMappingURL=DocsModulesList.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsModulesList.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsModulesList.svelte"],"names":[],"mappings":"AAQC,KAAK,gBAAgB,GAAI;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AA8BH,QAAA,MAAM,eAAe,sDAAwC,CAAC;AAC9D,KAAK,eAAe,GAAG,UAAU,CAAC,OAAO,eAAe,CAAC,CAAC;AAC1D,eAAe,eAAe,CAAC"}
@@ -0,0 +1,61 @@
1
+ <script lang="ts">
2
+ import {page} from '$app/state';
3
+ import {slide} from 'svelte/transition';
4
+
5
+ import DocsList from './DocsList.svelte';
6
+ import {docs_links_context} from './docs_helpers.svelte.js';
7
+
8
+ const {
9
+ sidebar = true,
10
+ expand_width = false,
11
+ }: {
12
+ sidebar?: boolean; // TODO @many dialog navs (this shouldn't exist)
13
+ expand_width?: boolean;
14
+ } = $props();
15
+
16
+ const docs_links = docs_links_context.get();
17
+
18
+ const hash = $derived(page.url.hash.slice(1));
19
+ </script>
20
+
21
+ <DocsList {expand_width} class="docs_page_links">
22
+ <h4 class="mb_sm">on this page</h4>
23
+ {#if sidebar}
24
+ <div class="sidebar_wrapper">{@render content()}</div>
25
+ {:else}
26
+ {@render content()}
27
+ {/if}
28
+ </DocsList>
29
+
30
+ {#snippet content()}
31
+ <nav aria-label="on this page" class="width_100">
32
+ <ul class="unstyled">
33
+ {#each docs_links.docs_links as item (item.id)}
34
+ <li
35
+ role="none"
36
+ transition:slide
37
+ class:pl_xl={item.depth === 2}
38
+ class:pl_xl2={item.depth === 3}
39
+ class:pl_xl3={item.depth >= 4}
40
+ >
41
+ <a
42
+ class="menu_item"
43
+ href="#{item.fragment}"
44
+ class:selected={item.fragment === hash}
45
+ class:highlighted={docs_links.fragments_onscreen.has(item.fragment)}
46
+ ><div class="ellipsis">{item.text}</div></a
47
+ >
48
+ </li>
49
+ {/each}
50
+ </ul>
51
+ </nav>
52
+ {/snippet}
53
+
54
+ <style>
55
+ /* this is needed because `.docs_page_links` needs to be a block to collapse the vertical margin */
56
+ .sidebar_wrapper {
57
+ display: flex;
58
+ flex-direction: column;
59
+ align-items: flex-start;
60
+ }
61
+ </style>
@@ -0,0 +1,8 @@
1
+ type $$ComponentProps = {
2
+ sidebar?: boolean;
3
+ expand_width?: boolean;
4
+ };
5
+ declare const DocsPageLinks: import("svelte").Component<$$ComponentProps, {}, "">;
6
+ type DocsPageLinks = ReturnType<typeof DocsPageLinks>;
7
+ export default DocsPageLinks;
8
+ //# sourceMappingURL=DocsPageLinks.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsPageLinks.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsPageLinks.svelte"],"names":[],"mappings":"AASC,KAAK,gBAAgB,GAAI;IACxB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,YAAY,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AA2CH,QAAA,MAAM,aAAa,sDAAwC,CAAC;AAC5D,KAAK,aAAa,GAAG,UAAU,CAAC,OAAO,aAAa,CAAC,CAAC;AACtD,eAAe,aAAa,CAAC"}
@@ -0,0 +1,93 @@
1
+ <script lang="ts">
2
+ import {is_iframed} from '@fuzdev/fuz_util/dom.js';
3
+ import type {Snippet} from 'svelte';
4
+ import {scrollY} from 'svelte/reactivity/window';
5
+
6
+ import type {Library} from './library.svelte.js';
7
+ import Breadcrumb from './Breadcrumb.svelte';
8
+
9
+ const {
10
+ library,
11
+ breadcrumb_children,
12
+ children,
13
+ }: {
14
+ library: Library;
15
+ breadcrumb_children?: Snippet<[is_primary_nav: boolean]>;
16
+ children?: Snippet;
17
+ } = $props();
18
+
19
+ const iframed = is_iframed();
20
+ const enabled = !iframed;
21
+
22
+ const scrolled = $derived(scrollY.current && scrollY.current > 0);
23
+ </script>
24
+
25
+ {#if enabled}
26
+ <div class="docs_primary_nav" class:scrolled>
27
+ <div class="background" aria-hidden="true"></div>
28
+ <div class="content">
29
+ <nav aria-label="Primary nav">
30
+ <Breadcrumb>
31
+ {#if breadcrumb_children}
32
+ {@render breadcrumb_children(true)}
33
+ {:else}
34
+ {library.package_json.glyph ?? '🏠'}
35
+ {/if}
36
+ </Breadcrumb>
37
+ </nav>
38
+ {@render children?.()}
39
+ </div>
40
+ </div>
41
+ {/if}
42
+
43
+ <style>
44
+ .docs_primary_nav {
45
+ position: sticky;
46
+ top: 0;
47
+ z-index: 10;
48
+ background-color: var(--bg);
49
+ height: var(--docs_primary_nav_height);
50
+ transition: box-shadow var(--duration_2);
51
+ box-shadow: none;
52
+ }
53
+
54
+ .scrolled {
55
+ box-shadow: var(--shadow_bottom_xs)
56
+ color-mix(in hsl, var(--shadow_color) var(--shadow_alpha_1), transparent);
57
+ }
58
+
59
+ .background {
60
+ position: absolute;
61
+ z-index: -1;
62
+ width: 100%;
63
+ height: 100%;
64
+ background-color: var(--fg_1);
65
+ }
66
+
67
+ .content {
68
+ max-width: 1300px;
69
+ height: 100%;
70
+ margin: 0 auto;
71
+ display: flex;
72
+ }
73
+
74
+ nav {
75
+ --font_size: var(--font_size_xl);
76
+ height: 100%;
77
+ display: flex;
78
+ flex: 1;
79
+ padding-left: var(--space_md);
80
+ }
81
+
82
+ /* sync this breakpoint with `Docs` */
83
+ @media (max-width: 800px) {
84
+ nav {
85
+ --font_size: var(--font_size_lg);
86
+ }
87
+ }
88
+ @media (max-width: 550px) {
89
+ nav {
90
+ --font_size: var(--font_size_md);
91
+ }
92
+ }
93
+ </style>
@@ -0,0 +1,11 @@
1
+ import type { Snippet } from 'svelte';
2
+ import type { Library } from './library.svelte.js';
3
+ type $$ComponentProps = {
4
+ library: Library;
5
+ breadcrumb_children?: Snippet<[is_primary_nav: boolean]>;
6
+ children?: Snippet;
7
+ };
8
+ declare const DocsPrimaryNav: import("svelte").Component<$$ComponentProps, {}, "">;
9
+ type DocsPrimaryNav = ReturnType<typeof DocsPrimaryNav>;
10
+ export default DocsPrimaryNav;
11
+ //# sourceMappingURL=DocsPrimaryNav.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsPrimaryNav.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsPrimaryNav.svelte"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,QAAQ,CAAC;AAGpC,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAGhD,KAAK,gBAAgB,GAAI;IACxB,OAAO,EAAE,OAAO,CAAC;IACjB,mBAAmB,CAAC,EAAE,OAAO,CAAC,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC;IACzD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AA2CH,QAAA,MAAM,cAAc,sDAAwC,CAAC;AAC7D,KAAK,cAAc,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AACxD,eAAe,cAAc,CAAC"}
@@ -0,0 +1,48 @@
1
+ <script lang="ts">
2
+ import type {SvelteHTMLElements} from 'svelte/elements';
3
+
4
+ let {
5
+ placeholder = 'search declarations and modules...',
6
+ total_count,
7
+ result_count,
8
+ search_query = $bindable(),
9
+ ...rest
10
+ }: SvelteHTMLElements['input'] & {
11
+ placeholder?: string;
12
+ total_count: number;
13
+ result_count?: number;
14
+ search_query: string;
15
+ } = $props();
16
+
17
+ const total_text = $derived(
18
+ total_count === 1 ? `${total_count} declaration` : `${total_count} declarations`,
19
+ );
20
+ const result_text = $derived(
21
+ result_count === 1 ? `${result_count} match found` : `${result_count} matches found`,
22
+ );
23
+ const has_search = $derived(search_query.trim().length > 0);
24
+ </script>
25
+
26
+ <label class="display_block position_relative">
27
+ <input {...rest} type="search" {placeholder} bind:value={search_query} />
28
+ {#if has_search}
29
+ <button
30
+ type="button"
31
+ class="plain icon_button position_absolute right_0 top_0"
32
+ onclick={() => {
33
+ search_query = '';
34
+ }}
35
+ title="clear search"
36
+ aria-label="clear search"
37
+ >
38
+ 🗙
39
+ </button>
40
+ {/if}
41
+ </label>
42
+
43
+ <p>
44
+ {total_text}
45
+ {#if has_search && result_count !== undefined}
46
+ · {result_text}
47
+ {/if}
48
+ </p>
@@ -0,0 +1,11 @@
1
+ import type { SvelteHTMLElements } from 'svelte/elements';
2
+ type $$ComponentProps = SvelteHTMLElements['input'] & {
3
+ placeholder?: string;
4
+ total_count: number;
5
+ result_count?: number;
6
+ search_query: string;
7
+ };
8
+ declare const DocsSearch: import("svelte").Component<$$ComponentProps, {}, "search_query">;
9
+ type DocsSearch = ReturnType<typeof DocsSearch>;
10
+ export default DocsSearch;
11
+ //# sourceMappingURL=DocsSearch.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DocsSearch.svelte.d.ts","sourceRoot":"../src/lib/","sources":["../src/lib/DocsSearch.svelte"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,kBAAkB,EAAC,MAAM,iBAAiB,CAAC;AAEvD,KAAK,gBAAgB,GAAI,kBAAkB,CAAC,OAAO,CAAC,GAAG;IACtD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;CACrB,CAAC;AAwCH,QAAA,MAAM,UAAU,kEAAwC,CAAC;AACzD,KAAK,UAAU,GAAG,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;AAChD,eAAe,UAAU,CAAC"}
@@ -0,0 +1,63 @@
1
+ <script lang="ts">
2
+ import DocsMenu from './DocsMenu.svelte';
3
+ import {Tome} from './tome.js';
4
+
5
+ const {
6
+ tomes,
7
+ sidebar = true,
8
+ }: {
9
+ tomes: Array<Tome>;
10
+ sidebar?: boolean; // TODO @many dialog navs (this shouldn't exist)
11
+ } = $props();
12
+
13
+ const expand_width = $derived(!sidebar);
14
+ </script>
15
+
16
+ <aside class="docs_secondary_nav unstyled" class:sidebar>
17
+ <nav aria-label="Secondary nav">
18
+ <DocsMenu {tomes} {expand_width} />
19
+ </nav>
20
+ </aside>
21
+
22
+ <style>
23
+ .docs_secondary_nav {
24
+ /* TODO @many lots of duplicate code between `DocsSecondaryNav` and `DocsTertiaryNav` */
25
+ position: fixed;
26
+ left: 0;
27
+ top: var(--docs_primary_nav_height);
28
+ z-index: 1;
29
+ width: var(--docs_sidebar_width);
30
+ height: calc(100% - var(--docs_primary_nav_height));
31
+ padding: var(
32
+ --docs_secondary_nav_padding
33
+ ); /* needed with `overflow: auto` to avoid cutting off outline */
34
+ margin-bottom: 0;
35
+ overflow: auto;
36
+ scrollbar-width: thin;
37
+ background-color: var(--fg_1);
38
+ }
39
+
40
+ .sidebar nav {
41
+ display: flex;
42
+ flex-direction: column;
43
+ align-items: flex-end;
44
+ }
45
+
46
+ /* sync this breakpoint with `Docs` */
47
+ @media (max-width: 800px) {
48
+ .docs_secondary_nav {
49
+ position: static;
50
+ background-color: initial;
51
+ align-items: initial;
52
+ overflow: initial;
53
+ }
54
+ }
55
+ /* TODO @many dialog navs */
56
+ .docs_secondary_nav:not(.sidebar) {
57
+ position: static;
58
+ background-color: initial;
59
+ align-items: initial;
60
+ overflow: initial;
61
+ display: block; /* collapse margin */
62
+ }
63
+ </style>