zudoku 0.0.0-fcb84d6 → 0.0.0-ff3751f

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 (455) hide show
  1. package/README.md +121 -0
  2. package/cli.js +2 -2
  3. package/dist/app/entry.client.js +2 -2
  4. package/dist/app/entry.client.js.map +1 -1
  5. package/dist/app/entry.server.js +3 -0
  6. package/dist/app/entry.server.js.map +1 -1
  7. package/dist/app/main.d.ts +1 -0
  8. package/dist/app/main.js +9 -26
  9. package/dist/app/main.js.map +1 -1
  10. package/dist/app/standalone.js.map +1 -1
  11. package/dist/cli/cli.js +1 -2
  12. package/dist/cli/cli.js.map +1 -1
  13. package/dist/cli/common/machine-id/lib.js.map +1 -1
  14. package/dist/cli/common/outdated.js.map +1 -1
  15. package/dist/cli/common/utils/box.js.map +1 -1
  16. package/dist/config/validators/InputSidebarSchema.d.ts +2 -2
  17. package/dist/config/validators/SidebarSchema.d.ts +24 -1
  18. package/dist/config/validators/SidebarSchema.js +76 -39
  19. package/dist/config/validators/SidebarSchema.js.map +1 -1
  20. package/dist/config/validators/validate.d.ts +406 -260
  21. package/dist/config/validators/validate.js +23 -7
  22. package/dist/config/validators/validate.js.map +1 -1
  23. package/dist/index.d.ts +4 -1
  24. package/dist/index.js +1 -1
  25. package/dist/index.js.map +1 -1
  26. package/dist/lib/authentication/components/CallbackHandler.js +21 -31
  27. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  28. package/dist/lib/authentication/hook.d.ts +1 -1
  29. package/dist/lib/authentication/hook.js +1 -1
  30. package/dist/lib/authentication/hook.js.map +1 -1
  31. package/dist/lib/components/Header.js +6 -1
  32. package/dist/lib/components/Header.js.map +1 -1
  33. package/dist/lib/components/Heading.d.ts +1 -1
  34. package/dist/lib/components/MobileTopNavigation.js +4 -1
  35. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  36. package/dist/lib/components/SlotletProvider.d.ts +2 -1
  37. package/dist/lib/components/SlotletProvider.js.map +1 -1
  38. package/dist/lib/components/SyntaxHighlight.js +4 -1
  39. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  40. package/dist/lib/components/TopNavigation.d.ts +3 -0
  41. package/dist/lib/components/TopNavigation.js +38 -5
  42. package/dist/lib/components/TopNavigation.js.map +1 -1
  43. package/dist/lib/components/context/ZudokuContext.d.ts +6 -10
  44. package/dist/lib/components/context/ZudokuContext.js +26 -20
  45. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  46. package/dist/lib/components/index.d.ts +17 -8
  47. package/dist/lib/components/index.js +10 -3
  48. package/dist/lib/components/index.js.map +1 -1
  49. package/dist/lib/components/navigation/Sidebar.js +3 -3
  50. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  51. package/dist/lib/components/navigation/SidebarCategory.js +12 -7
  52. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  53. package/dist/lib/components/navigation/SidebarItem.js +3 -5
  54. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  55. package/dist/lib/components/navigation/utils.js +10 -14
  56. package/dist/lib/components/navigation/utils.js.map +1 -1
  57. package/dist/lib/core/DevPortalContext.d.ts +3 -6
  58. package/dist/lib/core/DevPortalContext.js.map +1 -1
  59. package/dist/lib/core/plugins.d.ts +1 -0
  60. package/dist/lib/core/plugins.js.map +1 -1
  61. package/dist/lib/errors/ErrorAlert.d.ts +1 -1
  62. package/dist/lib/errors/ErrorAlert.js +8 -3
  63. package/dist/lib/errors/ErrorAlert.js.map +1 -1
  64. package/dist/lib/plugins/api-keys/CreateApiKey.js +1 -1
  65. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  66. package/dist/lib/plugins/custom-pages/CustomPage.js +2 -2
  67. package/dist/lib/plugins/markdown/index.d.ts +5 -6
  68. package/dist/lib/plugins/markdown/index.js +31 -3
  69. package/dist/lib/plugins/markdown/index.js.map +1 -1
  70. package/dist/lib/plugins/markdown/resolver.d.ts +38 -0
  71. package/dist/lib/plugins/markdown/resolver.js +75 -0
  72. package/dist/lib/plugins/markdown/resolver.js.map +1 -0
  73. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  74. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  75. package/dist/lib/plugins/openapi/Sidecar.js +2 -2
  76. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  77. package/dist/lib/plugins/openapi/client/worker.js.map +1 -1
  78. package/dist/lib/plugins/openapi/index.js.map +1 -1
  79. package/dist/lib/plugins/openapi/playground/Playground.js +2 -1
  80. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  81. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
  82. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  83. package/dist/lib/plugins/redirect/index.d.ts +2 -5
  84. package/dist/lib/plugins/redirect/index.js +1 -1
  85. package/dist/lib/plugins/redirect/index.js.map +1 -1
  86. package/dist/lib/ui/Accordion.d.ts +7 -0
  87. package/dist/lib/ui/Accordion.js +14 -0
  88. package/dist/lib/ui/Accordion.js.map +1 -0
  89. package/dist/lib/ui/Alert.d.ts +8 -0
  90. package/dist/lib/ui/Alert.js +23 -0
  91. package/dist/lib/ui/Alert.js.map +1 -0
  92. package/dist/lib/ui/AlertDialog.d.ts +20 -0
  93. package/dist/lib/ui/AlertDialog.js +27 -0
  94. package/dist/lib/ui/AlertDialog.js.map +1 -0
  95. package/dist/lib/ui/AspectRatio.d.ts +3 -0
  96. package/dist/lib/ui/AspectRatio.js +4 -0
  97. package/dist/lib/ui/AspectRatio.js.map +1 -0
  98. package/dist/lib/ui/Badge.d.ts +9 -0
  99. package/dist/lib/ui/Badge.js +21 -0
  100. package/dist/lib/ui/Badge.js.map +1 -0
  101. package/dist/lib/ui/Breadcrumb.d.ts +19 -0
  102. package/dist/lib/ui/Breadcrumb.js +24 -0
  103. package/dist/lib/ui/Breadcrumb.js.map +1 -0
  104. package/dist/lib/ui/Button.d.ts +2 -3
  105. package/dist/lib/ui/Button.js +1 -1
  106. package/dist/lib/ui/Button.js.map +1 -1
  107. package/dist/lib/ui/Carousel.d.ts +18 -0
  108. package/dist/lib/ui/Carousel.js +99 -0
  109. package/dist/lib/ui/Carousel.js.map +1 -0
  110. package/dist/lib/ui/Checkbox.d.ts +4 -0
  111. package/dist/lib/ui/Checkbox.js +9 -0
  112. package/dist/lib/ui/Checkbox.js.map +1 -0
  113. package/dist/lib/ui/Collapsible.d.ts +5 -0
  114. package/dist/lib/ui/Collapsible.js +6 -0
  115. package/dist/lib/ui/Collapsible.js.map +1 -0
  116. package/dist/lib/ui/Command.d.ts +80 -0
  117. package/dist/lib/ui/Command.js +31 -0
  118. package/dist/lib/ui/Command.js.map +1 -0
  119. package/dist/lib/{components → ui}/Dialog.js +2 -2
  120. package/dist/lib/ui/Dialog.js.map +1 -0
  121. package/dist/lib/ui/Form.d.ts +23 -0
  122. package/dist/lib/ui/Form.js +63 -0
  123. package/dist/lib/ui/Form.js.map +1 -0
  124. package/dist/lib/ui/HoverCard.d.ts +6 -0
  125. package/dist/lib/ui/HoverCard.js +10 -0
  126. package/dist/lib/ui/HoverCard.js.map +1 -0
  127. package/dist/lib/ui/Label.d.ts +5 -0
  128. package/dist/lib/ui/Label.js +10 -0
  129. package/dist/lib/ui/Label.js.map +1 -0
  130. package/dist/lib/ui/Pagination.d.ts +28 -0
  131. package/dist/lib/ui/Pagination.js +24 -0
  132. package/dist/lib/ui/Pagination.js.map +1 -0
  133. package/dist/lib/ui/Popover.d.ts +6 -0
  134. package/dist/lib/ui/Popover.js +10 -0
  135. package/dist/lib/ui/Popover.js.map +1 -0
  136. package/dist/lib/ui/Progress.d.ts +4 -0
  137. package/dist/lib/ui/Progress.js +8 -0
  138. package/dist/lib/ui/Progress.js.map +1 -0
  139. package/dist/lib/ui/RadioGroup.d.ts +5 -0
  140. package/dist/lib/ui/RadioGroup.js +15 -0
  141. package/dist/lib/ui/RadioGroup.js.map +1 -0
  142. package/dist/lib/ui/ScrollArea.d.ts +5 -0
  143. package/dist/lib/ui/ScrollArea.js +12 -0
  144. package/dist/lib/ui/ScrollArea.js.map +1 -0
  145. package/dist/lib/ui/Select.js.map +1 -0
  146. package/dist/lib/ui/Skeleton.d.ts +2 -0
  147. package/dist/lib/ui/Skeleton.js +7 -0
  148. package/dist/lib/ui/Skeleton.js.map +1 -0
  149. package/dist/lib/ui/Slider.d.ts +4 -0
  150. package/dist/lib/ui/Slider.js +8 -0
  151. package/dist/lib/ui/Slider.js.map +1 -0
  152. package/dist/lib/ui/Switch.d.ts +4 -0
  153. package/dist/lib/ui/Switch.js +8 -0
  154. package/dist/lib/ui/Switch.js.map +1 -0
  155. package/dist/lib/ui/Textarea.d.ts +4 -0
  156. package/dist/lib/ui/Textarea.js +9 -0
  157. package/dist/lib/ui/Textarea.js.map +1 -0
  158. package/dist/lib/ui/Toggle.d.ts +12 -0
  159. package/dist/lib/ui/Toggle.js +26 -0
  160. package/dist/lib/ui/Toggle.js.map +1 -0
  161. package/dist/lib/ui/ToggleGroup.d.ts +12 -0
  162. package/dist/lib/ui/ToggleGroup.js +21 -0
  163. package/dist/lib/ui/ToggleGroup.js.map +1 -0
  164. package/dist/lib/ui/Tooltip.d.ts +7 -0
  165. package/dist/lib/ui/Tooltip.js +11 -0
  166. package/dist/lib/ui/Tooltip.js.map +1 -0
  167. package/dist/lib/util/MdxComponents.js.map +1 -1
  168. package/dist/lib/util/invariant.d.ts +9 -0
  169. package/dist/lib/util/invariant.js +7 -3
  170. package/dist/lib/util/invariant.js.map +1 -1
  171. package/dist/lib/util/useExposedProps.js +3 -2
  172. package/dist/lib/util/useExposedProps.js.map +1 -1
  173. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  174. package/dist/vite/build.js +12 -3
  175. package/dist/vite/build.js.map +1 -1
  176. package/dist/vite/config.d.ts +2 -8
  177. package/dist/vite/config.js +24 -59
  178. package/dist/vite/config.js.map +1 -1
  179. package/dist/vite/debug.d.ts +1 -0
  180. package/dist/vite/debug.js +10 -0
  181. package/dist/vite/debug.js.map +1 -0
  182. package/dist/vite/dev-server.js +1 -1
  183. package/dist/vite/dev-server.js.map +1 -1
  184. package/dist/vite/output.d.ts +101 -0
  185. package/dist/vite/output.js +30 -0
  186. package/dist/vite/output.js.map +1 -0
  187. package/dist/vite/plugin-component.js +17 -7
  188. package/dist/vite/plugin-component.js.map +1 -1
  189. package/dist/vite/plugin-config-reload.js +0 -2
  190. package/dist/vite/plugin-config-reload.js.map +1 -1
  191. package/dist/vite/plugin-config.d.ts +2 -3
  192. package/dist/vite/plugin-config.js +2 -3
  193. package/dist/vite/plugin-config.js.map +1 -1
  194. package/dist/vite/plugin-docs.js +37 -26
  195. package/dist/vite/plugin-docs.js.map +1 -1
  196. package/dist/vite/plugin-frontmatter.d.ts +2 -1
  197. package/dist/vite/plugin-frontmatter.js +27 -24
  198. package/dist/vite/plugin-frontmatter.js.map +1 -1
  199. package/dist/vite/plugin-search.d.ts +3 -0
  200. package/dist/vite/plugin-search.js +26 -0
  201. package/dist/vite/plugin-search.js.map +1 -0
  202. package/dist/vite/plugin-sidebar.js +7 -6
  203. package/dist/vite/plugin-sidebar.js.map +1 -1
  204. package/dist/vite/plugin.js +4 -2
  205. package/dist/vite/plugin.js.map +1 -1
  206. package/dist/vite/prerender.d.ts +5 -1
  207. package/dist/vite/prerender.js +6 -5
  208. package/dist/vite/prerender.js.map +1 -1
  209. package/lib/{utils-C8S3st2k.js → AnchorLink-BbB2q-jx.js} +231 -275
  210. package/lib/AnchorLink-BbB2q-jx.js.map +1 -0
  211. package/lib/{AuthenticationPlugin-D1nhROkO.js → AuthenticationPlugin-C9BHGXlE.js} +3 -3
  212. package/lib/{AuthenticationPlugin-D1nhROkO.js.map → AuthenticationPlugin-C9BHGXlE.js.map} +1 -1
  213. package/lib/{CategoryHeading-B7TlPvuN.js → CategoryHeading-Bb9dqxD3.js} +4 -4
  214. package/lib/{CategoryHeading-B7TlPvuN.js.map → CategoryHeading-Bb9dqxD3.js.map} +1 -1
  215. package/lib/ClientOnly-CVN6leDu.js +11 -0
  216. package/lib/ClientOnly-CVN6leDu.js.map +1 -0
  217. package/lib/{DeveloperHint-B_QCCafl.js → DeveloperHint-DHdLXGHA.js} +2 -2
  218. package/lib/{DeveloperHint-B_QCCafl.js.map → DeveloperHint-DHdLXGHA.js.map} +1 -1
  219. package/lib/Dialog-k70Qfukb.js +67 -0
  220. package/lib/Dialog-k70Qfukb.js.map +1 -0
  221. package/lib/{Markdown-Y__eLG0x.js → Markdown-BDcCAWwm.js} +4268 -6650
  222. package/lib/Markdown-BDcCAWwm.js.map +1 -0
  223. package/lib/{MdxPage-B4FcPIi5.js → MdxPage-DKMH_t0f.js} +33 -31
  224. package/lib/{MdxPage-B4FcPIi5.js.map → MdxPage-DKMH_t0f.js.map} +1 -1
  225. package/lib/{OperationList-DuPG2FA2.js → OperationList-Tj7ubW_t.js} +131 -128
  226. package/lib/OperationList-Tj7ubW_t.js.map +1 -0
  227. package/lib/{Route-Bb3QClHu.js → Route-C3DGB6OS.js} +3 -3
  228. package/lib/{Route-Bb3QClHu.js.map → Route-C3DGB6OS.js.map} +1 -1
  229. package/lib/Select-Bagt3Bme.js +223 -0
  230. package/lib/Select-Bagt3Bme.js.map +1 -0
  231. package/lib/SlotletProvider-Da7eFgd2.js +241 -0
  232. package/lib/SlotletProvider-Da7eFgd2.js.map +1 -0
  233. package/lib/Spinner-C6zroowC.js +40 -0
  234. package/lib/Spinner-C6zroowC.js.map +1 -0
  235. package/lib/StaggeredRender-DDHSzQKE.js +17 -0
  236. package/lib/StaggeredRender-DDHSzQKE.js.map +1 -0
  237. package/lib/{ZudokuContext-MRoel6bS.js → ZudokuContext-BKXGJTmu.js} +460 -411
  238. package/lib/ZudokuContext-BKXGJTmu.js.map +1 -0
  239. package/lib/__vite-browser-external-BYRIRx8p.js +9 -0
  240. package/lib/__vite-browser-external-BYRIRx8p.js.map +1 -0
  241. package/lib/_commonjsHelpers-BkfeUUK-.js +29 -0
  242. package/lib/_commonjsHelpers-BkfeUUK-.js.map +1 -0
  243. package/lib/assets/worker-Bf8vjASY.js.map +1 -1
  244. package/lib/cn-BmFQLtkS.js +2279 -0
  245. package/lib/cn-BmFQLtkS.js.map +1 -0
  246. package/lib/hook-sn0zMTkE.js +229 -0
  247. package/lib/hook-sn0zMTkE.js.map +1 -0
  248. package/lib/{index-CCa8ojDW.js → index-AjWCJNGC.js} +1332 -1606
  249. package/lib/index-AjWCJNGC.js.map +1 -0
  250. package/lib/index-Bn6Lc9tq.js +9 -0
  251. package/lib/{index-DJqnphbT.js.map → index-Bn6Lc9tq.js.map} +1 -1
  252. package/lib/index-BuAyrJe3.js +46 -0
  253. package/lib/index-BuAyrJe3.js.map +1 -0
  254. package/lib/{index-DFN92YJN.js → index-CRo94sKK.js} +5 -4
  255. package/lib/{index-DFN92YJN.js.map → index-CRo94sKK.js.map} +1 -1
  256. package/lib/{index-D06ATMgg.js → index-LNp6rxyU.js} +2 -2
  257. package/lib/{index-D06ATMgg.js.map → index-LNp6rxyU.js.map} +1 -1
  258. package/lib/index.esm-C5mr_sKO.js +1193 -0
  259. package/lib/index.esm-C5mr_sKO.js.map +1 -0
  260. package/lib/invariant-Caa8-XvF.js +26 -0
  261. package/lib/invariant-Caa8-XvF.js.map +1 -0
  262. package/lib/ui/Accordion.js +47 -0
  263. package/lib/ui/Accordion.js.map +1 -0
  264. package/lib/ui/Alert.js +51 -0
  265. package/lib/ui/Alert.js.map +1 -0
  266. package/lib/ui/AlertDialog.js +114 -0
  267. package/lib/ui/AlertDialog.js.map +1 -0
  268. package/lib/ui/AspectRatio.js +6 -0
  269. package/lib/ui/AspectRatio.js.map +1 -0
  270. package/lib/ui/Badge.js +27 -0
  271. package/lib/ui/Badge.js.map +1 -0
  272. package/lib/ui/Breadcrumb.js +94 -0
  273. package/lib/ui/Breadcrumb.js.map +1 -0
  274. package/lib/ui/Button.js +49 -0
  275. package/lib/ui/Button.js.map +1 -0
  276. package/lib/ui/Callout.js +77 -0
  277. package/lib/ui/Callout.js.map +1 -0
  278. package/lib/ui/Card.js +62 -0
  279. package/lib/ui/Card.js.map +1 -0
  280. package/lib/ui/Carousel.js +1410 -0
  281. package/lib/ui/Carousel.js.map +1 -0
  282. package/lib/ui/Checkbox.js +28 -0
  283. package/lib/ui/Checkbox.js.map +1 -0
  284. package/lib/ui/Collapsible.js +8 -0
  285. package/lib/ui/Collapsible.js.map +1 -0
  286. package/lib/ui/Command.js +550 -0
  287. package/lib/ui/Command.js.map +1 -0
  288. package/lib/ui/Dialog.js +101 -0
  289. package/lib/ui/Dialog.js.map +1 -0
  290. package/lib/ui/Drawer.js +1153 -0
  291. package/lib/ui/Drawer.js.map +1 -0
  292. package/lib/ui/DropdownMenu.js +145 -0
  293. package/lib/ui/DropdownMenu.js.map +1 -0
  294. package/lib/ui/Form.js +95 -0
  295. package/lib/ui/Form.js.map +1 -0
  296. package/lib/ui/HoverCard.js +24 -0
  297. package/lib/ui/HoverCard.js.map +1 -0
  298. package/lib/ui/Input.js +22 -0
  299. package/lib/ui/Input.js.map +1 -0
  300. package/lib/ui/Label.js +20 -0
  301. package/lib/ui/Label.js.map +1 -0
  302. package/lib/ui/Pagination.js +106 -0
  303. package/lib/ui/Pagination.js.map +1 -0
  304. package/lib/ui/Popover.js +24 -0
  305. package/lib/ui/Popover.js.map +1 -0
  306. package/lib/ui/Progress.js +27 -0
  307. package/lib/ui/Progress.js.map +1 -0
  308. package/lib/ui/RadioGroup.js +32 -0
  309. package/lib/ui/RadioGroup.js.map +1 -0
  310. package/lib/ui/ScrollArea.js +39 -0
  311. package/lib/ui/ScrollArea.js.map +1 -0
  312. package/lib/ui/Select.js +122 -0
  313. package/lib/ui/Select.js.map +1 -0
  314. package/lib/ui/Skeleton.js +18 -0
  315. package/lib/ui/Skeleton.js.map +1 -0
  316. package/lib/ui/Slider.js +24 -0
  317. package/lib/ui/Slider.js.map +1 -0
  318. package/lib/ui/Switch.js +28 -0
  319. package/lib/ui/Switch.js.map +1 -0
  320. package/lib/ui/Tabs.js +47 -0
  321. package/lib/ui/Tabs.js.map +1 -0
  322. package/lib/ui/Textarea.js +21 -0
  323. package/lib/ui/Textarea.js.map +1 -0
  324. package/lib/ui/Toggle.js +38 -0
  325. package/lib/ui/Toggle.js.map +1 -0
  326. package/lib/ui/ToggleGroup.js +42 -0
  327. package/lib/ui/ToggleGroup.js.map +1 -0
  328. package/lib/ui/Tooltip.js +24 -0
  329. package/lib/ui/Tooltip.js.map +1 -0
  330. package/lib/urql-core-KJnLL26g.js.map +1 -1
  331. package/lib/useExposedProps-ChOIUaS4.js +9 -0
  332. package/lib/useExposedProps-ChOIUaS4.js.map +1 -0
  333. package/lib/zudoku.auth-clerk.js +1 -1
  334. package/lib/zudoku.auth-openid.js +477 -483
  335. package/lib/zudoku.auth-openid.js.map +1 -1
  336. package/lib/zudoku.components.js +907 -2881
  337. package/lib/zudoku.components.js.map +1 -1
  338. package/lib/zudoku.openapi-worker.js +2 -2
  339. package/lib/zudoku.plugin-api-keys.js +69 -76
  340. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  341. package/lib/zudoku.plugin-custom-pages.js +9 -8
  342. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  343. package/lib/zudoku.plugin-markdown.js +93 -27
  344. package/lib/zudoku.plugin-markdown.js.map +1 -1
  345. package/lib/zudoku.plugin-openapi.js +7 -8
  346. package/lib/zudoku.plugin-openapi.js.map +1 -1
  347. package/lib/zudoku.plugin-redirect.js +1 -1
  348. package/lib/zudoku.plugin-redirect.js.map +1 -1
  349. package/lib/zudoku.plugin-search-inkeep.js +9 -13
  350. package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
  351. package/package.json +32 -9
  352. package/src/app/entry.client.tsx +4 -2
  353. package/src/app/entry.server.tsx +4 -0
  354. package/src/app/main.css +4 -1
  355. package/src/app/main.tsx +12 -30
  356. package/src/app/standalone.tsx +1 -1
  357. package/src/lib/authentication/components/CallbackHandler.tsx +20 -51
  358. package/src/lib/authentication/hook.ts +1 -1
  359. package/src/lib/components/Header.tsx +17 -2
  360. package/src/lib/components/MobileTopNavigation.tsx +5 -1
  361. package/src/lib/components/SlotletProvider.tsx +2 -0
  362. package/src/lib/components/SyntaxHighlight.tsx +5 -1
  363. package/src/lib/components/TopNavigation.tsx +70 -23
  364. package/src/lib/components/context/ZudokuContext.ts +28 -20
  365. package/src/lib/components/index.ts +13 -4
  366. package/src/lib/components/navigation/Sidebar.tsx +5 -5
  367. package/src/lib/components/navigation/SidebarCategory.tsx +13 -13
  368. package/src/lib/components/navigation/SidebarItem.tsx +3 -5
  369. package/src/lib/components/navigation/utils.ts +11 -16
  370. package/src/lib/core/DevPortalContext.ts +3 -2
  371. package/src/lib/core/plugins.ts +2 -0
  372. package/src/lib/errors/ErrorAlert.tsx +18 -5
  373. package/src/lib/plugins/api-keys/CreateApiKey.tsx +2 -2
  374. package/src/lib/plugins/custom-pages/CustomPage.tsx +2 -2
  375. package/src/lib/plugins/markdown/index.tsx +49 -12
  376. package/src/lib/plugins/markdown/resolver.ts +92 -0
  377. package/src/lib/plugins/openapi/Endpoint.tsx +2 -2
  378. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +1 -1
  379. package/src/lib/plugins/openapi/Sidecar.tsx +3 -3
  380. package/src/lib/plugins/openapi/client/worker.ts +2 -2
  381. package/src/lib/plugins/openapi/index.tsx +1 -1
  382. package/src/lib/plugins/openapi/playground/Playground.tsx +4 -3
  383. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +1 -1
  384. package/src/lib/plugins/redirect/index.tsx +3 -7
  385. package/src/lib/ui/Accordion.tsx +56 -0
  386. package/src/lib/ui/{Note.tsx → Alert.tsx} +11 -10
  387. package/src/lib/ui/AlertDialog.tsx +139 -0
  388. package/src/lib/ui/AspectRatio.tsx +5 -0
  389. package/src/lib/ui/Badge.tsx +36 -0
  390. package/src/lib/ui/Breadcrumb.tsx +115 -0
  391. package/src/lib/ui/Button.tsx +1 -1
  392. package/src/lib/ui/Carousel.tsx +260 -0
  393. package/src/lib/ui/Checkbox.tsx +28 -0
  394. package/src/lib/ui/Collapsible.tsx +9 -0
  395. package/src/lib/ui/Command.tsx +151 -0
  396. package/src/lib/{components → ui}/Dialog.tsx +4 -3
  397. package/src/lib/ui/Form.tsx +177 -0
  398. package/src/lib/ui/HoverCard.tsx +27 -0
  399. package/src/lib/ui/Label.tsx +24 -0
  400. package/src/lib/ui/Pagination.tsx +117 -0
  401. package/src/lib/ui/Popover.tsx +29 -0
  402. package/src/lib/ui/Progress.tsx +26 -0
  403. package/src/lib/ui/RadioGroup.tsx +42 -0
  404. package/src/lib/ui/ScrollArea.tsx +46 -0
  405. package/src/lib/ui/Skeleton.tsx +15 -0
  406. package/src/lib/ui/Slider.tsx +26 -0
  407. package/src/lib/ui/Switch.tsx +27 -0
  408. package/src/lib/ui/Textarea.tsx +23 -0
  409. package/src/lib/ui/Toggle.tsx +43 -0
  410. package/src/lib/ui/ToggleGroup.tsx +59 -0
  411. package/src/lib/ui/Tooltip.tsx +28 -0
  412. package/src/lib/util/MdxComponents.tsx +0 -1
  413. package/src/lib/util/invariant.ts +15 -3
  414. package/src/lib/util/useExposedProps.tsx +8 -2
  415. package/src/lib/util/useScrollToAnchor.ts +1 -1
  416. package/dist/internal.d.ts +0 -1
  417. package/dist/internal.js +0 -2
  418. package/dist/internal.js.map +0 -1
  419. package/dist/lib/components/Dialog.js.map +0 -1
  420. package/dist/lib/components/Select.js.map +0 -1
  421. package/dist/lib/plugins/markdown/generateRoutes.d.ts +0 -3
  422. package/dist/lib/plugins/markdown/generateRoutes.js +0 -21
  423. package/dist/lib/plugins/markdown/generateRoutes.js.map +0 -1
  424. package/dist/lib/ui/Note.d.ts +0 -8
  425. package/dist/lib/ui/Note.js +0 -23
  426. package/dist/lib/ui/Note.js.map +0 -1
  427. package/lib/ErrorPage-DqqAV1dr.js +0 -16
  428. package/lib/ErrorPage-DqqAV1dr.js.map +0 -1
  429. package/lib/Input-a9rLgbP_.js +0 -2229
  430. package/lib/Input-a9rLgbP_.js.map +0 -1
  431. package/lib/Markdown-Y__eLG0x.js.map +0 -1
  432. package/lib/OperationList-DuPG2FA2.js.map +0 -1
  433. package/lib/SidebarBadge-BdzN0ZBK.js +0 -503
  434. package/lib/SidebarBadge-BdzN0ZBK.js.map +0 -1
  435. package/lib/SlotletProvider-DmqWiVFt.js +0 -239
  436. package/lib/SlotletProvider-DmqWiVFt.js.map +0 -1
  437. package/lib/Spinner-3cQDBVGr.js +0 -7
  438. package/lib/Spinner-3cQDBVGr.js.map +0 -1
  439. package/lib/ZudokuContext-MRoel6bS.js.map +0 -1
  440. package/lib/index-BijFM__9.js +0 -124
  441. package/lib/index-BijFM__9.js.map +0 -1
  442. package/lib/index-CCa8ojDW.js.map +0 -1
  443. package/lib/index-DJqnphbT.js +0 -35
  444. package/lib/index-_GxJ8hpM.js +0 -2867
  445. package/lib/index-_GxJ8hpM.js.map +0 -1
  446. package/lib/joinPath-B7kNnUX4.js +0 -8
  447. package/lib/joinPath-B7kNnUX4.js.map +0 -1
  448. package/lib/useExposedProps-BWwxa-Hg.js +0 -9
  449. package/lib/useExposedProps-BWwxa-Hg.js.map +0 -1
  450. package/lib/utils-C8S3st2k.js.map +0 -1
  451. package/src/lib/plugins/markdown/generateRoutes.tsx +0 -38
  452. /package/dist/lib/{components → ui}/Dialog.d.ts +0 -0
  453. /package/dist/lib/{components → ui}/Select.d.ts +0 -0
  454. /package/dist/lib/{components → ui}/Select.js +0 -0
  455. /package/src/lib/{components → ui}/Select.tsx +0 -0
