zudoku 0.0.0-fix-downgrade-openapi-parser.aac00796 → 0.0.0-fix-firebase-export.2e421fda

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 (566) hide show
  1. package/dist/app/main.d.ts +91 -1
  2. package/dist/app/main.js +5 -1
  3. package/dist/app/main.js.map +1 -1
  4. package/dist/app/sentry.js +1 -1
  5. package/dist/config/config.d.ts +15 -46
  6. package/dist/config/validators/BuildSchema.js +18 -3
  7. package/dist/config/validators/BuildSchema.js.map +1 -1
  8. package/dist/config/validators/InputNavigationSchema.d.ts +61 -61
  9. package/dist/config/validators/NavigationSchema.js +2 -4
  10. package/dist/config/validators/NavigationSchema.js.map +1 -1
  11. package/dist/config/validators/ProtectedRoutesSchema.d.ts +1 -1
  12. package/dist/config/validators/validate.d.ts +203 -5
  13. package/dist/config/validators/validate.js +44 -1
  14. package/dist/config/validators/validate.js.map +1 -1
  15. package/dist/config/validators/validate.test.js +43 -0
  16. package/dist/config/validators/validate.test.js.map +1 -1
  17. package/dist/flat-config.d.ts +31 -2
  18. package/dist/lib/auth/issuer.js +3 -0
  19. package/dist/lib/auth/issuer.js.map +1 -1
  20. package/dist/lib/authentication/authentication.d.ts +1 -1
  21. package/dist/lib/authentication/providers/auth0.js +6 -1
  22. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  23. package/dist/lib/authentication/providers/firebase.d.ts +4 -0
  24. package/dist/lib/authentication/providers/firebase.js +215 -0
  25. package/dist/lib/authentication/providers/firebase.js.map +1 -0
  26. package/dist/lib/authentication/providers/supabase.js +1 -6
  27. package/dist/lib/authentication/providers/supabase.js.map +1 -1
  28. package/dist/lib/authentication/ui/ZudokuAuthUi.d.ts +24 -0
  29. package/dist/lib/authentication/ui/ZudokuAuthUi.js +124 -0
  30. package/dist/lib/authentication/ui/ZudokuAuthUi.js.map +1 -0
  31. package/dist/lib/authentication/ui/icons/Apple.d.ts +3 -0
  32. package/dist/lib/authentication/ui/icons/Apple.js +4 -0
  33. package/dist/lib/authentication/ui/icons/Apple.js.map +1 -0
  34. package/dist/lib/authentication/ui/icons/Facebook.d.ts +3 -0
  35. package/dist/lib/authentication/ui/icons/Facebook.js +4 -0
  36. package/dist/lib/authentication/ui/icons/Facebook.js.map +1 -0
  37. package/dist/lib/authentication/ui/icons/Github.d.ts +3 -0
  38. package/dist/lib/authentication/ui/icons/Github.js +4 -0
  39. package/dist/lib/authentication/ui/icons/Github.js.map +1 -0
  40. package/dist/lib/authentication/ui/icons/Google.d.ts +3 -0
  41. package/dist/lib/authentication/ui/icons/Google.js +4 -0
  42. package/dist/lib/authentication/ui/icons/Google.js.map +1 -0
  43. package/dist/lib/authentication/ui/icons/Microsoft.d.ts +3 -0
  44. package/dist/lib/authentication/ui/icons/Microsoft.js +4 -0
  45. package/dist/lib/authentication/ui/icons/Microsoft.js.map +1 -0
  46. package/dist/lib/authentication/ui/icons/X.d.ts +3 -0
  47. package/dist/lib/authentication/ui/icons/X.js +4 -0
  48. package/dist/lib/authentication/ui/icons/X.js.map +1 -0
  49. package/dist/lib/components/Autocomplete.d.ts +3 -1
  50. package/dist/lib/components/Autocomplete.js +6 -2
  51. package/dist/lib/components/Autocomplete.js.map +1 -1
  52. package/dist/lib/components/Heading.d.ts +1 -1
  53. package/dist/lib/components/Layout.js +3 -2
  54. package/dist/lib/components/Layout.js.map +1 -1
  55. package/dist/lib/components/Mermaid.d.ts +7 -0
  56. package/dist/lib/components/Mermaid.js +42 -0
  57. package/dist/lib/components/Mermaid.js.map +1 -0
  58. package/dist/lib/components/PagefindSearchMeta.d.ts +8 -0
  59. package/dist/lib/components/PagefindSearchMeta.js +7 -0
  60. package/dist/lib/components/PagefindSearchMeta.js.map +1 -0
  61. package/dist/lib/components/Zudoku.js +2 -5
  62. package/dist/lib/components/Zudoku.js.map +1 -1
  63. package/dist/lib/components/navigation/NavigationItem.js +2 -2
  64. package/dist/lib/components/navigation/NavigationItem.js.map +1 -1
  65. package/dist/lib/core/RouteGuard.js +7 -7
  66. package/dist/lib/core/RouteGuard.js.map +1 -1
  67. package/dist/lib/core/plugins.d.ts +3 -3
  68. package/dist/lib/errors/ErrorAlert.js +1 -1
  69. package/dist/lib/errors/RouterError.d.ts +3 -1
  70. package/dist/lib/errors/RouterError.js +3 -2
  71. package/dist/lib/errors/RouterError.js.map +1 -1
  72. package/dist/lib/oas/parser/index.d.ts +1 -0
  73. package/dist/lib/oas/parser/index.js +7 -3
  74. package/dist/lib/oas/parser/index.js.map +1 -1
  75. package/dist/lib/plugins/api-keys/ProtectedRoute.js +4 -1
  76. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  77. package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +1 -0
  78. package/dist/lib/plugins/openapi/CollapsibleCode.js +2 -1
  79. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -1
  80. package/dist/lib/plugins/openapi/DownloadSchemaButton.d.ts +3 -0
  81. package/dist/lib/plugins/openapi/DownloadSchemaButton.js +47 -0
  82. package/dist/lib/plugins/openapi/DownloadSchemaButton.js.map +1 -0
  83. package/dist/lib/plugins/openapi/Endpoint.js +3 -6
  84. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  85. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.d.ts +5 -0
  86. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js +10 -0
  87. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js.map +1 -0
  88. package/dist/lib/plugins/openapi/OasProvider.js +22 -13
  89. package/dist/lib/plugins/openapi/OasProvider.js.map +1 -1
  90. package/dist/lib/plugins/openapi/OperationList.js +16 -6
  91. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  92. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  93. package/dist/lib/plugins/openapi/OperationListItem.js +4 -3
  94. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  95. package/dist/lib/plugins/openapi/ParameterList.js +7 -4
  96. package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
  97. package/dist/lib/plugins/openapi/ParameterListItem.js +17 -6
  98. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  99. package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +9 -2
  100. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +5 -2
  101. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  102. package/dist/lib/plugins/openapi/ResponsesSidecarBox.d.ts +4 -2
  103. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +26 -4
  104. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  105. package/dist/lib/plugins/openapi/SchemaList.js +2 -1
  106. package/dist/lib/plugins/openapi/SchemaList.js.map +1 -1
  107. package/dist/lib/plugins/openapi/Sidecar.d.ts +2 -2
  108. package/dist/lib/plugins/openapi/Sidecar.js +61 -26
  109. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  110. package/dist/lib/plugins/openapi/SidecarBox.js +4 -4
  111. package/dist/lib/plugins/openapi/SidecarBox.js.map +1 -1
  112. package/dist/lib/plugins/openapi/SidecarExamples.d.ts +9 -2
  113. package/dist/lib/plugins/openapi/SidecarExamples.js +24 -43
  114. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
  115. package/dist/lib/plugins/openapi/components/ConstValue.js +1 -1
  116. package/dist/lib/plugins/openapi/components/ConstValue.js.map +1 -1
  117. package/dist/lib/plugins/openapi/components/EnumValues.js +1 -1
  118. package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -1
  119. package/dist/lib/plugins/openapi/components/NonHighlightedCode.d.ts +4 -0
  120. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js +5 -0
  121. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js.map +1 -0
  122. package/dist/lib/plugins/openapi/components/ResponseContent.js +5 -6
  123. package/dist/lib/plugins/openapi/components/ResponseContent.js.map +1 -1
  124. package/dist/lib/plugins/openapi/index.js +11 -5
  125. package/dist/lib/plugins/openapi/index.js.map +1 -1
  126. package/dist/lib/plugins/openapi/interfaces.d.ts +29 -13
  127. package/dist/lib/plugins/openapi/playground/BodyPanel.js +67 -15
  128. package/dist/lib/plugins/openapi/playground/BodyPanel.js.map +1 -1
  129. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js +2 -2
  130. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js.map +1 -1
  131. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -1
  132. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
  133. package/dist/lib/plugins/openapi/playground/Headers.js +23 -83
  134. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  135. package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +10 -2
  136. package/dist/lib/plugins/openapi/playground/ParamsGrid.js +8 -1
  137. package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -1
  138. package/dist/lib/plugins/openapi/playground/PathParams.js +2 -3
  139. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  140. package/dist/lib/plugins/openapi/playground/Playground.d.ts +7 -0
  141. package/dist/lib/plugins/openapi/playground/Playground.js +58 -26
  142. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  143. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +3 -2
  144. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  145. package/dist/lib/plugins/openapi/playground/QueryParams.js +16 -40
  146. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  147. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.d.ts +8 -0
  148. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js +19 -0
  149. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js.map +1 -0
  150. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js +1 -1
  151. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js.map +1 -1
  152. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.d.ts +1 -0
  153. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js +540 -0
  154. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js.map +1 -0
  155. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.d.ts +40 -0
  156. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js +205 -0
  157. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js.map +1 -0
  158. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +2 -2
  159. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
  160. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +1 -1
  161. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -1
  162. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +17 -8
  163. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
  164. package/dist/lib/plugins/openapi/schema/SchemaView.d.ts +1 -1
  165. package/dist/lib/plugins/openapi/schema/SchemaView.js +31 -16
  166. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  167. package/dist/lib/plugins/openapi/schema/UnionView.js +2 -5
  168. package/dist/lib/plugins/openapi/schema/UnionView.js.map +1 -1
  169. package/dist/lib/plugins/openapi/schema/union-helpers.js +0 -1
  170. package/dist/lib/plugins/openapi/schema/union-helpers.js.map +1 -1
  171. package/dist/lib/plugins/openapi/schema/utils.d.ts +2 -2
  172. package/dist/lib/plugins/openapi/schema/utils.js.map +1 -1
  173. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +9 -11
  174. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  175. package/dist/lib/plugins/openapi/util/getRoutes.d.ts +6 -1
  176. package/dist/lib/plugins/openapi/util/getRoutes.js +29 -2
  177. package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -1
  178. package/dist/lib/plugins/search-pagefind/IndexingDialog.d.ts +3 -0
  179. package/dist/lib/plugins/search-pagefind/IndexingDialog.js +64 -0
  180. package/dist/lib/plugins/search-pagefind/IndexingDialog.js.map +1 -0
  181. package/dist/lib/plugins/search-pagefind/PagefindSearch.js +22 -5
  182. package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -1
  183. package/dist/lib/plugins/search-pagefind/ResultList.js +5 -4
  184. package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -1
  185. package/dist/lib/shiki.d.ts +1 -1
  186. package/dist/lib/shiki.js +18 -12
  187. package/dist/lib/shiki.js.map +1 -1
  188. package/dist/lib/ui/Badge.d.ts +3 -3
  189. package/dist/lib/ui/Badge.js +9 -7
  190. package/dist/lib/ui/Badge.js.map +1 -1
  191. package/dist/lib/ui/Button.d.ts +2 -2
  192. package/dist/lib/ui/Button.js +9 -7
  193. package/dist/lib/ui/Button.js.map +1 -1
  194. package/dist/lib/ui/ButtonGroup.d.ts +11 -0
  195. package/dist/lib/ui/ButtonGroup.js +28 -0
  196. package/dist/lib/ui/ButtonGroup.js.map +1 -0
  197. package/dist/lib/ui/Checkbox.d.ts +2 -2
  198. package/dist/lib/ui/Checkbox.js +4 -4
  199. package/dist/lib/ui/Checkbox.js.map +1 -1
  200. package/dist/lib/ui/CodeBlock.d.ts +0 -1
  201. package/dist/lib/ui/CodeBlock.js +1 -1
  202. package/dist/lib/ui/CodeBlock.js.map +1 -1
  203. package/dist/lib/ui/Collapsible.d.ts +4 -4
  204. package/dist/lib/ui/Collapsible.js +11 -4
  205. package/dist/lib/ui/Collapsible.js.map +1 -1
  206. package/dist/lib/ui/Command.d.ts +3 -3
  207. package/dist/lib/ui/Command.js +2 -2
  208. package/dist/lib/ui/Command.js.map +1 -1
  209. package/dist/lib/ui/DropdownMenu.d.ts +21 -23
  210. package/dist/lib/ui/DropdownMenu.js +47 -32
  211. package/dist/lib/ui/DropdownMenu.js.map +1 -1
  212. package/dist/lib/ui/EmbeddedCodeBlock.d.ts +0 -1
  213. package/dist/lib/ui/EmbeddedCodeBlock.js +3 -2
  214. package/dist/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  215. package/dist/lib/ui/Frame.d.ts +8 -0
  216. package/dist/lib/ui/Frame.js +22 -0
  217. package/dist/lib/ui/Frame.js.map +1 -0
  218. package/dist/lib/ui/Item.d.ts +23 -0
  219. package/dist/lib/ui/Item.js +67 -0
  220. package/dist/lib/ui/Item.js.map +1 -0
  221. package/dist/lib/ui/Kbd.d.ts +3 -0
  222. package/dist/lib/ui/Kbd.js +10 -0
  223. package/dist/lib/ui/Kbd.js.map +1 -0
  224. package/dist/lib/ui/NativeSelect.d.ts +5 -0
  225. package/dist/lib/ui/NativeSelect.js +14 -0
  226. package/dist/lib/ui/NativeSelect.js.map +1 -0
  227. package/dist/lib/ui/Select.d.ts +13 -11
  228. package/dist/lib/ui/Select.js +34 -23
  229. package/dist/lib/ui/Select.js.map +1 -1
  230. package/dist/lib/ui/Separator.d.ts +4 -0
  231. package/dist/lib/ui/Separator.js +8 -0
  232. package/dist/lib/ui/Separator.js.map +1 -0
  233. package/dist/lib/ui/Tooltip.d.ts +7 -7
  234. package/dist/lib/ui/Tooltip.js +16 -10
  235. package/dist/lib/ui/Tooltip.js.map +1 -1
  236. package/dist/lib/util/MdxComponents.d.ts +1 -0
  237. package/dist/lib/util/MdxComponents.js +2 -0
  238. package/dist/lib/util/MdxComponents.js.map +1 -1
  239. package/dist/lib/util/createVariantComponent.d.ts +5 -2
  240. package/dist/lib/util/createVariantComponent.js +5 -2
  241. package/dist/lib/util/createVariantComponent.js.map +1 -1
  242. package/dist/lib/util/flattenAllOf.d.ts +4 -0
  243. package/dist/lib/util/flattenAllOf.js +88 -0
  244. package/dist/lib/util/flattenAllOf.js.map +1 -0
  245. package/dist/lib/util/flattenAllOf.test.d.ts +1 -0
  246. package/dist/lib/util/flattenAllOf.test.js +587 -0
  247. package/dist/lib/util/flattenAllOf.test.js.map +1 -0
  248. package/dist/lib/util/readFrontmatter.d.ts +6 -0
  249. package/dist/lib/util/readFrontmatter.js +12 -0
  250. package/dist/lib/util/readFrontmatter.js.map +1 -0
  251. package/dist/vite/api/SchemaManager.d.ts +5 -0
  252. package/dist/vite/api/SchemaManager.js +30 -18
  253. package/dist/vite/api/SchemaManager.js.map +1 -1
  254. package/dist/vite/api/SchemaManager.test.js +67 -0
  255. package/dist/vite/api/SchemaManager.test.js.map +1 -1
  256. package/dist/vite/config.js +8 -2
  257. package/dist/vite/config.js.map +1 -1
  258. package/dist/vite/dev-server.js +25 -0
  259. package/dist/vite/dev-server.js.map +1 -1
  260. package/dist/vite/mdx/remark-last-modified.js +57 -3
  261. package/dist/vite/mdx/remark-last-modified.js.map +1 -1
  262. package/dist/vite/pagefind-dev-index.d.ts +16 -0
  263. package/dist/vite/pagefind-dev-index.js +68 -0
  264. package/dist/vite/pagefind-dev-index.js.map +1 -0
  265. package/dist/vite/plugin-api.js +41 -3
  266. package/dist/vite/plugin-api.js.map +1 -1
  267. package/dist/vite/plugin-frontmatter.js +3 -5
  268. package/dist/vite/plugin-frontmatter.js.map +1 -1
  269. package/dist/vite/plugin-markdown-export.js +3 -4
  270. package/dist/vite/plugin-markdown-export.js.map +1 -1
  271. package/dist/vite/plugin-theme.js +10 -1
  272. package/dist/vite/plugin-theme.js.map +1 -1
  273. package/dist/vite/prerender/prerender.js +1 -19
  274. package/dist/vite/prerender/prerender.js.map +1 -1
  275. package/dist/vite/prerender/utils.d.ts +2 -0
  276. package/dist/vite/prerender/utils.js +24 -0
  277. package/dist/vite/prerender/utils.js.map +1 -0
  278. package/lib/ActionButton-DUgvSylL.js +25 -0
  279. package/lib/ActionButton-DUgvSylL.js.map +1 -0
  280. package/lib/Button-CynVW1JV.js +53 -0
  281. package/lib/Button-CynVW1JV.js.map +1 -0
  282. package/lib/ClaudeLogo-B4Xxt-x_.js +69 -0
  283. package/lib/ClaudeLogo-B4Xxt-x_.js.map +1 -0
  284. package/lib/{Command-CUcrW3qs.js → Command-BpT1iBE6.js} +25 -25
  285. package/lib/Command-BpT1iBE6.js.map +1 -0
  286. package/lib/Drawer-Ci7XwhqT.js.map +1 -1
  287. package/lib/DropdownMenu-C8SX_-S_.js +104 -0
  288. package/lib/DropdownMenu-C8SX_-S_.js.map +1 -0
  289. package/lib/{ErrorAlert-DE3Sf66a.js → ErrorAlert-DrOR8w3f.js} +475 -456
  290. package/lib/ErrorAlert-DrOR8w3f.js.map +1 -0
  291. package/lib/IndexingDialog-B5zCiUKr.js +100 -0
  292. package/lib/IndexingDialog-B5zCiUKr.js.map +1 -0
  293. package/lib/MdxPage-BagO2c-n.js +210 -0
  294. package/lib/MdxPage-BagO2c-n.js.map +1 -0
  295. package/lib/Mermaid-D_VSX7_Q.js +102 -0
  296. package/lib/Mermaid-D_VSX7_Q.js.map +1 -0
  297. package/lib/{OAuthErrorPage-BycMozgn.js → OAuthErrorPage-Fq54RLgt.js} +7 -7
  298. package/lib/{OAuthErrorPage-BycMozgn.js.map → OAuthErrorPage-Fq54RLgt.js.map} +1 -1
  299. package/lib/OasProvider-DPH8mwDa.js +40 -0
  300. package/lib/OasProvider-DPH8mwDa.js.map +1 -0
  301. package/lib/OperationList-C0jiEaG5.js +5805 -0
  302. package/lib/OperationList-C0jiEaG5.js.map +1 -0
  303. package/lib/RouteGuard-9wjejsKm.js +77 -0
  304. package/lib/RouteGuard-9wjejsKm.js.map +1 -0
  305. package/lib/RouterError-DSLXagd5.js +42 -0
  306. package/lib/RouterError-DSLXagd5.js.map +1 -0
  307. package/lib/{SchemaList-xZSf3IMh.js → SchemaList-BU0zCHn9.js} +28 -27
  308. package/lib/SchemaList-BU0zCHn9.js.map +1 -0
  309. package/lib/SchemaView-DVae4RO2.js +597 -0
  310. package/lib/SchemaView-DVae4RO2.js.map +1 -0
  311. package/lib/Select-CkxXP5I7.js +243 -0
  312. package/lib/Select-CkxXP5I7.js.map +1 -0
  313. package/lib/Separator-CTPSeW1S.js +27 -0
  314. package/lib/Separator-CTPSeW1S.js.map +1 -0
  315. package/lib/{SignUp-6SGx9Yyq.js → SignUp-BjS4ozA7.js} +13 -13
  316. package/lib/{SignUp-6SGx9Yyq.js.map → SignUp-BjS4ozA7.js.map} +1 -1
  317. package/lib/{SyntaxHighlight-zvlnSnHB.js → SyntaxHighlight-Kdyskw3C.js} +710 -662
  318. package/lib/{SyntaxHighlight-zvlnSnHB.js.map → SyntaxHighlight-Kdyskw3C.js.map} +1 -1
  319. package/lib/{Toc-Da9yp7lo.js → Toc-DJxFPfcS.js} +2 -2
  320. package/lib/{Toc-Da9yp7lo.js.map → Toc-DJxFPfcS.js.map} +1 -1
  321. package/lib/{ZudokuContext-BUZ5hkWB.js → ZudokuContext-BXldanA8.js} +11 -11
  322. package/lib/{ZudokuContext-BUZ5hkWB.js.map → ZudokuContext-BXldanA8.js.map} +1 -1
  323. package/lib/___vite-browser-external_commonjs-proxy-Cga3HsWk.js +9 -0
  324. package/lib/___vite-browser-external_commonjs-proxy-Cga3HsWk.js.map +1 -0
  325. package/lib/{chunk-PVWAREVJ-BMhpCH5D.js → chunk-PVWAREVJ-dLIqswPy.js} +5 -5
  326. package/lib/{chunk-PVWAREVJ-BMhpCH5D.js.map → chunk-PVWAREVJ-dLIqswPy.js.map} +1 -1
  327. package/lib/{circular-DvuimBGQ.js → circular-CzWF1hj5.js} +6360 -5953
  328. package/lib/circular-CzWF1hj5.js.map +1 -0
  329. package/lib/createServer-BIr2_tGn.js +16693 -0
  330. package/lib/createServer-BIr2_tGn.js.map +1 -0
  331. package/lib/createVariantComponent-B9_dVBvu.js +35 -0
  332. package/lib/createVariantComponent-B9_dVBvu.js.map +1 -0
  333. package/lib/{errors-CuGgh3hf.js → errors-Bs4duWDy.js} +3 -3
  334. package/lib/{errors-CuGgh3hf.js.map → errors-Bs4duWDy.js.map} +1 -1
  335. package/lib/firebase-Cax7HPzn.js +7360 -0
  336. package/lib/firebase-Cax7HPzn.js.map +1 -0
  337. package/lib/{hook-CMeoxziF.js → hook-BNxidGQq.js} +3 -3
  338. package/lib/{hook-CMeoxziF.js.map → hook-BNxidGQq.js.map} +1 -1
  339. package/lib/index-0oT9beQN.js +3676 -0
  340. package/lib/index-0oT9beQN.js.map +1 -0
  341. package/lib/{index-rYHsvtTo.js → index-Bh-MffiL.js} +2 -2
  342. package/lib/{index-rYHsvtTo.js.map → index-Bh-MffiL.js.map} +1 -1
  343. package/lib/{index-B1rmok4X.js → index-CCmMJp02.js} +10 -10
  344. package/lib/{index-B1rmok4X.js.map → index-CCmMJp02.js.map} +1 -1
  345. package/lib/index-CrcNWbel.js.map +1 -1
  346. package/lib/index-Css56y3F.js +133 -0
  347. package/lib/index-Css56y3F.js.map +1 -0
  348. package/lib/index.esm-DDENMN4y.js +32 -0
  349. package/lib/index.esm-DDENMN4y.js.map +1 -0
  350. package/lib/{index.esm-BnYHxCYC.js → index.esm-DtzT_KoE.js} +20 -20
  351. package/lib/{index.esm-BnYHxCYC.js.map → index.esm-DtzT_KoE.js.map} +1 -1
  352. package/lib/{invariant-Bm-FVUQE.js → invariant-CGOLuIIz.js} +3 -3
  353. package/lib/{invariant-Bm-FVUQE.js.map → invariant-CGOLuIIz.js.map} +1 -1
  354. package/lib/{mutation-BSU0xu4m.js → mutation-BoVlx8yA.js} +2 -2
  355. package/lib/{mutation-BSU0xu4m.js.map → mutation-BoVlx8yA.js.map} +1 -1
  356. package/lib/ui/ActionButton.js +1 -1
  357. package/lib/ui/Badge.js +27 -13
  358. package/lib/ui/Badge.js.map +1 -1
  359. package/lib/ui/Button.js +26 -24
  360. package/lib/ui/Button.js.map +1 -1
  361. package/lib/ui/ButtonGroup.js +77 -0
  362. package/lib/ui/ButtonGroup.js.map +1 -0
  363. package/lib/ui/Checkbox.js +29 -26
  364. package/lib/ui/Checkbox.js.map +1 -1
  365. package/lib/ui/CodeBlock.js +7 -7
  366. package/lib/ui/CodeBlock.js.map +1 -1
  367. package/lib/ui/Collapsible.js +32 -5
  368. package/lib/ui/Collapsible.js.map +1 -1
  369. package/lib/ui/Command.js +3 -3
  370. package/lib/ui/Command.js.map +1 -1
  371. package/lib/ui/DropdownMenu.js +227 -140
  372. package/lib/ui/DropdownMenu.js.map +1 -1
  373. package/lib/ui/EmbeddedCodeBlock.js +26 -25
  374. package/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  375. package/lib/ui/Frame.js +81 -0
  376. package/lib/ui/Frame.js.map +1 -0
  377. package/lib/ui/Item.js +188 -0
  378. package/lib/ui/Item.js.map +1 -0
  379. package/lib/ui/Kbd.js +32 -0
  380. package/lib/ui/Kbd.js.map +1 -0
  381. package/lib/ui/NativeSelect.js +57 -0
  382. package/lib/ui/NativeSelect.js.map +1 -0
  383. package/lib/ui/Select.js +166 -116
  384. package/lib/ui/Select.js.map +1 -1
  385. package/lib/ui/Separator.js +27 -0
  386. package/lib/ui/Separator.js.map +1 -0
  387. package/lib/ui/SyntaxHighlight.js +3 -3
  388. package/lib/ui/Tabs.js +10 -10
  389. package/lib/ui/Tooltip.js +55 -28
  390. package/lib/ui/Tooltip.js.map +1 -1
  391. package/lib/useMutation-C6RqWmTS.js +97 -0
  392. package/lib/useMutation-C6RqWmTS.js.map +1 -0
  393. package/lib/zudoku.__internal.js +349 -349
  394. package/lib/zudoku.__internal.js.map +1 -1
  395. package/lib/zudoku.auth-auth0.js +7 -7
  396. package/lib/zudoku.auth-auth0.js.map +1 -1
  397. package/lib/zudoku.auth-azureb2c.js +4 -4
  398. package/lib/zudoku.auth-clerk.js +2 -2
  399. package/lib/zudoku.auth-firebase.js +9 -0
  400. package/lib/zudoku.auth-firebase.js.map +1 -0
  401. package/lib/zudoku.auth-openid.js +5 -5
  402. package/lib/zudoku.auth-supabase.js +31 -34
  403. package/lib/zudoku.auth-supabase.js.map +1 -1
  404. package/lib/zudoku.components.js +7 -7
  405. package/lib/zudoku.hooks.js +11 -24
  406. package/lib/zudoku.hooks.js.map +1 -1
  407. package/lib/zudoku.mermaid.js +10 -0
  408. package/lib/zudoku.mermaid.js.map +1 -0
  409. package/lib/zudoku.plugin-api-catalog.js +6 -6
  410. package/lib/zudoku.plugin-api-keys.js +225 -216
  411. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  412. package/lib/zudoku.plugin-custom-pages.js +1 -1
  413. package/lib/zudoku.plugin-markdown.js +1 -1
  414. package/lib/zudoku.plugin-openapi.js +3 -3
  415. package/lib/zudoku.plugin-redirect.js +1 -1
  416. package/lib/zudoku.plugin-search-pagefind.js +184 -226
  417. package/lib/zudoku.plugin-search-pagefind.js.map +1 -1
  418. package/lib/zudoku.plugins.js.map +1 -1
  419. package/lib/zudoku.router.js +2 -2
  420. package/package.json +44 -27
  421. package/src/app/main.css +1 -1
  422. package/src/app/main.tsx +5 -1
  423. package/src/app/sentry.ts +1 -1
  424. package/src/lib/auth/issuer.ts +3 -0
  425. package/src/lib/authentication/authentication.ts +1 -1
  426. package/src/lib/authentication/providers/auth0.tsx +6 -1
  427. package/src/lib/authentication/providers/firebase.tsx +284 -0
  428. package/src/lib/authentication/providers/supabase.tsx +2 -7
  429. package/src/lib/authentication/ui/ZudokuAuthUi.tsx +335 -0
  430. package/src/lib/authentication/ui/icons/Apple.tsx +10 -0
  431. package/src/lib/authentication/ui/icons/Facebook.tsx +15 -0
  432. package/src/lib/authentication/ui/icons/Github.tsx +16 -0
  433. package/src/lib/authentication/ui/icons/Google.tsx +16 -0
  434. package/src/lib/authentication/ui/icons/Microsoft.tsx +12 -0
  435. package/src/lib/authentication/ui/icons/X.tsx +10 -0
  436. package/src/lib/components/Autocomplete.tsx +11 -2
  437. package/src/lib/components/Layout.tsx +3 -2
  438. package/src/lib/components/Mermaid.tsx +68 -0
  439. package/src/lib/components/PagefindSearchMeta.tsx +14 -0
  440. package/src/lib/components/Zudoku.tsx +4 -7
  441. package/src/lib/components/navigation/NavigationItem.tsx +7 -20
  442. package/src/lib/core/RouteGuard.tsx +9 -9
  443. package/src/lib/core/plugins.ts +2 -2
  444. package/src/lib/errors/ErrorAlert.tsx +1 -1
  445. package/src/lib/errors/RouterError.tsx +7 -2
  446. package/src/lib/oas/parser/index.ts +10 -3
  447. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +11 -7
  448. package/src/lib/plugins/openapi/CollapsibleCode.tsx +5 -3
  449. package/src/lib/plugins/openapi/DownloadSchemaButton.tsx +115 -0
  450. package/src/lib/plugins/openapi/Endpoint.tsx +20 -27
  451. package/src/lib/plugins/openapi/GeneratedExampleSidecarBox.tsx +52 -0
  452. package/src/lib/plugins/openapi/OasProvider.tsx +30 -17
  453. package/src/lib/plugins/openapi/OperationList.tsx +46 -21
  454. package/src/lib/plugins/openapi/OperationListItem.tsx +15 -12
  455. package/src/lib/plugins/openapi/ParameterList.tsx +37 -23
  456. package/src/lib/plugins/openapi/ParameterListItem.tsx +105 -54
  457. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +48 -7
  458. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +101 -33
  459. package/src/lib/plugins/openapi/SchemaList.tsx +4 -0
  460. package/src/lib/plugins/openapi/Sidecar.tsx +145 -65
  461. package/src/lib/plugins/openapi/SidecarBox.tsx +26 -4
  462. package/src/lib/plugins/openapi/SidecarExamples.tsx +91 -79
  463. package/src/lib/plugins/openapi/components/ConstValue.tsx +1 -1
  464. package/src/lib/plugins/openapi/components/EnumValues.tsx +2 -2
  465. package/src/lib/plugins/openapi/components/NonHighlightedCode.tsx +22 -0
  466. package/src/lib/plugins/openapi/components/ResponseContent.tsx +63 -53
  467. package/src/lib/plugins/openapi/index.tsx +16 -7
  468. package/src/lib/plugins/openapi/interfaces.ts +28 -7
  469. package/src/lib/plugins/openapi/playground/BodyPanel.tsx +246 -30
  470. package/src/lib/plugins/openapi/playground/CollapsibleHeader.tsx +10 -6
  471. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +3 -2
  472. package/src/lib/plugins/openapi/playground/Headers.tsx +103 -219
  473. package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +33 -1
  474. package/src/lib/plugins/openapi/playground/PathParams.tsx +26 -34
  475. package/src/lib/plugins/openapi/playground/Playground.tsx +75 -33
  476. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +9 -30
  477. package/src/lib/plugins/openapi/playground/QueryParams.tsx +82 -136
  478. package/src/lib/plugins/openapi/playground/request-panel/MultipartField.tsx +91 -0
  479. package/src/lib/plugins/openapi/playground/request-panel/UrlQueryParams.tsx +1 -1
  480. package/src/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.tsx +872 -0
  481. package/src/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.ts +349 -0
  482. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +2 -6
  483. package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +1 -1
  484. package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +89 -55
  485. package/src/lib/plugins/openapi/schema/SchemaView.tsx +98 -60
  486. package/src/lib/plugins/openapi/schema/UnionView.tsx +6 -17
  487. package/src/lib/plugins/openapi/schema/union-helpers.ts +0 -1
  488. package/src/lib/plugins/openapi/schema/utils.ts +5 -2
  489. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +11 -11
  490. package/src/lib/plugins/openapi/util/getRoutes.tsx +35 -3
  491. package/src/lib/plugins/search-pagefind/IndexingDialog.tsx +163 -0
  492. package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +61 -22
  493. package/src/lib/plugins/search-pagefind/ResultList.tsx +8 -3
  494. package/src/lib/shiki.ts +21 -12
  495. package/src/lib/ui/Badge.tsx +21 -12
  496. package/src/lib/ui/Button.tsx +10 -9
  497. package/src/lib/ui/ButtonGroup.tsx +82 -0
  498. package/src/lib/ui/Checkbox.tsx +23 -24
  499. package/src/lib/ui/CodeBlock.tsx +3 -4
  500. package/src/lib/ui/Collapsible.tsx +26 -4
  501. package/src/lib/ui/Command.tsx +3 -3
  502. package/src/lib/ui/DropdownMenu.tsx +226 -170
  503. package/src/lib/ui/EmbeddedCodeBlock.tsx +21 -19
  504. package/src/lib/ui/Frame.tsx +81 -0
  505. package/src/lib/ui/Item.tsx +192 -0
  506. package/src/lib/ui/Kbd.tsx +28 -0
  507. package/src/lib/ui/NativeSelect.tsx +47 -0
  508. package/src/lib/ui/Select.tsx +153 -126
  509. package/src/lib/ui/Separator.tsx +25 -0
  510. package/src/lib/ui/Tooltip.tsx +54 -32
  511. package/src/lib/util/MdxComponents.tsx +2 -0
  512. package/src/lib/util/createVariantComponent.tsx +31 -5
  513. package/src/lib/util/flattenAllOf.test.ts +689 -0
  514. package/src/lib/util/flattenAllOf.ts +122 -0
  515. package/src/lib/util/readFrontmatter.ts +13 -0
  516. package/src/shiki/langs/markdown-nix.js +1 -0
  517. package/src/shiki/langs/openscad.js +1 -0
  518. package/dist/lib/plugins/openapi/playground/InlineInput.d.ts +0 -4
  519. package/dist/lib/plugins/openapi/playground/InlineInput.js +0 -3
  520. package/dist/lib/plugins/openapi/playground/InlineInput.js.map +0 -1
  521. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.d.ts +0 -5
  522. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js +0 -7
  523. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js.map +0 -1
  524. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.d.ts +0 -4
  525. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js +0 -10
  526. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js.map +0 -1
  527. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.d.ts +0 -5
  528. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js +0 -16
  529. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js.map +0 -1
  530. package/dist/vite/create-pagefind-index.d.ts +0 -4
  531. package/dist/vite/create-pagefind-index.js +0 -12
  532. package/dist/vite/create-pagefind-index.js.map +0 -1
  533. package/lib/Button-DmS4u8Lj.js +0 -51
  534. package/lib/Button-DmS4u8Lj.js.map +0 -1
  535. package/lib/Command-CUcrW3qs.js.map +0 -1
  536. package/lib/DropdownMenu-BZ2NKQ3K.js +0 -126
  537. package/lib/DropdownMenu-BZ2NKQ3K.js.map +0 -1
  538. package/lib/ErrorAlert-DE3Sf66a.js.map +0 -1
  539. package/lib/MdxPage-DZfeC0QY.js +0 -240
  540. package/lib/MdxPage-DZfeC0QY.js.map +0 -1
  541. package/lib/OasProvider-Bf5zBDBY.js +0 -36
  542. package/lib/OasProvider-Bf5zBDBY.js.map +0 -1
  543. package/lib/OperationList-Cmiw1xm2.js +0 -5446
  544. package/lib/OperationList-Cmiw1xm2.js.map +0 -1
  545. package/lib/Pagination-CJszmeSA.js +0 -37
  546. package/lib/Pagination-CJszmeSA.js.map +0 -1
  547. package/lib/RouteGuard-DhU3LRr1.js +0 -81
  548. package/lib/RouteGuard-DhU3LRr1.js.map +0 -1
  549. package/lib/RouterError-VDLnrFqF.js +0 -41
  550. package/lib/RouterError-VDLnrFqF.js.map +0 -1
  551. package/lib/SchemaList-xZSf3IMh.js.map +0 -1
  552. package/lib/SchemaView-tHXTm5oM.js +0 -458
  553. package/lib/SchemaView-tHXTm5oM.js.map +0 -1
  554. package/lib/Select-C1DeCqKv.js +0 -372
  555. package/lib/Select-C1DeCqKv.js.map +0 -1
  556. package/lib/circular-DvuimBGQ.js.map +0 -1
  557. package/lib/createServer-D9UvCoDf.js +0 -12559
  558. package/lib/createServer-D9UvCoDf.js.map +0 -1
  559. package/lib/index-Cr9_YzOZ.js +0 -3364
  560. package/lib/index-Cr9_YzOZ.js.map +0 -1
  561. package/lib/useExposedProps-U3pmsHaG.js +0 -113
  562. package/lib/useExposedProps-U3pmsHaG.js.map +0 -1
  563. package/src/lib/plugins/openapi/playground/InlineInput.tsx +0 -6
  564. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.tsx +0 -36
  565. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.tsx +0 -25
  566. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.tsx +0 -42
