@hanzo/ui 5.3.25 → 5.3.28

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 (326) hide show
  1. package/content/index.ts +26 -0
  2. package/docs/_registry/index.ts +426 -0
  3. package/docs/_registry/layout/docs-min.tsx +197 -0
  4. package/docs/_registry/layout/page-min.tsx +128 -0
  5. package/docs/components/accordion.tsx +118 -0
  6. package/docs/components/banner.tsx +144 -0
  7. package/docs/components/callout.tsx +112 -0
  8. package/docs/components/card.tsx +52 -0
  9. package/docs/components/codeblock.tsx +258 -0
  10. package/docs/components/dialog/search-algolia.tsx +132 -0
  11. package/docs/components/dialog/search-default.tsx +131 -0
  12. package/docs/components/dialog/search-orama.tsx +143 -0
  13. package/docs/components/dialog/search.tsx +529 -0
  14. package/docs/components/dynamic-codeblock.tsx +129 -0
  15. package/docs/components/files.tsx +81 -0
  16. package/docs/components/github-info.tsx +107 -0
  17. package/docs/components/heading.tsx +33 -0
  18. package/docs/components/image-zoom.css +77 -0
  19. package/docs/components/image-zoom.tsx +58 -0
  20. package/docs/components/index.ts +7 -0
  21. package/docs/components/inline-toc.tsx +48 -0
  22. package/docs/components/sidebar/base.tsx +451 -0
  23. package/docs/components/sidebar/link-item.tsx +65 -0
  24. package/docs/components/sidebar/page-tree.tsx +113 -0
  25. package/docs/components/sidebar/tabs/dropdown.tsx +109 -0
  26. package/docs/components/sidebar/tabs/index.tsx +89 -0
  27. package/docs/components/steps.tsx +9 -0
  28. package/docs/components/tabs.tsx +203 -0
  29. package/docs/components/toc/clerk.tsx +173 -0
  30. package/docs/components/toc/default.tsx +57 -0
  31. package/docs/components/toc/index.tsx +136 -0
  32. package/docs/components/type-table.tsx +174 -0
  33. package/docs/components/ui/accordion.tsx +88 -0
  34. package/docs/components/ui/button.tsx +28 -0
  35. package/docs/components/ui/collapsible.tsx +42 -0
  36. package/docs/components/ui/navigation-menu.tsx +83 -0
  37. package/docs/components/ui/popover.tsx +32 -0
  38. package/docs/components/ui/scroll-area.tsx +59 -0
  39. package/docs/components/ui/tabs.tsx +145 -0
  40. package/docs/contexts/i18n.tsx +56 -0
  41. package/docs/contexts/search.tsx +165 -0
  42. package/docs/contexts/tree.tsx +65 -0
  43. package/docs/css/black.css +39 -0
  44. package/docs/css/catppuccin.css +49 -0
  45. package/docs/css/colors/index.css +51 -0
  46. package/docs/css/dusk.css +47 -0
  47. package/docs/css/layouts/docs.css +1 -0
  48. package/docs/css/layouts/home.css +1 -0
  49. package/docs/css/layouts/notebook.css +1 -0
  50. package/docs/css/neutral.css +7 -0
  51. package/docs/css/ocean.css +48 -0
  52. package/docs/css/preset.css +305 -0
  53. package/docs/css/purple.css +39 -0
  54. package/docs/css/shadcn.css +36 -0
  55. package/docs/css/shiki.css +90 -0
  56. package/docs/css/solar.css +75 -0
  57. package/docs/css/style.css +9 -0
  58. package/docs/css/vitepress.css +77 -0
  59. package/docs/i18n.tsx +30 -0
  60. package/docs/icons.tsx +354 -0
  61. package/docs/layouts/docs/client.tsx +129 -0
  62. package/docs/layouts/docs/index.tsx +321 -0
  63. package/docs/layouts/docs/page/client.tsx +376 -0
  64. package/docs/layouts/docs/page/index.tsx +251 -0
  65. package/docs/layouts/docs/sidebar.tsx +265 -0
  66. package/docs/layouts/home/client.tsx +375 -0
  67. package/docs/layouts/home/index.tsx +51 -0
  68. package/docs/layouts/home/navbar.tsx +55 -0
  69. package/docs/layouts/notebook/client.tsx +281 -0
  70. package/docs/layouts/notebook/index.tsx +461 -0
  71. package/docs/layouts/notebook/page/client.tsx +375 -0
  72. package/docs/layouts/notebook/page/index.tsx +251 -0
  73. package/docs/layouts/notebook/sidebar.tsx +248 -0
  74. package/docs/layouts/shared/index.tsx +89 -0
  75. package/docs/layouts/shared/language-toggle.tsx +66 -0
  76. package/docs/layouts/shared/link-item.tsx +119 -0
  77. package/docs/layouts/shared/search-toggle.tsx +78 -0
  78. package/docs/layouts/shared/theme-toggle.tsx +86 -0
  79. package/docs/mdx.server.tsx +37 -0
  80. package/docs/mdx.tsx +97 -0
  81. package/docs/og.tsx +101 -0
  82. package/docs/page.tsx +85 -0
  83. package/docs/provider/base.tsx +173 -0
  84. package/docs/provider/next.tsx +23 -0
  85. package/docs/provider/react-router.tsx +23 -0
  86. package/docs/provider/tanstack.tsx +23 -0
  87. package/docs/provider/waku.tsx +23 -0
  88. package/docs/source.ts +3 -0
  89. package/docs/theme/typography/LICENSE +21 -0
  90. package/docs/theme/typography/index.ts +201 -0
  91. package/docs/theme/typography/styles.ts +449 -0
  92. package/docs/utils/cn.ts +1 -0
  93. package/docs/utils/is-active.ts +23 -0
  94. package/docs/utils/merge-refs.ts +15 -0
  95. package/docs/utils/use-copy-button.ts +39 -0
  96. package/docs/utils/use-footer-items.ts +27 -0
  97. package/docs/utils/use-is-scroll-top.ts +21 -0
  98. package/package.json +8 -2
  99. package/dist/3d/button.js +0 -298
  100. package/dist/3d/button.mjs +0 -273
  101. package/dist/3d/card.js +0 -234
  102. package/dist/3d/card.mjs +0 -207
  103. package/dist/3d/carousel.js +0 -371
  104. package/dist/3d/carousel.mjs +0 -344
  105. package/dist/3d/grid.js +0 -362
  106. package/dist/3d/grid.mjs +0 -337
  107. package/dist/3d/index.js +0 -1518
  108. package/dist/3d/index.mjs +0 -1472
  109. package/dist/3d/marquee.js +0 -352
  110. package/dist/3d/marquee.mjs +0 -327
  111. package/dist/3d/pin.js +0 -46
  112. package/dist/3d/pin.mjs +0 -24
  113. package/dist/accordion.js +0 -80
  114. package/dist/accordion.mjs +0 -55
  115. package/dist/alert-dialog.js +0 -220
  116. package/dist/alert-dialog.mjs +0 -187
  117. package/dist/alert.js +0 -68
  118. package/dist/alert.mjs +0 -64
  119. package/dist/animation/animated-background.js +0 -424
  120. package/dist/animation/animated-background.mjs +0 -418
  121. package/dist/animation/animated-beam.js +0 -119
  122. package/dist/animation/animated-beam.mjs +0 -97
  123. package/dist/animation/animated-cursor.js +0 -275
  124. package/dist/animation/animated-cursor.mjs +0 -270
  125. package/dist/animation/animated-icon.js +0 -357
  126. package/dist/animation/animated-icon.mjs +0 -351
  127. package/dist/animation/animated-list.js +0 -339
  128. package/dist/animation/animated-list.mjs +0 -333
  129. package/dist/animation/animated-number.js +0 -283
  130. package/dist/animation/animated-number.mjs +0 -277
  131. package/dist/animation/animated-testimonials.js +0 -97
  132. package/dist/animation/animated-testimonials.mjs +0 -75
  133. package/dist/animation/animated-tooltip.js +0 -67
  134. package/dist/animation/animated-tooltip.mjs +0 -45
  135. package/dist/animation/apple-cards-carousel.js +0 -308
  136. package/dist/animation/apple-cards-carousel.mjs +0 -285
  137. package/dist/animation/apple-hello-effect.js +0 -60
  138. package/dist/animation/apple-hello-effect.mjs +0 -38
  139. package/dist/animation/index.js +0 -1952
  140. package/dist/animation/index.mjs +0 -1921
  141. package/dist/avatar.js +0 -71
  142. package/dist/avatar.mjs +0 -47
  143. package/dist/badge.js +0 -66
  144. package/dist/badge.mjs +0 -40
  145. package/dist/blocks/index.js +0 -1665
  146. package/dist/blocks/index.mjs +0 -1626
  147. package/dist/breadcrumb.js +0 -107
  148. package/dist/breadcrumb.mjs +0 -99
  149. package/dist/calendar.js +0 -189
  150. package/dist/calendar.mjs +0 -164
  151. package/dist/carousel.js +0 -278
  152. package/dist/carousel.mjs +0 -249
  153. package/dist/checkbox.js +0 -60
  154. package/dist/checkbox.mjs +0 -35
  155. package/dist/code/block.js +0 -226
  156. package/dist/code/block.mjs +0 -203
  157. package/dist/code/compare.js +0 -446
  158. package/dist/code/compare.mjs +0 -423
  159. package/dist/code/diff.js +0 -430
  160. package/dist/code/diff.mjs +0 -407
  161. package/dist/code/editor.js +0 -243
  162. package/dist/code/editor.mjs +0 -218
  163. package/dist/code/explorer.js +0 -291
  164. package/dist/code/explorer.mjs +0 -268
  165. package/dist/code/index.js +0 -2551
  166. package/dist/code/index.mjs +0 -2510
  167. package/dist/code/preview.js +0 -400
  168. package/dist/code/preview.mjs +0 -377
  169. package/dist/code/snippet.js +0 -274
  170. package/dist/code/snippet.mjs +0 -250
  171. package/dist/code/tabs.js +0 -75
  172. package/dist/code/tabs.mjs +0 -53
  173. package/dist/code/terminal.js +0 -437
  174. package/dist/code/terminal.mjs +0 -414
  175. package/dist/collapsible.js +0 -33
  176. package/dist/collapsible.mjs +0 -9
  177. package/dist/command.js +0 -262
  178. package/dist/command.mjs +0 -232
  179. package/dist/context-menu.js +0 -207
  180. package/dist/context-menu.mjs +0 -171
  181. package/dist/device/index.js +0 -3
  182. package/dist/device/index.mjs +0 -2
  183. package/dist/dialog.js +0 -151
  184. package/dist/dialog.mjs +0 -121
  185. package/dist/dock/basic.js +0 -174
  186. package/dist/dock/basic.mjs +0 -151
  187. package/dist/dock/index.js +0 -628
  188. package/dist/dock/index.mjs +0 -601
  189. package/dist/dock/limelight-nav.js +0 -295
  190. package/dist/dock/limelight-nav.mjs +0 -274
  191. package/dist/dock/macos.js +0 -141
  192. package/dist/dock/macos.mjs +0 -118
  193. package/dist/dock/menu.js +0 -70
  194. package/dist/dock/menu.mjs +0 -48
  195. package/dist/dock/message.js +0 -144
  196. package/dist/dock/message.mjs +0 -122
  197. package/dist/drawer.js +0 -115
  198. package/dist/drawer.mjs +0 -103
  199. package/dist/dropdown-menu.js +0 -202
  200. package/dist/dropdown-menu.mjs +0 -166
  201. package/dist/finance/AdvancedChart.js +0 -48
  202. package/dist/finance/AdvancedChart.mjs +0 -46
  203. package/dist/finance/CompanyProfile.js +0 -48
  204. package/dist/finance/CompanyProfile.mjs +0 -46
  205. package/dist/finance/CryptoScreener.js +0 -45
  206. package/dist/finance/CryptoScreener.mjs +0 -43
  207. package/dist/finance/Financials.js +0 -52
  208. package/dist/finance/Financials.mjs +0 -50
  209. package/dist/finance/ForexScreener.js +0 -46
  210. package/dist/finance/ForexScreener.mjs +0 -44
  211. package/dist/finance/MarketOverview.js +0 -104
  212. package/dist/finance/MarketOverview.mjs +0 -102
  213. package/dist/finance/NewsTimeline.js +0 -44
  214. package/dist/finance/NewsTimeline.mjs +0 -42
  215. package/dist/finance/OrderEntry.js +0 -131
  216. package/dist/finance/OrderEntry.mjs +0 -129
  217. package/dist/finance/OrdersHistory.js +0 -64
  218. package/dist/finance/OrdersHistory.mjs +0 -62
  219. package/dist/finance/PositionsList.js +0 -80
  220. package/dist/finance/PositionsList.mjs +0 -78
  221. package/dist/finance/StockScreener.js +0 -46
  222. package/dist/finance/StockScreener.mjs +0 -44
  223. package/dist/finance/SymbolInfo.js +0 -46
  224. package/dist/finance/SymbolInfo.mjs +0 -44
  225. package/dist/finance/TechnicalAnalysis.js +0 -54
  226. package/dist/finance/TechnicalAnalysis.mjs +0 -52
  227. package/dist/finance/TickerTape.js +0 -56
  228. package/dist/finance/TickerTape.mjs +0 -54
  229. package/dist/finance/TradingPanel.js +0 -191
  230. package/dist/finance/TradingPanel.mjs +0 -189
  231. package/dist/finance/index.js +0 -930
  232. package/dist/finance/index.mjs +0 -914
  233. package/dist/form/index.js +0 -155
  234. package/dist/form/index.mjs +0 -125
  235. package/dist/form.js +0 -172
  236. package/dist/form.mjs +0 -142
  237. package/dist/hover-card.js +0 -58
  238. package/dist/hover-card.mjs +0 -34
  239. package/dist/index.js +0 -10179
  240. package/dist/index.mjs +0 -9785
  241. package/dist/input-otp.js +0 -79
  242. package/dist/input-otp.mjs +0 -54
  243. package/dist/lib/utils.js +0 -28
  244. package/dist/lib/utils.mjs +0 -24
  245. package/dist/navigation/index.js +0 -98
  246. package/dist/navigation/index.mjs +0 -79
  247. package/dist/navigation-menu.js +0 -149
  248. package/dist/navigation-menu.mjs +0 -116
  249. package/dist/pattern/grid-pattern.js +0 -333
  250. package/dist/pattern/grid-pattern.mjs +0 -310
  251. package/dist/pattern/index.js +0 -333
  252. package/dist/pattern/index.mjs +0 -310
  253. package/dist/popover.js +0 -63
  254. package/dist/popover.mjs +0 -37
  255. package/dist/primitives/index.js +0 -10179
  256. package/dist/primitives/index.mjs +0 -9785
  257. package/dist/primitives-export.js +0 -10179
  258. package/dist/primitives-export.mjs +0 -9785
  259. package/dist/progress.js +0 -62
  260. package/dist/progress.mjs +0 -37
  261. package/dist/project/gantt.js +0 -65
  262. package/dist/project/gantt.mjs +0 -43
  263. package/dist/project/index.js +0 -636
  264. package/dist/project/index.mjs +0 -611
  265. package/dist/project/kanban.js +0 -597
  266. package/dist/project/kanban.mjs +0 -572
  267. package/dist/project/list.js +0 -35
  268. package/dist/project/list.mjs +0 -12
  269. package/dist/radio-group.js +0 -68
  270. package/dist/radio-group.mjs +0 -45
  271. package/dist/resizable.js +0 -72
  272. package/dist/resizable.mjs +0 -48
  273. package/dist/scroll-area.js +0 -89
  274. package/dist/scroll-area.mjs +0 -66
  275. package/dist/select.js +0 -140
  276. package/dist/select.mjs +0 -111
  277. package/dist/separator.js +0 -59
  278. package/dist/separator.mjs +0 -34
  279. package/dist/sheet.js +0 -148
  280. package/dist/sheet.mjs +0 -117
  281. package/dist/skeleton.js +0 -32
  282. package/dist/skeleton.mjs +0 -27
  283. package/dist/slider.js +0 -99
  284. package/dist/slider.mjs +0 -73
  285. package/dist/sonner.js +0 -34
  286. package/dist/sonner.mjs +0 -29
  287. package/dist/switch.js +0 -62
  288. package/dist/switch.mjs +0 -37
  289. package/dist/table.js +0 -110
  290. package/dist/table.mjs +0 -101
  291. package/dist/tabs.js +0 -82
  292. package/dist/tabs.mjs +0 -57
  293. package/dist/tailwind/index.js +0 -2023
  294. package/dist/tailwind/index.mjs +0 -2011
  295. package/dist/textarea.js +0 -78
  296. package/dist/textarea.mjs +0 -56
  297. package/dist/toggle-group.js +0 -118
  298. package/dist/toggle-group.mjs +0 -93
  299. package/dist/toggle.js +0 -71
  300. package/dist/toggle.mjs +0 -48
  301. package/dist/tooltip.js +0 -67
  302. package/dist/tooltip.mjs +0 -40
  303. package/dist/types/index.js +0 -57
  304. package/dist/types/index.mjs +0 -51
  305. package/dist/ui/announcement.js +0 -129
  306. package/dist/ui/announcement.mjs +0 -107
  307. package/dist/ui/avatar-group.js +0 -88
  308. package/dist/ui/avatar-group.mjs +0 -65
  309. package/dist/ui/banner.js +0 -85
  310. package/dist/ui/banner.mjs +0 -62
  311. package/dist/ui/cursor.js +0 -78
  312. package/dist/ui/cursor.mjs +0 -56
  313. package/dist/ui/index.js +0 -475
  314. package/dist/ui/index.mjs +0 -442
  315. package/dist/ui/marquee.js +0 -74
  316. package/dist/ui/marquee.mjs +0 -52
  317. package/dist/ui/pill.js +0 -85
  318. package/dist/ui/pill.mjs +0 -62
  319. package/dist/ui/spinner.js +0 -28
  320. package/dist/ui/spinner.mjs +0 -26
  321. package/dist/ui/tags.js +0 -101
  322. package/dist/ui/tags.mjs +0 -79
  323. package/dist/ui/ticker.js +0 -73
  324. package/dist/ui/ticker.mjs +0 -51
  325. package/dist/util/index.js +0 -457
  326. package/dist/util/index.mjs +0 -399
@@ -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
+ }