@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.
Files changed (183) hide show
  1. package/README.md +397 -0
  2. package/bin/greg.js +241 -0
  3. package/bin/init.js +351 -0
  4. package/bin/templates/docs/getting-started.md +47 -0
  5. package/bin/templates/docs/index.md +11 -0
  6. package/bin/templates/greg.config.js +39 -0
  7. package/bin/templates/greg.config.ts +38 -0
  8. package/bin/templates/index.html +16 -0
  9. package/bin/templates/src/App.svelte +5 -0
  10. package/bin/templates/src/app.css +20 -0
  11. package/bin/templates/src/main.js +9 -0
  12. package/bin/templates/svelte.config.js +1 -0
  13. package/bin/templates/tsconfig.json +21 -0
  14. package/bin/templates/vite.config.js +23 -0
  15. package/docs/__partials/markdown/examples/basic.md +4 -0
  16. package/docs/__partials/markdown/examples/diff.md +10 -0
  17. package/docs/__partials/markdown/examples/focus.md +5 -0
  18. package/docs/__partials/markdown/examples/language-title.md +3 -0
  19. package/docs/__partials/markdown/examples/line-highlighting.md +5 -0
  20. package/docs/__partials/markdown/examples/line-numbers.md +5 -0
  21. package/docs/__partials/note.md +4 -0
  22. package/docs/guide/__shared-warning.md +4 -0
  23. package/docs/guide/asset-handling.md +88 -0
  24. package/docs/guide/deploying.md +162 -0
  25. package/docs/guide/getting-started.md +334 -0
  26. package/docs/guide/index.md +23 -0
  27. package/docs/guide/localization.md +290 -0
  28. package/docs/guide/markdown/code.md +95 -0
  29. package/docs/guide/markdown/components-and-mermaid.md +43 -0
  30. package/docs/guide/markdown/containers.md +110 -0
  31. package/docs/guide/markdown/header-anchors.md +34 -0
  32. package/docs/guide/markdown/includes.md +84 -0
  33. package/docs/guide/markdown/index.md +20 -0
  34. package/docs/guide/markdown/inline-attributes.md +21 -0
  35. package/docs/guide/markdown/links-and-toc.md +64 -0
  36. package/docs/guide/markdown/math.md +54 -0
  37. package/docs/guide/markdown/syntax-highlighting.md +75 -0
  38. package/docs/guide/routing.md +150 -0
  39. package/docs/guide/using-svelte.md +88 -0
  40. package/docs/guide/versioning.md +281 -0
  41. package/docs/incompatibilities.md +48 -0
  42. package/docs/index.md +43 -0
  43. package/docs/reference/badge.md +100 -0
  44. package/docs/reference/carbon-ads.md +46 -0
  45. package/docs/reference/code-group.md +126 -0
  46. package/docs/reference/home-page.md +232 -0
  47. package/docs/reference/index.md +18 -0
  48. package/docs/reference/markdowndocs.md +275 -0
  49. package/docs/reference/outline.md +79 -0
  50. package/docs/reference/search.md +263 -0
  51. package/docs/reference/steps.md +200 -0
  52. package/docs/reference/team-page.md +189 -0
  53. package/docs/reference/theme.md +150 -0
  54. package/fakeDocsGenerator/generate_docs.js +310 -0
  55. package/package.json +92 -0
  56. package/scripts/build-versions.js +609 -0
  57. package/scripts/generate-static.js +79 -0
  58. package/scripts/render-markdown.js +420 -0
  59. package/src/lib/MarkdownDocs/AiChat.svelte +936 -0
  60. package/src/lib/MarkdownDocs/BackToTop.svelte +68 -0
  61. package/src/lib/MarkdownDocs/Breadcrumb.svelte +68 -0
  62. package/src/lib/MarkdownDocs/DocsNavigation.svelte +149 -0
  63. package/src/lib/MarkdownDocs/DocsSiteHeader.svelte +758 -0
  64. package/src/lib/MarkdownDocs/DocsVersionSwitcher.svelte +103 -0
  65. package/src/lib/MarkdownDocs/MarkdownDocs.svelte +2115 -0
  66. package/src/lib/MarkdownDocs/MarkdownRenderer.svelte +487 -0
  67. package/src/lib/MarkdownDocs/Outline.svelte +238 -0
  68. package/src/lib/MarkdownDocs/PrevNext.svelte +115 -0
  69. package/src/lib/MarkdownDocs/SearchModal.svelte +1241 -0
  70. package/src/lib/MarkdownDocs/TreeView.svelte +32 -0
  71. package/src/lib/MarkdownDocs/TreeViewItem.svelte +219 -0
  72. package/src/lib/MarkdownDocs/VersionOutdatedNotice.svelte +72 -0
  73. package/src/lib/MarkdownDocs/__tests__/codeDirectives.test.js +54 -0
  74. package/src/lib/MarkdownDocs/__tests__/common.test.js +41 -0
  75. package/src/lib/MarkdownDocs/__tests__/docsExamplesLint.test.js +77 -0
  76. package/src/lib/MarkdownDocs/__tests__/fixtures/docs/markdown/__partial-basic.md +3 -0
  77. package/src/lib/MarkdownDocs/__tests__/fixtures/docs/markdown/snippet.js +9 -0
  78. package/src/lib/MarkdownDocs/__tests__/fixtures/includes/part.md +11 -0
  79. package/src/lib/MarkdownDocs/__tests__/fixtures/includes/wrapper.md +5 -0
  80. package/src/lib/MarkdownDocs/__tests__/fixtures/snippets/sample.js +8 -0
  81. package/src/lib/MarkdownDocs/__tests__/fixtures/snippets/sample.md +5 -0
  82. package/src/lib/MarkdownDocs/__tests__/helpers.js +67 -0
  83. package/src/lib/MarkdownDocs/__tests__/localeUtils.test.js +204 -0
  84. package/src/lib/MarkdownDocs/__tests__/markdown.test.js +704 -0
  85. package/src/lib/MarkdownDocs/__tests__/markdownRendererRuntime.test.js +65 -0
  86. package/src/lib/MarkdownDocs/__tests__/searchIndexBuilder.test.js +117 -0
  87. package/src/lib/MarkdownDocs/__tests__/sqliteStore.test.js +202 -0
  88. package/src/lib/MarkdownDocs/__tests__/useRouter.test.js +16 -0
  89. package/src/lib/MarkdownDocs/ai/adapters/customAdapter.js +14 -0
  90. package/src/lib/MarkdownDocs/ai/adapters/customAdapter.ts +43 -0
  91. package/src/lib/MarkdownDocs/ai/adapters/ollamaAdapter.js +81 -0
  92. package/src/lib/MarkdownDocs/ai/adapters/ollamaAdapter.ts +116 -0
  93. package/src/lib/MarkdownDocs/ai/adapters/openaiAdapter.js +92 -0
  94. package/src/lib/MarkdownDocs/ai/adapters/openaiAdapter.ts +137 -0
  95. package/src/lib/MarkdownDocs/ai/aiProvider.ts +31 -0
  96. package/src/lib/MarkdownDocs/ai/characters.js +52 -0
  97. package/src/lib/MarkdownDocs/ai/characters.ts +69 -0
  98. package/src/lib/MarkdownDocs/ai/chunkStore.ts +25 -0
  99. package/src/lib/MarkdownDocs/ai/chunker.js +85 -0
  100. package/src/lib/MarkdownDocs/ai/chunker.ts +135 -0
  101. package/src/lib/MarkdownDocs/ai/docLinker.js +26 -0
  102. package/src/lib/MarkdownDocs/ai/docLinker.ts +36 -0
  103. package/src/lib/MarkdownDocs/ai/promptBuilder.js +33 -0
  104. package/src/lib/MarkdownDocs/ai/promptBuilder.ts +53 -0
  105. package/src/lib/MarkdownDocs/ai/ragPipeline.js +54 -0
  106. package/src/lib/MarkdownDocs/ai/ragPipeline.ts +106 -0
  107. package/src/lib/MarkdownDocs/ai/stores/memoryStore.js +88 -0
  108. package/src/lib/MarkdownDocs/ai/stores/memoryStore.ts +112 -0
  109. package/src/lib/MarkdownDocs/ai/stores/sqliteStore.ts +372 -0
  110. package/src/lib/MarkdownDocs/ai/types.ts +71 -0
  111. package/src/lib/MarkdownDocs/aiServer.js +288 -0
  112. package/src/lib/MarkdownDocs/codeDirectives.js +191 -0
  113. package/src/lib/MarkdownDocs/codeFenceInfo.js +45 -0
  114. package/src/lib/MarkdownDocs/codeGroup.ts +46 -0
  115. package/src/lib/MarkdownDocs/common.ts +47 -0
  116. package/src/lib/MarkdownDocs/docsUtils.js +281 -0
  117. package/src/lib/MarkdownDocs/index.plugins.js +22 -0
  118. package/src/lib/MarkdownDocs/layouts/LayoutDoc.svelte +8 -0
  119. package/src/lib/MarkdownDocs/layouts/LayoutHome.svelte +58 -0
  120. package/src/lib/MarkdownDocs/layouts/LayoutPage.svelte +9 -0
  121. package/src/lib/MarkdownDocs/loadGregConfig.js +82 -0
  122. package/src/lib/MarkdownDocs/localeUtils.ts +682 -0
  123. package/src/lib/MarkdownDocs/markdownRendererRuntime.ts +314 -0
  124. package/src/lib/MarkdownDocs/mermaidThemes.js +319 -0
  125. package/src/lib/MarkdownDocs/navigationUtils.js +22 -0
  126. package/src/lib/MarkdownDocs/rehypeCodeGroup.js +326 -0
  127. package/src/lib/MarkdownDocs/rehypeCodeTitle.js +96 -0
  128. package/src/lib/MarkdownDocs/rehypeToc.js +170 -0
  129. package/src/lib/MarkdownDocs/remarkCodeMeta.js +22 -0
  130. package/src/lib/MarkdownDocs/remarkContainers.js +329 -0
  131. package/src/lib/MarkdownDocs/remarkCustomAnchors.js +42 -0
  132. package/src/lib/MarkdownDocs/remarkEscapeSvelte.js +33 -0
  133. package/src/lib/MarkdownDocs/remarkGlobalComponents.js +65 -0
  134. package/src/lib/MarkdownDocs/remarkImports.js +461 -0
  135. package/src/lib/MarkdownDocs/remarkImportsBrowser.js +349 -0
  136. package/src/lib/MarkdownDocs/remarkInlineAttrs.js +95 -0
  137. package/src/lib/MarkdownDocs/remarkMathToHtml.js +138 -0
  138. package/src/lib/MarkdownDocs/searchIndexBuilder.js +497 -0
  139. package/src/lib/MarkdownDocs/searchServer.js +263 -0
  140. package/src/lib/MarkdownDocs/treeViewTypes.ts +11 -0
  141. package/src/lib/MarkdownDocs/useRouter.svelte.ts +114 -0
  142. package/src/lib/MarkdownDocs/useSplitter.svelte.ts +33 -0
  143. package/src/lib/MarkdownDocs/versioningDefaults.js +20 -0
  144. package/src/lib/MarkdownDocs/vitePluginAiServer.js +204 -0
  145. package/src/lib/MarkdownDocs/vitePluginCopyDocs.js +153 -0
  146. package/src/lib/MarkdownDocs/vitePluginFrontmatter.js +109 -0
  147. package/src/lib/MarkdownDocs/vitePluginGregConfig.js +108 -0
  148. package/src/lib/MarkdownDocs/vitePluginSearchIndex.js +57 -0
  149. package/src/lib/MarkdownDocs/vitePluginSearchServer.js +190 -0
  150. package/src/lib/components/Badge.svelte +59 -0
  151. package/src/lib/components/Button.svelte +138 -0
  152. package/src/lib/components/CarbonAds.svelte +99 -0
  153. package/src/lib/components/CodeGroup.svelte +102 -0
  154. package/src/lib/components/Feature.svelte +209 -0
  155. package/src/lib/components/Features.svelte +123 -0
  156. package/src/lib/components/Hero.svelte +399 -0
  157. package/src/lib/components/Image.svelte +128 -0
  158. package/src/lib/components/Link.svelte +105 -0
  159. package/src/lib/components/SocialLink.svelte +84 -0
  160. package/src/lib/components/SocialLinks.svelte +33 -0
  161. package/src/lib/components/Steps.svelte +143 -0
  162. package/src/lib/components/TeamMember.svelte +273 -0
  163. package/src/lib/components/TeamMembers.svelte +81 -0
  164. package/src/lib/components/TeamPage.svelte +65 -0
  165. package/src/lib/components/TeamPageSection.svelte +108 -0
  166. package/src/lib/components/TeamPageTitle.svelte +89 -0
  167. package/src/lib/components/index.js +24 -0
  168. package/src/lib/portal/context.js +12 -0
  169. package/src/lib/portal/index.js +3 -0
  170. package/src/lib/portal/portal.svelte +14 -0
  171. package/src/lib/portal/slot.svelte +8 -0
  172. package/src/lib/scss/__code.scss +128 -0
  173. package/src/lib/scss/__containers.scss +99 -0
  174. package/src/lib/scss/__markdown.scss +447 -0
  175. package/src/lib/scss/__scrollbar.scss +60 -0
  176. package/src/lib/scss/__steps.scss +100 -0
  177. package/src/lib/scss/__theme.scss +238 -0
  178. package/src/lib/scss/__toc.scss +55 -0
  179. package/src/lib/scss/__utilities.scss +7 -0
  180. package/src/lib/scss/greg.scss +9 -0
  181. package/src/lib/spinner/spinner.svelte +42 -0
  182. package/svelte.config.js +146 -0
  183. 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>