@@ -0,0 +1,349 @@
1
+ import {
2
+ type ComponentPropsWithoutRef,
3
+ type KeyboardEvent,
4
+ startTransition,
5
+ useCallback,
6
+ useEffect,
7
+ useRef,
8
+ } from "react";
9
+ import type {
10
+ Control,
11
+ FieldArrayPath,
12
+ FieldArrayWithId,
13
+ FieldValues,
14
+ PathValue,
15
+ } from "react-hook-form";
16
+ import { useFieldArray, useFormContext } from "react-hook-form";
17
+
18
+ export type Value =
19
+ | string
20
+ | number
21
+ | readonly string[]
22
+ | File
23
+ | boolean
24
+ | undefined;
25
+
26
+ export type KeyValueField = {
27
+ name: string;
28
+ value: Value;
29
+ active: boolean;
30
+ };
31
+
32
+ export type KeyValueFieldManagerOptions<
33
+ TFormData extends FieldValues,
34
+ TName extends FieldArrayPath<TFormData>,
35
+ T extends KeyValueField = PathValue<TFormData, TName>[number],
36
+ > = {
37
+ control: Control<TFormData>;
38
+ name: TName;
39
+ defaultValue: T;
40
+ isEmpty?: (item: T) => boolean;
41
+ shouldSetActive?: (item: T) => boolean;
42
+ };
43
+
44
+ export type CheckboxProps = {
45
+ checked: boolean;
46
+ disabled?: boolean;
47
+ onCheckedChange: (checked: boolean) => void;
48
+ };
49
+
50
+ export type RemoveButtonProps = { onClick: () => void; disabled?: boolean };
51
+
52
+ type SetValueFn = (
53
+ index: number,
54
+ field: keyof KeyValueField,
55
+ value: Value,
56
+ options?: { focus?: "next" | "previous" },
57
+ ) => void;
58
+
59
+ type GetValueFn = (index: number, field: keyof KeyValueField) => Value;
60
+
61
+ export type UseKeyValueFieldManagerReturn<TFormData extends FieldValues> = {
62
+ fields: FieldArrayWithId<TFormData>[];
63
+ getNameInputProps: GetInputPropsFn;
64
+ getValueInputProps: GetInputPropsFn;
65
+ getCheckboxProps: (index: number) => CheckboxProps;
66
+ getRemoveButtonProps: (index: number) => RemoveButtonProps;
67
+ setValue: SetValueFn;
68
+ getValue: GetValueFn;
69
+ };
70
+
71
+ type GetInputPropsFn = (index: number) => ComponentPropsWithoutRef<"input">;
72
+
73
+ export const useKeyValueFieldManager = <
74
+ TFormData extends FieldValues,
75
+ TName extends FieldArrayPath<TFormData>,
76
+ T extends KeyValueField = PathValue<TFormData, TName>[number],
77
+ >(
78
+ options: KeyValueFieldManagerOptions<TFormData, TName>,
79
+ ): UseKeyValueFieldManagerReturn<TFormData> => {
80
+ const {
81
+ control,
82
+ name,
83
+ defaultValue,
84
+ isEmpty: customIsEmpty,
85
+ shouldSetActive: customShouldSetActive,
86
+ } = options;
87
+ const {
88
+ setValue: internalSetValue,
89
+ watch,
90
+ setFocus,
91
+ register,
92
+ } = useFormContext();
93
+ const { fields, append, remove } = useFieldArray({ control, name });
94
+ const watchedFields = watch(name) as T[];
95
+ const lastEditedIndexRef = useRef(-1);
96
+ const prevLengthRef = useRef(-1);
97
+
98
+ const setValue = useCallback<SetValueFn>(
99
+ (index, field, value, options) => {
100
+ if (field === "value" || field === "name") {
101
+ lastEditedIndexRef.current = index;
102
+ }
103
+
104
+ // biome-ignore lint/suspicious/noExplicitAny: Can't infer the type of the value here
105
+ internalSetValue(`${name}.${index}.${field}`, value as any);
106
+
107
+ if (options?.focus === "next") {
108
+ setFocus(
109
+ field === "name"
110
+ ? `${name}.${index}.value`
111
+ : `${name}.${index + 1}.name`,
112
+ );
113
+ } else if (options?.focus === "previous") {
114
+ setFocus(
115
+ field === "name"
116
+ ? `${name}.${index - 1}.value`
117
+ : `${name}.${index}.name`,
118
+ );
119
+ }
120
+ },
121
+ [name, internalSetValue, setFocus],
122
+ );
123
+
124
+ const isEmpty = useCallback(
125
+ (item: T) => {
126
+ if (customIsEmpty) return customIsEmpty(item);
127
+ return !item.name && !item.value;
128
+ },
129
+ [customIsEmpty],
130
+ );
131
+
132
+ const shouldSetActive = useCallback(
133
+ (item: T) => {
134
+ if (customShouldSetActive) return customShouldSetActive(item);
135
+ return Boolean(item.name || item.value);
136
+ },
137
+ [customShouldSetActive],
138
+ );
139
+
140
+ // Handle auto append/remove of rows
141
+ useEffect(() => {
142
+ if (!watchedFields) return;
143
+
144
+ // Prevents double-appending in Strict Mode
145
+ if (prevLengthRef.current === -1) {
146
+ prevLengthRef.current = watchedFields.length;
147
+
148
+ if (watchedFields.length === 0) {
149
+ // biome-ignore lint/suspicious/noExplicitAny: Generic field array type
150
+ append(defaultValue as any, {
151
+ shouldFocus: false,
152
+ });
153
+ }
154
+ return;
155
+ }
156
+
157
+ prevLengthRef.current = watchedFields.length;
158
+
159
+ // If no fields, append one
160
+ if (watchedFields.length === 0) {
161
+ // biome-ignore lint/suspicious/noExplicitAny: Generic field array type
162
+ append(defaultValue as any, {
163
+ shouldFocus: false,
164
+ });
165
+ return;
166
+ }
167
+
168
+ // Auto-remove empty fields (except the last one, keep at least one)
169
+ if (watchedFields.length > 1) {
170
+ const emptyIndices: number[] = [];
171
+
172
+ // Check all fields except the last one
173
+ for (let i = 0; i < watchedFields.length - 1; i++) {
174
+ const field = watchedFields[i];
175
+ if (field && isEmpty(field) && !shouldSetActive(field)) {
176
+ emptyIndices.push(i);
177
+ }
178
+ }
179
+
180
+ // Remove from highest index to lowest to avoid index shifting
181
+ if (emptyIndices.length > 0) {
182
+ const lowestRemovedIndex = emptyIndices[0];
183
+
184
+ if (lowestRemovedIndex === undefined) return;
185
+
186
+ for (let i = emptyIndices.length - 1; i >= 0; i--) {
187
+ const indexToRemove = emptyIndices[i];
188
+ if (indexToRemove !== undefined) {
189
+ remove(indexToRemove);
190
+ }
191
+ }
192
+
193
+ // If we just edited this field, focus the name field at the same index
194
+ // (which now contains what was the next row), or previous row if needed
195
+ if (lastEditedIndexRef.current === lowestRemovedIndex) {
196
+ const newLength = watchedFields.length - emptyIndices.length;
197
+
198
+ if (lowestRemovedIndex < newLength) {
199
+ // Next row moved into this position, focus its name field
200
+ setFocus(`${name}.${lowestRemovedIndex}.name`);
201
+ } else if (lowestRemovedIndex > 0) {
202
+ // Removed row was at the end, focus previous row's name
203
+ setFocus(`${name}.${lowestRemovedIndex - 1}.name`);
204
+ } else {
205
+ setFocus(`${name}.0.name`);
206
+ }
207
+ }
208
+ lastEditedIndexRef.current = -1;
209
+ }
210
+ }
211
+
212
+ // If last field has content, append empty one
213
+ const lastField = watchedFields[watchedFields.length - 1];
214
+ if (lastField && !isEmpty(lastField)) {
215
+ // biome-ignore lint/suspicious/noExplicitAny: Generic field array type
216
+ append(defaultValue as any, {
217
+ shouldFocus: false,
218
+ });
219
+ }
220
+ }, [
221
+ watchedFields,
222
+ append,
223
+ remove,
224
+ defaultValue,
225
+ isEmpty,
226
+ name,
227
+ setFocus,
228
+ shouldSetActive,
229
+ ]);
230
+
231
+ // Auto set active state of row checkbox
232
+ useEffect(() => {
233
+ if (!watchedFields) return;
234
+
235
+ const updates: Array<() => void> = [];
236
+
237
+ for (let i = 0; i < watchedFields.length; i++) {
238
+ const field = watchedFields[i];
239
+ if (!field) continue;
240
+
241
+ const shouldBeActive = shouldSetActive(field);
242
+ if (field.active === shouldBeActive) continue;
243
+
244
+ updates.push(() => setValue(i, "active", shouldBeActive));
245
+ }
246
+
247
+ if (updates.length === 0) return;
248
+
249
+ startTransition(() => updates.forEach((update) => update()));
250
+ }, [watchedFields, shouldSetActive, setValue]);
251
+
252
+ const isFieldEmpty = useCallback(
253
+ (index: number) => {
254
+ const field = watchedFields?.[index];
255
+ return field ? isEmpty(field) : true;
256
+ },
257
+ [watchedFields, isEmpty],
258
+ );
259
+
260
+ const createKeyDownHandler = useCallback(
261
+ (index: number, field: "name" | "value") => {
262
+ const next =
263
+ field === "name"
264
+ ? `${name}.${index}.value`
265
+ : `${name}.${index + 1}.name`;
266
+
267
+ const previous =
268
+ field === "name"
269
+ ? `${name}.${index - 1}.value`
270
+ : `${name}.${index}.name`;
271
+ const canNavigatePrevious = field === "value" || index > 0;
272
+
273
+ return (e: KeyboardEvent<HTMLInputElement>) => {
274
+ if (!(e.target instanceof HTMLInputElement)) return;
275
+
276
+ const isAtStart = e.target.selectionStart === 0;
277
+ const isAtEnd = e.target.selectionStart === e.target.value.length;
278
+ const isEmpty = !e.target.value;
279
+
280
+ if (e.key === "Enter") {
281
+ setFocus(next);
282
+ } else if (e.key === "Backspace" && isEmpty && canNavigatePrevious) {
283
+ e.preventDefault();
284
+ setFocus(previous);
285
+ } else if (e.key === "ArrowLeft" && isAtStart && canNavigatePrevious) {
286
+ e.preventDefault();
287
+ setFocus(previous);
288
+ } else if (e.key === "ArrowRight" && isAtEnd) {
289
+ e.preventDefault();
290
+ setFocus(next);
291
+ }
292
+ };
293
+ },
294
+ [name, setFocus],
295
+ );
296
+
297
+ const getNameInputProps = useCallback<GetInputPropsFn>(
298
+ (index) => ({
299
+ ...register(`${name}.${index}.name`),
300
+ onChange: (e) => setValue(index, "name", e.target.value),
301
+ onKeyDown: createKeyDownHandler(index, "name"),
302
+ }),
303
+ [register, name, setValue, createKeyDownHandler],
304
+ );
305
+
306
+ const getValueInputProps = useCallback<GetInputPropsFn>(
307
+ (index) => ({
308
+ ...register(`${name}.${index}.value`),
309
+ onChange: (e) => setValue(index, "value", e.target.value),
310
+ onKeyDown: createKeyDownHandler(index, "value"),
311
+ }),
312
+ [register, name, setValue, createKeyDownHandler],
313
+ );
314
+
315
+ const getCheckboxProps = useCallback<(index: number) => CheckboxProps>(
316
+ (index) => ({
317
+ ...register(`${name}.${index}.active`),
318
+ checked: watch(`${name}.${index}.active`) ?? false,
319
+ disabled: isFieldEmpty(index),
320
+ onCheckedChange: (checked: boolean) => {
321
+ setValue(index, "active", checked === true);
322
+ },
323
+ }),
324
+ [name, register, isFieldEmpty, watch, setValue],
325
+ );
326
+
327
+ const getValue = useCallback<GetValueFn>(
328
+ (index, field) => watchedFields?.[index]?.[field],
329
+ [watchedFields],
330
+ );
331
+
332
+ const getRemoveButtonProps = useCallback(
333
+ (index: number) => ({
334
+ onClick: () => remove(index),
335
+ disabled: index === fields.length - 1,
336
+ }),
337
+ [remove, fields.length],
338
+ );
339
+
340
+ return {
341
+ fields,
342
+ getNameInputProps,
343
+ getValueInputProps,
344
+ getCheckboxProps,
345
+ getRemoveButtonProps,
346
+ setValue,
347
+ getValue,
348
+ };
349
+ };
@@ -184,9 +184,7 @@ export const ResponseTab = ({
184
184
  <Collapsible defaultOpen>
185
185
  <CollapsibleHeaderTrigger>
186
186
  <CornerDownRightIcon size={14} />
187
- <CollapsibleHeader className="col-span-2">
188
- Request Headers
189
- </CollapsibleHeader>
187
+ <CollapsibleHeader>Request Headers</CollapsibleHeader>
190
188
  </CollapsibleHeaderTrigger>
191
189
  <CollapsibleContent>
192
190
  <div className="grid grid-cols-[2fr_3fr] gap-x-6 text-sm">
@@ -231,9 +229,7 @@ export const ResponseTab = ({
231
229
  <Collapsible defaultOpen>
232
230
  <CollapsibleHeaderTrigger>
233
231
  <CornerDownLeftIcon size={14} />
234
- <CollapsibleHeader className="col-span-2">
235
- Response Headers
236
- </CollapsibleHeader>
232
+ <CollapsibleHeader>Response Headers</CollapsibleHeader>
237
233
  </CollapsibleHeaderTrigger>
238
234
  <CollapsibleContent>
239
235
  <div className="grid grid-cols-[2fr_3fr] gap-x-6 text-sm">
@@ -12,7 +12,7 @@ export const SchemaExampleAndDefault = ({
12
12
  if (example === undefined && defaultValue === undefined) return null;
13
13
 
14
14
  return (
15
- <div className="flex flex-col gap-1 text-xs">
15
+ <div className="flex flex-col gap-1">
16
16
  {example !== undefined && (
17
17
  <div>
18
18
  <span className="text-muted-foreground">Example: </span>
@@ -1,15 +1,15 @@
1
1
  import * as Collapsible from "@radix-ui/react-collapsible";
2
2
  import { MinusIcon, PlusIcon, RefreshCcwDotIcon } from "lucide-react";
3
3
  import { useState } from "react";
4
+ import { Item, ItemActions, ItemContent, ItemTitle } from "zudoku/ui/Item.js";
4
5
  import { InlineCode } from "../../../components/InlineCode.js";
5
6
  import { Markdown } from "../../../components/Markdown.js";
6
7
  import type { SchemaObject } from "../../../oas/parser/index.js";
7
8
  import { Button } from "../../../ui/Button.js";
9
+ import { cn } from "../../../util/cn.js";
8
10
  import { ConstValue } from "../components/ConstValue.js";
9
11
  import { EnumValues } from "../components/EnumValues.js";
10
- import { SelectOnClick } from "../components/SelectOnClick.js";
11
12
  import { ParamInfos } from "../ParamInfos.js";
12
- import { AllOfGroupView } from "./AllOfGroup/AllOfGroupView.js";
13
13
  import { SchemaExampleAndDefault } from "./SchemaExampleAndDefault.js";
14
14
  import { SchemaView } from "./SchemaView.js";
15
15
  import {
@@ -22,7 +22,7 @@ import {
22
22
 
23
23
  const RecursiveIndicator = ({ circularProp }: { circularProp?: string }) => (
24
24
  <InlineCode
25
- className="inline-flex items-center gap-1.5 italic text-xs translate-y-0.5"
25
+ className="inline-flex items-center gap-1.5 text-xs translate-y-0.5"
26
26
  selectOnClick={false}
27
27
  >
28
28
  <RefreshCcwDotIcon size={13} />
@@ -47,18 +47,26 @@ export const SchemaPropertyItem = ({
47
47
 
48
48
  if (isCircularRef(schema)) {
49
49
  return (
50
- <li className="p-4 bg-border/20 hover:bg-border/30">
51
- <div className="flex flex-col gap-2.5 justify-between text-sm">
52
- <div className="space-x-2 rtl:space-x-reverse">
53
- <code>{name}</code>
50
+ <Item>
51
+ <ItemContent className="gap-y-2">
52
+ <div>
53
+ <ItemTitle className="inline me-2">
54
+ <code>{name}</code>
55
+ </ItemTitle>
54
56
  <ParamInfos
57
+ className="inline"
55
58
  schema={schema}
56
- extraItems={[<RecursiveIndicator key="circular-ref" />]}
59
+ extraItems={[
60
+ group !== "optional" && (
61
+ <span className="text-primary">required</span>
62
+ ),
63
+ <RecursiveIndicator key="circular-ref" />,
64
+ ]}
57
65
  />
58
66
  </div>
59
67
  <SchemaExampleAndDefault schema={schema} />
60
- </div>
61
- </li>
68
+ </ItemContent>
69
+ </Item>
62
70
  );
63
71
  }
64
72
 
@@ -74,14 +82,34 @@ export const SchemaPropertyItem = ({
74
82
  !isArrayCircularRef(schema),
75
83
  );
76
84
 
85
+ const shouldRenderDescription = Boolean(
86
+ schema.description ||
87
+ ("items" in schema && schema.items?.enum) ||
88
+ schema.const ||
89
+ schema.enum ||
90
+ schema.example !== undefined ||
91
+ schema.default !== undefined,
92
+ );
93
+
77
94
  return (
78
- <li className="p-4 bg-border/20 hover:bg-border/30">
79
- <div className="flex flex-col gap-2.5 justify-between text-sm">
80
- <div className="space-x-2 rtl:space-x-reverse">
81
- <SelectOnClick asChild>
82
- <code>{name}</code>
83
- </SelectOnClick>
95
+ <Item>
96
+ <ItemContent className="gap-y-2">
97
+ <div>
98
+ <ItemTitle className="inline me-2">
99
+ {isCollapsible ? (
100
+ <button
101
+ onClick={() => setIsOpen(!isOpen)}
102
+ type="button"
103
+ className="hover:underline"
104
+ >
105
+ <code>{name}</code>
106
+ </button>
107
+ ) : (
108
+ <code>{name}</code>
109
+ )}
110
+ </ItemTitle>
84
111
  <ParamInfos
112
+ className="inline"
85
113
  schema={schema}
86
114
  extraItems={[
87
115
  group !== "optional" && (
@@ -95,47 +123,53 @@ export const SchemaPropertyItem = ({
95
123
  ]}
96
124
  />
97
125
  </div>
98
- {schema.description && (
99
- <Markdown
100
- className="text-sm leading-normal"
101
- content={schema.description}
102
- />
103
- )}
104
- {schema.type === "array" && "items" in schema && schema.items.enum && (
105
- <EnumValues values={schema.items.enum} />
126
+ {shouldRenderDescription && (
127
+ <div className="flex flex-col gap-1.5">
128
+ {schema.description && (
129
+ <Markdown className="prose-sm" content={schema.description} />
130
+ )}
131
+ {"items" in schema && schema.items?.enum && (
132
+ <EnumValues values={schema.items.enum} />
133
+ )}
134
+ {schema.const && <ConstValue schema={schema} hideDescription />}
135
+ {schema.enum && <EnumValues values={schema.enum} />}
136
+ <SchemaExampleAndDefault schema={schema} />
137
+ </div>
106
138
  )}
107
- {schema.const && <ConstValue schema={schema} hideDescription />}
108
- {schema.enum && <EnumValues values={schema.enum} />}
109
- <SchemaExampleAndDefault schema={schema} />
139
+ </ItemContent>
110
140
 
111
- {isCollapsible && (
112
- <Collapsible.Root
113
- defaultOpen={defaultOpen}
114
- open={isOpen}
115
- onOpenChange={() => setIsOpen(!isOpen)}
141
+ {isCollapsible && showCollapseButton && (
142
+ <ItemActions className="self-start">
143
+ <Button
144
+ variant="ghost"
145
+ size="icon"
146
+ className="rounded-full"
147
+ onClick={() => setIsOpen(!isOpen)}
148
+ aria-label="Toggle properties"
116
149
  >
117
- {showCollapseButton && (
118
- <Collapsible.Trigger asChild>
119
- <Button variant="expand" size="sm">
120
- {isOpen ? <MinusIcon size={12} /> : <PlusIcon size={12} />}
121
- {!isOpen ? "Show properties" : "Hide properties"}
122
- </Button>
123
- </Collapsible.Trigger>
124
- )}
125
- <Collapsible.Content>
126
- <div className="mt-2">
127
- {schema.allOf ? (
128
- <AllOfGroupView schema={schema} />
129
- ) : schema.anyOf || schema.oneOf || schema.type === "object" ? (
130
- <SchemaView schema={schema} />
131
- ) : isArrayType(schema) && "items" in schema ? (
132
- <SchemaView schema={schema.items} />
133
- ) : null}
134
- </div>
135
- </Collapsible.Content>
136
- </Collapsible.Root>
137
- )}
138
- </div>
139
- </li>
150
+ {isOpen ? <MinusIcon size={16} /> : <PlusIcon size={16} />}
151
+ </Button>
152
+ </ItemActions>
153
+ )}
154
+
155
+ {isCollapsible && (
156
+ <Collapsible.Root
157
+ defaultOpen={defaultOpen}
158
+ open={isOpen}
159
+ onOpenChange={setIsOpen}
160
+ className={cn("w-full", !isOpen && "contents")}
161
+ >
162
+ <Collapsible.Content asChild>
163
+ <ItemContent>
164
+ {schema.anyOf || schema.oneOf || schema.type === "object" ? (
165
+ <SchemaView schema={schema} />
166
+ ) : isArrayType(schema) && "items" in schema ? (
167
+ <SchemaView schema={schema.items} />
168
+ ) : null}
169
+ </ItemContent>
170
+ </Collapsible.Content>
171
+ </Collapsible.Root>
172
+ )}
173
+ </Item>
140
174
  );
141
175
  };