@dominikcz/greg 0.9.27
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/README.md +397 -0
- package/bin/greg.js +241 -0
- package/bin/init.js +351 -0
- package/bin/templates/docs/getting-started.md +47 -0
- package/bin/templates/docs/index.md +11 -0
- package/bin/templates/greg.config.js +39 -0
- package/bin/templates/greg.config.ts +38 -0
- package/bin/templates/index.html +16 -0
- package/bin/templates/src/App.svelte +5 -0
- package/bin/templates/src/app.css +20 -0
- package/bin/templates/src/main.js +9 -0
- package/bin/templates/svelte.config.js +1 -0
- package/bin/templates/tsconfig.json +21 -0
- package/bin/templates/vite.config.js +23 -0
- package/docs/__partials/markdown/examples/basic.md +4 -0
- package/docs/__partials/markdown/examples/diff.md +10 -0
- package/docs/__partials/markdown/examples/focus.md +5 -0
- package/docs/__partials/markdown/examples/language-title.md +3 -0
- package/docs/__partials/markdown/examples/line-highlighting.md +5 -0
- package/docs/__partials/markdown/examples/line-numbers.md +5 -0
- package/docs/__partials/note.md +4 -0
- package/docs/guide/__shared-warning.md +4 -0
- package/docs/guide/asset-handling.md +88 -0
- package/docs/guide/deploying.md +162 -0
- package/docs/guide/getting-started.md +334 -0
- package/docs/guide/index.md +23 -0
- package/docs/guide/localization.md +290 -0
- package/docs/guide/markdown/code.md +95 -0
- package/docs/guide/markdown/components-and-mermaid.md +43 -0
- package/docs/guide/markdown/containers.md +110 -0
- package/docs/guide/markdown/header-anchors.md +34 -0
- package/docs/guide/markdown/includes.md +84 -0
- package/docs/guide/markdown/index.md +20 -0
- package/docs/guide/markdown/inline-attributes.md +21 -0
- package/docs/guide/markdown/links-and-toc.md +64 -0
- package/docs/guide/markdown/math.md +54 -0
- package/docs/guide/markdown/syntax-highlighting.md +75 -0
- package/docs/guide/routing.md +150 -0
- package/docs/guide/using-svelte.md +88 -0
- package/docs/guide/versioning.md +281 -0
- package/docs/incompatibilities.md +48 -0
- package/docs/index.md +43 -0
- package/docs/reference/badge.md +100 -0
- package/docs/reference/carbon-ads.md +46 -0
- package/docs/reference/code-group.md +126 -0
- package/docs/reference/home-page.md +232 -0
- package/docs/reference/index.md +18 -0
- package/docs/reference/markdowndocs.md +275 -0
- package/docs/reference/outline.md +79 -0
- package/docs/reference/search.md +263 -0
- package/docs/reference/steps.md +200 -0
- package/docs/reference/team-page.md +189 -0
- package/docs/reference/theme.md +150 -0
- package/fakeDocsGenerator/generate_docs.js +310 -0
- package/package.json +92 -0
- package/scripts/build-versions.js +609 -0
- package/scripts/generate-static.js +79 -0
- package/scripts/render-markdown.js +420 -0
- package/src/lib/MarkdownDocs/AiChat.svelte +936 -0
- package/src/lib/MarkdownDocs/BackToTop.svelte +68 -0
- package/src/lib/MarkdownDocs/Breadcrumb.svelte +68 -0
- package/src/lib/MarkdownDocs/DocsNavigation.svelte +149 -0
- package/src/lib/MarkdownDocs/DocsSiteHeader.svelte +758 -0
- package/src/lib/MarkdownDocs/DocsVersionSwitcher.svelte +103 -0
- package/src/lib/MarkdownDocs/MarkdownDocs.svelte +2115 -0
- package/src/lib/MarkdownDocs/MarkdownRenderer.svelte +487 -0
- package/src/lib/MarkdownDocs/Outline.svelte +238 -0
- package/src/lib/MarkdownDocs/PrevNext.svelte +115 -0
- package/src/lib/MarkdownDocs/SearchModal.svelte +1241 -0
- package/src/lib/MarkdownDocs/TreeView.svelte +32 -0
- package/src/lib/MarkdownDocs/TreeViewItem.svelte +219 -0
- package/src/lib/MarkdownDocs/VersionOutdatedNotice.svelte +72 -0
- package/src/lib/MarkdownDocs/__tests__/codeDirectives.test.js +54 -0
- package/src/lib/MarkdownDocs/__tests__/common.test.js +41 -0
- package/src/lib/MarkdownDocs/__tests__/docsExamplesLint.test.js +77 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/docs/markdown/__partial-basic.md +3 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/docs/markdown/snippet.js +9 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/includes/part.md +11 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/includes/wrapper.md +5 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/snippets/sample.js +8 -0
- package/src/lib/MarkdownDocs/__tests__/fixtures/snippets/sample.md +5 -0
- package/src/lib/MarkdownDocs/__tests__/helpers.js +67 -0
- package/src/lib/MarkdownDocs/__tests__/localeUtils.test.js +204 -0
- package/src/lib/MarkdownDocs/__tests__/markdown.test.js +704 -0
- package/src/lib/MarkdownDocs/__tests__/markdownRendererRuntime.test.js +65 -0
- package/src/lib/MarkdownDocs/__tests__/searchIndexBuilder.test.js +117 -0
- package/src/lib/MarkdownDocs/__tests__/sqliteStore.test.js +202 -0
- package/src/lib/MarkdownDocs/__tests__/useRouter.test.js +16 -0
- package/src/lib/MarkdownDocs/ai/adapters/customAdapter.js +14 -0
- package/src/lib/MarkdownDocs/ai/adapters/customAdapter.ts +43 -0
- package/src/lib/MarkdownDocs/ai/adapters/ollamaAdapter.js +81 -0
- package/src/lib/MarkdownDocs/ai/adapters/ollamaAdapter.ts +116 -0
- package/src/lib/MarkdownDocs/ai/adapters/openaiAdapter.js +92 -0
- package/src/lib/MarkdownDocs/ai/adapters/openaiAdapter.ts +137 -0
- package/src/lib/MarkdownDocs/ai/aiProvider.ts +31 -0
- package/src/lib/MarkdownDocs/ai/characters.js +52 -0
- package/src/lib/MarkdownDocs/ai/characters.ts +69 -0
- package/src/lib/MarkdownDocs/ai/chunkStore.ts +25 -0
- package/src/lib/MarkdownDocs/ai/chunker.js +85 -0
- package/src/lib/MarkdownDocs/ai/chunker.ts +135 -0
- package/src/lib/MarkdownDocs/ai/docLinker.js +26 -0
- package/src/lib/MarkdownDocs/ai/docLinker.ts +36 -0
- package/src/lib/MarkdownDocs/ai/promptBuilder.js +33 -0
- package/src/lib/MarkdownDocs/ai/promptBuilder.ts +53 -0
- package/src/lib/MarkdownDocs/ai/ragPipeline.js +54 -0
- package/src/lib/MarkdownDocs/ai/ragPipeline.ts +106 -0
- package/src/lib/MarkdownDocs/ai/stores/memoryStore.js +88 -0
- package/src/lib/MarkdownDocs/ai/stores/memoryStore.ts +112 -0
- package/src/lib/MarkdownDocs/ai/stores/sqliteStore.ts +372 -0
- package/src/lib/MarkdownDocs/ai/types.ts +71 -0
- package/src/lib/MarkdownDocs/aiServer.js +288 -0
- package/src/lib/MarkdownDocs/codeDirectives.js +191 -0
- package/src/lib/MarkdownDocs/codeFenceInfo.js +45 -0
- package/src/lib/MarkdownDocs/codeGroup.ts +46 -0
- package/src/lib/MarkdownDocs/common.ts +47 -0
- package/src/lib/MarkdownDocs/docsUtils.js +281 -0
- package/src/lib/MarkdownDocs/index.plugins.js +22 -0
- package/src/lib/MarkdownDocs/layouts/LayoutDoc.svelte +8 -0
- package/src/lib/MarkdownDocs/layouts/LayoutHome.svelte +58 -0
- package/src/lib/MarkdownDocs/layouts/LayoutPage.svelte +9 -0
- package/src/lib/MarkdownDocs/loadGregConfig.js +82 -0
- package/src/lib/MarkdownDocs/localeUtils.ts +682 -0
- package/src/lib/MarkdownDocs/markdownRendererRuntime.ts +314 -0
- package/src/lib/MarkdownDocs/mermaidThemes.js +319 -0
- package/src/lib/MarkdownDocs/navigationUtils.js +22 -0
- package/src/lib/MarkdownDocs/rehypeCodeGroup.js +326 -0
- package/src/lib/MarkdownDocs/rehypeCodeTitle.js +96 -0
- package/src/lib/MarkdownDocs/rehypeToc.js +170 -0
- package/src/lib/MarkdownDocs/remarkCodeMeta.js +22 -0
- package/src/lib/MarkdownDocs/remarkContainers.js +329 -0
- package/src/lib/MarkdownDocs/remarkCustomAnchors.js +42 -0
- package/src/lib/MarkdownDocs/remarkEscapeSvelte.js +33 -0
- package/src/lib/MarkdownDocs/remarkGlobalComponents.js +65 -0
- package/src/lib/MarkdownDocs/remarkImports.js +461 -0
- package/src/lib/MarkdownDocs/remarkImportsBrowser.js +349 -0
- package/src/lib/MarkdownDocs/remarkInlineAttrs.js +95 -0
- package/src/lib/MarkdownDocs/remarkMathToHtml.js +138 -0
- package/src/lib/MarkdownDocs/searchIndexBuilder.js +497 -0
- package/src/lib/MarkdownDocs/searchServer.js +263 -0
- package/src/lib/MarkdownDocs/treeViewTypes.ts +11 -0
- package/src/lib/MarkdownDocs/useRouter.svelte.ts +114 -0
- package/src/lib/MarkdownDocs/useSplitter.svelte.ts +33 -0
- package/src/lib/MarkdownDocs/versioningDefaults.js +20 -0
- package/src/lib/MarkdownDocs/vitePluginAiServer.js +204 -0
- package/src/lib/MarkdownDocs/vitePluginCopyDocs.js +153 -0
- package/src/lib/MarkdownDocs/vitePluginFrontmatter.js +109 -0
- package/src/lib/MarkdownDocs/vitePluginGregConfig.js +108 -0
- package/src/lib/MarkdownDocs/vitePluginSearchIndex.js +57 -0
- package/src/lib/MarkdownDocs/vitePluginSearchServer.js +190 -0
- package/src/lib/components/Badge.svelte +59 -0
- package/src/lib/components/Button.svelte +138 -0
- package/src/lib/components/CarbonAds.svelte +99 -0
- package/src/lib/components/CodeGroup.svelte +102 -0
- package/src/lib/components/Feature.svelte +209 -0
- package/src/lib/components/Features.svelte +123 -0
- package/src/lib/components/Hero.svelte +399 -0
- package/src/lib/components/Image.svelte +128 -0
- package/src/lib/components/Link.svelte +105 -0
- package/src/lib/components/SocialLink.svelte +84 -0
- package/src/lib/components/SocialLinks.svelte +33 -0
- package/src/lib/components/Steps.svelte +143 -0
- package/src/lib/components/TeamMember.svelte +273 -0
- package/src/lib/components/TeamMembers.svelte +81 -0
- package/src/lib/components/TeamPage.svelte +65 -0
- package/src/lib/components/TeamPageSection.svelte +108 -0
- package/src/lib/components/TeamPageTitle.svelte +89 -0
- package/src/lib/components/index.js +24 -0
- package/src/lib/portal/context.js +12 -0
- package/src/lib/portal/index.js +3 -0
- package/src/lib/portal/portal.svelte +14 -0
- package/src/lib/portal/slot.svelte +8 -0
- package/src/lib/scss/__code.scss +128 -0
- package/src/lib/scss/__containers.scss +99 -0
- package/src/lib/scss/__markdown.scss +447 -0
- package/src/lib/scss/__scrollbar.scss +60 -0
- package/src/lib/scss/__steps.scss +100 -0
- package/src/lib/scss/__theme.scss +238 -0
- package/src/lib/scss/__toc.scss +55 -0
- package/src/lib/scss/__utilities.scss +7 -0
- package/src/lib/scss/greg.scss +9 -0
- package/src/lib/spinner/spinner.svelte +42 -0
- package/svelte.config.js +146 -0
- package/types/index.d.ts +456 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import SocialLink from "./SocialLink.svelte";
|
|
3
|
+
|
|
4
|
+
type SocialLinkIcon = string | { svg: string };
|
|
5
|
+
|
|
6
|
+
type SocialLinkItem = {
|
|
7
|
+
icon: SocialLinkIcon;
|
|
8
|
+
link: string;
|
|
9
|
+
ariaLabel?: string;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
type Props = {
|
|
13
|
+
links: SocialLinkItem[];
|
|
14
|
+
me?: boolean;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
let { links, me = true }: Props = $props();
|
|
18
|
+
</script>
|
|
19
|
+
|
|
20
|
+
<div class="SocialLinks">
|
|
21
|
+
{#each links as { link, icon, ariaLabel } (link)}
|
|
22
|
+
<SocialLink {icon} {link} {ariaLabel} {me} />
|
|
23
|
+
{/each}
|
|
24
|
+
</div>
|
|
25
|
+
|
|
26
|
+
<style>
|
|
27
|
+
.SocialLinks {
|
|
28
|
+
display: flex;
|
|
29
|
+
justify-content: center;
|
|
30
|
+
align-items: center;
|
|
31
|
+
flex-wrap: wrap;
|
|
32
|
+
}
|
|
33
|
+
</style>
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from "svelte";
|
|
3
|
+
let { children }: { children?: Snippet } = $props();
|
|
4
|
+
</script>
|
|
5
|
+
|
|
6
|
+
<!--
|
|
7
|
+
Steps — an ordered procedural steps list, inspired by Starlight.
|
|
8
|
+
|
|
9
|
+
Usage in Markdown:
|
|
10
|
+
<Steps>
|
|
11
|
+
1. **Install dependencies**
|
|
12
|
+
Run `npm install` in your project folder.
|
|
13
|
+
2. **Start the dev server**
|
|
14
|
+
Run `npm run dev`.
|
|
15
|
+
3. **Open the app**
|
|
16
|
+
Navigate to `http://localhost:5173`.
|
|
17
|
+
</Steps>
|
|
18
|
+
-->
|
|
19
|
+
<div class="greg-steps">
|
|
20
|
+
{@render children?.()}
|
|
21
|
+
</div>
|
|
22
|
+
|
|
23
|
+
<style>
|
|
24
|
+
/* ── design tokens ───────────────────────────────────────────────────── */
|
|
25
|
+
.greg-steps {
|
|
26
|
+
--_size: 1.75rem; /* bullet circle diameter */
|
|
27
|
+
--_margin: var(
|
|
28
|
+
--greg-steps-guide-gap,
|
|
29
|
+
0.5rem
|
|
30
|
+
); /* gap above/below connector */
|
|
31
|
+
--_bullet-bg: var(--greg-accent, #646cff);
|
|
32
|
+
--_bullet-fg: #fff;
|
|
33
|
+
--_guide: var(
|
|
34
|
+
--greg-steps-guide-color,
|
|
35
|
+
color-mix(
|
|
36
|
+
in srgb,
|
|
37
|
+
var(--greg-accent, #646cff) 42%,
|
|
38
|
+
var(--greg-border-color, #e5e5ea)
|
|
39
|
+
)
|
|
40
|
+
);
|
|
41
|
+
margin-block: 1.75rem;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/* ── ordered list ────────────────────────────────────────────────────── */
|
|
45
|
+
.greg-steps :global(ol) {
|
|
46
|
+
list-style: none;
|
|
47
|
+
counter-reset: greg-steps-counter;
|
|
48
|
+
padding-inline-start: 0;
|
|
49
|
+
margin: 0;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/* ── individual step ─────────────────────────────────────────────────── */
|
|
53
|
+
.greg-steps :global(ol > li) {
|
|
54
|
+
counter-increment: greg-steps-counter;
|
|
55
|
+
position: relative;
|
|
56
|
+
list-style: none;
|
|
57
|
+
padding-inline-start: calc(var(--_size) + 1rem);
|
|
58
|
+
/* HACK: keeps any margin-bottom inside the li's padding box to avoid
|
|
59
|
+
gaps in the connector line (same as Starlight) */
|
|
60
|
+
padding-bottom: 1px;
|
|
61
|
+
min-height: calc(var(--_size) + var(--_margin));
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
.greg-steps :global(ol > li::marker) {
|
|
65
|
+
content: "";
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.greg-steps :global(ol > li + li) {
|
|
69
|
+
margin-top: 0;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/* ── number badge (::before) ─────────────────────────────────────────── */
|
|
73
|
+
.greg-steps :global(ol > li::before) {
|
|
74
|
+
content: counter(greg-steps-counter);
|
|
75
|
+
position: absolute;
|
|
76
|
+
top: 0;
|
|
77
|
+
inset-inline-start: 0;
|
|
78
|
+
width: var(--_size);
|
|
79
|
+
height: var(--_size);
|
|
80
|
+
/* line-height centres the number without flexbox (pseudo-element safe) */
|
|
81
|
+
line-height: var(--_size);
|
|
82
|
+
font-size: 0.8rem;
|
|
83
|
+
font-weight: 600;
|
|
84
|
+
text-align: center;
|
|
85
|
+
/* solid filled circle — clearly distinct from the page background */
|
|
86
|
+
color: var(--_bullet-fg);
|
|
87
|
+
background-color: var(--_bullet-bg);
|
|
88
|
+
border-radius: 99rem;
|
|
89
|
+
box-shadow: inset 0 0 0 1px
|
|
90
|
+
color-mix(in srgb, var(--_bullet-bg) 82%, black);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
/* ── vertical connector line (::after) ──────────────────────────────── */
|
|
94
|
+
.greg-steps :global(ol > li::after) {
|
|
95
|
+
content: "";
|
|
96
|
+
position: absolute;
|
|
97
|
+
top: calc(var(--_size) + var(--_margin));
|
|
98
|
+
/* compensate li padding-bottom:1px so top and bottom gaps are equal */
|
|
99
|
+
bottom: max(0px, calc(var(--_margin) - 1px));
|
|
100
|
+
inset-inline-start: calc((var(--_size) - 2px) / 2);
|
|
101
|
+
width: 2px;
|
|
102
|
+
background-color: var(--_guide);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.greg-steps :global(ol > li:last-child::after) {
|
|
106
|
+
display: none;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/* ── first-child vertical alignment with circle centre ──────────────── */
|
|
110
|
+
/*
|
|
111
|
+
* Shifts the first block element down so its text baseline aligns with
|
|
112
|
+
* the vertical centre of the bullet circle (the same technique Starlight
|
|
113
|
+
* uses with `lh` units, falling back to an approximation).
|
|
114
|
+
*/
|
|
115
|
+
.greg-steps :global(ol > li > :first-child) {
|
|
116
|
+
--lh: calc(
|
|
117
|
+
1em * 1.75
|
|
118
|
+
); /* approximation: font-size × body line-height */
|
|
119
|
+
--shift-y: calc(0.5 * (var(--_size) - var(--lh)));
|
|
120
|
+
margin-top: 0;
|
|
121
|
+
transform: translateY(var(--shift-y));
|
|
122
|
+
margin-bottom: var(--shift-y);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/* Use the precise lh unit where supported */
|
|
126
|
+
@supports (--prop: 1lh) {
|
|
127
|
+
.greg-steps :global(ol > li > :first-child) {
|
|
128
|
+
--lh: 1lh;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/* Headings have a tighter own line-height */
|
|
133
|
+
.greg-steps :global(ol > li > :first-child:where(h1, h2, h3, h4, h5, h6)) {
|
|
134
|
+
--lh: calc(1em * 1.3);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/* ── step title (first bold in a paragraph) ──────────────────────────── */
|
|
138
|
+
.greg-steps :global(ol > li > p:first-child > strong:first-child) {
|
|
139
|
+
display: block;
|
|
140
|
+
font-weight: 600;
|
|
141
|
+
color: var(--greg-color, inherit);
|
|
142
|
+
}
|
|
143
|
+
</style>
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import Link from "./Link.svelte";
|
|
3
|
+
import SocialLinks from "./SocialLinks.svelte";
|
|
4
|
+
|
|
5
|
+
type SocialLinkIcon = string | { svg: string };
|
|
6
|
+
type SocialLinkItem = {
|
|
7
|
+
icon: SocialLinkIcon;
|
|
8
|
+
link: string;
|
|
9
|
+
ariaLabel?: string;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
type TeamMember = {
|
|
13
|
+
avatar: string;
|
|
14
|
+
name: string;
|
|
15
|
+
title?: string;
|
|
16
|
+
org?: string;
|
|
17
|
+
orgLink?: string;
|
|
18
|
+
desc?: string;
|
|
19
|
+
links?: SocialLinkItem[];
|
|
20
|
+
sponsor?: string;
|
|
21
|
+
actionText?: string;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
type Props = {
|
|
25
|
+
size?: "small" | "medium";
|
|
26
|
+
member: TeamMember;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
let { size = "medium", member }: Props = $props();
|
|
30
|
+
</script>
|
|
31
|
+
|
|
32
|
+
<article class="TeamMember {size}">
|
|
33
|
+
<div class="profile">
|
|
34
|
+
<figure class="avatar">
|
|
35
|
+
<img class="avatar-img" src={member.avatar} alt={member.name} />
|
|
36
|
+
</figure>
|
|
37
|
+
<div class="data">
|
|
38
|
+
<h1 class="name">{member.name}</h1>
|
|
39
|
+
{#if member.title || member.org}
|
|
40
|
+
<p class="affiliation">
|
|
41
|
+
{#if member.title}
|
|
42
|
+
<span class="title">{member.title}</span>
|
|
43
|
+
{/if}
|
|
44
|
+
{#if member.title && member.org}
|
|
45
|
+
<span class="at"> @ </span>
|
|
46
|
+
{/if}
|
|
47
|
+
{#if member.org}
|
|
48
|
+
<Link
|
|
49
|
+
class="org {member.orgLink ? 'link' : ''}"
|
|
50
|
+
href={member.orgLink}
|
|
51
|
+
noIcon
|
|
52
|
+
>
|
|
53
|
+
{member.org}
|
|
54
|
+
</Link>
|
|
55
|
+
{/if}
|
|
56
|
+
</p>
|
|
57
|
+
{/if}
|
|
58
|
+
{#if member.desc}
|
|
59
|
+
<!-- eslint-disable-next-line svelte/no-at-html-tags -->
|
|
60
|
+
<p class="desc">{@html member.desc}</p>
|
|
61
|
+
{/if}
|
|
62
|
+
{#if member.links?.length}
|
|
63
|
+
<div class="links">
|
|
64
|
+
<SocialLinks links={member.links} me={false} />
|
|
65
|
+
</div>
|
|
66
|
+
{/if}
|
|
67
|
+
</div>
|
|
68
|
+
</div>
|
|
69
|
+
|
|
70
|
+
{#if member.sponsor}
|
|
71
|
+
<div class="sp">
|
|
72
|
+
<Link class="sp-link link" href={member.sponsor} noIcon>
|
|
73
|
+
<svg
|
|
74
|
+
class="sp-icon"
|
|
75
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
76
|
+
viewBox="0 0 24 24"
|
|
77
|
+
aria-hidden="true"
|
|
78
|
+
>
|
|
79
|
+
<path
|
|
80
|
+
d="M12,22.2c-0.3,0-0.5-0.1-0.7-0.3l-8.8-8.8c-2.5-2.5-2.5-6.7,0-9.2c2.5-2.5,6.7-2.5,9.2,0L12,4.3l0.4-0.4c0,0,0,0,0,0C13.6,2.7,15.2,2,16.9,2c0,0,0,0,0,0c1.7,0,3.4,0.7,4.6,1.9l0,0c1.2,1.2,1.9,2.9,1.9,4.6c0,1.7-0.7,3.4-1.9,4.6l-8.8,8.8C12.5,22.1,12.3,22.2,12,22.2z"
|
|
81
|
+
/>
|
|
82
|
+
</svg>
|
|
83
|
+
{member.actionText ?? "Sponsor"}
|
|
84
|
+
</Link>
|
|
85
|
+
</div>
|
|
86
|
+
{/if}
|
|
87
|
+
</article>
|
|
88
|
+
|
|
89
|
+
<style>
|
|
90
|
+
.TeamMember {
|
|
91
|
+
display: flex;
|
|
92
|
+
flex-direction: column;
|
|
93
|
+
gap: 2px;
|
|
94
|
+
border-radius: 12px;
|
|
95
|
+
width: 100%;
|
|
96
|
+
height: 100%;
|
|
97
|
+
overflow: hidden;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/* Small */
|
|
101
|
+
.TeamMember.small .profile {
|
|
102
|
+
padding: 32px;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.TeamMember.small .data {
|
|
106
|
+
padding-top: 20px;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
.TeamMember.small .avatar {
|
|
110
|
+
width: 64px;
|
|
111
|
+
height: 64px;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
.TeamMember.small .name {
|
|
115
|
+
line-height: 24px;
|
|
116
|
+
font-size: 16px;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
.TeamMember.small .affiliation {
|
|
120
|
+
padding-top: 4px;
|
|
121
|
+
line-height: 20px;
|
|
122
|
+
font-size: 14px;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
.TeamMember.small .desc {
|
|
126
|
+
padding-top: 12px;
|
|
127
|
+
line-height: 20px;
|
|
128
|
+
font-size: 14px;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
.TeamMember.small .links {
|
|
132
|
+
margin: 0 -16px -20px;
|
|
133
|
+
padding: 10px 0 0;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/* Medium */
|
|
137
|
+
.TeamMember.medium .profile {
|
|
138
|
+
padding: 48px 32px;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
.TeamMember.medium .data {
|
|
142
|
+
padding-top: 24px;
|
|
143
|
+
text-align: center;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
.TeamMember.medium .avatar {
|
|
147
|
+
width: 96px;
|
|
148
|
+
height: 96px;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
.TeamMember.medium .name {
|
|
152
|
+
letter-spacing: 0.15px;
|
|
153
|
+
line-height: 28px;
|
|
154
|
+
font-size: 20px;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
.TeamMember.medium .affiliation {
|
|
158
|
+
padding-top: 4px;
|
|
159
|
+
font-size: 16px;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
.TeamMember.medium .desc {
|
|
163
|
+
padding-top: 16px;
|
|
164
|
+
max-width: 288px;
|
|
165
|
+
font-size: 16px;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
.TeamMember.medium .links {
|
|
169
|
+
margin: 0 -16px -12px;
|
|
170
|
+
padding: 16px 12px 0;
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
.profile {
|
|
174
|
+
flex-grow: 1;
|
|
175
|
+
background-color: var(--greg-menu-background);
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
.data {
|
|
179
|
+
text-align: center;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.avatar {
|
|
183
|
+
position: relative;
|
|
184
|
+
flex-shrink: 0;
|
|
185
|
+
margin: 0 auto;
|
|
186
|
+
border-radius: 50%;
|
|
187
|
+
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
.avatar-img {
|
|
191
|
+
position: absolute;
|
|
192
|
+
top: 0;
|
|
193
|
+
right: 0;
|
|
194
|
+
bottom: 0;
|
|
195
|
+
left: 0;
|
|
196
|
+
border-radius: 50%;
|
|
197
|
+
object-fit: cover;
|
|
198
|
+
width: 100%;
|
|
199
|
+
height: 100%;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
.name {
|
|
203
|
+
margin: 0;
|
|
204
|
+
font-weight: 600;
|
|
205
|
+
border: none;
|
|
206
|
+
padding: 0;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
.affiliation {
|
|
210
|
+
margin: 0;
|
|
211
|
+
font-weight: 500;
|
|
212
|
+
color: var(--greg-menu-section-color);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
:global(.org.link) {
|
|
216
|
+
color: var(--greg-menu-section-color);
|
|
217
|
+
transition: color 0.25s;
|
|
218
|
+
text-decoration: none;
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
:global(.org.link:hover) {
|
|
222
|
+
color: var(--greg-accent);
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
.desc {
|
|
226
|
+
margin: 0 auto;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
.desc :global(a) {
|
|
230
|
+
font-weight: 500;
|
|
231
|
+
color: var(--greg-accent);
|
|
232
|
+
text-decoration-style: dotted;
|
|
233
|
+
transition: color 0.25s;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
.links {
|
|
237
|
+
display: flex;
|
|
238
|
+
justify-content: center;
|
|
239
|
+
height: 56px;
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
:global(.sp-link) {
|
|
243
|
+
display: flex;
|
|
244
|
+
justify-content: center;
|
|
245
|
+
align-items: center;
|
|
246
|
+
text-align: center;
|
|
247
|
+
padding: 16px;
|
|
248
|
+
font-size: 14px;
|
|
249
|
+
font-weight: 500;
|
|
250
|
+
color: var(--greg-sponsor-color);
|
|
251
|
+
background-color: var(--greg-menu-background);
|
|
252
|
+
transition:
|
|
253
|
+
color 0.25s,
|
|
254
|
+
background-color 0.25s;
|
|
255
|
+
text-decoration: none;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
:global(.sp-link:hover),
|
|
259
|
+
.links:focus-within :global(.sp-link),
|
|
260
|
+
:global(.sp-link:focus-within) {
|
|
261
|
+
outline: none;
|
|
262
|
+
color: var(--greg-menu-active-color);
|
|
263
|
+
background-color: var(--greg-sponsor-color);
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
.sp-icon {
|
|
267
|
+
margin-right: 8px;
|
|
268
|
+
width: 16px;
|
|
269
|
+
height: 16px;
|
|
270
|
+
fill: currentColor;
|
|
271
|
+
flex-shrink: 0;
|
|
272
|
+
}
|
|
273
|
+
</style>
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import TeamMember from "./TeamMember.svelte";
|
|
3
|
+
|
|
4
|
+
type SocialLinkIcon = string | { svg: string };
|
|
5
|
+
type SocialLinkItem = {
|
|
6
|
+
icon: SocialLinkIcon;
|
|
7
|
+
link: string;
|
|
8
|
+
ariaLabel?: string;
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
type TeamMemberData = {
|
|
12
|
+
avatar: string;
|
|
13
|
+
name: string;
|
|
14
|
+
title?: string;
|
|
15
|
+
org?: string;
|
|
16
|
+
orgLink?: string;
|
|
17
|
+
desc?: string;
|
|
18
|
+
links?: SocialLinkItem[];
|
|
19
|
+
sponsor?: string;
|
|
20
|
+
actionText?: string;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
type Props = {
|
|
24
|
+
size?: "small" | "medium";
|
|
25
|
+
members: TeamMemberData[];
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
let { size = "medium", members }: Props = $props();
|
|
29
|
+
|
|
30
|
+
let classes = $derived([size, `count-${members.length}`].join(" "));
|
|
31
|
+
</script>
|
|
32
|
+
|
|
33
|
+
<div class="TeamMembers {classes}">
|
|
34
|
+
<div class="container">
|
|
35
|
+
{#each members as member (member.name)}
|
|
36
|
+
<div class="item">
|
|
37
|
+
<TeamMember {size} {member} />
|
|
38
|
+
</div>
|
|
39
|
+
{/each}
|
|
40
|
+
</div>
|
|
41
|
+
</div>
|
|
42
|
+
|
|
43
|
+
<style>
|
|
44
|
+
.TeamMembers.small .container {
|
|
45
|
+
grid-template-columns: repeat(auto-fit, minmax(224px, 1fr));
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.TeamMembers.small.count-1 .container {
|
|
49
|
+
max-width: 276px;
|
|
50
|
+
}
|
|
51
|
+
.TeamMembers.small.count-2 .container {
|
|
52
|
+
max-width: calc(276px * 2 + 24px);
|
|
53
|
+
}
|
|
54
|
+
.TeamMembers.small.count-3 .container {
|
|
55
|
+
max-width: calc(276px * 3 + 24px * 2);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.TeamMembers.medium .container {
|
|
59
|
+
grid-template-columns: repeat(auto-fit, minmax(256px, 1fr));
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
@media (min-width: 375px) {
|
|
63
|
+
.TeamMembers.medium .container {
|
|
64
|
+
grid-template-columns: repeat(auto-fit, minmax(288px, 1fr));
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.TeamMembers.medium.count-1 .container {
|
|
69
|
+
max-width: 368px;
|
|
70
|
+
}
|
|
71
|
+
.TeamMembers.medium.count-2 .container {
|
|
72
|
+
max-width: calc(368px * 2 + 24px);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
.container {
|
|
76
|
+
display: grid;
|
|
77
|
+
gap: 24px;
|
|
78
|
+
margin: 0 auto;
|
|
79
|
+
max-width: 1152px;
|
|
80
|
+
}
|
|
81
|
+
</style>
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from "svelte";
|
|
3
|
+
|
|
4
|
+
type Props = {
|
|
5
|
+
children?: Snippet;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
let { children }: Props = $props();
|
|
9
|
+
</script>
|
|
10
|
+
|
|
11
|
+
<div class="TeamPage">
|
|
12
|
+
{#if children}
|
|
13
|
+
{@render children()}
|
|
14
|
+
{/if}
|
|
15
|
+
</div>
|
|
16
|
+
|
|
17
|
+
<style>
|
|
18
|
+
.TeamPage {
|
|
19
|
+
margin: 96px 0;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
@media (min-width: 768px) {
|
|
23
|
+
.TeamPage {
|
|
24
|
+
margin: 128px 0;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
/* Spacing between sections within a TeamPage */
|
|
29
|
+
.TeamPage :global(.TeamPageTitle + .TeamPageSection),
|
|
30
|
+
.TeamPage :global(.TeamPageSection + .TeamPageSection),
|
|
31
|
+
.TeamPage :global(.TeamMembers + .TeamPageSection) {
|
|
32
|
+
margin-top: 64px;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
@media (min-width: 768px) {
|
|
36
|
+
.TeamPage :global(.TeamPageTitle + .TeamPageSection) {
|
|
37
|
+
margin-top: 16px;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.TeamPage :global(.TeamPageSection + .TeamPageSection),
|
|
41
|
+
.TeamPage :global(.TeamMembers + .TeamPageSection) {
|
|
42
|
+
margin-top: 96px;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.TeamPage :global(.TeamMembers + .TeamMembers) {
|
|
47
|
+
margin-top: 24px;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.TeamPage :global(.TeamMembers) {
|
|
51
|
+
padding: 0 24px;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
@media (min-width: 768px) {
|
|
55
|
+
.TeamPage :global(.TeamMembers) {
|
|
56
|
+
padding: 0 48px;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
@media (min-width: 960px) {
|
|
61
|
+
.TeamPage :global(.TeamMembers) {
|
|
62
|
+
padding: 0 64px;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
</style>
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from "svelte";
|
|
3
|
+
|
|
4
|
+
type Props = {
|
|
5
|
+
title?: string;
|
|
6
|
+
lead?: string;
|
|
7
|
+
titleSnippet?: Snippet;
|
|
8
|
+
leadSnippet?: Snippet;
|
|
9
|
+
children?: Snippet;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
let { title, lead, titleSnippet, leadSnippet, children }: Props = $props();
|
|
13
|
+
|
|
14
|
+
let hasTitle = $derived(!!(titleSnippet || title));
|
|
15
|
+
let hasLead = $derived(!!(leadSnippet || lead));
|
|
16
|
+
</script>
|
|
17
|
+
|
|
18
|
+
<section class="TeamPageSection">
|
|
19
|
+
{#if hasTitle}
|
|
20
|
+
<div class="title">
|
|
21
|
+
<div class="title-line"></div>
|
|
22
|
+
<h2 class="title-text">
|
|
23
|
+
{#if titleSnippet}
|
|
24
|
+
{@render titleSnippet()}
|
|
25
|
+
{:else}
|
|
26
|
+
{title}
|
|
27
|
+
{/if}
|
|
28
|
+
</h2>
|
|
29
|
+
</div>
|
|
30
|
+
{/if}
|
|
31
|
+
{#if hasLead}
|
|
32
|
+
<p class="lead">
|
|
33
|
+
{#if leadSnippet}
|
|
34
|
+
{@render leadSnippet()}
|
|
35
|
+
{:else}
|
|
36
|
+
{lead}
|
|
37
|
+
{/if}
|
|
38
|
+
</p>
|
|
39
|
+
{/if}
|
|
40
|
+
{#if children}
|
|
41
|
+
<div class="members">
|
|
42
|
+
{@render children()}
|
|
43
|
+
</div>
|
|
44
|
+
{/if}
|
|
45
|
+
</section>
|
|
46
|
+
|
|
47
|
+
<style>
|
|
48
|
+
.TeamPageSection {
|
|
49
|
+
padding: 0 32px;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
@media (min-width: 768px) {
|
|
53
|
+
.TeamPageSection {
|
|
54
|
+
padding: 0 48px;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@media (min-width: 960px) {
|
|
59
|
+
.TeamPageSection {
|
|
60
|
+
padding: 0 64px;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
.title {
|
|
65
|
+
position: relative;
|
|
66
|
+
margin: 0 auto;
|
|
67
|
+
max-width: 1152px;
|
|
68
|
+
text-align: center;
|
|
69
|
+
color: var(--greg-menu-section-color);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.title-line {
|
|
73
|
+
position: absolute;
|
|
74
|
+
top: 16px;
|
|
75
|
+
left: 0;
|
|
76
|
+
width: 100%;
|
|
77
|
+
height: 1px;
|
|
78
|
+
background-color: var(--greg-border-color);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.title-text {
|
|
82
|
+
position: relative;
|
|
83
|
+
display: inline-block;
|
|
84
|
+
padding: 0 24px;
|
|
85
|
+
letter-spacing: 0;
|
|
86
|
+
line-height: 32px;
|
|
87
|
+
font-size: 20px;
|
|
88
|
+
font-weight: 500;
|
|
89
|
+
background-color: var(--greg-background);
|
|
90
|
+
margin: 0;
|
|
91
|
+
border: none;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
.lead {
|
|
95
|
+
margin: 0 auto;
|
|
96
|
+
max-width: 480px;
|
|
97
|
+
padding-top: 12px;
|
|
98
|
+
text-align: center;
|
|
99
|
+
line-height: 24px;
|
|
100
|
+
font-size: 16px;
|
|
101
|
+
font-weight: 500;
|
|
102
|
+
color: var(--greg-menu-section-color);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.members {
|
|
106
|
+
padding-top: 40px;
|
|
107
|
+
}
|
|
108
|
+
</style>
|