@hanzo/ui 5.3.26 → 5.3.29

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 (100) hide show
  1. package/content/index.ts +26 -0
  2. package/dist/util/index.js +6 -0
  3. package/dist/util/index.mjs +6 -1
  4. package/docs/_registry/index.ts +426 -0
  5. package/docs/_registry/layout/docs-min.tsx +197 -0
  6. package/docs/_registry/layout/page-min.tsx +128 -0
  7. package/docs/components/accordion.tsx +118 -0
  8. package/docs/components/banner.tsx +144 -0
  9. package/docs/components/callout.tsx +112 -0
  10. package/docs/components/card.tsx +52 -0
  11. package/docs/components/codeblock.tsx +258 -0
  12. package/docs/components/dialog/search-algolia.tsx +132 -0
  13. package/docs/components/dialog/search-default.tsx +131 -0
  14. package/docs/components/dialog/search-orama.tsx +143 -0
  15. package/docs/components/dialog/search.tsx +529 -0
  16. package/docs/components/dynamic-codeblock.tsx +129 -0
  17. package/docs/components/files.tsx +81 -0
  18. package/docs/components/github-info.tsx +107 -0
  19. package/docs/components/heading.tsx +33 -0
  20. package/docs/components/image-zoom.css +77 -0
  21. package/docs/components/image-zoom.tsx +58 -0
  22. package/docs/components/index.ts +7 -0
  23. package/docs/components/inline-toc.tsx +48 -0
  24. package/docs/components/sidebar/base.tsx +451 -0
  25. package/docs/components/sidebar/link-item.tsx +65 -0
  26. package/docs/components/sidebar/page-tree.tsx +113 -0
  27. package/docs/components/sidebar/tabs/dropdown.tsx +109 -0
  28. package/docs/components/sidebar/tabs/index.tsx +89 -0
  29. package/docs/components/steps.tsx +9 -0
  30. package/docs/components/tabs.tsx +203 -0
  31. package/docs/components/toc/clerk.tsx +173 -0
  32. package/docs/components/toc/default.tsx +57 -0
  33. package/docs/components/toc/index.tsx +136 -0
  34. package/docs/components/type-table.tsx +174 -0
  35. package/docs/components/ui/accordion.tsx +88 -0
  36. package/docs/components/ui/button.tsx +28 -0
  37. package/docs/components/ui/collapsible.tsx +42 -0
  38. package/docs/components/ui/navigation-menu.tsx +83 -0
  39. package/docs/components/ui/popover.tsx +32 -0
  40. package/docs/components/ui/scroll-area.tsx +59 -0
  41. package/docs/components/ui/tabs.tsx +145 -0
  42. package/docs/contexts/i18n.tsx +56 -0
  43. package/docs/contexts/search.tsx +165 -0
  44. package/docs/contexts/tree.tsx +65 -0
  45. package/docs/css/black.css +39 -0
  46. package/docs/css/catppuccin.css +49 -0
  47. package/docs/css/colors/index.css +51 -0
  48. package/docs/css/dusk.css +47 -0
  49. package/docs/css/layouts/docs.css +1 -0
  50. package/docs/css/layouts/home.css +1 -0
  51. package/docs/css/layouts/notebook.css +1 -0
  52. package/docs/css/neutral.css +7 -0
  53. package/docs/css/ocean.css +48 -0
  54. package/docs/css/preset.css +305 -0
  55. package/docs/css/purple.css +39 -0
  56. package/docs/css/shadcn.css +36 -0
  57. package/docs/css/shiki.css +90 -0
  58. package/docs/css/solar.css +75 -0
  59. package/docs/css/style.css +9 -0
  60. package/docs/css/vitepress.css +77 -0
  61. package/docs/i18n.tsx +30 -0
  62. package/docs/icons.tsx +354 -0
  63. package/docs/layouts/docs/client.tsx +129 -0
  64. package/docs/layouts/docs/index.tsx +321 -0
  65. package/docs/layouts/docs/page/client.tsx +376 -0
  66. package/docs/layouts/docs/page/index.tsx +251 -0
  67. package/docs/layouts/docs/sidebar.tsx +265 -0
  68. package/docs/layouts/home/client.tsx +375 -0
  69. package/docs/layouts/home/index.tsx +51 -0
  70. package/docs/layouts/home/navbar.tsx +55 -0
  71. package/docs/layouts/notebook/client.tsx +281 -0
  72. package/docs/layouts/notebook/index.tsx +461 -0
  73. package/docs/layouts/notebook/page/client.tsx +375 -0
  74. package/docs/layouts/notebook/page/index.tsx +251 -0
  75. package/docs/layouts/notebook/sidebar.tsx +248 -0
  76. package/docs/layouts/shared/index.tsx +89 -0
  77. package/docs/layouts/shared/language-toggle.tsx +66 -0
  78. package/docs/layouts/shared/link-item.tsx +119 -0
  79. package/docs/layouts/shared/search-toggle.tsx +78 -0
  80. package/docs/layouts/shared/theme-toggle.tsx +86 -0
  81. package/docs/mdx.server.tsx +37 -0
  82. package/docs/mdx.tsx +97 -0
  83. package/docs/og.tsx +101 -0
  84. package/docs/page.tsx +85 -0
  85. package/docs/provider/base.tsx +173 -0
  86. package/docs/provider/next.tsx +23 -0
  87. package/docs/provider/react-router.tsx +23 -0
  88. package/docs/provider/tanstack.tsx +23 -0
  89. package/docs/provider/waku.tsx +23 -0
  90. package/docs/source.ts +3 -0
  91. package/docs/theme/typography/LICENSE +21 -0
  92. package/docs/theme/typography/index.ts +201 -0
  93. package/docs/theme/typography/styles.ts +449 -0
  94. package/docs/utils/cn.ts +1 -0
  95. package/docs/utils/is-active.ts +23 -0
  96. package/docs/utils/merge-refs.ts +15 -0
  97. package/docs/utils/use-copy-button.ts +39 -0
  98. package/docs/utils/use-footer-items.ts +27 -0
  99. package/docs/utils/use-is-scroll-top.ts +21 -0
  100. package/package.json +4 -2
