zudoku 0.64.1 → 0.65.0

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 (402) 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/config/config.d.ts +15 -46
  5. package/dist/config/validators/InputNavigationSchema.d.ts +61 -61
  6. package/dist/config/validators/NavigationSchema.js +2 -4
  7. package/dist/config/validators/NavigationSchema.js.map +1 -1
  8. package/dist/config/validators/ProtectedRoutesSchema.d.ts +1 -1
  9. package/dist/config/validators/validate.d.ts +158 -2
  10. package/dist/config/validators/validate.js +37 -0
  11. package/dist/config/validators/validate.js.map +1 -1
  12. package/dist/config/validators/validate.test.js +43 -0
  13. package/dist/config/validators/validate.test.js.map +1 -1
  14. package/dist/flat-config.d.ts +22 -0
  15. package/dist/lib/auth/issuer.js +3 -0
  16. package/dist/lib/auth/issuer.js.map +1 -1
  17. package/dist/lib/authentication/authentication.d.ts +1 -1
  18. package/dist/lib/authentication/providers/auth0.js +6 -1
  19. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  20. package/dist/lib/authentication/providers/firebase.d.ts +4 -0
  21. package/dist/lib/authentication/providers/firebase.js +215 -0
  22. package/dist/lib/authentication/providers/firebase.js.map +1 -0
  23. package/dist/lib/authentication/providers/supabase.js +1 -6
  24. package/dist/lib/authentication/providers/supabase.js.map +1 -1
  25. package/dist/lib/authentication/ui/ZudokuAuthUi.d.ts +24 -0
  26. package/dist/lib/authentication/ui/ZudokuAuthUi.js +124 -0
  27. package/dist/lib/authentication/ui/ZudokuAuthUi.js.map +1 -0
  28. package/dist/lib/authentication/ui/icons/Apple.d.ts +3 -0
  29. package/dist/lib/authentication/ui/icons/Apple.js +4 -0
  30. package/dist/lib/authentication/ui/icons/Apple.js.map +1 -0
  31. package/dist/lib/authentication/ui/icons/Facebook.d.ts +3 -0
  32. package/dist/lib/authentication/ui/icons/Facebook.js +4 -0
  33. package/dist/lib/authentication/ui/icons/Facebook.js.map +1 -0
  34. package/dist/lib/authentication/ui/icons/Github.d.ts +3 -0
  35. package/dist/lib/authentication/ui/icons/Github.js +4 -0
  36. package/dist/lib/authentication/ui/icons/Github.js.map +1 -0
  37. package/dist/lib/authentication/ui/icons/Google.d.ts +3 -0
  38. package/dist/lib/authentication/ui/icons/Google.js +4 -0
  39. package/dist/lib/authentication/ui/icons/Google.js.map +1 -0
  40. package/dist/lib/authentication/ui/icons/Microsoft.d.ts +3 -0
  41. package/dist/lib/authentication/ui/icons/Microsoft.js +4 -0
  42. package/dist/lib/authentication/ui/icons/Microsoft.js.map +1 -0
  43. package/dist/lib/authentication/ui/icons/X.d.ts +3 -0
  44. package/dist/lib/authentication/ui/icons/X.js +4 -0
  45. package/dist/lib/authentication/ui/icons/X.js.map +1 -0
  46. package/dist/lib/components/Autocomplete.d.ts +3 -1
  47. package/dist/lib/components/Autocomplete.js +6 -2
  48. package/dist/lib/components/Autocomplete.js.map +1 -1
  49. package/dist/lib/components/Heading.d.ts +1 -1
  50. package/dist/lib/components/Layout.js +3 -2
  51. package/dist/lib/components/Layout.js.map +1 -1
  52. package/dist/lib/components/navigation/NavigationItem.js +2 -2
  53. package/dist/lib/components/navigation/NavigationItem.js.map +1 -1
  54. package/dist/lib/core/RouteGuard.js +6 -6
  55. package/dist/lib/core/RouteGuard.js.map +1 -1
  56. package/dist/lib/errors/ErrorAlert.js +1 -1
  57. package/dist/lib/errors/RouterError.d.ts +3 -1
  58. package/dist/lib/errors/RouterError.js +3 -2
  59. package/dist/lib/errors/RouterError.js.map +1 -1
  60. package/dist/lib/oas/parser/index.js +7 -3
  61. package/dist/lib/oas/parser/index.js.map +1 -1
  62. package/dist/lib/plugins/api-keys/ProtectedRoute.js +4 -1
  63. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  64. package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +1 -0
  65. package/dist/lib/plugins/openapi/CollapsibleCode.js +2 -1
  66. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -1
  67. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.d.ts +5 -0
  68. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js +10 -0
  69. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js.map +1 -0
  70. package/dist/lib/plugins/openapi/OperationList.js +5 -1
  71. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  72. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  73. package/dist/lib/plugins/openapi/OperationListItem.js +3 -2
  74. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  75. package/dist/lib/plugins/openapi/ParameterList.js +7 -4
  76. package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
  77. package/dist/lib/plugins/openapi/ParameterListItem.js +17 -6
  78. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  79. package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +9 -2
  80. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +5 -2
  81. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  82. package/dist/lib/plugins/openapi/ResponsesSidecarBox.d.ts +3 -2
  83. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +25 -4
  84. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  85. package/dist/lib/plugins/openapi/Sidecar.d.ts +2 -2
  86. package/dist/lib/plugins/openapi/Sidecar.js +53 -26
  87. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  88. package/dist/lib/plugins/openapi/SidecarBox.js +4 -4
  89. package/dist/lib/plugins/openapi/SidecarBox.js.map +1 -1
  90. package/dist/lib/plugins/openapi/SidecarExamples.d.ts +9 -2
  91. package/dist/lib/plugins/openapi/SidecarExamples.js +24 -43
  92. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
  93. package/dist/lib/plugins/openapi/components/ConstValue.js +1 -1
  94. package/dist/lib/plugins/openapi/components/ConstValue.js.map +1 -1
  95. package/dist/lib/plugins/openapi/components/EnumValues.js +1 -1
  96. package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -1
  97. package/dist/lib/plugins/openapi/components/NonHighlightedCode.d.ts +4 -0
  98. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js +5 -0
  99. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js.map +1 -0
  100. package/dist/lib/plugins/openapi/components/ResponseContent.js +5 -6
  101. package/dist/lib/plugins/openapi/components/ResponseContent.js.map +1 -1
  102. package/dist/lib/plugins/openapi/interfaces.d.ts +13 -0
  103. package/dist/lib/plugins/openapi/playground/BodyPanel.js +67 -15
  104. package/dist/lib/plugins/openapi/playground/BodyPanel.js.map +1 -1
  105. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js +2 -2
  106. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js.map +1 -1
  107. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -1
  108. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
  109. package/dist/lib/plugins/openapi/playground/Headers.js +23 -83
  110. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  111. package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +10 -2
  112. package/dist/lib/plugins/openapi/playground/ParamsGrid.js +8 -1
  113. package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -1
  114. package/dist/lib/plugins/openapi/playground/PathParams.js +2 -3
  115. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  116. package/dist/lib/plugins/openapi/playground/Playground.d.ts +7 -0
  117. package/dist/lib/plugins/openapi/playground/Playground.js +56 -28
  118. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  119. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +3 -2
  120. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  121. package/dist/lib/plugins/openapi/playground/QueryParams.js +16 -40
  122. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  123. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.d.ts +8 -0
  124. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js +19 -0
  125. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js.map +1 -0
  126. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js +1 -1
  127. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js.map +1 -1
  128. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.d.ts +1 -0
  129. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js +540 -0
  130. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js.map +1 -0
  131. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.d.ts +40 -0
  132. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js +205 -0
  133. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js.map +1 -0
  134. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +2 -2
  135. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
  136. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +1 -1
  137. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -1
  138. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +17 -8
  139. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
  140. package/dist/lib/plugins/openapi/schema/SchemaView.d.ts +1 -1
  141. package/dist/lib/plugins/openapi/schema/SchemaView.js +20 -13
  142. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  143. package/dist/lib/plugins/openapi/schema/UnionView.js +2 -5
  144. package/dist/lib/plugins/openapi/schema/UnionView.js.map +1 -1
  145. package/dist/lib/plugins/openapi/schema/union-helpers.js +0 -1
  146. package/dist/lib/plugins/openapi/schema/union-helpers.js.map +1 -1
  147. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +5 -14
  148. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  149. package/dist/lib/ui/Badge.d.ts +3 -3
  150. package/dist/lib/ui/Badge.js +9 -7
  151. package/dist/lib/ui/Badge.js.map +1 -1
  152. package/dist/lib/ui/Button.d.ts +1 -1
  153. package/dist/lib/ui/Button.js +1 -0
  154. package/dist/lib/ui/Button.js.map +1 -1
  155. package/dist/lib/ui/Checkbox.d.ts +2 -2
  156. package/dist/lib/ui/Checkbox.js +4 -4
  157. package/dist/lib/ui/Checkbox.js.map +1 -1
  158. package/dist/lib/ui/CodeBlock.d.ts +0 -1
  159. package/dist/lib/ui/CodeBlock.js +1 -1
  160. package/dist/lib/ui/CodeBlock.js.map +1 -1
  161. package/dist/lib/ui/Collapsible.d.ts +4 -4
  162. package/dist/lib/ui/Collapsible.js +11 -4
  163. package/dist/lib/ui/Collapsible.js.map +1 -1
  164. package/dist/lib/ui/Command.d.ts +3 -3
  165. package/dist/lib/ui/EmbeddedCodeBlock.d.ts +0 -1
  166. package/dist/lib/ui/EmbeddedCodeBlock.js +3 -2
  167. package/dist/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  168. package/dist/lib/ui/Frame.d.ts +8 -0
  169. package/dist/lib/ui/Frame.js +22 -0
  170. package/dist/lib/ui/Frame.js.map +1 -0
  171. package/dist/lib/ui/Item.d.ts +23 -0
  172. package/dist/lib/ui/Item.js +67 -0
  173. package/dist/lib/ui/Item.js.map +1 -0
  174. package/dist/lib/ui/NativeSelect.d.ts +5 -0
  175. package/dist/lib/ui/NativeSelect.js +14 -0
  176. package/dist/lib/ui/NativeSelect.js.map +1 -0
  177. package/dist/lib/ui/Select.d.ts +13 -11
  178. package/dist/lib/ui/Select.js +34 -23
  179. package/dist/lib/ui/Select.js.map +1 -1
  180. package/dist/lib/ui/Separator.d.ts +4 -0
  181. package/dist/lib/ui/Separator.js +8 -0
  182. package/dist/lib/ui/Separator.js.map +1 -0
  183. package/dist/lib/ui/Tooltip.d.ts +7 -7
  184. package/dist/lib/ui/Tooltip.js +16 -10
  185. package/dist/lib/ui/Tooltip.js.map +1 -1
  186. package/dist/lib/util/createVariantComponent.d.ts +5 -2
  187. package/dist/lib/util/createVariantComponent.js +5 -2
  188. package/dist/lib/util/createVariantComponent.js.map +1 -1
  189. package/dist/lib/util/flattenAllOf.d.ts +4 -0
  190. package/dist/lib/util/flattenAllOf.js +65 -0
  191. package/dist/lib/util/flattenAllOf.js.map +1 -0
  192. package/dist/lib/util/flattenAllOf.test.d.ts +1 -0
  193. package/dist/lib/util/flattenAllOf.test.js +532 -0
  194. package/dist/lib/util/flattenAllOf.test.js.map +1 -0
  195. package/dist/lib/util/readFrontmatter.d.ts +6 -0
  196. package/dist/lib/util/readFrontmatter.js +12 -0
  197. package/dist/lib/util/readFrontmatter.js.map +1 -0
  198. package/dist/vite/api/SchemaManager.js +6 -18
  199. package/dist/vite/api/SchemaManager.js.map +1 -1
  200. package/dist/vite/mdx/remark-last-modified.js +57 -3
  201. package/dist/vite/mdx/remark-last-modified.js.map +1 -1
  202. package/dist/vite/plugin-api.js +2 -2
  203. package/dist/vite/plugin-api.js.map +1 -1
  204. package/dist/vite/plugin-frontmatter.js +3 -5
  205. package/dist/vite/plugin-frontmatter.js.map +1 -1
  206. package/dist/vite/plugin-markdown-export.js +3 -4
  207. package/dist/vite/plugin-markdown-export.js.map +1 -1
  208. package/dist/vite/plugin-theme.js +10 -1
  209. package/dist/vite/plugin-theme.js.map +1 -1
  210. package/lib/{Button-DmS4u8Lj.js → Button-B3ucvvQw.js} +7 -6
  211. package/lib/Button-B3ucvvQw.js.map +1 -0
  212. package/lib/{ErrorAlert-DE3Sf66a.js → ErrorAlert-BOVgwTRP.js} +2832 -2857
  213. package/lib/ErrorAlert-BOVgwTRP.js.map +1 -0
  214. package/lib/{MdxPage-DZfeC0QY.js → MdxPage-CBYFyqUs.js} +6 -6
  215. package/lib/{MdxPage-DZfeC0QY.js.map → MdxPage-CBYFyqUs.js.map} +1 -1
  216. package/lib/{OAuthErrorPage-BycMozgn.js → OAuthErrorPage-DlTYnbLO.js} +4 -4
  217. package/lib/{OAuthErrorPage-BycMozgn.js.map → OAuthErrorPage-DlTYnbLO.js.map} +1 -1
  218. package/lib/{OasProvider-1XEOsIiW.js → OasProvider-DIPAQ79S.js} +2 -2
  219. package/lib/{OasProvider-1XEOsIiW.js.map → OasProvider-DIPAQ79S.js.map} +1 -1
  220. package/lib/OperationList-BOTFIfda.js +5688 -0
  221. package/lib/OperationList-BOTFIfda.js.map +1 -0
  222. package/lib/{Pagination-CJszmeSA.js → Pagination-BOZ9Pxcw.js} +2 -2
  223. package/lib/{Pagination-CJszmeSA.js.map → Pagination-BOZ9Pxcw.js.map} +1 -1
  224. package/lib/RouteGuard-Brz95MSt.js +77 -0
  225. package/lib/RouteGuard-Brz95MSt.js.map +1 -0
  226. package/lib/RouterError-DQS_bMwf.js +42 -0
  227. package/lib/RouterError-DQS_bMwf.js.map +1 -0
  228. package/lib/{SchemaList-qOHkDzSz.js → SchemaList-Bu95q_q2.js} +7 -7
  229. package/lib/{SchemaList-qOHkDzSz.js.map → SchemaList-Bu95q_q2.js.map} +1 -1
  230. package/lib/SchemaView-CaxK_HV4.js +586 -0
  231. package/lib/SchemaView-CaxK_HV4.js.map +1 -0
  232. package/lib/Select-DFRCS31-.js +399 -0
  233. package/lib/Select-DFRCS31-.js.map +1 -0
  234. package/lib/{SignUp-6SGx9Yyq.js → SignUp-CfB278ao.js} +2 -2
  235. package/lib/{SignUp-6SGx9Yyq.js.map → SignUp-CfB278ao.js.map} +1 -1
  236. package/lib/{SyntaxHighlight-zvlnSnHB.js → SyntaxHighlight-C19vH0V_.js} +525 -509
  237. package/lib/SyntaxHighlight-C19vH0V_.js.map +1 -0
  238. package/lib/{Toc-Da9yp7lo.js → Toc-DQIqdghO.js} +2 -2
  239. package/lib/{Toc-Da9yp7lo.js.map → Toc-DQIqdghO.js.map} +1 -1
  240. package/lib/{circular-CSSuz-LS.js → circular-B-_VyILZ.js} +6360 -5953
  241. package/lib/circular-B-_VyILZ.js.map +1 -0
  242. package/lib/{createServer-CLbcVLbK.js → createServer-C5lXk4ba.js} +4732 -4273
  243. package/lib/createServer-C5lXk4ba.js.map +1 -0
  244. package/lib/{errors-CuGgh3hf.js → errors-DqoyOKev.js} +2 -2
  245. package/lib/{errors-CuGgh3hf.js.map → errors-DqoyOKev.js.map} +1 -1
  246. package/lib/index-B7yD7ZUk.js +3680 -0
  247. package/lib/index-B7yD7ZUk.js.map +1 -0
  248. package/lib/{index-rYHsvtTo.js → index-BG79m3lF.js} +2 -2
  249. package/lib/{index-rYHsvtTo.js.map → index-BG79m3lF.js.map} +1 -1
  250. package/lib/{index-B1rmok4X.js → index-DHDtI9H5.js} +3 -3
  251. package/lib/{index-B1rmok4X.js.map → index-DHDtI9H5.js.map} +1 -1
  252. package/lib/ui/ActionButton.js +1 -1
  253. package/lib/ui/Badge.js +27 -13
  254. package/lib/ui/Badge.js.map +1 -1
  255. package/lib/ui/Button.js +6 -5
  256. package/lib/ui/Button.js.map +1 -1
  257. package/lib/ui/Checkbox.js +29 -26
  258. package/lib/ui/Checkbox.js.map +1 -1
  259. package/lib/ui/CodeBlock.js +7 -7
  260. package/lib/ui/CodeBlock.js.map +1 -1
  261. package/lib/ui/Collapsible.js +32 -5
  262. package/lib/ui/Collapsible.js.map +1 -1
  263. package/lib/ui/EmbeddedCodeBlock.js +26 -25
  264. package/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  265. package/lib/ui/Frame.js +81 -0
  266. package/lib/ui/Frame.js.map +1 -0
  267. package/lib/ui/Item.js +188 -0
  268. package/lib/ui/Item.js.map +1 -0
  269. package/lib/ui/NativeSelect.js +57 -0
  270. package/lib/ui/NativeSelect.js.map +1 -0
  271. package/lib/ui/Select.js +166 -116
  272. package/lib/ui/Select.js.map +1 -1
  273. package/lib/ui/Separator.js +27 -0
  274. package/lib/ui/Separator.js.map +1 -0
  275. package/lib/ui/SyntaxHighlight.js +1 -1
  276. package/lib/ui/Tabs.js +10 -10
  277. package/lib/ui/Tooltip.js +55 -28
  278. package/lib/ui/Tooltip.js.map +1 -1
  279. package/lib/zudoku.__internal.js +345 -345
  280. package/lib/zudoku.__internal.js.map +1 -1
  281. package/lib/zudoku.auth-auth0.js +7 -7
  282. package/lib/zudoku.auth-auth0.js.map +1 -1
  283. package/lib/zudoku.auth-azureb2c.js +3 -3
  284. package/lib/zudoku.auth-clerk.js +1 -1
  285. package/lib/zudoku.auth-openid.js +3 -3
  286. package/lib/zudoku.auth-supabase.js +30 -33
  287. package/lib/zudoku.auth-supabase.js.map +1 -1
  288. package/lib/zudoku.components.js +2 -2
  289. package/lib/zudoku.plugin-api-catalog.js +3 -3
  290. package/lib/zudoku.plugin-api-keys.js +5 -5
  291. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  292. package/lib/zudoku.plugin-markdown.js +1 -1
  293. package/lib/zudoku.plugin-openapi.js +1 -1
  294. package/lib/zudoku.plugin-search-pagefind.js +2 -2
  295. package/package.json +18 -13
  296. package/src/app/main.css +1 -1
  297. package/src/app/main.tsx +5 -1
  298. package/src/lib/auth/issuer.ts +3 -0
  299. package/src/lib/authentication/authentication.ts +1 -1
  300. package/src/lib/authentication/providers/auth0.tsx +6 -1
  301. package/src/lib/authentication/providers/firebase.tsx +284 -0
  302. package/src/lib/authentication/providers/supabase.tsx +2 -7
  303. package/src/lib/authentication/ui/ZudokuAuthUi.tsx +335 -0
  304. package/src/lib/authentication/ui/icons/Apple.tsx +10 -0
  305. package/src/lib/authentication/ui/icons/Facebook.tsx +15 -0
  306. package/src/lib/authentication/ui/icons/Github.tsx +16 -0
  307. package/src/lib/authentication/ui/icons/Google.tsx +16 -0
  308. package/src/lib/authentication/ui/icons/Microsoft.tsx +12 -0
  309. package/src/lib/authentication/ui/icons/X.tsx +10 -0
  310. package/src/lib/components/Autocomplete.tsx +11 -2
  311. package/src/lib/components/Layout.tsx +3 -2
  312. package/src/lib/components/navigation/NavigationItem.tsx +7 -20
  313. package/src/lib/core/RouteGuard.tsx +8 -8
  314. package/src/lib/errors/ErrorAlert.tsx +1 -1
  315. package/src/lib/errors/RouterError.tsx +7 -2
  316. package/src/lib/oas/parser/index.ts +8 -3
  317. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +11 -7
  318. package/src/lib/plugins/openapi/CollapsibleCode.tsx +5 -3
  319. package/src/lib/plugins/openapi/GeneratedExampleSidecarBox.tsx +52 -0
  320. package/src/lib/plugins/openapi/OperationList.tsx +7 -0
  321. package/src/lib/plugins/openapi/OperationListItem.tsx +10 -7
  322. package/src/lib/plugins/openapi/ParameterList.tsx +37 -23
  323. package/src/lib/plugins/openapi/ParameterListItem.tsx +105 -54
  324. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +48 -7
  325. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +81 -33
  326. package/src/lib/plugins/openapi/Sidecar.tsx +129 -65
  327. package/src/lib/plugins/openapi/SidecarBox.tsx +26 -4
  328. package/src/lib/plugins/openapi/SidecarExamples.tsx +91 -79
  329. package/src/lib/plugins/openapi/components/ConstValue.tsx +1 -1
  330. package/src/lib/plugins/openapi/components/EnumValues.tsx +2 -2
  331. package/src/lib/plugins/openapi/components/NonHighlightedCode.tsx +22 -0
  332. package/src/lib/plugins/openapi/components/ResponseContent.tsx +63 -53
  333. package/src/lib/plugins/openapi/interfaces.ts +12 -0
  334. package/src/lib/plugins/openapi/playground/BodyPanel.tsx +246 -30
  335. package/src/lib/plugins/openapi/playground/CollapsibleHeader.tsx +10 -6
  336. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +3 -2
  337. package/src/lib/plugins/openapi/playground/Headers.tsx +103 -219
  338. package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +33 -1
  339. package/src/lib/plugins/openapi/playground/PathParams.tsx +26 -34
  340. package/src/lib/plugins/openapi/playground/Playground.tsx +73 -35
  341. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +9 -30
  342. package/src/lib/plugins/openapi/playground/QueryParams.tsx +82 -136
  343. package/src/lib/plugins/openapi/playground/request-panel/MultipartField.tsx +91 -0
  344. package/src/lib/plugins/openapi/playground/request-panel/UrlQueryParams.tsx +1 -1
  345. package/src/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.tsx +872 -0
  346. package/src/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.ts +349 -0
  347. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +2 -6
  348. package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +1 -1
  349. package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +89 -55
  350. package/src/lib/plugins/openapi/schema/SchemaView.tsx +82 -53
  351. package/src/lib/plugins/openapi/schema/UnionView.tsx +6 -17
  352. package/src/lib/plugins/openapi/schema/union-helpers.ts +0 -1
  353. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +5 -15
  354. package/src/lib/ui/Badge.tsx +21 -12
  355. package/src/lib/ui/Button.tsx +1 -0
  356. package/src/lib/ui/Checkbox.tsx +23 -24
  357. package/src/lib/ui/CodeBlock.tsx +3 -4
  358. package/src/lib/ui/Collapsible.tsx +26 -4
  359. package/src/lib/ui/EmbeddedCodeBlock.tsx +21 -19
  360. package/src/lib/ui/Frame.tsx +81 -0
  361. package/src/lib/ui/Item.tsx +192 -0
  362. package/src/lib/ui/NativeSelect.tsx +47 -0
  363. package/src/lib/ui/Select.tsx +153 -126
  364. package/src/lib/ui/Separator.tsx +25 -0
  365. package/src/lib/ui/Tooltip.tsx +54 -32
  366. package/src/lib/util/createVariantComponent.tsx +31 -5
  367. package/src/lib/util/flattenAllOf.test.ts +637 -0
  368. package/src/lib/util/flattenAllOf.ts +101 -0
  369. package/src/lib/util/readFrontmatter.ts +13 -0
  370. package/dist/lib/plugins/openapi/playground/InlineInput.d.ts +0 -4
  371. package/dist/lib/plugins/openapi/playground/InlineInput.js +0 -3
  372. package/dist/lib/plugins/openapi/playground/InlineInput.js.map +0 -1
  373. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.d.ts +0 -5
  374. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js +0 -7
  375. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js.map +0 -1
  376. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.d.ts +0 -4
  377. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js +0 -10
  378. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js.map +0 -1
  379. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.d.ts +0 -5
  380. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js +0 -16
  381. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js.map +0 -1
  382. package/lib/Button-DmS4u8Lj.js.map +0 -1
  383. package/lib/ErrorAlert-DE3Sf66a.js.map +0 -1
  384. package/lib/OperationList-DCJw6wXL.js +0 -5450
  385. package/lib/OperationList-DCJw6wXL.js.map +0 -1
  386. package/lib/RouteGuard-DhU3LRr1.js +0 -81
  387. package/lib/RouteGuard-DhU3LRr1.js.map +0 -1
  388. package/lib/RouterError-VDLnrFqF.js +0 -41
  389. package/lib/RouterError-VDLnrFqF.js.map +0 -1
  390. package/lib/SchemaView-D3hm65cc.js +0 -458
  391. package/lib/SchemaView-D3hm65cc.js.map +0 -1
  392. package/lib/Select-C1DeCqKv.js +0 -372
  393. package/lib/Select-C1DeCqKv.js.map +0 -1
  394. package/lib/SyntaxHighlight-zvlnSnHB.js.map +0 -1
  395. package/lib/circular-CSSuz-LS.js.map +0 -1
  396. package/lib/createServer-CLbcVLbK.js.map +0 -1
  397. package/lib/index-RNAxx6IF.js +0 -3364
  398. package/lib/index-RNAxx6IF.js.map +0 -1
  399. package/src/lib/plugins/openapi/playground/InlineInput.tsx +0 -6
  400. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.tsx +0 -36
  401. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.tsx +0 -25
  402. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.tsx +0 -42
