@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.
- package/LICENSE +21 -0
- package/README.md +93 -0
- package/dist/Alert.svelte +108 -0
- package/dist/Alert.svelte.d.ts +16 -0
- package/dist/Alert.svelte.d.ts.map +1 -0
- package/dist/ApiDeclarationList.svelte +35 -0
- package/dist/ApiDeclarationList.svelte.d.ts +9 -0
- package/dist/ApiDeclarationList.svelte.d.ts.map +1 -0
- package/dist/ApiIndex.svelte +65 -0
- package/dist/ApiIndex.svelte.d.ts +23 -0
- package/dist/ApiIndex.svelte.d.ts.map +1 -0
- package/dist/ApiModule.svelte +124 -0
- package/dist/ApiModule.svelte.d.ts +22 -0
- package/dist/ApiModule.svelte.d.ts.map +1 -0
- package/dist/Breadcrumb.svelte +83 -0
- package/dist/Breadcrumb.svelte.d.ts +23 -0
- package/dist/Breadcrumb.svelte.d.ts.map +1 -0
- package/dist/Card.svelte +157 -0
- package/dist/Card.svelte.d.ts +13 -0
- package/dist/Card.svelte.d.ts.map +1 -0
- package/dist/ColorSchemeInput.svelte +65 -0
- package/dist/ColorSchemeInput.svelte.d.ts +11 -0
- package/dist/ColorSchemeInput.svelte.d.ts.map +1 -0
- package/dist/Contextmenu.svelte +30 -0
- package/dist/Contextmenu.svelte.d.ts +32 -0
- package/dist/Contextmenu.svelte.d.ts.map +1 -0
- package/dist/ContextmenuEntry.svelte +74 -0
- package/dist/ContextmenuEntry.svelte.d.ts +12 -0
- package/dist/ContextmenuEntry.svelte.d.ts.map +1 -0
- package/dist/ContextmenuLinkEntry.svelte +112 -0
- package/dist/ContextmenuLinkEntry.svelte.d.ts +12 -0
- package/dist/ContextmenuLinkEntry.svelte.d.ts.map +1 -0
- package/dist/ContextmenuRoot.svelte +372 -0
- package/dist/ContextmenuRoot.svelte.d.ts +71 -0
- package/dist/ContextmenuRoot.svelte.d.ts.map +1 -0
- package/dist/ContextmenuRootForSafariCompatibility.svelte +541 -0
- package/dist/ContextmenuRootForSafariCompatibility.svelte.d.ts +79 -0
- package/dist/ContextmenuRootForSafariCompatibility.svelte.d.ts.map +1 -0
- package/dist/ContextmenuSeparator.svelte +16 -0
- package/dist/ContextmenuSeparator.svelte.d.ts +4 -0
- package/dist/ContextmenuSeparator.svelte.d.ts.map +1 -0
- package/dist/ContextmenuSubmenu.svelte +116 -0
- package/dist/ContextmenuSubmenu.svelte.d.ts +10 -0
- package/dist/ContextmenuSubmenu.svelte.d.ts.map +1 -0
- package/dist/ContextmenuTextEntry.svelte +21 -0
- package/dist/ContextmenuTextEntry.svelte.d.ts +10 -0
- package/dist/ContextmenuTextEntry.svelte.d.ts.map +1 -0
- package/dist/CopyToClipboard.svelte +81 -0
- package/dist/CopyToClipboard.svelte.d.ts +18 -0
- package/dist/CopyToClipboard.svelte.d.ts.map +1 -0
- package/dist/DeclarationDetail.svelte +340 -0
- package/dist/DeclarationDetail.svelte.d.ts +8 -0
- package/dist/DeclarationDetail.svelte.d.ts.map +1 -0
- package/dist/DeclarationLink.svelte +50 -0
- package/dist/DeclarationLink.svelte.d.ts +8 -0
- package/dist/DeclarationLink.svelte.d.ts.map +1 -0
- package/dist/Details.svelte +51 -0
- package/dist/Details.svelte.d.ts +20 -0
- package/dist/Details.svelte.d.ts.map +1 -0
- package/dist/Dialog.svelte +217 -0
- package/dist/Dialog.svelte.d.ts +30 -0
- package/dist/Dialog.svelte.d.ts.map +1 -0
- package/dist/Dialogs.svelte +28 -0
- package/dist/Dialogs.svelte.d.ts +11 -0
- package/dist/Dialogs.svelte.d.ts.map +1 -0
- package/dist/Docs.svelte +179 -0
- package/dist/Docs.svelte.d.ts +13 -0
- package/dist/Docs.svelte.d.ts.map +1 -0
- package/dist/DocsContent.svelte +40 -0
- package/dist/DocsContent.svelte.d.ts +14 -0
- package/dist/DocsContent.svelte.d.ts.map +1 -0
- package/dist/DocsFooter.svelte +64 -0
- package/dist/DocsFooter.svelte.d.ts +15 -0
- package/dist/DocsFooter.svelte.d.ts.map +1 -0
- package/dist/DocsLink.svelte +41 -0
- package/dist/DocsLink.svelte.d.ts +12 -0
- package/dist/DocsLink.svelte.d.ts.map +1 -0
- package/dist/DocsList.svelte +44 -0
- package/dist/DocsList.svelte.d.ts +11 -0
- package/dist/DocsList.svelte.d.ts.map +1 -0
- package/dist/DocsMenu.svelte +55 -0
- package/dist/DocsMenu.svelte.d.ts +11 -0
- package/dist/DocsMenu.svelte.d.ts.map +1 -0
- package/dist/DocsMenuHeader.svelte +15 -0
- package/dist/DocsMenuHeader.svelte.d.ts +9 -0
- package/dist/DocsMenuHeader.svelte.d.ts.map +1 -0
- package/dist/DocsModulesList.svelte +32 -0
- package/dist/DocsModulesList.svelte.d.ts +7 -0
- package/dist/DocsModulesList.svelte.d.ts.map +1 -0
- package/dist/DocsPageLinks.svelte +61 -0
- package/dist/DocsPageLinks.svelte.d.ts +8 -0
- package/dist/DocsPageLinks.svelte.d.ts.map +1 -0
- package/dist/DocsPrimaryNav.svelte +93 -0
- package/dist/DocsPrimaryNav.svelte.d.ts +11 -0
- package/dist/DocsPrimaryNav.svelte.d.ts.map +1 -0
- package/dist/DocsSearch.svelte +48 -0
- package/dist/DocsSearch.svelte.d.ts +11 -0
- package/dist/DocsSearch.svelte.d.ts.map +1 -0
- package/dist/DocsSecondaryNav.svelte +63 -0
- package/dist/DocsSecondaryNav.svelte.d.ts +9 -0
- package/dist/DocsSecondaryNav.svelte.d.ts.map +1 -0
- package/dist/DocsTertiaryNav.svelte +118 -0
- package/dist/DocsTertiaryNav.svelte.d.ts +10 -0
- package/dist/DocsTertiaryNav.svelte.d.ts.map +1 -0
- package/dist/EcosystemLinks.svelte +53 -0
- package/dist/EcosystemLinks.svelte.d.ts +7 -0
- package/dist/EcosystemLinks.svelte.d.ts.map +1 -0
- package/dist/EcosystemLinksPanel.svelte +22 -0
- package/dist/EcosystemLinksPanel.svelte.d.ts +8 -0
- package/dist/EcosystemLinksPanel.svelte.d.ts.map +1 -0
- package/dist/GithubLink.svelte +75 -0
- package/dist/GithubLink.svelte.d.ts +14 -0
- package/dist/GithubLink.svelte.d.ts.map +1 -0
- package/dist/Glyph.svelte +28 -0
- package/dist/Glyph.svelte.d.ts +9 -0
- package/dist/Glyph.svelte.d.ts.map +1 -0
- package/dist/Hashlink.svelte +41 -0
- package/dist/Hashlink.svelte.d.ts +8 -0
- package/dist/Hashlink.svelte.d.ts.map +1 -0
- package/dist/HiddenPersonalLinks.svelte +6 -0
- package/dist/HiddenPersonalLinks.svelte.d.ts +27 -0
- package/dist/HiddenPersonalLinks.svelte.d.ts.map +1 -0
- package/dist/HueInput.svelte +127 -0
- package/dist/HueInput.svelte.d.ts +11 -0
- package/dist/HueInput.svelte.d.ts.map +1 -0
- package/dist/ImgOrSvg.svelte +58 -0
- package/dist/ImgOrSvg.svelte.d.ts +25 -0
- package/dist/ImgOrSvg.svelte.d.ts.map +1 -0
- package/dist/LibraryDetail.svelte +297 -0
- package/dist/LibraryDetail.svelte.d.ts +15 -0
- package/dist/LibraryDetail.svelte.d.ts.map +1 -0
- package/dist/LibrarySummary.svelte +151 -0
- package/dist/LibrarySummary.svelte.d.ts +16 -0
- package/dist/LibrarySummary.svelte.d.ts.map +1 -0
- package/dist/MdnLink.svelte +40 -0
- package/dist/MdnLink.svelte.d.ts +8 -0
- package/dist/MdnLink.svelte.d.ts.map +1 -0
- package/dist/Mdz.svelte +30 -0
- package/dist/Mdz.svelte.d.ts +10 -0
- package/dist/Mdz.svelte.d.ts.map +1 -0
- package/dist/MdzNodeView.svelte +93 -0
- package/dist/MdzNodeView.svelte.d.ts +9 -0
- package/dist/MdzNodeView.svelte.d.ts.map +1 -0
- package/dist/ModuleLink.svelte +48 -0
- package/dist/ModuleLink.svelte.d.ts +8 -0
- package/dist/ModuleLink.svelte.d.ts.map +1 -0
- package/dist/PasteFromClipboard.svelte +35 -0
- package/dist/PasteFromClipboard.svelte.d.ts +9 -0
- package/dist/PasteFromClipboard.svelte.d.ts.map +1 -0
- package/dist/PendingAnimation.svelte +62 -0
- package/dist/PendingAnimation.svelte.d.ts +13 -0
- package/dist/PendingAnimation.svelte.d.ts.map +1 -0
- package/dist/PendingButton.svelte +75 -0
- package/dist/PendingButton.svelte.d.ts +17 -0
- package/dist/PendingButton.svelte.d.ts.map +1 -0
- package/dist/ProjectLinks.svelte +54 -0
- package/dist/ProjectLinks.svelte.d.ts +19 -0
- package/dist/ProjectLinks.svelte.d.ts.map +1 -0
- package/dist/Redirect.svelte +44 -0
- package/dist/Redirect.svelte.d.ts +23 -0
- package/dist/Redirect.svelte.d.ts.map +1 -0
- package/dist/Spiders.svelte +57 -0
- package/dist/Spiders.svelte.d.ts +9 -0
- package/dist/Spiders.svelte.d.ts.map +1 -0
- package/dist/Svg.svelte +99 -0
- package/dist/Svg.svelte.d.ts +54 -0
- package/dist/Svg.svelte.d.ts.map +1 -0
- package/dist/Teleport.svelte +48 -0
- package/dist/Teleport.svelte.d.ts +15 -0
- package/dist/Teleport.svelte.d.ts.map +1 -0
- package/dist/ThemeInput.svelte +75 -0
- package/dist/ThemeInput.svelte.d.ts +15 -0
- package/dist/ThemeInput.svelte.d.ts.map +1 -0
- package/dist/Themed.svelte +101 -0
- package/dist/Themed.svelte.d.ts +24 -0
- package/dist/Themed.svelte.d.ts.map +1 -0
- package/dist/TomeContent.svelte +67 -0
- package/dist/TomeContent.svelte.d.ts +12 -0
- package/dist/TomeContent.svelte.d.ts.map +1 -0
- package/dist/TomeHeader.svelte +56 -0
- package/dist/TomeHeader.svelte.d.ts +4 -0
- package/dist/TomeHeader.svelte.d.ts.map +1 -0
- package/dist/TomeLink.svelte +29 -0
- package/dist/TomeLink.svelte.d.ts +10 -0
- package/dist/TomeLink.svelte.d.ts.map +1 -0
- package/dist/TomeSection.svelte +65 -0
- package/dist/TomeSection.svelte.d.ts +24 -0
- package/dist/TomeSection.svelte.d.ts.map +1 -0
- package/dist/TomeSectionHeader.svelte +90 -0
- package/dist/TomeSectionHeader.svelte.d.ts +13 -0
- package/dist/TomeSectionHeader.svelte.d.ts.map +1 -0
- package/dist/TypeLink.svelte +19 -0
- package/dist/TypeLink.svelte.d.ts +7 -0
- package/dist/TypeLink.svelte.d.ts.map +1 -0
- package/dist/alert.d.ts +7 -0
- package/dist/alert.d.ts.map +1 -0
- package/dist/alert.js +6 -0
- package/dist/api_search.svelte.d.ts +16 -0
- package/dist/api_search.svelte.d.ts.map +1 -0
- package/dist/api_search.svelte.js +61 -0
- package/dist/constants.d.ts +2 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +3 -0
- package/dist/context_helpers.d.ts +17 -0
- package/dist/context_helpers.d.ts.map +1 -0
- package/dist/context_helpers.js +19 -0
- package/dist/contextmenu_helpers.d.ts +16 -0
- package/dist/contextmenu_helpers.d.ts.map +1 -0
- package/dist/contextmenu_helpers.js +39 -0
- package/dist/contextmenu_state.svelte.d.ts +152 -0
- package/dist/contextmenu_state.svelte.d.ts.map +1 -0
- package/dist/contextmenu_state.svelte.js +424 -0
- package/dist/csp.d.ts +160 -0
- package/dist/csp.d.ts.map +1 -0
- package/dist/csp.js +354 -0
- package/dist/csp_of_ryanatkn.d.ts +6 -0
- package/dist/csp_of_ryanatkn.d.ts.map +1 -0
- package/dist/csp_of_ryanatkn.js +14 -0
- package/dist/declaration.svelte.d.ts +84 -0
- package/dist/declaration.svelte.d.ts.map +1 -0
- package/dist/declaration.svelte.js +66 -0
- package/dist/declaration_contextmenu.d.ts +4 -0
- package/dist/declaration_contextmenu.d.ts.map +1 -0
- package/dist/declaration_contextmenu.js +14 -0
- package/dist/dialog.d.ts +24 -0
- package/dist/dialog.d.ts.map +1 -0
- package/dist/dialog.js +12 -0
- package/dist/dimensions.svelte.d.ts +5 -0
- package/dist/dimensions.svelte.d.ts.map +1 -0
- package/dist/dimensions.svelte.js +4 -0
- package/dist/docs_helpers.svelte.d.ts +48 -0
- package/dist/docs_helpers.svelte.d.ts.map +1 -0
- package/dist/docs_helpers.svelte.js +99 -0
- package/dist/helpers.d.ts +2 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/helpers.js +16 -0
- package/dist/intersect.svelte.d.ts +47 -0
- package/dist/intersect.svelte.d.ts.map +1 -0
- package/dist/intersect.svelte.js +92 -0
- package/dist/library.svelte.d.ts +197 -0
- package/dist/library.svelte.d.ts.map +1 -0
- package/dist/library.svelte.js +130 -0
- package/dist/library_gen.d.ts +34 -0
- package/dist/library_gen.d.ts.map +1 -0
- package/dist/library_gen.js +123 -0
- package/dist/library_gen_helpers.d.ts +85 -0
- package/dist/library_gen_helpers.d.ts.map +1 -0
- package/dist/library_gen_helpers.js +188 -0
- package/dist/library_helpers.d.ts +54 -0
- package/dist/library_helpers.d.ts.map +1 -0
- package/dist/library_helpers.js +102 -0
- package/dist/logos.d.ts +134 -0
- package/dist/logos.d.ts.map +1 -0
- package/dist/logos.js +281 -0
- package/dist/mdz.d.ts +106 -0
- package/dist/mdz.d.ts.map +1 -0
- package/dist/mdz.js +1481 -0
- package/dist/mdz_components.d.ts +37 -0
- package/dist/mdz_components.d.ts.map +1 -0
- package/dist/mdz_components.js +12 -0
- package/dist/module.svelte.d.ts +47 -0
- package/dist/module.svelte.d.ts.map +1 -0
- package/dist/module.svelte.js +56 -0
- package/dist/module_contextmenu.d.ts +4 -0
- package/dist/module_contextmenu.d.ts.map +1 -0
- package/dist/module_contextmenu.js +14 -0
- package/dist/module_helpers.d.ts +69 -0
- package/dist/module_helpers.d.ts.map +1 -0
- package/dist/module_helpers.js +87 -0
- package/dist/rune_helpers.svelte.d.ts +6 -0
- package/dist/rune_helpers.svelte.d.ts.map +1 -0
- package/dist/rune_helpers.svelte.js +10 -0
- package/dist/storage.d.ts +13 -0
- package/dist/storage.d.ts.map +1 -0
- package/dist/storage.js +43 -0
- package/dist/svelte_helpers.d.ts +37 -0
- package/dist/svelte_helpers.d.ts.map +1 -0
- package/dist/svelte_helpers.js +245 -0
- package/dist/themer.svelte.d.ts +24 -0
- package/dist/themer.svelte.d.ts.map +1 -0
- package/dist/themer.svelte.js +43 -0
- package/dist/tome.d.ts +80 -0
- package/dist/tome.d.ts.map +1 -0
- package/dist/tome.js +27 -0
- package/dist/ts_helpers.d.ts +110 -0
- package/dist/ts_helpers.d.ts.map +1 -0
- package/dist/ts_helpers.js +533 -0
- package/dist/tsdoc_helpers.d.ts +98 -0
- package/dist/tsdoc_helpers.d.ts.map +1 -0
- package/dist/tsdoc_helpers.js +221 -0
- package/package.json +128 -0
- package/src/lib/alert.ts +14 -0
- package/src/lib/api_search.svelte.ts +85 -0
- package/src/lib/constants.ts +3 -0
- package/src/lib/context_helpers.ts +47 -0
- package/src/lib/contextmenu_helpers.ts +63 -0
- package/src/lib/contextmenu_state.svelte.ts +515 -0
- package/src/lib/csp.ts +576 -0
- package/src/lib/csp_of_ryanatkn.ts +16 -0
- package/src/lib/declaration.svelte.ts +102 -0
- package/src/lib/declaration_contextmenu.ts +22 -0
- package/src/lib/dialog.ts +35 -0
- package/src/lib/dimensions.svelte.ts +4 -0
- package/src/lib/docs_helpers.svelte.ts +149 -0
- package/src/lib/helpers.ts +10 -0
- package/src/lib/intersect.svelte.ts +152 -0
- package/src/lib/library.svelte.ts +162 -0
- package/src/lib/library_gen.ts +160 -0
- package/src/lib/library_gen_helpers.ts +262 -0
- package/src/lib/library_helpers.ts +123 -0
- package/src/lib/logos.ts +302 -0
- package/src/lib/mdz.ts +1819 -0
- package/src/lib/mdz_components.ts +34 -0
- package/src/lib/module.svelte.ts +78 -0
- package/src/lib/module_contextmenu.ts +20 -0
- package/src/lib/module_helpers.ts +113 -0
- package/src/lib/rune_helpers.svelte.ts +10 -0
- package/src/lib/storage.ts +48 -0
- package/src/lib/svelte_helpers.ts +303 -0
- package/src/lib/themer.svelte.ts +68 -0
- package/src/lib/tome.ts +38 -0
- package/src/lib/ts_helpers.ts +662 -0
- 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>
|