@@ -0,0 +1,260 @@
1
+ import useEmblaCarousel, {
2
+ type UseEmblaCarouselType,
3
+ } from "embla-carousel-react";
4
+ import { ArrowLeft, ArrowRight } from "lucide-react";
5
+ import * as React from "react";
6
+
7
+ import { cn } from "../util/cn.js";
8
+ import { Button } from "./Button.js";
9
+
10
+ type CarouselApi = UseEmblaCarouselType[1];
11
+ type UseCarouselParameters = Parameters<typeof useEmblaCarousel>;
12
+ type CarouselOptions = UseCarouselParameters[0];
13
+ type CarouselPlugin = UseCarouselParameters[1];
14
+
15
+ type CarouselProps = {
16
+ opts?: CarouselOptions;
17
+ plugins?: CarouselPlugin;
18
+ orientation?: "horizontal" | "vertical";
19
+ setApi?: (api: CarouselApi) => void;
20
+ };
21
+
22
+ type CarouselContextProps = {
23
+ carouselRef: ReturnType<typeof useEmblaCarousel>[0];
24
+ api: ReturnType<typeof useEmblaCarousel>[1];
25
+ scrollPrev: () => void;
26
+ scrollNext: () => void;
27
+ canScrollPrev: boolean;
28
+ canScrollNext: boolean;
29
+ } & CarouselProps;
30
+
31
+ const CarouselContext = React.createContext<CarouselContextProps | null>(null);
32
+
33
+ function useCarousel() {
34
+ const context = React.useContext(CarouselContext);
35
+
36
+ if (!context) {
37
+ throw new Error("useCarousel must be used within a <Carousel />");
38
+ }
39
+
40
+ return context;
41
+ }
42
+
43
+ const Carousel = React.forwardRef<
44
+ HTMLDivElement,
45
+ React.HTMLAttributes<HTMLDivElement> & CarouselProps
46
+ >(
47
+ (
48
+ {
49
+ orientation = "horizontal",
50
+ opts,
51
+ setApi,
52
+ plugins,
53
+ className,
54
+ children,
55
+ ...props
56
+ },
57
+ ref,
58
+ ) => {
59
+ const [carouselRef, api] = useEmblaCarousel(
60
+ {
61
+ ...opts,
62
+ axis: orientation === "horizontal" ? "x" : "y",
63
+ },
64
+ plugins,
65
+ );
66
+ const [canScrollPrev, setCanScrollPrev] = React.useState(false);
67
+ const [canScrollNext, setCanScrollNext] = React.useState(false);
68
+
69
+ const onSelect = React.useCallback((api: CarouselApi) => {
70
+ if (!api) {
71
+ return;
72
+ }
73
+
74
+ setCanScrollPrev(api.canScrollPrev());
75
+ setCanScrollNext(api.canScrollNext());
76
+ }, []);
77
+
78
+ const scrollPrev = React.useCallback(() => {
79
+ api?.scrollPrev();
80
+ }, [api]);
81
+
82
+ const scrollNext = React.useCallback(() => {
83
+ api?.scrollNext();
84
+ }, [api]);
85
+
86
+ const handleKeyDown = React.useCallback(
87
+ (event: React.KeyboardEvent<HTMLDivElement>) => {
88
+ if (event.key === "ArrowLeft") {
89
+ event.preventDefault();
90
+ scrollPrev();
91
+ } else if (event.key === "ArrowRight") {
92
+ event.preventDefault();
93
+ scrollNext();
94
+ }
95
+ },
96
+ [scrollPrev, scrollNext],
97
+ );
98
+
99
+ React.useEffect(() => {
100
+ if (!api || !setApi) {
101
+ return;
102
+ }
103
+
104
+ setApi(api);
105
+ }, [api, setApi]);
106
+
107
+ React.useEffect(() => {
108
+ if (!api) {
109
+ return;
110
+ }
111
+
112
+ onSelect(api);
113
+ api.on("reInit", onSelect);
114
+ api.on("select", onSelect);
115
+
116
+ return () => {
117
+ api.off("select", onSelect);
118
+ };
119
+ }, [api, onSelect]);
120
+
121
+ return (
122
+ <CarouselContext.Provider
123
+ value={{
124
+ carouselRef,
125
+ api: api,
126
+ opts,
127
+ orientation:
128
+ orientation || (opts?.axis === "y" ? "vertical" : "horizontal"),
129
+ scrollPrev,
130
+ scrollNext,
131
+ canScrollPrev,
132
+ canScrollNext,
133
+ }}
134
+ >
135
+ <div
136
+ ref={ref}
137
+ onKeyDownCapture={handleKeyDown}
138
+ className={cn("relative", className)}
139
+ role="region"
140
+ aria-roledescription="carousel"
141
+ {...props}
142
+ >
143
+ {children}
144
+ </div>
145
+ </CarouselContext.Provider>
146
+ );
147
+ },
148
+ );
149
+ Carousel.displayName = "Carousel";
150
+
151
+ const CarouselContent = React.forwardRef<
152
+ HTMLDivElement,
153
+ React.HTMLAttributes<HTMLDivElement>
154
+ >(({ className, ...props }, ref) => {
155
+ const { carouselRef, orientation } = useCarousel();
156
+
157
+ return (
158
+ <div ref={carouselRef} className="overflow-hidden">
159
+ <div
160
+ ref={ref}
161
+ className={cn(
162
+ "flex",
163
+ orientation === "horizontal" ? "-ml-4" : "-mt-4 flex-col",
164
+ className,
165
+ )}
166
+ {...props}
167
+ />
168
+ </div>
169
+ );
170
+ });
171
+ CarouselContent.displayName = "CarouselContent";
172
+
173
+ const CarouselItem = React.forwardRef<
174
+ HTMLDivElement,
175
+ React.HTMLAttributes<HTMLDivElement>
176
+ >(({ className, ...props }, ref) => {
177
+ const { orientation } = useCarousel();
178
+
179
+ return (
180
+ <div
181
+ ref={ref}
182
+ role="group"
183
+ aria-roledescription="slide"
184
+ className={cn(
185
+ "min-w-0 shrink-0 grow-0 basis-full",
186
+ orientation === "horizontal" ? "pl-4" : "pt-4",
187
+ className,
188
+ )}
189
+ {...props}
190
+ />
191
+ );
192
+ });
193
+ CarouselItem.displayName = "CarouselItem";
194
+
195
+ const CarouselPrevious = React.forwardRef<
196
+ HTMLButtonElement,
197
+ React.ComponentProps<typeof Button>
198
+ >(({ className, variant = "outline", size = "icon", ...props }, ref) => {
199
+ const { orientation, scrollPrev, canScrollPrev } = useCarousel();
200
+
201
+ return (
202
+ <Button
203
+ ref={ref}
204
+ variant={variant}
205
+ size={size}
206
+ className={cn(
207
+ "absolute h-8 w-8 rounded-full",
208
+ orientation === "horizontal"
209
+ ? "-left-12 top-1/2 -translate-y-1/2"
210
+ : "-top-12 left-1/2 -translate-x-1/2 rotate-90",
211
+ className,
212
+ )}
213
+ disabled={!canScrollPrev}
214
+ onClick={scrollPrev}
215
+ {...props}
216
+ >
217
+ <ArrowLeft className="h-4 w-4" />
218
+ <span className="sr-only">Previous slide</span>
219
+ </Button>
220
+ );
221
+ });
222
+ CarouselPrevious.displayName = "CarouselPrevious";
223
+
224
+ const CarouselNext = React.forwardRef<
225
+ HTMLButtonElement,
226
+ React.ComponentProps<typeof Button>
227
+ >(({ className, variant = "outline", size = "icon", ...props }, ref) => {
228
+ const { orientation, scrollNext, canScrollNext } = useCarousel();
229
+
230
+ return (
231
+ <Button
232
+ ref={ref}
233
+ variant={variant}
234
+ size={size}
235
+ className={cn(
236
+ "absolute h-8 w-8 rounded-full",
237
+ orientation === "horizontal"
238
+ ? "-right-12 top-1/2 -translate-y-1/2"
239
+ : "-bottom-12 left-1/2 -translate-x-1/2 rotate-90",
240
+ className,
241
+ )}
242
+ disabled={!canScrollNext}
243
+ onClick={scrollNext}
244
+ {...props}
245
+ >
246
+ <ArrowRight className="h-4 w-4" />
247
+ <span className="sr-only">Next slide</span>
248
+ </Button>
249
+ );
250
+ });
251
+ CarouselNext.displayName = "CarouselNext";
252
+
253
+ export {
254
+ Carousel,
255
+ CarouselContent,
256
+ CarouselItem,
257
+ CarouselNext,
258
+ CarouselPrevious,
259
+ type CarouselApi,
260
+ };
@@ -0,0 +1,28 @@
1
+ import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
2
+ import { Check } from "lucide-react";
3
+ import * as React from "react";
4
+
5
+ import { cn } from "../util/cn.js";
6
+
7
+ const Checkbox = React.forwardRef<
8
+ React.ElementRef<typeof CheckboxPrimitive.Root>,
9
+ React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>
10
+ >(({ className, ...props }, ref) => (
11
+ <CheckboxPrimitive.Root
12
+ ref={ref}
13
+ className={cn(
14
+ "peer h-4 w-4 shrink-0 rounded-sm border border-primary ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground",
15
+ className,
16
+ )}
17
+ {...props}
18
+ >
19
+ <CheckboxPrimitive.Indicator
20
+ className={cn("flex items-center justify-center text-current")}
21
+ >
22
+ <Check className="h-4 w-4" />
23
+ </CheckboxPrimitive.Indicator>
24
+ </CheckboxPrimitive.Root>
25
+ ));
26
+ Checkbox.displayName = CheckboxPrimitive.Root.displayName;
27
+
28
+ export { Checkbox };
@@ -0,0 +1,9 @@
1
+ import * as CollapsiblePrimitive from "@radix-ui/react-collapsible";
2
+
3
+ const Collapsible = CollapsiblePrimitive.Root;
4
+
5
+ const CollapsibleTrigger = CollapsiblePrimitive.CollapsibleTrigger;
6
+
7
+ const CollapsibleContent = CollapsiblePrimitive.CollapsibleContent;
8
+
9
+ export { Collapsible, CollapsibleContent, CollapsibleTrigger };
@@ -0,0 +1,151 @@
1
+ import { type DialogProps } from "@radix-ui/react-dialog";
2
+ import { Command as CommandPrimitive } from "cmdk";
3
+ import { Search } from "lucide-react";
4
+ import * as React from "react";
5
+ import { Dialog, DialogContent } from "zudoku/ui/Dialog.js";
6
+ import { cn } from "../util/cn.js";
7
+
8
+ const Command = React.forwardRef<
9
+ React.ElementRef<typeof CommandPrimitive>,
10
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive>
11
+ >(({ className, ...props }, ref) => (
12
+ <CommandPrimitive
13
+ ref={ref}
14
+ className={cn(
15
+ "flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground",
16
+ className,
17
+ )}
18
+ {...props}
19
+ />
20
+ ));
21
+ Command.displayName = CommandPrimitive.displayName;
22
+
23
+ const CommandDialog = ({ children, ...props }: DialogProps) => {
24
+ return (
25
+ <Dialog {...props}>
26
+ <DialogContent className="overflow-hidden p-0 shadow-lg">
27
+ <Command className="[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5">
28
+ {children}
29
+ </Command>
30
+ </DialogContent>
31
+ </Dialog>
32
+ );
33
+ };
34
+
35
+ const CommandInput = React.forwardRef<
36
+ React.ElementRef<typeof CommandPrimitive.Input>,
37
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>
38
+ >(({ className, ...props }, ref) => (
39
+ // eslint-disable-next-line react/no-unknown-property
40
+ <div className="flex items-center border-b px-3" cmdk-input-wrapper="">
41
+ <Search className="mr-2 h-4 w-4 shrink-0 opacity-50" />
42
+ <CommandPrimitive.Input
43
+ ref={ref}
44
+ className={cn(
45
+ "flex h-11 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50",
46
+ className,
47
+ )}
48
+ {...props}
49
+ />
50
+ </div>
51
+ ));
52
+
53
+ CommandInput.displayName = CommandPrimitive.Input.displayName;
54
+
55
+ const CommandList = React.forwardRef<
56
+ React.ElementRef<typeof CommandPrimitive.List>,
57
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>
58
+ >(({ className, ...props }, ref) => (
59
+ <CommandPrimitive.List
60
+ ref={ref}
61
+ className={cn("max-h-[300px] overflow-y-auto overflow-x-hidden", className)}
62
+ {...props}
63
+ />
64
+ ));
65
+
66
+ CommandList.displayName = CommandPrimitive.List.displayName;
67
+
68
+ const CommandEmpty = React.forwardRef<
69
+ React.ElementRef<typeof CommandPrimitive.Empty>,
70
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>
71
+ >((props, ref) => (
72
+ <CommandPrimitive.Empty
73
+ ref={ref}
74
+ className="py-6 text-center text-sm"
75
+ {...props}
76
+ />
77
+ ));
78
+
79
+ CommandEmpty.displayName = CommandPrimitive.Empty.displayName;
80
+
81
+ const CommandGroup = React.forwardRef<
82
+ React.ElementRef<typeof CommandPrimitive.Group>,
83
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>
84
+ >(({ className, ...props }, ref) => (
85
+ <CommandPrimitive.Group
86
+ ref={ref}
87
+ className={cn(
88
+ "overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground",
89
+ className,
90
+ )}
91
+ {...props}
92
+ />
93
+ ));
94
+
95
+ CommandGroup.displayName = CommandPrimitive.Group.displayName;
96
+
97
+ const CommandSeparator = React.forwardRef<
98
+ React.ElementRef<typeof CommandPrimitive.Separator>,
99
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>
100
+ >(({ className, ...props }, ref) => (
101
+ <CommandPrimitive.Separator
102
+ ref={ref}
103
+ className={cn("-mx-1 h-px bg-border", className)}
104
+ {...props}
105
+ />
106
+ ));
107
+ CommandSeparator.displayName = CommandPrimitive.Separator.displayName;
108
+
109
+ const CommandItem = React.forwardRef<
110
+ React.ElementRef<typeof CommandPrimitive.Item>,
111
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>
112
+ >(({ className, ...props }, ref) => (
113
+ <CommandPrimitive.Item
114
+ ref={ref}
115
+ className={cn(
116
+ "relative flex cursor-default gap-2 select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected='true']:bg-accent data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",
117
+ className,
118
+ )}
119
+ {...props}
120
+ />
121
+ ));
122
+
123
+ CommandItem.displayName = CommandPrimitive.Item.displayName;
124
+
125
+ const CommandShortcut = ({
126
+ className,
127
+ ...props
128
+ }: React.HTMLAttributes<HTMLSpanElement>) => {
129
+ return (
130
+ <span
131
+ className={cn(
132
+ "ml-auto text-xs tracking-widest text-muted-foreground",
133
+ className,
134
+ )}
135
+ {...props}
136
+ />
137
+ );
138
+ };
139
+ CommandShortcut.displayName = "CommandShortcut";
140
+
141
+ export {
142
+ Command,
143
+ CommandDialog,
144
+ CommandEmpty,
145
+ CommandGroup,
146
+ CommandInput,
147
+ CommandItem,
148
+ CommandList,
149
+ CommandSeparator,
150
+ CommandShortcut,
151
+ };
@@ -1,6 +1,7 @@
1
1
  import * as DialogPrimitive from "@radix-ui/react-dialog";