@@ -0,0 +1,305 @@
1
+ @import './shiki.css';
2
+
3
+ /* TODO: remove them on next major */
4
+ @import './layouts/docs.css';
5
+ @import './layouts/home.css';
6
+ @import './layouts/notebook.css';
7
+
8
+ @source '../dist/*.js';
9
+ @source '../dist/{components,contexts,provider,utils}/**/*.js';
10
+ @source '../dist/layouts/shared/**/*.js';
11
+
12
+ @plugin '../dist/theme/typography/index.js';
13
+
14
+ :root {
15
+ --fd-sidebar-drawer-offset: 100%;
16
+ }
17
+
18
+ [dir='rtl'] {
19
+ --fd-sidebar-drawer-offset: -100%;
20
+ }
21
+
22
+ @theme {
23
+ --animate-fd-fade-in: fd-fade-in 300ms ease;
24
+ --animate-fd-fade-out: fd-fade-out 300ms ease;
25
+
26
+ --animate-fd-dialog-in: fd-dialog-in 300ms cubic-bezier(0.16, 1, 0.3, 1);
27
+ --animate-fd-dialog-out: fd-dialog-out 300ms cubic-bezier(0.16, 1, 0.3, 1);
28
+
29
+ --animate-fd-popover-in: fd-popover-in 100ms ease;
30
+ --animate-fd-popover-out: fd-popover-out 100ms ease;
31
+
32
+ --animate-fd-collapsible-down: fd-collapsible-down 150ms
33
+ cubic-bezier(0.45, 0, 0.55, 1);
34
+ --animate-fd-collapsible-up: fd-collapsible-up 150ms
35
+ cubic-bezier(0.45, 0, 0.55, 1);
36
+
37
+ --animate-fd-accordion-down: fd-accordion-down 200ms ease-out;
38
+ --animate-fd-accordion-up: fd-accordion-up 200ms ease-out;
39
+
40
+ --animate-fd-nav-menu-in: fd-nav-menu-in 200ms ease;
41
+ --animate-fd-nav-menu-out: fd-nav-menu-out 200ms ease;
42
+
43
+ --animate-fd-enterFromLeft: fd-enterFromLeft 250ms ease;
44
+ --animate-fd-enterFromRight: fd-enterFromRight 250ms ease;
45
+
46
+ --animate-fd-sidebar-in: fd-sidebar-in 250ms ease;
47
+ --animate-fd-sidebar-out: fd-sidebar-out 250ms ease;
48
+
49
+ --animate-fd-exitToLeft: fd-exitToLeft 250ms ease;
50
+ --animate-fd-exitToRight: fd-exitToRight 250ms ease;
51
+
52
+ @keyframes fd-sidebar-in {
53
+ from {
54
+ transform: translateX(var(--fd-sidebar-drawer-offset));
55
+ }
56
+ }
57
+
58
+ @keyframes fd-sidebar-out {
59
+ to {
60
+ transform: translateX(var(--fd-sidebar-drawer-offset));
61
+ }
62
+ }
63
+
64
+ @keyframes fd-collapsible-down {
65
+ from {
66
+ height: 0;
67
+ opacity: 0;
68
+ }
69
+ to {
70
+ height: var(--radix-collapsible-content-height);
71
+ }
72
+ }
73
+
74
+ @keyframes fd-collapsible-up {
75
+ from {
76
+ height: var(--radix-collapsible-content-height);
77
+ }
78
+ to {
79
+ height: 0;
80
+ opacity: 0;
81
+ }
82
+ }
83
+
84
+ @keyframes fd-accordion-down {
85
+ from {
86
+ height: 0;
87
+ opacity: 0.5;
88
+ }
89
+ to {
90
+ height: var(--radix-accordion-content-height);
91
+ }
92
+ }
93
+
94
+ @keyframes fd-accordion-up {
95
+ from {
96
+ height: var(--radix-accordion-content-height);
97
+ }
98
+ to {
99
+ height: 0;
100
+ opacity: 0.5;
101
+ }
102
+ }
103
+
104
+ @keyframes fd-dialog-in {
105
+ from {
106
+ transform: scale(1.06);
107
+ opacity: 0;
108
+ }
109
+ to {
110
+ transform: scale(1);
111
+ }
112
+ }
113
+
114
+ @keyframes fd-dialog-out {
115
+ from {
116
+ transform: scale(1);
117
+ }
118
+ to {
119
+ transform: scale(1.04);
120
+ opacity: 0;
121
+ }
122
+ }
123
+
124
+ @keyframes fd-popover-in {
125
+ from {
126
+ opacity: 0;
127
+ transform: scale(0.9);
128
+ }
129
+ }
130
+
131
+ @keyframes fd-popover-out {
132
+ to {
133
+ opacity: 0;
134
+ transform: scale(0.9);
135
+ }
136
+ }
137
+
138
+ @keyframes fd-fade-in {
139
+ from {
140
+ opacity: 0;
141
+ }
142
+ to {
143
+ opacity: 1;
144
+ }
145
+ }
146
+
147
+ @keyframes fd-fade-out {
148
+ from {
149
+ opacity: 1;
150
+ }
151
+ to {
152
+ opacity: 0;
153
+ }
154
+ }
155
+
156
+ @keyframes fd-enterFromRight {
157
+ from {
158
+ opacity: 0;
159
+ transform: translateX(200px);
160
+ }
161
+ to {
162
+ opacity: 1;
163
+ transform: translateX(0);
164
+ }
165
+ }
166
+
167
+ @keyframes fd-enterFromLeft {
168
+ from {
169
+ opacity: 0;
170
+ transform: translateX(-200px);
171
+ }
172
+ to {
173
+ opacity: 1;
174
+ transform: translateX(0);
175
+ }
176
+ }
177
+
178
+ @keyframes fd-exitToRight {
179
+ from {
180
+ opacity: 1;
181
+ transform: translateX(0);
182
+ }
183
+ to {
184
+ opacity: 0;
185
+ transform: translateX(200px);
186
+ }
187
+ }
188
+
189
+ @keyframes fd-exitToLeft {
190
+ from {
191
+ opacity: 1;
192
+ transform: translateX(0);
193
+ }
194
+ to {
195
+ opacity: 0;
196
+ transform: translateX(-200px);
197
+ }
198
+ }
199
+
200
+ @keyframes fd-nav-menu-in {
201
+ from {
202
+ opacity: 0;
203
+ height: 0px;
204
+ }
205
+ to {
206
+ opacity: 1;
207
+ height: var(--radix-navigation-menu-viewport-height);
208
+ }
209
+ }
210
+
211
+ @keyframes fd-nav-menu-out {
212
+ from {
213
+ opacity: 1;
214
+ height: var(--radix-navigation-menu-viewport-height);
215
+ }
216
+ to {
217
+ opacity: 0;
218
+ height: 0px;
219
+ }
220
+ }
221
+ }
222
+
223
+ @layer base {
224
+ *,
225
+ ::after,
226
+ ::before,
227
+ ::backdrop,
228
+ ::file-selector-button {
229
+ border-color: var(--color-fd-border, currentColor);
230
+ }
231
+
232
+ body {
233
+ background-color: var(--color-fd-background);
234
+ color: var(--color-fd-foreground);
235
+ }
236
+ }
237
+
238
+ @utility fd-scroll-container {
239
+ &::-webkit-scrollbar {
240
+ width: 5px;
241
+ height: 5px;
242
+ }
243
+
244
+ &::-webkit-scrollbar-thumb {
245
+ border-radius: 5px;
246
+ background: var(--color-fd-border);
247
+ }
248
+
249
+ &::-webkit-scrollbar-track {
250
+ background: transparent;
251
+ }
252
+
253
+ &::-webkit-scrollbar-corner {
254
+ display: none;
255
+ }
256
+ }
257
+
258
+ @utility fd-steps {
259
+ counter-reset: step;
260
+ position: relative;
261
+ @apply pl-6 ml-2 border-l sm:ml-4 sm:pl-7;
262
+ }
263
+
264
+ @utility fd-step {
265
+ &:before {
266
+ background-color: var(--color-fd-secondary);
267
+ color: var(--color-fd-secondary-foreground);
268
+ content: counter(step);
269
+ counter-increment: step;
270
+ justify-content: center;
271
+ align-items: center;
272
+ font-size: 0.875rem;
273
+ line-height: 1.25rem;
274
+ display: flex;
275
+ position: absolute;
276
+ @apply size-8 -start-4 rounded-full;
277
+ }
278
+ }
279
+
280
+ @utility prose-no-margin {
281
+ & > :first-child {
282
+ margin-top: 0;
283
+ }
284
+
285
+ & > :last-child {
286
+ margin-bottom: 0;
287
+ }
288
+ }
289
+
290
+ @property --radix-collapsible-content-height {
291
+ syntax: '<length>';
292
+ inherits: false;
293
+ initial-value: 0px;
294
+ }
295
+
296
+ @variant dark (&:where(.dark, .dark *));
297
+
298
+ /* define/override layout variables */
299
+ @variant layout {
300
+ #nd-docs-layout:has(&),
301
+ #nd-notebook-layout:has(&),
302
+ #nd-home-layout:has(&) {
303
+ @slot;
304
+ }
305
+ }
@@ -0,0 +1,39 @@
1
+ @import './colors/index.css';
2
+
3
+ @theme {
4
+ --color-fd-background: hsl(256, 100%, 96%);
5
+ --color-fd-primary: hsl(270, 100%, 52%);
6
+ --color-fd-border: hsla(270, 40%, 80%, 0.5);
7
+ --color-fd-accent: hsl(270, 40%, 88%);
8
+ --color-fd-accent-foreground: hsl(270, 100%, 20%);
9
+ --color-fd-muted: hsl(256, 60%, 94%);
10
+ --color-fd-muted-foreground: hsl(256, 50%, 50%);
11
+ --color-fd-foreground: hsl(256, 60%, 26%);
12
+ --color-fd-secondary: hsl(270, 60%, 90%);
13
+ --color-fd-secondary-foreground: hsl(256, 60%, 10%);
14
+ --color-fd-card: hsl(256, 60%, 92%);
15
+ --color-fd-card-foreground: hsl(256, 100%, 20%);
16
+ --color-fd-popover-foreground: hsl(256, 100%, 20%);
17
+ --color-fd-popover: hsl(256, 60%, 96%);
18
+ --color-fd-primary-foreground: hsl(270, 100%, 20%);
19
+ --color-fd-ring: hsl(270, 100%, 52%);
20
+ }
21
+
22
+ .dark {
23
+ --color-fd-background: hsl(256, 20%, 6%);
24
+ --color-fd-primary: hsl(270, 100%, 86%);
25
+ --color-fd-border: hsla(270, 50%, 40%, 0.3);
26
+ --color-fd-accent: hsl(256, 23%, 22%);
27
+ --color-fd-accent-foreground: hsl(270, 40%, 86%);
28
+ --color-fd-muted: hsl(256, 23%, 10%);
29
+ --color-fd-foreground: hsl(256, 60%, 90%);
30
+ --color-fd-muted-foreground: hsl(256, 50%, 75%);
31
+ --color-fd-secondary: hsl(270, 23%, 20%);
32
+ --color-fd-secondary-foreground: hsl(256, 60%, 90%);
33
+ --color-fd-card: hsl(256, 23%, 10%);
34
+ --color-fd-card-foreground: hsl(256, 60%, 90%);
35
+ --color-fd-popover-foreground: hsl(256, 60%, 90%);
36
+ --color-fd-popover: hsl(256, 23%, 6%);
37
+ --color-fd-primary-foreground: hsl(256, 60%, 6%);
38
+ --color-fd-ring: hsl(270, 100%, 86%);
39
+ }
@@ -0,0 +1,36 @@
1
+ @import './colors/index.css';
2
+
3
+ :root,
4
+ .dark {
5
+ --color-fd-background: var(--background);
6
+ --color-fd-foreground: var(--foreground);
7
+ --color-fd-muted: var(--muted);
8
+ --color-fd-muted-foreground: var(--muted-foreground);
9
+ --color-fd-popover: var(--popover);
10
+ --color-fd-popover-foreground: var(--popover-foreground);
11
+ --color-fd-card: var(--card);
12
+ --color-fd-card-foreground: var(--card-foreground);
13
+ --color-fd-border: var(--border);
14
+ --color-fd-primary: var(--primary);
15
+ --color-fd-primary-foreground: var(--primary-foreground);
16
+ --color-fd-secondary: var(--secondary);
17
+ --color-fd-secondary-foreground: var(--secondary-foreground);
18
+ --color-fd-accent: var(--accent);
19
+ --color-fd-accent-foreground: var(--accent-foreground);
20
+ --color-fd-ring: var(--ring);
21
+ }
22
+
23
+ #nd-sidebar {
24
+ background-color: var(--sidebar);
25
+ color: var(--sidebar-foreground);
26
+ border-color: var(--sidebar-border);
27
+
28
+ --color-fd-accent: var(--sidebar-accent);
29
+ --color-fd-accent-foreground: var(--sidebar-accent-foreground);
30
+ --color-fd-ring: var(--sidebar-ring);
31
+ --color-fd-primary-foreground: var(--sidebar-primary-foreground);
32
+ }
33
+
34
+ @theme static {
35
+ --color-fd-error: var(--destructive);
36
+ }
@@ -0,0 +1,90 @@
1
+ .shiki:not(.not-fumadocs-codeblock *) {
2
+ --padding-left: calc(var(--spacing) * 4);
3
+ --padding-right: calc(var(--spacing) * 4);
4
+
5
+ code span {
6
+ color: var(--shiki-light);
7
+ }
8
+ }
9
+
10
+ .dark .shiki:not(.not-fumadocs-codeblock *) {
11
+ code span {
12
+ color: var(--shiki-dark);
13
+ }
14
+ }
15
+
16
+ :is(pre *):is(.shiki *):not(.not-fumadocs-codeblock *) {
17
+ .line& {
18
+ position: relative;
19
+ min-height: 1lh;
20
+ padding-left: var(--padding-left);
21
+ padding-right: var(--padding-right);
22
+ }
23
+
24
+ .has-focused .line&:not(.focused) {
25
+ filter: blur(2px);
26
+ transition: filter 200ms;
27
+ }
28
+
29
+ .has-focused:hover .line&:not(.focused) {
30
+ filter: blur(0);
31
+ }
32
+
33
+ [data-line-numbers] .twoslash-meta-line& {
34
+ padding-left: calc(var(--padding-left) + 7 * var(--spacing));
35
+ }
36
+
37
+ [data-line-numbers] .line& {
38
+ counter-increment: line;
39
+ padding-left: calc(var(--padding-left) + 7 * var(--spacing));
40
+ }
41
+
42
+ [data-line-numbers] .line&::after {
43
+ position: absolute;
44
+ content: counter(line);
45
+ color: color-mix(
46
+ in oklab,
47
+ var(--fd-counter-color, var(--color-fd-muted-foreground)) 60%,
48
+ transparent
49
+ );
50
+ @apply top-0 left-4;
51
+ }
52
+
53
+ .diff&::before {
54
+ position: absolute;
55
+ left: calc(var(--spacing) * 1.5);
56
+ }
57
+
58
+ .diff.remove& {
59
+ opacity: 0.7;
60
+ --fd-counter-color: var(--color-fd-diff-remove-symbol);
61
+ @apply bg-fd-diff-remove;
62
+ }
63
+
64
+ .diff.remove&::before {
65
+ content: '-';
66
+ @apply text-fd-diff-remove-symbol;
67
+ }
68
+
69
+ .diff.add& {
70
+ --fd-counter-color: var(--color-fd-diff-add-symbol);
71
+ @apply bg-fd-diff-add;
72
+ }
73
+
74
+ .diff.add&::before {
75
+ content: '+';
76
+ @apply text-fd-diff-add-symbol;
77
+ }
78
+
79
+ .highlighted& {
80
+ --fd-counter-color: var(--color-fd-primary);
81
+ padding-left: calc(var(--padding-left) - 2px);
82
+
83
+ @apply border-l-2 border-fd-primary/50 bg-fd-primary/10;
84
+ }
85
+
86
+ .highlighted-word& {
87
+ padding: 1px;
88
+ @apply border -my-px border-fd-primary/30 bg-fd-primary/10 rounded-md font-medium;
89
+ }
90
+ }
@@ -0,0 +1,75 @@
1
+ @import './colors/index.css';
2
+
3
+ @theme {
4
+ --color-fd-primary: oklch(0.487 0.083 262.691);
5
+ --color-fd-article: hsl(0, 0%, 97%);
6
+ }
7
+
8
+ :root {
9
+ letter-spacing: -0.25px;
10
+ }
11
+
12
+ .dark {
13
+ --color-fd-primary: oklch(0.902 0.0461 259.51);
14
+ --color-fd-article: hsl(0, 0%, 7.04%);
15
+ --color-fd-background: hsl(0, 0%, 5.04%);
16
+ }
17
+
18
+ @variant md {
19
+ #nd-docs-layout {
20
+ #nd-page {
21
+ @apply relative md:px-9 xl:px-12;
22
+ }
23
+
24
+ #nd-page:before {
25
+ content: '';
26
+ @apply absolute inset-0 bg-fd-article rounded-xl border shadow-xl m-4 mb-2 -z-1;
27
+ }
28
+
29
+ [data-toc-popover-trigger],
30
+ [data-toc-popover-content] {
31
+ @apply px-4;
32
+ }
33
+
34
+ [data-toc-popover] {
35
+ top: calc(var(--fd-docs-row-1) + 2.5 * var(--spacing));
36
+ @apply mx-4 mt-2.5;
37
+
38
+ header {
39
+ transform-origin: top center;
40
+ @apply border rounded-xl shadow-lg transition-[margin] has-data-[active=true]:-mx-2 has-data-[active=true]:bg-fd-popover/80;
41
+ }
42
+ }
43
+ }
44
+
45
+ #nd-notebook-layout {
46
+ #nd-page {
47
+ @apply relative md:px-9 xl:px-12;
48
+ }
49
+
50
+ #nd-page:before {
51
+ content: '';
52
+ @apply absolute inset-0 bg-fd-article rounded-xl border shadow-xl m-4 mb-2 -z-1;
53
+ }
54
+
55
+ [data-toc-popover-trigger],
56
+ [data-toc-popover-content] {
57
+ @apply px-4;
58
+ }
59
+
60
+ [data-toc-popover] {
61
+ top: calc(var(--fd-docs-row-2) + 2.5 * var(--spacing));
62
+ @apply mx-4 mt-2.5;
63
+
64
+ header {
65
+ transform-origin: top center;
66
+ @apply border rounded-xl shadow-lg transition-[margin] has-data-[active=true]:-mx-2 has-data-[active=true]:bg-fd-popover/80;
67
+ }
68
+ }
69
+ }
70
+ }
71
+
72
+ #nd-sidebar[data-collapsed='false'] {
73
+ border: none;
74
+ @apply bg-fd-background;
75
+ }
@@ -0,0 +1,9 @@
1
+ @import 'tailwindcss';
2
+ @import './neutral.css';
3
+ @import './preset.css';
4
+
5
+ @layer base {
6
+ body {
7
+ @apply flex flex-col min-h-screen;
8
+ }
9
+ }
@@ -0,0 +1,77 @@
1
+ @import './colors/index.css';
2
+
3
+ @theme {
4
+ --color-fd-muted: hsl(0, 0%, 96.1%);
5
+ --color-fd-popover: hsl(0, 0%, 100%);
6
+ --color-fd-popover-foreground: hsl(0, 0%, 15.1%);
7
+ --color-fd-card-foreground: hsl(0, 0%, 3.9%);
8
+ --color-fd-border: hsl(0, 0%, 89.8%);
9
+ --color-fd-primary-foreground: hsl(0, 0%, 98%);
10
+ --color-fd-secondary-foreground: hsl(0, 0%, 9%);
11
+ --color-fd-accent: hsl(0, 0%, 94.1%);
12
+ --color-fd-ring: hsl(0, 0%, 63.9%);
13
+
14
+ --color-fd-background: hsl(0, 0%, 100%);
15
+ --color-fd-card: hsl(0, 0%, 100%);
16
+ --color-fd-foreground: hsl(240, 6%, 25%);
17
+ --color-fd-muted-foreground: hsl(240, 6%, 50%);
18
+ --color-fd-secondary: hsl(240, 6%, 97%);
19
+ --color-fd-accent-foreground: hsl(240, 6%, 25%);
20
+ --color-fd-primary: hsl(226, 55%, 45%);
21
+ }
22
+
23
+ .dark {
24
+ --color-fd-ring: hsl(234, 100%, 83%);
25
+ --color-fd-primary: hsl(234, 100%, 83%);
26
+ --color-fd-secondary-foreground: hsl(60, 100%, 98%);
27
+ --color-fd-card-foreground: hsl(60, 100%, 98%);
28
+ --color-fd-background: hsl(240, 7%, 11%);
29
+ --color-fd-foreground: hsl(60, 100%, 98%);
30
+ --color-fd-popover: hsl(240, 7%, 11%);
31
+ --color-fd-popover-foreground: hsl(60, 100%, 98%);
32
+ --color-fd-primary-foreground: hsl(240, 7%, 11%);
33
+ --color-fd-card: hsl(240, 7%, 11%);
34
+ --color-fd-muted: hsl(0, 0%, 13%);
35
+ --color-fd-border: hsl(240, 4%, 19%);
36
+ --color-fd-accent: hsl(0, 0%, 15%);
37
+ --color-fd-secondary: hsl(240, 4%, 9%);
38
+ --color-fd-accent-foreground: hsl(0, 0%, 100%);
39
+ --color-fd-muted-foreground: hsl(240, 4%, 65%);
40
+ }
41
+
42
+ .prose {
43
+ --tw-prose-body: color-mix(
44
+ in oklab,
45
+ var(--color-fd-foreground) 85%,
46
+ transparent
47
+ );
48
+ --tw-prose-headings: color-mix(
49
+ in oklab,
50
+ var(--color-fd-foreground) 85%,
51
+ transparent
52
+ );
53
+ --tw-prose-links: var(--color-fd-primary);
54
+ --tw-prose-code: var(--color-fd-primary);
55
+ }
56
+
57
+ .prose :where(code):not(:where([class~='not-prose'], [class~='not-prose'] *)) {
58
+ border: none;
59
+ background-color: color-mix(
60
+ in oklab,
61
+ var(--color-fd-primary) 10%,
62
+ transparent
63
+ );
64
+ }
65
+
66
+ #nd-sidebar {
67
+ background-color: hsl(240, 6%, 97%);
68
+ border-color: transparent;
69
+ }
70
+
71
+ .dark #nd-sidebar {
72
+ background-color: hsl(240, 4%, 9%);
73
+ }
74
+
75
+ button[data-search-full] {
76
+ background-color: var(--color-fd-background);
77
+ }
package/docs/i18n.tsx ADDED
@@ -0,0 +1,30 @@
1
+ import type { Translations } from '@/contexts/i18n';
2
+ import type { I18nProviderProps } from './provider/base';
3
+ import type { I18nConfig } from '@hanzo/docs-core/i18n';
4
+
5
+ export type { I18nProviderProps, Translations };
6
+ export { defaultTranslations } from './contexts/i18n';
7
+
8
+ export function defineI18nUI<Languages extends string>(
9
+ config: I18nConfig<Languages>,
10
+ options: {
11
+ translations: {
12
+ [K in Languages]?: Partial<Translations> & { displayName?: string };
13
+ };
14
+ },
15
+ ) {
16
+ const { translations } = options;
17
+
18
+ return {
19
+ provider(locale: string = config.defaultLanguage): I18nProviderProps {
20
+ return {
21
+ locale,
22
+ translations: translations[locale as Languages],
23
+ locales: config.languages.map((locale) => ({
24
+ locale,
25
+ name: translations[locale]?.displayName ?? locale,
26
+ })),
27
+ };
28
+ },
29
+ };
30
+ }