@@ -5,8 +5,31 @@ import type { HTMLElementType, JSX } from "react";
5
5
  import * as React from "react";
6
6
  import { cn } from "./cn.js";
7
7
 
8
+ type ComponentOrElement =
9
+ | HTMLElementType
10
+ // biome-ignore lint/suspicious/noExplicitAny: Need to accept any component type
11
+ | React.ComponentType<any>
12
+ // biome-ignore lint/suspicious/noExplicitAny: Need to accept any component type
13
+ | React.ForwardRefExoticComponent<any>;
14
+
15
+ type PropsOf<T> = T extends HTMLElementType
16
+ ? JSX.IntrinsicElements[T]
17
+ : T extends React.ComponentType<infer P>
18
+ ? P
19
+ : T extends React.ForwardRefExoticComponent<infer P>
20
+ ? P
21
+ : never;
22
+
23
+ type RefOf<T> = T extends HTMLElementType
24
+ ? T extends keyof HTMLElementTagNameMap
25
+ ? HTMLElementTagNameMap[T]
26
+ : HTMLElement
27
+ : T extends React.ForwardRefExoticComponent<React.RefAttributes<infer R>>
28
+ ? R
29
+ : HTMLElement;
30
+
8
31
  const createVariantComponent = <
9
- E extends HTMLElementType,
32
+ E extends ComponentOrElement,
10
33
  C extends ReturnType<typeof cva>,