2
- import { XIcon } from "lucide-react";
2
+ import { X } from "lucide-react";
3
3
  import * as React from "react";
4
+
4
5
  import { cn } from "../util/cn.js";
5
6
 
6
7
  const Dialog = DialogPrimitive.Root;
@@ -35,14 +36,14 @@ const DialogContent = React.forwardRef<
35
36
  <DialogPrimitive.Content
36
37
  ref={ref}
37
38
  className={cn(
38
- "fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg border-border",
39
+ "fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",
39
40
  className,
40
41
  )}
41
42
  {...props}
42
43
  >
43
44
  {children}
44
45
  <DialogPrimitive.Close className="absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground">
45
- <XIcon className="h-4 w-4" />
46
+ <X className="h-4 w-4" />
46
47
  <span className="sr-only">Close</span>
47
48
  </DialogPrimitive.Close>
48
49
  </DialogPrimitive.Content>
@@ -0,0 +1,177 @@
1
+ import * as LabelPrimitive from "@radix-ui/react-label";
2
+ import { Slot } from "@radix-ui/react-slot";
3
+ import * as React from "react";
4
+ import {
5
+ Controller,
6
+ ControllerProps,
7
+ FieldPath,
8
+ FieldValues,
9
+ FormProvider,
10
+ useFormContext,
11
+ } from "react-hook-form";
12
+
13
+ import { cn } from "../util/cn.js";
14
+ import { Label } from "./Label.js";
15
+
16
+ const Form = FormProvider;
17
+
18
+ type FormFieldContextValue<
19
+ TFieldValues extends FieldValues = FieldValues,
20
+ TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
21
+ > = {
22
+ name: TName;
23
+ };
24
+
25
+ const FormFieldContext = React.createContext<FormFieldContextValue>(
26
+ {} as FormFieldContextValue,
27
+ );
28
+
29
+ const FormField = <
30
+ TFieldValues extends FieldValues = FieldValues,
31
+ TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
32
+ >({
33
+ ...props
34
+ }: ControllerProps<TFieldValues, TName>) => {
35
+ return (
36
+ <FormFieldContext.Provider value={{ name: props.name }}>
37
+ <Controller {...props} />
38
+ </FormFieldContext.Provider>
39
+ );
40
+ };
41
+
42
+ const useFormField = () => {
43
+ const fieldContext = React.useContext(FormFieldContext);
44
+ const itemContext = React.useContext(FormItemContext);
45
+ const { getFieldState, formState } = useFormContext();
46
+
47
+ const fieldState = getFieldState(fieldContext.name, formState);
48
+
49
+ if (!fieldContext) {
50
+ throw new Error("useFormField should be used within <FormField>");
51
+ }
52
+
53
+ const { id } = itemContext;
54
+
55
+ return {
56
+ id,
57
+ name: fieldContext.name,
58
+ formItemId: `${id}-form-item`,
59
+ formDescriptionId: `${id}-form-item-description`,
60
+ formMessageId: `${id}-form-item-message`,
61
+ ...fieldState,
62
+ };
63
+ };
64
+
65
+ type FormItemContextValue = {
66
+ id: string;
67
+ };
68
+
69
+ const FormItemContext = React.createContext<FormItemContextValue>(
70
+ {} as FormItemContextValue,
71
+ );
72
+
73
+ const FormItem = React.forwardRef<
74
+ HTMLDivElement,
75
+ React.HTMLAttributes<HTMLDivElement>
76
+ >(({ className, ...props }, ref) => {
77
+ const id = React.useId();
78
+
79
+ return (
80
+ <FormItemContext.Provider value={{ id }}>
81
+ <div ref={ref} className={cn("space-y-2", className)} {...props} />
82
+ </FormItemContext.Provider>
83
+ );
84
+ });
85
+ FormItem.displayName = "FormItem";
86
+
87
+ const FormLabel = React.forwardRef<
88
+ React.ElementRef<typeof LabelPrimitive.Root>,
89
+ React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root>
90
+ >(({ className, ...props }, ref) => {
91
+ const { error, formItemId } = useFormField();
92
+
93
+ return (
94
+ <Label
95
+ ref={ref}
96
+ className={cn(error && "text-destructive", className)}
97
+ htmlFor={formItemId}
98
+ {...props}
99
+ />
100
+ );
101
+ });
102
+ FormLabel.displayName = "FormLabel";
103
+
104
+ const FormControl = React.forwardRef<
105
+ React.ElementRef<typeof Slot>,
106
+ React.ComponentPropsWithoutRef<typeof Slot>
107
+ >(({ ...props }, ref) => {
108
+ const { error, formItemId, formDescriptionId, formMessageId } =
109
+ useFormField();
110
+
111
+ return (
112
+ <Slot
113
+ ref={ref}
114
+ id={formItemId}
115
+ aria-describedby={
116
+ !error
117
+ ? `${formDescriptionId}`
118
+ : `${formDescriptionId} ${formMessageId}`
119
+ }
120
+ aria-invalid={!!error}
121
+ {...props}
122
+ />
123
+ );
124
+ });
125
+ FormControl.displayName = "FormControl";
126
+
127
+ const FormDescription = React.forwardRef<
128
+ HTMLParagraphElement,
129
+ React.HTMLAttributes<HTMLParagraphElement>
130
+ >(({ className, ...props }, ref) => {
131
+ const { formDescriptionId } = useFormField();
132
+
133
+ return (
134
+ <p
135
+ ref={ref}
136
+ id={formDescriptionId}
137
+ className={cn("text-sm text-muted-foreground", className)}
138
+ {...props}
139
+ />
140
+ );
141
+ });
142
+ FormDescription.displayName = "FormDescription";
143
+
144
+ const FormMessage = React.forwardRef<
145
+ HTMLParagraphElement,
146
+ React.HTMLAttributes<HTMLParagraphElement>
147
+ >(({ className, children, ...props }, ref) => {
148
+ const { error, formMessageId } = useFormField();
149
+ const body = error ? String(error.message) : children;
150
+
151
+ if (!body) {
152
+ return null;
153
+ }
154
+
155
+ return (
156
+ <p
157
+ ref={ref}
158
+ id={formMessageId}
159
+ className={cn("text-sm font-medium text-destructive", className)}
160
+ {...props}
161
+ >
162
+ {body}
163
+ </p>
164
+ );
165
+ });
166
+ FormMessage.displayName = "FormMessage";
167
+
168
+ export {
169
+ Form,
170
+ FormControl,
171
+ FormDescription,
172
+ FormField,
173
+ FormItem,
174
+ FormLabel,
175
+ FormMessage,
176
+ useFormField,
177
+ };
@@ -0,0 +1,27 @@
1
+ import * as HoverCardPrimitive from "@radix-ui/react-hover-card";
2
+ import * as React from "react";
3
+
4
+ import { cn } from "../util/cn.js";
5
+
6
+ const HoverCard = HoverCardPrimitive.Root;
7
+
8
+ const HoverCardTrigger = HoverCardPrimitive.Trigger;
9
+
10
+ const HoverCardContent = React.forwardRef<
11
+ React.ElementRef<typeof HoverCardPrimitive.Content>,
12
+ React.ComponentPropsWithoutRef<typeof HoverCardPrimitive.Content>
13
+ >(({ className, align = "center", sideOffset = 4, ...props }, ref) => (
14
+ <HoverCardPrimitive.Content
15
+ ref={ref}
16
+ align={align}
17
+ sideOffset={sideOffset}
18
+ className={cn(
19
+ "z-50 w-64 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
20
+ className,
21
+ )}
22
+ {...props}
23
+ />
24
+ ));
25
+ HoverCardContent.displayName = HoverCardPrimitive.Content.displayName;
26
+
27
+ export { HoverCard, HoverCardContent, HoverCardTrigger };
@@ -0,0 +1,24 @@
1
+ import * as LabelPrimitive from "@radix-ui/react-label";
2
+ import { cva, type VariantProps } from "class-variance-authority";
3
+ import * as React from "react";
4
+
5
+ import { cn } from "../util/cn.js";
6
+
7
+ const labelVariants = cva(
8
+ "text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70",
9
+ );
10
+
11
+ const Label = React.forwardRef<
12
+ React.ElementRef<typeof LabelPrimitive.Root>,
13
+ React.ComponentPropsWithoutRef<typeof LabelPrimitive.Root> &
14
+ VariantProps<typeof labelVariants>
15
+ >(({ className, ...props }, ref) => (
16
+ <LabelPrimitive.Root
17
+ ref={ref}
18
+ className={cn(labelVariants(), className)}
19
+ {...props}
20
+ />
21
+ ));
22
+ Label.displayName = LabelPrimitive.Root.displayName;
23
+
24
+ export { Label };