11
34
  >(
12
35
  tag: E,
@@ -14,20 +37,23 @@ const createVariantComponent = <
14
37
  // variantProps: Array<keyof VariantProps<C>> = [],
15
38
  ) => {
16
39
  const MyVariant = React.forwardRef<
17
- HTMLElement,
18
- JSX.IntrinsicElements[E] & { className?: ClassValue; asChild?: boolean }
40
+ RefOf<E>,
41
+ PropsOf<E> & { className?: ClassValue; asChild?: boolean }
19
42
  >(({ className, asChild, ...props }, ref) => {
20
43
  const Comp = asChild ? Slot : tag;
21
44
 
22
45
  return React.createElement(Comp, {
23
46
  ...props,
24
- ref,
47
+ ref: ref as React.Ref<HTMLElement>,
25
48
  className:
26
49
  typeof cvx === "function" ? cvx({ className }) : cn(cvx, className),
27
50
  });
28
51
  });
29
52
 
30
- MyVariant.displayName = `VariantComponent(${tag})`;
53
+ MyVariant.displayName =
54
+ typeof tag === "string"
55
+ ? `VariantComponent(${tag})`
56
+ : `VariantComponent(${tag.displayName || tag.name || "Component"})`;
31
57
 
32
58
  return MyVariant;
33
59
  };
@@ -0,0 +1,637 @@
1
+ import type { JSONSchema7 } from "json-schema";
2
+ import { describe, expect, it, vi } from "vitest";
3
+ import type { OpenAPIDocument } from "../oas/parser/index.js";
4
+ import { flattenAllOf, flattenAllOfProcessor } from "./flattenAllOf.js";
5
+ import invariant from "./invariant.js";
6
+
7
+ describe("flattenAllOf", () => {
8
+ it("should merge two simple schemas", () => {
9
+ const schema = {
10
+ allOf: [
11
+ { type: "object", properties: { id: { type: "string" } } },
12
+ { type: "object", properties: { name: { type: "string" } } },
13
+ ],
14
+ } as JSONSchema7;
15
+
16
+ const result = flattenAllOf(schema);
17
+
18
+ expect(result).toMatchObject({
19
+ type: "object",
20
+ properties: {
21
+ id: { type: "string" },
22
+ name: { type: "string" },
23
+ },
24
+ });
25
+ expect(result).not.toHaveProperty("allOf");
26
+ });
27
+
28
+ it("should merge nested allOf chains", () => {
29
+ const schema = {
30
+ allOf: [
31
+ {
32
+ allOf: [
33
+ { type: "object", properties: { id: { type: "string" } } },
34
+ { type: "object", properties: { name: { type: "string" } } },
35
+ ],
36
+ },
37
+ { type: "object", properties: { email: { type: "string" } } },
38
+ ],
39
+ } as JSONSchema7;
40
+
41
+ const result = flattenAllOf(schema);
42
+
43
+ expect(result).toMatchObject({
44
+ type: "object",
45
+ properties: {
46
+ id: { type: "string" },
47
+ name: { type: "string" },
48
+ email: { type: "string" },
49
+ },
50
+ });
51
+ expect(result).not.toHaveProperty("allOf");
52
+ });
53
+
54
+ it("should recursively flatten allOf in nested properties", () => {
55
+ const schema = {
56
+ type: "object",
57
+ properties: {
58
+ user: {
59
+ allOf: [
60
+ { type: "object", properties: { id: { type: "string" } } },
61
+ { type: "object", properties: { name: { type: "string" } } },
62
+ ],
63
+ },
64
+ },
65
+ } as JSONSchema7;
66
+
67
+ const result = flattenAllOf(schema);
68
+
69
+ invariant(
70
+ typeof result === "object" && result.properties,
71
+ "Result is not a schema",
72
+ );
73
+
74
+ expect(result.properties?.user).toMatchObject({
75
+ type: "object",
76
+ properties: {
77
+ id: { type: "string" },
78
+ name: { type: "string" },
79
+ },
80
+ });
81
+ expect(result.properties.user).not.toHaveProperty("allOf");
82
+ });
83
+
84
+ it("should flatten allOf in array items", () => {
85
+ const schema = {
86
+ type: "array",
87
+ items: {
88
+ allOf: [
89
+ { type: "object", properties: { id: { type: "string" } } },
90
+ { type: "object", properties: { name: { type: "string" } } },
91
+ ],
92
+ },
93
+ } as JSONSchema7;
94
+
95
+ const result = flattenAllOf(schema);
96
+
97
+ invariant(
98
+ typeof result === "object" && result.items,
99
+ "Result is not a schema",
100
+ );
101
+
102
+ expect(result.items).toMatchObject({
103
+ type: "object",
104
+ properties: {
105
+ id: { type: "string" },
106
+ name: { type: "string" },
107
+ },
108
+ });
109
+ expect(result.items).not.toHaveProperty("allOf");
110
+ });
111
+
112
+ it("should flatten allOf in tuple items", () => {
113
+ const schema = {
114
+ type: "array",
115
+ items: [
116
+ {
117
+ allOf: [
118
+ { type: "object", properties: { id: { type: "string" } } },
119
+ { type: "object", properties: { name: { type: "string" } } },
120
+ ],
121
+ },
122
+ { type: "string" },
123
+ ],
124
+ } as JSONSchema7;
125
+
126
+ const result = flattenAllOf(schema);
127
+
128
+ invariant(
129
+ typeof result === "object" && Array.isArray(result.items),
130
+ "Result is not a schema",
131
+ );
132
+
133
+ expect(result.items[0]).toMatchObject({
134
+ type: "object",
135
+ properties: {
136
+ id: { type: "string" },
137
+ name: { type: "string" },
138
+ },
139
+ });
140
+ expect(result.items[0]).not.toHaveProperty("allOf");
141
+ expect(result.items[1]).toEqual({ type: "string" });
142
+ });
143
+
144
+ it("should flatten allOf in additionalProperties", () => {
145
+ const schema = {
146
+ type: "object",
147
+ additionalProperties: {
148
+ allOf: [
149
+ { type: "object", properties: { id: { type: "string" } } },
150
+ { type: "object", properties: { name: { type: "string" } } },
151
+ ],
152
+ },
153
+ } as JSONSchema7;
154
+
155
+ const result = flattenAllOf(schema);
156
+
157
+ invariant(
158
+ typeof result === "object" && result.additionalProperties,
159
+ "Result is not a schema",
160
+ );
161
+
162
+ expect(result.additionalProperties as JSONSchema7).toMatchObject({
163
+ type: "object",
164
+ properties: {
165
+ id: { type: "string" },
166
+ name: { type: "string" },
167
+ },
168
+ });
169
+ expect(result.additionalProperties).not.toHaveProperty("allOf");
170
+ });
171
+
172
+ it("should flatten allOf within anyOf", () => {
173
+ const schema = {
174
+ anyOf: [
175
+ {
176
+ allOf: [
177
+ { type: "object", properties: { id: { type: "string" } } },
178
+ { type: "object", properties: { name: { type: "string" } } },
179
+ ],
180
+ },
181
+ { type: "string" },
182
+ ],
183
+ } as JSONSchema7;
184
+
185
+ const result = flattenAllOf(schema);
186
+
187
+ invariant(
188
+ typeof result === "object" && result.anyOf,
189
+ "Result is not a schema",
190
+ );
191
+
192
+ expect(result.anyOf[0]).toMatchObject({
193
+ type: "object",
194
+ properties: {
195
+ id: { type: "string" },
196
+ name: { type: "string" },
197
+ },
198
+ });
199
+ expect(result.anyOf[0]).not.toHaveProperty("allOf");
200
+ expect(result.anyOf[1]).toEqual({ type: "string" });
201
+ });
202
+
203
+ it("should flatten allOf within oneOf", () => {
204
+ const schema = {
205
+ oneOf: [
206
+ {
207
+ allOf: [
208
+ { type: "object", properties: { id: { type: "string" } } },
209
+ { type: "object", properties: { name: { type: "string" } } },
210
+ ],
211
+ },
212
+ { type: "string" },
213
+ ],
214
+ } as JSONSchema7;
215
+
216
+ const result = flattenAllOf(schema);
217
+
218
+ invariant(
219
+ typeof result === "object" && result.oneOf,
220
+ "Result is not a schema",
221
+ );
222
+
223
+ expect(result.oneOf[0]).toMatchObject({
224
+ type: "object",
225
+ properties: {
226
+ id: { type: "string" },
227
+ name: { type: "string" },
228
+ },
229
+ });
230
+ expect(result.oneOf[0]).not.toHaveProperty("allOf");
231
+ expect(result.oneOf[1]).toEqual({ type: "string" });
232
+ });
233
+
234
+ it("should handle schemas without allOf", () => {
235
+ const schema = { type: "string" } as JSONSchema7;
236
+ expect(flattenAllOf(schema)).toEqual({ type: "string" });
237
+
238
+ const objectSchema = {
239
+ type: "object",
240
+ properties: { id: { type: "string" } },
241
+ } as JSONSchema7;
242
+ expect(flattenAllOf(objectSchema)).toEqual(objectSchema);
243
+ });
244
+
245
+ it("should preserve description and other properties", () => {
246
+ const schema = {
247
+ description: "A test schema",
248
+ allOf: [
249
+ { type: "object", properties: { id: { type: "string" } } },
250
+ { type: "object", properties: { name: { type: "string" } } },
251
+ ],
252
+ } as JSONSchema7;
253
+
254
+ const result = flattenAllOf(schema);
255
+
256
+ invariant(typeof result === "object", "Result is not a schema");
257
+
258
+ expect(result.description).toBe("A test schema");
259
+ expect(result.properties).toBeDefined();
260
+ });
261
+
262
+ it("should merge required arrays", () => {
263
+ const schema = {
264
+ allOf: [
265
+ {
266
+ type: "object",
267
+ properties: { id: { type: "string" } },
268
+ required: ["id"],
269
+ },
270
+ {
271
+ type: "object",
272
+ properties: { name: { type: "string" } },
273
+ required: ["name"],
274
+ },
275
+ ],
276
+ } as JSONSchema7;
277
+
278
+ const result = flattenAllOf(schema);
279
+
280
+ invariant(typeof result === "object", "Result is not a schema");
281
+
282
+ expect(result.required).toEqual(expect.arrayContaining(["id", "name"]));
283
+ });
284
+
285
+ it("should handle complex nested structures", () => {
286
+ const schema = {
287
+ type: "object",
288
+ properties: {
289
+ booking: {
290
+ allOf: [
291
+ {
292
+ allOf: [
293
+ {
294
+ type: "object",
295
+ properties: { quoteId: { type: "string" } },
296
+ },
297
+ {
298
+ type: "object",
299
+ properties: { price: { type: "number" } },
300
+ },
301
+ ],
302
+ },
303
+ {
304
+ type: "object",
305
+ properties: { bookingId: { type: "string" } },
306
+ },
307
+ ],
308
+ },
309
+ },
310
+ } as JSONSchema7;
311
+
312
+ const result = flattenAllOf(schema);
313
+
314
+ invariant(
315
+ typeof result === "object" && result.properties,
316
+ "Result is not a schema",
317
+ );
318
+
319
+ expect(result.properties.booking).toMatchObject({
320
+ type: "object",
321
+ properties: {
322
+ quoteId: { type: "string" },
323
+ price: { type: "number" },
324
+ bookingId: { type: "string" },
325
+ },
326
+ });
327
+ expect(result.properties.booking).not.toHaveProperty("allOf");
328
+ });
329
+ });
330
+
331
+ describe("flattenAllOf processor", () => {
332
+ it("should process an OpenAPI document and flatten allOf", async () => {
333
+ const schema: OpenAPIDocument = {
334
+ openapi: "3.0.0",
335
+ info: { title: "Test API", version: "1.0.0" },
336
+ paths: {
337
+ "/users": {
338
+ get: {
339
+ responses: {
340
+ "200": {
341
+ description: "Success",
342
+ content: {
343
+ "application/json": {
344
+ schema: {
345
+ allOf: [
346
+ {
347
+ type: "object",
348
+ properties: { id: { type: "string" } },
349
+ },
350
+ {
351
+ type: "object",
352
+ properties: { name: { type: "string" } },
353
+ },
354
+ ],
355
+ },
356
+ },
357
+ },
358
+ },
359
+ },
360
+ },
361
+ },
362
+ },
363
+ };
364
+
365
+ const mockDereference = vi.fn().mockResolvedValue(schema);
366
+
367
+ const result = await flattenAllOfProcessor({
368
+ schema,
369
+ file: "/test/schema.json",
370
+ dereference: mockDereference,
371
+ });
372
+
373
+ expect(mockDereference).toHaveBeenCalledWith(schema);
374
+
375
+ const responseSchema =
376
+ result.paths?.["/users"]?.get?.responses?.[200]?.content?.[
377
+ "application/json"
378
+ ]?.schema;
379
+
380
+ expect(responseSchema).toMatchObject({
381
+ type: "object",
382
+ properties: {
383
+ id: { type: "string" },
384
+ name: { type: "string" },
385
+ },
386
+ });
387
+ expect(responseSchema).not.toHaveProperty("allOf");
388
+ });
389
+
390
+ it("should process components.schemas and flatten allOf", async () => {
391
+ const schema: OpenAPIDocument = {
392
+ openapi: "3.0.0",
393
+ info: { title: "Test API", version: "1.0.0" },
394
+ paths: {},
395
+ components: {
396
+ schemas: {
397
+ User: {
398
+ allOf: [
399
+ { type: "object", properties: { id: { type: "string" } } },
400
+ { type: "object", properties: { name: { type: "string" } } },
401
+ ],
402
+ },
403
+ },
404
+ },
405
+ };
406
+
407
+ const mockDereference = vi.fn().mockResolvedValue(schema);
408
+
409
+ const result = await flattenAllOfProcessor({
410
+ schema,
411
+ file: "/test/schema.json",
412
+ dereference: mockDereference,
413
+ });
414
+
415
+ const userSchema = result.components?.schemas?.User;
416
+ expect(userSchema).toMatchObject({
417
+ type: "object",
418
+ properties: {
419
+ id: { type: "string" },
420
+ name: { type: "string" },
421
+ },
422
+ });
423
+ expect(userSchema).not.toHaveProperty("allOf");
424
+ });
425
+
426
+ it("should handle errors gracefully and return original schema", async () => {
427
+ const schema: OpenAPIDocument = {
428
+ openapi: "3.0.0",
429
+ info: { title: "Test API", version: "1.0.0" },
430
+ paths: {},
431
+ };
432
+
433
+ const mockDereference = vi
434
+ .fn()
435
+ .mockRejectedValue(new Error("Dereference failed"));
436
+
437
+ const consoleSpy = vi.spyOn(console, "warn").mockImplementation(() => {});
438
+
439
+ const result = await flattenAllOfProcessor({
440
+ schema,
441
+ file: "/test/schema.json",
442
+ dereference: mockDereference,
443
+ });
444
+
445
+ expect(result).toBe(schema);
446
+ expect(consoleSpy).toHaveBeenCalledWith(
447
+ expect.stringContaining("Failed to flatten"),
448
+ );
449
+
450
+ consoleSpy.mockRestore();
451
+ });
452
+
453
+ it("should only flatten schema objects, not other OpenAPI structures", async () => {
454
+ const schema: OpenAPIDocument = {
455
+ openapi: "3.0.0",
456
+ info: { title: "Test API", version: "1.0.0" },
457
+ paths: {
458
+ "/users": {
459
+ get: {
460
+ operationId: "getUsers",
461
+ tags: ["users"],
462
+ responses: {
463
+ "200": {
464
+ description: "Success",
465
+ content: {
466
+ "application/json": {
467
+ schema: {
468
+ allOf: [
469
+ {
470
+ type: "object",
471
+ properties: { id: { type: "string" } },
472
+ },
473
+ {
474
+ type: "object",
475
+ properties: { name: { type: "string" } },
476
+ },
477
+ ],
478
+ },
479
+ },
480
+ },
481
+ },
482
+ },
483
+ },
484
+ },
485
+ },
486
+ };
487
+
488
+ const mockDereference = vi.fn().mockResolvedValue(schema);
489
+
490
+ const result = await flattenAllOfProcessor({
491
+ schema,
492
+ file: "/test/schema.json",
493
+ dereference: mockDereference,
494
+ });
495
+
496
+ // Operation objects should not be flattened
497
+ const operation = result.paths?.["/users"]?.get;
498
+ expect(operation?.operationId).toBe("getUsers");
499
+ expect(operation?.tags).toEqual(["users"]);
500
+
501
+ // But schema objects should be flattened
502
+ const responseSchema =
503
+ operation?.responses?.[200]?.content?.["application/json"]?.schema;
504
+ expect(responseSchema).not.toHaveProperty("allOf");
505
+ });
506
+
507
+ it("should handle deeply nested allOf in request bodies", async () => {
508
+ const schema: OpenAPIDocument = {
509
+ openapi: "3.0.0",
510
+ info: { title: "Test API", version: "1.0.0" },
511
+ paths: {
512
+ "/bookings": {
513
+ post: {
514
+ requestBody: {
515
+ content: {
516
+ "application/json": {
517
+ schema: {
518
+ allOf: [
519
+ {
520
+ allOf: [
521
+ {
522
+ type: "object",
523
+ properties: { quoteId: { type: "string" } },
524
+ },
525
+ {
526
+ type: "object",
527
+ properties: { price: { type: "number" } },
528
+ },
529
+ ],
530
+ },
531
+ {
532
+ type: "object",
533
+ properties: { bookingId: { type: "string" } },
534
+ },
535
+ ],
536
+ },
537
+ },
538
+ },
539
+ },
540
+ responses: {},
541
+ },
542
+ },
543
+ },
544
+ };
545
+
546
+ const mockDereference = vi.fn().mockResolvedValue(schema);
547
+
548
+ const result = await flattenAllOfProcessor({
549
+ schema,
550
+ file: "/test/schema.json",
551
+ dereference: mockDereference,
552
+ });
553
+
554
+ const requestSchema =
555
+ result.paths?.["/bookings"]?.post?.requestBody?.content?.[
556
+ "application/json"
557
+ ]?.schema;
558
+
559
+ expect(requestSchema).toMatchObject({
560
+ type: "object",
561
+ properties: {
562
+ quoteId: { type: "string" },
563
+ price: { type: "number" },
564
+ bookingId: { type: "string" },
565
+ },
566
+ });
567
+ expect(requestSchema).not.toHaveProperty("allOf");
568
+ });
569
+
570
+ it("should handle mixed allOf and oneOf combinations", async () => {
571
+ const schema: OpenAPIDocument = {
572
+ openapi: "3.0.0",
573
+ info: { title: "Test API", version: "1.0.0" },
574
+ paths: {},
575
+ components: {
576
+ schemas: {
577
+ Container: {
578
+ oneOf: [
579
+ {
580
+ allOf: [
581
+ {
582
+ type: "object",
583
+ properties: { type: { type: "string", const: "standard" } },
584
+ },
585
+ {
586
+ type: "object",
587
+ properties: { weight: { type: "number" } },
588
+ },
589
+ ],
590
+ },
591
+ {
592
+ allOf: [
593
+ {
594
+ type: "object",
595
+ properties: {
596
+ type: { type: "string", const: "refrigerated" },
597
+ },
598
+ },
599
+ {
600
+ type: "object",
601
+ properties: { temperature: { type: "number" } },
602
+ },
603
+ ],
604
+ },
605
+ ],
606
+ },
607
+ },
608
+ },
609
+ };
610
+
611
+ const mockDereference = vi.fn().mockResolvedValue(schema);
612
+
613
+ const result = await flattenAllOfProcessor({
614
+ schema,
615
+ file: "/test/schema.json",
616
+ dereference: mockDereference,
617
+ });
618
+
619
+ const containerSchema = result.components?.schemas?.Container;
620
+ expect(containerSchema?.oneOf?.[0]).toMatchObject({
621
+ type: "object",
622
+ properties: {
623
+ type: { type: "string", const: "standard" },
624
+ weight: { type: "number" },
625
+ },
626
+ });
627
+ expect(containerSchema?.oneOf?.[0]).not.toHaveProperty("allOf");
628
+ expect(containerSchema?.oneOf?.[1]).toMatchObject({
629
+ type: "object",
630
+ properties: {
631
+ type: { type: "string", const: "refrigerated" },
632
+ temperature: { type: "number" },
633
+ },
634
+ });
635
+ expect(containerSchema?.oneOf?.[1]).not.toHaveProperty("allOf");
636
+ });
637
+ });