zudoku 0.0.0-f2fd45c → 0.0.0-f3786a4

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 (842) hide show
  1. package/client.d.ts +7 -0
  2. package/dist/app/demo.js +1 -4
  3. package/dist/app/demo.js.map +1 -1
  4. package/dist/app/entry.client.d.ts +1 -0
  5. package/dist/app/entry.client.js +14 -1
  6. package/dist/app/entry.client.js.map +1 -1
  7. package/dist/app/entry.server.d.ts +1 -0
  8. package/dist/app/entry.server.js +8 -8
  9. package/dist/app/entry.server.js.map +1 -1
  10. package/dist/app/main.d.ts +3 -3
  11. package/dist/app/main.js +23 -10
  12. package/dist/app/main.js.map +1 -1
  13. package/dist/app/sentry.d.ts +3 -0
  14. package/dist/app/sentry.js +19 -0
  15. package/dist/app/sentry.js.map +1 -0
  16. package/dist/app/standalone.js +1 -4
  17. package/dist/app/standalone.js.map +1 -1
  18. package/dist/app/tailwind.d.ts +2 -1
  19. package/dist/app/tailwind.js +64 -52
  20. package/dist/app/tailwind.js.map +1 -1
  21. package/dist/cli/cli.js +0 -2
  22. package/dist/cli/cli.js.map +1 -1
  23. package/dist/cli/cmds/build.js +1 -0
  24. package/dist/cli/cmds/build.js.map +1 -1
  25. package/dist/cli/cmds/dev.js +5 -0
  26. package/dist/cli/cmds/dev.js.map +1 -1
  27. package/dist/cli/common/logger.js +9 -0
  28. package/dist/cli/common/logger.js.map +1 -1
  29. package/dist/cli/common/outdated.js +2 -1
  30. package/dist/cli/common/outdated.js.map +1 -1
  31. package/dist/cli/dev/handler.d.ts +1 -0
  32. package/dist/cli/dev/handler.js +3 -3
  33. package/dist/cli/dev/handler.js.map +1 -1
  34. package/dist/codegen.d.ts +3 -0
  35. package/dist/codegen.js +45 -0
  36. package/dist/codegen.js.map +1 -0
  37. package/dist/config/common.d.ts +8 -0
  38. package/dist/config/common.js +2 -0
  39. package/dist/config/common.js.map +1 -0
  40. package/dist/config/config.d.ts +4 -2
  41. package/dist/config/loader.d.ts +20 -0
  42. package/dist/config/loader.js +154 -0
  43. package/dist/config/loader.js.map +1 -0
  44. package/dist/config/validators/InputSidebarSchema.d.ts +37 -21
  45. package/dist/config/validators/InputSidebarSchema.js +1 -0
  46. package/dist/config/validators/InputSidebarSchema.js.map +1 -1
  47. package/dist/config/validators/common.d.ts +5034 -0
  48. package/dist/config/validators/common.js +287 -0
  49. package/dist/config/validators/common.js.map +1 -0
  50. package/dist/config/validators/icon-types.d.ts +1 -0
  51. package/dist/config/validators/icon-types.js +2 -0
  52. package/dist/config/validators/icon-types.js.map +1 -0
  53. package/dist/config/validators/validate.d.ts +875 -566
  54. package/dist/config/validators/validate.js +9 -228
  55. package/dist/config/validators/validate.js.map +1 -1
  56. package/dist/index.d.ts +2 -2
  57. package/dist/index.js +1 -1
  58. package/dist/index.js.map +1 -1
  59. package/dist/lib/authentication/AuthenticationPlugin.d.ts +4 -2
  60. package/dist/lib/authentication/AuthenticationPlugin.js +3 -0
  61. package/dist/lib/authentication/AuthenticationPlugin.js.map +1 -1
  62. package/dist/lib/authentication/authentication.d.ts +3 -3
  63. package/dist/lib/authentication/components/CallbackHandler.js +1 -1
  64. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  65. package/dist/lib/authentication/components/SignIn.js +1 -1
  66. package/dist/lib/authentication/components/SignIn.js.map +1 -1
  67. package/dist/lib/authentication/components/SignOut.js +2 -2
  68. package/dist/lib/authentication/components/SignOut.js.map +1 -1
  69. package/dist/lib/authentication/hook.d.ts +5 -4
  70. package/dist/lib/authentication/hook.js +1 -3
  71. package/dist/lib/authentication/hook.js.map +1 -1
  72. package/dist/lib/authentication/providers/auth0.js +12 -12
  73. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  74. package/dist/lib/authentication/providers/clerk.js +29 -6
  75. package/dist/lib/authentication/providers/clerk.js.map +1 -1
  76. package/dist/lib/authentication/providers/openid.d.ts +8 -2
  77. package/dist/lib/authentication/providers/openid.js +31 -35
  78. package/dist/lib/authentication/providers/openid.js.map +1 -1
  79. package/dist/lib/authentication/state.d.ts +25 -4
  80. package/dist/lib/authentication/state.js +28 -3
  81. package/dist/lib/authentication/state.js.map +1 -1
  82. package/dist/lib/authentication/use-broadcast/shared.d.ts +48 -0
  83. package/dist/lib/authentication/use-broadcast/shared.js +243 -0
  84. package/dist/lib/authentication/use-broadcast/shared.js.map +1 -0
  85. package/dist/lib/authentication/use-broadcast/useBroadcast.d.ts +24 -0
  86. package/dist/lib/authentication/use-broadcast/useBroadcast.js +106 -0
  87. package/dist/lib/authentication/use-broadcast/useBroadcast.js.map +1 -0
  88. package/dist/lib/components/AnchorLink.d.ts +1 -1
  89. package/dist/lib/components/AnchorLink.js +6 -3
  90. package/dist/lib/components/AnchorLink.js.map +1 -1
  91. package/dist/lib/components/Autocomplete.d.ts +12 -0
  92. package/dist/lib/components/Autocomplete.js +47 -0
  93. package/dist/lib/components/Autocomplete.js.map +1 -0
  94. package/dist/lib/components/Bootstrap.d.ts +4 -3
  95. package/dist/lib/components/Bootstrap.js +12 -6
  96. package/dist/lib/components/Bootstrap.js.map +1 -1
  97. package/dist/lib/components/ClientOnly.d.ts +4 -2
  98. package/dist/lib/components/ClientOnly.js +1 -1
  99. package/dist/lib/components/ClientOnly.js.map +1 -1
  100. package/dist/lib/components/DeveloperHint.js +2 -1
  101. package/dist/lib/components/DeveloperHint.js.map +1 -1
  102. package/dist/lib/components/Header.js +21 -15
  103. package/dist/lib/components/Header.js.map +1 -1
  104. package/dist/lib/components/Heading.d.ts +4 -4
  105. package/dist/lib/components/Heading.js +1 -1
  106. package/dist/lib/components/Heading.js.map +1 -1
  107. package/dist/lib/components/Layout.js +14 -5
  108. package/dist/lib/components/Layout.js.map +1 -1
  109. package/dist/lib/components/Markdown.d.ts +2 -2
  110. package/dist/lib/components/Markdown.js +4 -2
  111. package/dist/lib/components/Markdown.js.map +1 -1
  112. package/dist/lib/components/MobileTopNavigation.js +6 -7
  113. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  114. package/dist/lib/components/NotFoundPage.js +1 -1
  115. package/dist/lib/components/NotFoundPage.js.map +1 -1
  116. package/dist/lib/components/ReactMarkdown.d.ts +29 -0
  117. package/dist/lib/components/ReactMarkdown.js +182 -0
  118. package/dist/lib/components/ReactMarkdown.js.map +1 -0
  119. package/dist/lib/components/Search.d.ts +3 -1
  120. package/dist/lib/components/Search.js +3 -3
  121. package/dist/lib/components/Search.js.map +1 -1
  122. package/dist/lib/components/SlotletProvider.d.ts +2 -2
  123. package/dist/lib/components/StatusPage.d.ts +7 -0
  124. package/dist/lib/components/StatusPage.js +71 -0
  125. package/dist/lib/components/StatusPage.js.map +1 -0
  126. package/dist/lib/components/SyntaxHighlight.d.ts +2 -1
  127. package/dist/lib/components/SyntaxHighlight.js +17 -17
  128. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  129. package/dist/lib/components/ThemeSwitch.d.ts +1 -0
  130. package/dist/lib/components/ThemeSwitch.js +13 -0
  131. package/dist/lib/components/ThemeSwitch.js.map +1 -0
  132. package/dist/lib/components/TopNavigation.d.ts +2 -0
  133. package/dist/lib/components/TopNavigation.js +14 -8
  134. package/dist/lib/components/TopNavigation.js.map +1 -1
  135. package/dist/lib/components/{DevPortal.d.ts → Zudoku.d.ts} +3 -3
  136. package/dist/lib/components/{DevPortal.js → Zudoku.js} +14 -15
  137. package/dist/lib/components/Zudoku.js.map +1 -0
  138. package/dist/lib/components/cache.d.ts +6 -0
  139. package/dist/lib/components/cache.js +13 -0
  140. package/dist/lib/components/cache.js.map +1 -0
  141. package/dist/lib/components/context/ViewportAnchorContext.js +16 -4
  142. package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
  143. package/dist/lib/components/context/ZudokuContext.d.ts +7 -7
  144. package/dist/lib/components/context/ZudokuContext.js +11 -15
  145. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  146. package/dist/lib/components/context/ZudokuProvider.d.ts +2 -2
  147. package/dist/lib/components/context/ZudokuProvider.js.map +1 -1
  148. package/dist/lib/components/index.d.ts +34 -15
  149. package/dist/lib/components/index.js +12 -6
  150. package/dist/lib/components/index.js.map +1 -1
  151. package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
  152. package/dist/lib/components/navigation/Sidebar.js +2 -2
  153. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  154. package/dist/lib/components/navigation/SidebarBadge.d.ts +4 -3
  155. package/dist/lib/components/navigation/SidebarBadge.js +11 -11
  156. package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
  157. package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
  158. package/dist/lib/components/navigation/SidebarCategory.js +5 -6
  159. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  160. package/dist/lib/components/navigation/SidebarItem.d.ts +2 -4
  161. package/dist/lib/components/navigation/SidebarItem.js +7 -12
  162. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  163. package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
  164. package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
  165. package/dist/lib/components/navigation/utils.js +3 -3
  166. package/dist/lib/components/navigation/utils.js.map +1 -1
  167. package/dist/lib/core/RouteGuard.d.ts +1 -0
  168. package/dist/lib/core/RouteGuard.js +28 -0
  169. package/dist/lib/core/RouteGuard.js.map +1 -0
  170. package/dist/lib/core/{DevPortalContext.d.ts → ZudokuContext.d.ts} +8 -10
  171. package/dist/lib/core/{DevPortalContext.js → ZudokuContext.js} +11 -14
  172. package/dist/lib/core/ZudokuContext.js.map +1 -0
  173. package/dist/lib/core/plugins.d.ts +17 -13
  174. package/dist/lib/core/plugins.js.map +1 -1
  175. package/dist/lib/errors/ErrorAlert.js +1 -1
  176. package/dist/lib/errors/ErrorAlert.js.map +1 -1
  177. package/dist/lib/errors/RouterError.js +1 -1
  178. package/dist/lib/errors/RouterError.js.map +1 -1
  179. package/dist/lib/oas/graphql/circular.d.ts +3 -0
  180. package/dist/lib/oas/graphql/circular.js +27 -0
  181. package/dist/lib/oas/graphql/circular.js.map +1 -0
  182. package/dist/lib/oas/graphql/index.d.ts +3 -0
  183. package/dist/lib/oas/graphql/index.js +40 -26
  184. package/dist/lib/oas/graphql/index.js.map +1 -1
  185. package/dist/lib/oas/parser/dereference/index.js +6 -3
  186. package/dist/lib/oas/parser/dereference/index.js.map +1 -1
  187. package/dist/lib/oas/parser/upgrade/index.d.ts +2 -2
  188. package/dist/lib/oas/parser/upgrade/index.js +19 -20
  189. package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
  190. package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -0
  191. package/dist/lib/plugins/api-catalog/Catalog.js +36 -0
  192. package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -0
  193. package/dist/lib/plugins/api-catalog/index.d.ts +30 -0
  194. package/dist/lib/plugins/api-catalog/index.js +15 -0
  195. package/dist/lib/plugins/api-catalog/index.js.map +1 -0
  196. package/dist/lib/plugins/api-keys/CreateApiKey.js +1 -1
  197. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  198. package/dist/lib/plugins/api-keys/ProtectedRoute.js +1 -1
  199. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  200. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +1 -1
  201. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
  202. package/dist/lib/plugins/api-keys/index.d.ts +9 -9
  203. package/dist/lib/plugins/api-keys/index.js +3 -0
  204. package/dist/lib/plugins/api-keys/index.js.map +1 -1
  205. package/dist/lib/plugins/custom-pages/index.d.ts +2 -2
  206. package/dist/lib/plugins/custom-pages/index.js.map +1 -1
  207. package/dist/lib/plugins/markdown/MdxPage.d.ts +9 -1
  208. package/dist/lib/plugins/markdown/MdxPage.js +22 -3
  209. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  210. package/dist/lib/plugins/markdown/index.d.ts +5 -3
  211. package/dist/lib/plugins/markdown/index.js +1 -1
  212. package/dist/lib/plugins/markdown/index.js.map +1 -1
  213. package/dist/lib/plugins/markdown/resolver.js.map +1 -1
  214. package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +5 -0
  215. package/dist/lib/plugins/openapi/CollapsibleCode.js +25 -0
  216. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -0
  217. package/dist/lib/plugins/openapi/ColorizedParam.d.ts +10 -2
  218. package/dist/lib/plugins/openapi/ColorizedParam.js +27 -14
  219. package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
  220. package/dist/lib/plugins/openapi/Endpoint.js +8 -10
  221. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  222. package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
  223. package/dist/lib/plugins/openapi/OperationList.js +46 -23
  224. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  225. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  226. package/dist/lib/plugins/openapi/OperationListItem.js +14 -4
  227. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  228. package/dist/lib/plugins/openapi/ParameterListItem.js +7 -1
  229. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  230. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +3 -1
  231. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +5 -2
  232. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
  233. package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +4 -5
  234. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +4 -10
  235. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  236. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +7 -6
  237. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  238. package/dist/lib/plugins/openapi/Route.d.ts +7 -5
  239. package/dist/lib/plugins/openapi/Route.js +23 -5
  240. package/dist/lib/plugins/openapi/Route.js.map +1 -1
  241. package/dist/lib/plugins/openapi/Sidecar.d.ts +1 -1
  242. package/dist/lib/plugins/openapi/Sidecar.js +46 -51
  243. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  244. package/dist/lib/plugins/openapi/SidecarBox.js +4 -4
  245. package/dist/lib/plugins/openapi/SidecarBox.js.map +1 -1
  246. package/dist/lib/plugins/openapi/SidecarExamples.d.ts +9 -0
  247. package/dist/lib/plugins/openapi/SidecarExamples.js +65 -0
  248. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -0
  249. package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +8 -0
  250. package/dist/lib/plugins/openapi/client/GraphQLClient.js +43 -0
  251. package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -0
  252. package/dist/lib/plugins/openapi/client/GraphQLContext.d.ts +7 -0
  253. package/dist/lib/plugins/openapi/client/GraphQLContext.js +5 -0
  254. package/dist/lib/plugins/openapi/client/GraphQLContext.js.map +1 -0
  255. package/dist/lib/plugins/openapi/client/createServer.d.ts +3 -1
  256. package/dist/lib/plugins/openapi/client/createServer.js +5 -2
  257. package/dist/lib/plugins/openapi/client/createServer.js.map +1 -1
  258. package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +5 -0
  259. package/dist/lib/plugins/openapi/client/useCreateQuery.js +13 -0
  260. package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -0
  261. package/dist/lib/plugins/openapi/context.d.ts +3 -3
  262. package/dist/lib/plugins/openapi/graphql/fragment-masking.d.ts +3 -3
  263. package/dist/lib/plugins/openapi/graphql/fragment-masking.js +3 -4
  264. package/dist/lib/plugins/openapi/graphql/fragment-masking.js.map +1 -1
  265. package/dist/lib/plugins/openapi/graphql/gql.d.ts +5 -51
  266. package/dist/lib/plugins/openapi/graphql/gql.js +5 -3
  267. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  268. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +34 -8
  269. package/dist/lib/plugins/openapi/graphql/graphql.js +195 -662
  270. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  271. package/dist/lib/plugins/openapi/index.d.ts +4 -3
  272. package/dist/lib/plugins/openapi/index.js +56 -74
  273. package/dist/lib/plugins/openapi/index.js.map +1 -1
  274. package/dist/lib/plugins/openapi/interfaces.d.ts +26 -2
  275. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +6 -0
  276. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +12 -0
  277. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -0
  278. package/dist/lib/plugins/openapi/playground/Headers.js +66 -4
  279. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  280. package/dist/lib/plugins/openapi/playground/PathParams.js +9 -4
  281. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  282. package/dist/lib/plugins/openapi/playground/Playground.d.ts +8 -1
  283. package/dist/lib/plugins/openapi/playground/Playground.js +40 -12
  284. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  285. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
  286. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  287. package/dist/lib/plugins/openapi/playground/QueryParams.js +19 -14
  288. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  289. package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +7 -0
  290. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +16 -0
  291. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -0
  292. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +174 -0
  293. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -0
  294. package/dist/lib/plugins/openapi/post-processors/removeParameters.d.ts +10 -0
  295. package/dist/lib/plugins/openapi/post-processors/removeParameters.js +66 -0
  296. package/dist/lib/plugins/openapi/post-processors/removeParameters.js.map +1 -0
  297. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.d.ts +1 -0
  298. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js +131 -0
  299. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js.map +1 -0
  300. package/dist/lib/plugins/openapi/post-processors/removePaths.d.ts +11 -0
  301. package/dist/lib/plugins/openapi/post-processors/removePaths.js +33 -0
  302. package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +1 -0
  303. package/dist/lib/plugins/openapi/post-processors/removePaths.test.d.ts +1 -0
  304. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +104 -0
  305. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +1 -0
  306. package/dist/lib/plugins/openapi/post-processors/traverse.d.ts +1 -0
  307. package/dist/lib/plugins/openapi/post-processors/traverse.js +2 -0
  308. package/dist/lib/plugins/openapi/post-processors/traverse.js.map +1 -0
  309. package/dist/lib/plugins/openapi/schema/SchemaComponents.js +9 -2
  310. package/dist/lib/plugins/openapi/schema/SchemaComponents.js.map +1 -1
  311. package/dist/lib/plugins/openapi/schema/SchemaView.js +2 -1
  312. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  313. package/dist/lib/plugins/openapi/util/generateSchemaExample.d.ts +0 -1
  314. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +36 -39
  315. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  316. package/dist/lib/plugins/openapi/util/methodToColor.d.ts +20 -0
  317. package/dist/lib/plugins/openapi/util/methodToColor.js +24 -0
  318. package/dist/lib/plugins/openapi/util/methodToColor.js.map +1 -0
  319. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.d.ts +1 -0
  320. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js +27 -0
  321. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js.map +1 -0
  322. package/dist/lib/plugins/redirect/index.d.ts +3 -3
  323. package/dist/lib/plugins/redirect/index.js +1 -1
  324. package/dist/lib/plugins/redirect/index.js.map +1 -1
  325. package/dist/lib/plugins/search-inkeep/index.d.ts +24 -5
  326. package/dist/lib/plugins/search-inkeep/index.js +41 -5
  327. package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
  328. package/dist/lib/plugins/search-inkeep/inkeep.d.ts +3 -4
  329. package/dist/lib/plugins/search-inkeep/inkeep.js.map +1 -1
  330. package/dist/lib/ui/ActionButton.d.ts +4 -0
  331. package/dist/lib/ui/ActionButton.js +10 -0
  332. package/dist/lib/ui/ActionButton.js.map +1 -0
  333. package/dist/lib/ui/Badge.d.ts +1 -1
  334. package/dist/lib/ui/Badge.js +2 -1
  335. package/dist/lib/ui/Badge.js.map +1 -1
  336. package/dist/lib/ui/Button.d.ts +1 -1
  337. package/dist/lib/ui/Card.js +1 -1
  338. package/dist/lib/ui/Card.js.map +1 -1
  339. package/dist/lib/ui/Checkbox.d.ts +8 -2
  340. package/dist/lib/ui/Checkbox.js +13 -1
  341. package/dist/lib/ui/Checkbox.js.map +1 -1
  342. package/dist/lib/ui/Command.d.ts +10 -2
  343. package/dist/lib/ui/Command.js +5 -1
  344. package/dist/lib/ui/Command.js.map +1 -1
  345. package/dist/lib/util/MdxComponents.d.ts +19 -20
  346. package/dist/lib/util/MdxComponents.js +3 -5
  347. package/dist/lib/util/MdxComponents.js.map +1 -1
  348. package/dist/lib/util/createVariantComponent.d.ts +2 -2
  349. package/dist/lib/util/joinUrl.d.ts +1 -0
  350. package/dist/lib/util/joinUrl.js +40 -0
  351. package/dist/lib/util/joinUrl.js.map +1 -0
  352. package/dist/lib/util/traverse.d.ts +9 -0
  353. package/dist/lib/util/traverse.js +22 -0
  354. package/dist/lib/util/traverse.js.map +1 -0
  355. package/dist/lib/util/useExposedProps.js +1 -1
  356. package/dist/lib/util/useExposedProps.js.map +1 -1
  357. package/dist/lib/util/useIsomorphicLayoutEffect.d.ts +3 -0
  358. package/dist/lib/util/useIsomorphicLayoutEffect.js +4 -0
  359. package/dist/lib/util/useIsomorphicLayoutEffect.js.map +1 -0
  360. package/dist/lib/util/useOnScreen.d.ts +4 -0
  361. package/dist/lib/util/useOnScreen.js +19 -0
  362. package/dist/lib/util/useOnScreen.js.map +1 -0
  363. package/dist/lib/util/useScrollToAnchor.d.ts +1 -0
  364. package/dist/lib/util/useScrollToAnchor.js +27 -16
  365. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  366. package/dist/lib/util/useScrollToTop.js +1 -1
  367. package/dist/lib/util/useScrollToTop.js.map +1 -1
  368. package/dist/vite/api/schema-codegen.d.ts +12 -0
  369. package/dist/vite/api/schema-codegen.js +62 -0
  370. package/dist/vite/api/schema-codegen.js.map +1 -0
  371. package/dist/vite/api/schema-codegen.test.d.ts +1 -0
  372. package/dist/vite/api/schema-codegen.test.js +247 -0
  373. package/dist/vite/api/schema-codegen.test.js.map +1 -0
  374. package/dist/vite/build.js +24 -10
  375. package/dist/vite/build.js.map +1 -1
  376. package/dist/vite/config.d.ts +6 -4
  377. package/dist/vite/config.js +83 -31
  378. package/dist/vite/config.js.map +1 -1
  379. package/dist/vite/config.test.js +11 -5
  380. package/dist/vite/config.test.js.map +1 -1
  381. package/dist/vite/css/collect.d.ts +2 -0
  382. package/dist/vite/css/collect.js +27 -0
  383. package/dist/vite/css/collect.js.map +1 -0
  384. package/dist/vite/css/plugin.d.ts +5 -0
  385. package/dist/vite/css/plugin.js +79 -0
  386. package/dist/vite/css/plugin.js.map +1 -0
  387. package/dist/vite/dev-server.d.ts +1 -0
  388. package/dist/vite/dev-server.js +26 -6
  389. package/dist/vite/dev-server.js.map +1 -1
  390. package/dist/vite/html.js +0 -2
  391. package/dist/vite/html.js.map +1 -1
  392. package/dist/vite/output.d.ts +1 -1
  393. package/dist/vite/output.js +44 -12
  394. package/dist/vite/output.js.map +1 -1
  395. package/dist/vite/plugin-api.d.ts +1 -1
  396. package/dist/vite/plugin-api.js +154 -22
  397. package/dist/vite/plugin-api.js.map +1 -1
  398. package/dist/vite/plugin-auth.js +4 -1
  399. package/dist/vite/plugin-auth.js.map +1 -1
  400. package/dist/vite/plugin-component.js +14 -19
  401. package/dist/vite/plugin-component.js.map +1 -1
  402. package/dist/vite/plugin-config-reload.d.ts +1 -2
  403. package/dist/vite/plugin-config-reload.js.map +1 -1
  404. package/dist/vite/plugin-config.js +20 -0
  405. package/dist/vite/plugin-config.js.map +1 -1
  406. package/dist/vite/plugin-docs.test.js +15 -23
  407. package/dist/vite/plugin-docs.test.js.map +1 -1
  408. package/dist/vite/plugin-mdx.d.ts +0 -6
  409. package/dist/vite/plugin-mdx.js +72 -10
  410. package/dist/vite/plugin-mdx.js.map +1 -1
  411. package/dist/vite/{plugin-custom-css.d.ts → plugin-theme-css.d.ts} +2 -2
  412. package/dist/vite/plugin-theme-css.js +114 -0
  413. package/dist/vite/plugin-theme-css.js.map +1 -0
  414. package/dist/vite/plugin.d.ts +1 -2
  415. package/dist/vite/plugin.js +6 -4
  416. package/dist/vite/plugin.js.map +1 -1
  417. package/dist/vite/prerender.d.ts +3 -2
  418. package/dist/vite/prerender.js +8 -6
  419. package/dist/vite/prerender.js.map +1 -1
  420. package/dist/vite/remarkStaticGeneration.d.ts +3 -0
  421. package/dist/vite/remarkStaticGeneration.js +125 -0
  422. package/dist/vite/remarkStaticGeneration.js.map +1 -0
  423. package/dist/vite/sitemap.d.ts +1 -1
  424. package/dist/zuplo/enrich-with-zuplo.d.ts +5 -0
  425. package/dist/zuplo/enrich-with-zuplo.js +184 -0
  426. package/dist/zuplo/enrich-with-zuplo.js.map +1 -0
  427. package/dist/zuplo/env.d.ts +7 -0
  428. package/dist/zuplo/env.js +12 -0
  429. package/dist/zuplo/env.js.map +1 -0
  430. package/dist/zuplo/policy-types.d.ts +33 -0
  431. package/dist/zuplo/policy-types.js +8 -0
  432. package/dist/zuplo/policy-types.js.map +1 -0
  433. package/dist/zuplo/with-zuplo-processors.d.ts +3 -0
  434. package/dist/zuplo/with-zuplo-processors.js +26 -0
  435. package/dist/zuplo/with-zuplo-processors.js.map +1 -0
  436. package/dist/zuplo/with-zuplo.d.ts +3 -0
  437. package/dist/zuplo/with-zuplo.js +9 -0
  438. package/dist/zuplo/with-zuplo.js.map +1 -0
  439. package/lib/AuthenticationPlugin-CvwlQWjV.js +58 -0
  440. package/lib/AuthenticationPlugin-CvwlQWjV.js.map +1 -0
  441. package/lib/{CategoryHeading-Bb9dqxD3.js → CategoryHeading-MYL1u_6K.js} +3 -3
  442. package/lib/{CategoryHeading-Bb9dqxD3.js.map → CategoryHeading-MYL1u_6K.js.map} +1 -1
  443. package/lib/{ClientOnly-CVN6leDu.js → ClientOnly-E7hGysn1.js} +4 -4
  444. package/lib/ClientOnly-E7hGysn1.js.map +1 -0
  445. package/lib/Markdown-B8o9Qz4q.js +15213 -0
  446. package/lib/Markdown-B8o9Qz4q.js.map +1 -0
  447. package/lib/MdxPage-DiWukCrZ.js +193 -0
  448. package/lib/MdxPage-DiWukCrZ.js.map +1 -0
  449. package/lib/OperationList-CyNwMHMV.js +5146 -0
  450. package/lib/OperationList-CyNwMHMV.js.map +1 -0
  451. package/lib/Route-DH64hIrR.js +35 -0
  452. package/lib/Route-DH64hIrR.js.map +1 -0
  453. package/lib/{Select-Bagt3Bme.js → Select-4kIgJ1bc.js} +39 -39
  454. package/lib/Select-4kIgJ1bc.js.map +1 -0
  455. package/lib/SlotletProvider-CtIp8rP3.js +221 -0
  456. package/lib/SlotletProvider-CtIp8rP3.js.map +1 -0
  457. package/lib/Spinner-BlzrEEk1.js +51 -0
  458. package/lib/Spinner-BlzrEEk1.js.map +1 -0
  459. package/lib/{StaggeredRender-DDHSzQKE.js → StaggeredRender-DgsamH_G.js} +3 -3
  460. package/lib/{StaggeredRender-DDHSzQKE.js.map → StaggeredRender-DgsamH_G.js.map} +1 -1
  461. package/lib/SyntaxHighlight-C1w1QPdY.js +2980 -0
  462. package/lib/SyntaxHighlight-C1w1QPdY.js.map +1 -0
  463. package/lib/ZudokuContext-Bp2uQx1d.js +1228 -0
  464. package/lib/ZudokuContext-Bp2uQx1d.js.map +1 -0
  465. package/lib/chunk-SYFQ2XB5-BPvC-soB.js +1821 -0
  466. package/lib/chunk-SYFQ2XB5-BPvC-soB.js.map +1 -0
  467. package/lib/circular-Dgpd6AN-.js +15397 -0
  468. package/lib/circular-Dgpd6AN-.js.map +1 -0
  469. package/lib/{cn-BmFQLtkS.js → cn-qaFjX9_3.js} +2 -2
  470. package/lib/cn-qaFjX9_3.js.map +1 -0
  471. package/lib/context-rwLGh-6_.js +22 -0
  472. package/lib/context-rwLGh-6_.js.map +1 -0
  473. package/lib/createServer-BV0tHzLK.js +12590 -0
  474. package/lib/createServer-BV0tHzLK.js.map +1 -0
  475. package/lib/{hook-sn0zMTkE.js → hook-BDmay56y.js} +22 -24
  476. package/lib/hook-BDmay56y.js.map +1 -0
  477. package/lib/index-B7mqiOei.js +509 -0
  478. package/lib/index-B7mqiOei.js.map +1 -0
  479. package/lib/index-BtNudmKQ.js +1744 -0
  480. package/lib/index-BtNudmKQ.js.map +1 -0
  481. package/lib/index-Djenk2Hj.js +36 -0
  482. package/lib/index-Djenk2Hj.js.map +1 -0
  483. package/lib/{index-CkwDvuPt.js → index-Dl3Yl0yb.js} +303 -286
  484. package/lib/index-Dl3Yl0yb.js.map +1 -0
  485. package/lib/index-LNp6rxyU.js.map +1 -1
  486. package/lib/index.esm-9-TF9KQB.js +692 -0
  487. package/lib/index.esm-9-TF9KQB.js.map +1 -0
  488. package/lib/index.esm-CrSoEshU.js +1207 -0
  489. package/lib/index.esm-CrSoEshU.js.map +1 -0
  490. package/lib/invariant-Caa8-XvF.js.map +1 -1
  491. package/lib/joinUrl-BTy9bvoK.js +20 -0
  492. package/lib/joinUrl-BTy9bvoK.js.map +1 -0
  493. package/lib/jsx-runtime-Bdg6XQ1m.js +446 -0
  494. package/lib/jsx-runtime-Bdg6XQ1m.js.map +1 -0
  495. package/lib/post-processors/removeExtensions.js +11 -0
  496. package/lib/post-processors/removeExtensions.js.map +1 -0
  497. package/lib/post-processors/removeParameters.js +48 -0
  498. package/lib/post-processors/removeParameters.js.map +1 -0
  499. package/lib/post-processors/removePaths.js +28 -0
  500. package/lib/post-processors/removePaths.js.map +1 -0
  501. package/lib/post-processors/traverse.js +15 -0
  502. package/lib/post-processors/traverse.js.map +1 -0
  503. package/lib/{prism-bash.min-DadFsM4Z.js → prism-bash.min-HHIMdNJ_.js} +4 -4
  504. package/lib/{prism-bash.min-DadFsM4Z.js.map → prism-bash.min-HHIMdNJ_.js.map} +1 -1
  505. package/lib/prism-csharp.min-bQAo2pmx.js +63 -0
  506. package/lib/{prism-csharp.min-Yizuc34Y.js.map → prism-csharp.min-bQAo2pmx.js.map} +1 -1
  507. package/lib/prism-java.min-BpvsOuIa.js +35 -0
  508. package/lib/{prism-java.min-d5iT_mOd.js.map → prism-java.min-BpvsOuIa.js.map} +1 -1
  509. package/lib/{prism-markdown.min-F3U-vPBi.js → prism-markdown.min-C0Qn0m-5.js} +30 -30
  510. package/lib/{prism-markdown.min-F3U-vPBi.js.map → prism-markdown.min-C0Qn0m-5.js.map} +1 -1
  511. package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
  512. package/lib/prism-ruby.min-Dx9KO9ds.js +38 -0
  513. package/lib/{prism-ruby.min-C7LwcKyz.js.map → prism-ruby.min-Dx9KO9ds.js.map} +1 -1
  514. package/lib/prism-typescript.min-CD7H2IYQ.js +34 -0
  515. package/lib/{prism-typescript.min-oSVeWCAd.js.map → prism-typescript.min-CD7H2IYQ.js.map} +1 -1
  516. package/lib/state-mM7uaXTW.js +202 -0
  517. package/lib/state-mM7uaXTW.js.map +1 -0
  518. package/lib/ui/Accordion.js +2 -2
  519. package/lib/ui/Accordion.js.map +1 -1
  520. package/lib/ui/ActionButton.js +24 -0
  521. package/lib/ui/ActionButton.js.map +1 -0
  522. package/lib/ui/Alert.js +3 -3
  523. package/lib/ui/Alert.js.map +1 -1
  524. package/lib/ui/AlertDialog.js +2 -2
  525. package/lib/ui/AlertDialog.js.map +1 -1
  526. package/lib/ui/Badge.js +5 -4
  527. package/lib/ui/Badge.js.map +1 -1
  528. package/lib/ui/Breadcrumb.js +2 -2
  529. package/lib/ui/Breadcrumb.js.map +1 -1
  530. package/lib/ui/Button.js +3 -3
  531. package/lib/ui/Button.js.map +1 -1
  532. package/lib/ui/Callout.js +2 -2
  533. package/lib/ui/Callout.js.map +1 -1
  534. package/lib/ui/Card.js +9 -9
  535. package/lib/ui/Card.js.map +1 -1
  536. package/lib/ui/Carousel.js +408 -402
  537. package/lib/ui/Carousel.js.map +1 -1
  538. package/lib/ui/Checkbox.js +26 -15
  539. package/lib/ui/Checkbox.js.map +1 -1
  540. package/lib/ui/Command.js +80 -501
  541. package/lib/ui/Command.js.map +1 -1
  542. package/lib/ui/Dialog.js +2 -2
  543. package/lib/ui/Dialog.js.map +1 -1
  544. package/lib/ui/Drawer.js +515 -514
  545. package/lib/ui/Drawer.js.map +1 -1
  546. package/lib/ui/DropdownMenu.js +2 -2
  547. package/lib/ui/DropdownMenu.js.map +1 -1
  548. package/lib/ui/Form.js +3 -3
  549. package/lib/ui/Form.js.map +1 -1
  550. package/lib/ui/HoverCard.js +2 -2
  551. package/lib/ui/Input.js +2 -2
  552. package/lib/ui/Input.js.map +1 -1
  553. package/lib/ui/Label.js +3 -3
  554. package/lib/ui/Pagination.js +8 -8
  555. package/lib/ui/Pagination.js.map +1 -1
  556. package/lib/ui/Popover.js +2 -2
  557. package/lib/ui/Popover.js.map +1 -1
  558. package/lib/ui/Progress.js +2 -2
  559. package/lib/ui/Progress.js.map +1 -1
  560. package/lib/ui/RadioGroup.js +2 -2
  561. package/lib/ui/RadioGroup.js.map +1 -1
  562. package/lib/ui/ScrollArea.js +2 -2
  563. package/lib/ui/ScrollArea.js.map +1 -1
  564. package/lib/ui/Select.js +2 -2
  565. package/lib/ui/Select.js.map +1 -1
  566. package/lib/ui/Skeleton.js +2 -2
  567. package/lib/ui/Skeleton.js.map +1 -1
  568. package/lib/ui/Slider.js +2 -2
  569. package/lib/ui/Switch.js +2 -2
  570. package/lib/ui/Switch.js.map +1 -1
  571. package/lib/ui/Tabs.js +2 -2
  572. package/lib/ui/Textarea.js +2 -2
  573. package/lib/ui/Textarea.js.map +1 -1
  574. package/lib/ui/Toggle.js +3 -3
  575. package/lib/ui/Toggle.js.map +1 -1
  576. package/lib/ui/ToggleGroup.js +2 -2
  577. package/lib/ui/ToggleGroup.js.map +1 -1
  578. package/lib/ui/Tooltip.js +2 -2
  579. package/lib/{useExposedProps-ChOIUaS4.js → useExposedProps-BLKFBylA.js} +2 -2
  580. package/lib/useExposedProps-BLKFBylA.js.map +1 -0
  581. package/lib/useScrollToAnchor-S-NbG5Za.js +288 -0
  582. package/lib/useScrollToAnchor-S-NbG5Za.js.map +1 -0
  583. package/lib/zudoku.auth-auth0.js +24 -20
  584. package/lib/zudoku.auth-auth0.js.map +1 -1
  585. package/lib/zudoku.auth-clerk.js +79 -51
  586. package/lib/zudoku.auth-clerk.js.map +1 -1
  587. package/lib/zudoku.auth-openid.js +409 -410
  588. package/lib/zudoku.auth-openid.js.map +1 -1
  589. package/lib/zudoku.components.js +855 -1120
  590. package/lib/zudoku.components.js.map +1 -1
  591. package/lib/zudoku.plugin-api-catalog.js +123 -0
  592. package/lib/zudoku.plugin-api-catalog.js.map +1 -0
  593. package/lib/zudoku.plugin-api-keys.js +40 -39
  594. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  595. package/lib/zudoku.plugin-custom-pages.js +4 -4
  596. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  597. package/lib/zudoku.plugin-markdown.js +16 -15
  598. package/lib/zudoku.plugin-markdown.js.map +1 -1
  599. package/lib/zudoku.plugin-openapi.js +6 -10
  600. package/lib/zudoku.plugin-openapi.js.map +1 -1
  601. package/lib/zudoku.plugin-redirect.js +1 -1
  602. package/lib/zudoku.plugin-redirect.js.map +1 -1
  603. package/lib/zudoku.plugin-search-inkeep.js +53 -24
  604. package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
  605. package/package.json +109 -82
  606. package/src/app/demo.tsx +1 -5
  607. package/src/app/entry.client.tsx +16 -1
  608. package/src/app/entry.server.tsx +62 -55
  609. package/src/app/main.css +58 -45
  610. package/src/app/main.tsx +36 -13
  611. package/src/app/sentry.ts +24 -0
  612. package/src/app/standalone.tsx +1 -5
  613. package/src/app/tailwind.ts +67 -52
  614. package/src/lib/authentication/AuthenticationPlugin.tsx +4 -1
  615. package/src/lib/authentication/authentication.ts +3 -3
  616. package/src/lib/authentication/components/CallbackHandler.tsx +1 -1
  617. package/src/lib/authentication/components/SignIn.tsx +1 -1
  618. package/src/lib/authentication/components/SignOut.tsx +3 -2
  619. package/src/lib/authentication/hook.ts +1 -3
  620. package/src/lib/authentication/providers/auth0.tsx +16 -14
  621. package/src/lib/authentication/providers/clerk.tsx +38 -7
  622. package/src/lib/authentication/providers/openid.tsx +41 -40
  623. package/src/lib/authentication/state.ts +50 -9
  624. package/{LICENSE.md → src/lib/authentication/use-broadcast/LICENSE.md} +2 -2
  625. package/src/lib/authentication/use-broadcast/shared.ts +372 -0
  626. package/src/lib/authentication/use-broadcast/useBroadcast.ts +146 -0
  627. package/src/lib/components/AnchorLink.tsx +6 -3
  628. package/src/lib/components/Autocomplete.tsx +111 -0
  629. package/src/lib/components/Bootstrap.tsx +36 -16
  630. package/src/lib/components/ClientOnly.tsx +6 -3
  631. package/src/lib/components/DeveloperHint.tsx +6 -1
  632. package/src/lib/components/Header.tsx +81 -49
  633. package/src/lib/components/Heading.tsx +13 -13
  634. package/src/lib/components/Layout.tsx +55 -38
  635. package/src/lib/components/Markdown.tsx +15 -16
  636. package/src/lib/components/MobileTopNavigation.tsx +27 -30
  637. package/src/lib/components/NotFoundPage.tsx +1 -1
  638. package/src/lib/components/ReactMarkdown.license.txt +21 -0
  639. package/src/lib/components/ReactMarkdown.tsx +264 -0
  640. package/src/lib/components/Search.tsx +3 -3
  641. package/src/lib/components/SlotletProvider.tsx +1 -1
  642. package/src/lib/components/StatusPage.tsx +91 -0
  643. package/src/lib/components/SyntaxHighlight.tsx +95 -50
  644. package/src/lib/components/ThemeSwitch.tsx +25 -0
  645. package/src/lib/components/TopNavigation.tsx +28 -20
  646. package/src/lib/components/Zudoku.tsx +108 -0
  647. package/src/lib/components/cache.ts +15 -0
  648. package/src/lib/components/context/ViewportAnchorContext.tsx +20 -6
  649. package/src/lib/components/context/ZudokuContext.ts +15 -18
  650. package/src/lib/components/context/ZudokuProvider.tsx +2 -2
  651. package/src/lib/components/index.ts +17 -7
  652. package/src/lib/components/navigation/Sidebar.tsx +20 -10
  653. package/src/lib/components/navigation/SidebarBadge.tsx +13 -11
  654. package/src/lib/components/navigation/SidebarCategory.tsx +8 -11
  655. package/src/lib/components/navigation/SidebarItem.tsx +12 -15
  656. package/src/lib/components/navigation/SidebarWrapper.tsx +3 -2
  657. package/src/lib/components/navigation/utils.ts +3 -3
  658. package/src/lib/core/RouteGuard.tsx +35 -0
  659. package/src/lib/core/{DevPortalContext.ts → ZudokuContext.ts} +13 -20
  660. package/src/lib/core/plugins.ts +17 -17
  661. package/src/lib/errors/ErrorAlert.tsx +2 -1
  662. package/src/lib/errors/RouterError.tsx +1 -1
  663. package/src/lib/oas/graphql/circular.ts +29 -0
  664. package/src/lib/oas/graphql/index.ts +51 -35
  665. package/src/lib/oas/parser/dereference/index.ts +8 -4
  666. package/src/lib/oas/parser/upgrade/index.ts +22 -28
  667. package/src/lib/plugins/api-catalog/Catalog.tsx +123 -0
  668. package/src/lib/plugins/api-catalog/index.tsx +64 -0
  669. package/src/lib/plugins/api-keys/CreateApiKey.tsx +1 -1
  670. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +1 -1
  671. package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +1 -1
  672. package/src/lib/plugins/api-keys/index.tsx +13 -10
  673. package/src/lib/plugins/custom-pages/index.tsx +3 -3
  674. package/src/lib/plugins/markdown/MdxPage.tsx +36 -2
  675. package/src/lib/plugins/markdown/index.tsx +7 -4
  676. package/src/lib/plugins/markdown/resolver.ts +2 -4
  677. package/src/lib/plugins/openapi/CollapsibleCode.tsx +83 -0
  678. package/src/lib/plugins/openapi/ColorizedParam.tsx +49 -23
  679. package/src/lib/plugins/openapi/Endpoint.tsx +8 -13
  680. package/src/lib/plugins/openapi/OperationList.tsx +84 -44
  681. package/src/lib/plugins/openapi/OperationListItem.tsx +33 -4
  682. package/src/lib/plugins/openapi/ParameterListItem.tsx +35 -31
  683. package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +7 -0
  684. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +14 -34
  685. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +46 -58
  686. package/src/lib/plugins/openapi/Route.tsx +42 -11
  687. package/src/lib/plugins/openapi/Sidecar.tsx +89 -82
  688. package/src/lib/plugins/openapi/SidecarBox.tsx +4 -16
  689. package/src/lib/plugins/openapi/SidecarExamples.tsx +163 -0
  690. package/src/lib/plugins/openapi/client/GraphQLClient.tsx +65 -0
  691. package/src/lib/plugins/openapi/client/GraphQLContext.tsx +16 -0
  692. package/src/lib/plugins/openapi/client/createServer.ts +8 -2
  693. package/src/lib/plugins/openapi/client/useCreateQuery.ts +18 -0
  694. package/src/lib/plugins/openapi/context.tsx +2 -2
  695. package/src/lib/plugins/openapi/graphql/fragment-masking.ts +11 -18
  696. package/src/lib/plugins/openapi/graphql/gql.ts +12 -29
  697. package/src/lib/plugins/openapi/graphql/graphql.ts +236 -665
  698. package/src/lib/plugins/openapi/index.tsx +85 -105
  699. package/src/lib/plugins/openapi/interfaces.ts +31 -2
  700. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +51 -0
  701. package/src/lib/plugins/openapi/playground/Headers.tsx +139 -41
  702. package/src/lib/plugins/openapi/playground/PathParams.tsx +72 -63
  703. package/src/lib/plugins/openapi/playground/Playground.tsx +181 -74
  704. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +1 -1
  705. package/src/lib/plugins/openapi/playground/QueryParams.tsx +87 -91
  706. package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +202 -0
  707. package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +27 -0
  708. package/src/lib/plugins/openapi/post-processors/removeParameters.test.ts +148 -0
  709. package/src/lib/plugins/openapi/post-processors/removeParameters.ts +101 -0
  710. package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +126 -0
  711. package/src/lib/plugins/openapi/post-processors/removePaths.ts +55 -0
  712. package/src/lib/plugins/openapi/post-processors/traverse.ts +1 -0
  713. package/src/lib/plugins/openapi/schema/SchemaComponents.tsx +29 -8
  714. package/src/lib/plugins/openapi/schema/SchemaView.tsx +5 -2
  715. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +44 -43
  716. package/src/lib/plugins/openapi/util/methodToColor.ts +27 -0
  717. package/src/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.tsx +32 -0
  718. package/src/lib/plugins/redirect/index.tsx +4 -4
  719. package/src/lib/plugins/search-inkeep/index.tsx +80 -25
  720. package/src/lib/plugins/search-inkeep/inkeep.ts +3 -9
  721. package/src/lib/ui/ActionButton.tsx +28 -0
  722. package/src/lib/ui/Badge.tsx +2 -1
  723. package/src/lib/ui/Card.tsx +1 -1
  724. package/src/lib/ui/Checkbox.tsx +24 -7
  725. package/src/lib/ui/Command.tsx +20 -0
  726. package/src/lib/util/MdxComponents.tsx +5 -9
  727. package/src/lib/util/createVariantComponent.tsx +2 -2
  728. package/src/lib/util/joinUrl.ts +57 -0
  729. package/src/lib/util/traverse.ts +35 -0
  730. package/src/lib/util/useExposedProps.tsx +1 -1
  731. package/src/lib/util/useIsomorphicLayoutEffect.ts +5 -0
  732. package/src/lib/util/useOnScreen.ts +32 -0
  733. package/src/lib/util/useScrollToAnchor.ts +33 -16
  734. package/src/lib/util/useScrollToTop.ts +1 -1
  735. package/dist/lib/components/DevPortal.js.map +0 -1
  736. package/dist/lib/components/context/ThemeContext.d.ts +0 -2
  737. package/dist/lib/components/context/ThemeContext.js +0 -7
  738. package/dist/lib/components/context/ThemeContext.js.map +0 -1
  739. package/dist/lib/components/context/ThemeProvider.d.ts +0 -4
  740. package/dist/lib/components/context/ThemeProvider.js +0 -23
  741. package/dist/lib/components/context/ThemeProvider.js.map +0 -1
  742. package/dist/lib/core/DevPortalContext.js.map +0 -1
  743. package/dist/lib/plugins/openapi/client/createMemoryClient.d.ts +0 -12
  744. package/dist/lib/plugins/openapi/client/createMemoryClient.js +0 -46
  745. package/dist/lib/plugins/openapi/client/createMemoryClient.js.map +0 -1
  746. package/dist/lib/plugins/openapi/client/createWorkerClient.d.ts +0 -10
  747. package/dist/lib/plugins/openapi/client/createWorkerClient.js +0 -61
  748. package/dist/lib/plugins/openapi/client/createWorkerClient.js.map +0 -1
  749. package/dist/lib/plugins/openapi/client/interfaces.d.ts +0 -4
  750. package/dist/lib/plugins/openapi/client/interfaces.js +0 -2
  751. package/dist/lib/plugins/openapi/client/interfaces.js.map +0 -1
  752. package/dist/lib/plugins/openapi/client/worker.js +0 -20
  753. package/dist/lib/plugins/openapi/client/worker.js.map +0 -1
  754. package/dist/lib/plugins/openapi-worker.d.ts +0 -1
  755. package/dist/lib/plugins/openapi-worker.js +0 -2
  756. package/dist/lib/plugins/openapi-worker.js.map +0 -1
  757. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.d.ts +0 -2
  758. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js +0 -3
  759. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js.map +0 -1
  760. package/dist/lib/themeToggle.d.ts +0 -1
  761. package/dist/lib/themeToggle.js +0 -7
  762. package/dist/lib/themeToggle.js.map +0 -1
  763. package/dist/lib/util/createWaitForNotify.d.ts +0 -1
  764. package/dist/lib/util/createWaitForNotify.js +0 -15
  765. package/dist/lib/util/createWaitForNotify.js.map +0 -1
  766. package/dist/vite/plugin-custom-css.js +0 -55
  767. package/dist/vite/plugin-custom-css.js.map +0 -1
  768. package/dist/vite/plugin-html-transform.d.ts +0 -2
  769. package/dist/vite/plugin-html-transform.js +0 -15
  770. package/dist/vite/plugin-html-transform.js.map +0 -1
  771. package/lib/AnchorLink-BbB2q-jx.js +0 -705
  772. package/lib/AnchorLink-BbB2q-jx.js.map +0 -1
  773. package/lib/AuthenticationPlugin-C9BHGXlE.js +0 -55
  774. package/lib/AuthenticationPlugin-C9BHGXlE.js.map +0 -1
  775. package/lib/ClientOnly-CVN6leDu.js.map +0 -1
  776. package/lib/DeveloperHint-DHdLXGHA.js +0 -16
  777. package/lib/DeveloperHint-DHdLXGHA.js.map +0 -1
  778. package/lib/Dialog-k70Qfukb.js +0 -67
  779. package/lib/Dialog-k70Qfukb.js.map +0 -1
  780. package/lib/InkeepCustomTrigger-CE5-K5ex.js +0 -6
  781. package/lib/InkeepCustomTrigger-CE5-K5ex.js.map +0 -1
  782. package/lib/Markdown-BDcCAWwm.js +0 -18059
  783. package/lib/Markdown-BDcCAWwm.js.map +0 -1
  784. package/lib/MdxPage-DKMH_t0f.js +0 -174
  785. package/lib/MdxPage-DKMH_t0f.js.map +0 -1
  786. package/lib/OperationList-Tj7ubW_t.js +0 -604
  787. package/lib/OperationList-Tj7ubW_t.js.map +0 -1
  788. package/lib/Route-C3DGB6OS.js +0 -13
  789. package/lib/Route-C3DGB6OS.js.map +0 -1
  790. package/lib/Select-Bagt3Bme.js.map +0 -1
  791. package/lib/SlotletProvider-Da7eFgd2.js +0 -241
  792. package/lib/SlotletProvider-Da7eFgd2.js.map +0 -1
  793. package/lib/Spinner-C6zroowC.js +0 -40
  794. package/lib/Spinner-C6zroowC.js.map +0 -1
  795. package/lib/ZudokuContext-BKXGJTmu.js +0 -1222
  796. package/lib/ZudokuContext-BKXGJTmu.js.map +0 -1
  797. package/lib/assets/index-B_Jk_Yzp.js +0 -4820
  798. package/lib/assets/index-B_Jk_Yzp.js.map +0 -1
  799. package/lib/assets/worker-Bf8vjASY.js +0 -18197
  800. package/lib/assets/worker-Bf8vjASY.js.map +0 -1
  801. package/lib/cn-BmFQLtkS.js.map +0 -1
  802. package/lib/hook-sn0zMTkE.js.map +0 -1
  803. package/lib/index-AjWCJNGC.js +0 -5690
  804. package/lib/index-AjWCJNGC.js.map +0 -1
  805. package/lib/index-BuAyrJe3.js +0 -46
  806. package/lib/index-BuAyrJe3.js.map +0 -1
  807. package/lib/index-CRo94sKK.js +0 -1783
  808. package/lib/index-CRo94sKK.js.map +0 -1
  809. package/lib/index-CkwDvuPt.js.map +0 -1
  810. package/lib/index.esm-C5mr_sKO.js +0 -1193
  811. package/lib/index.esm-C5mr_sKO.js.map +0 -1
  812. package/lib/jsx-runtime-B6kdoens.js +0 -635
  813. package/lib/jsx-runtime-B6kdoens.js.map +0 -1
  814. package/lib/prism-csharp.min-Yizuc34Y.js +0 -35
  815. package/lib/prism-java.min-d5iT_mOd.js +0 -7
  816. package/lib/prism-markup-templating-DZrrEs0A.js +0 -62
  817. package/lib/prism-markup-templating-DZrrEs0A.js.map +0 -1
  818. package/lib/prism-php.min-o7FpoMP_.js +0 -11
  819. package/lib/prism-php.min-o7FpoMP_.js.map +0 -1
  820. package/lib/prism-ruby.min-C7LwcKyz.js +0 -10
  821. package/lib/prism-typescript.min-oSVeWCAd.js +0 -6
  822. package/lib/router-BsfSoK2j.js +0 -3024
  823. package/lib/router-BsfSoK2j.js.map +0 -1
  824. package/lib/state-CsuHT8ZO.js +0 -183
  825. package/lib/state-CsuHT8ZO.js.map +0 -1
  826. package/lib/urql-core-KJnLL26g.js +0 -1455
  827. package/lib/urql-core-KJnLL26g.js.map +0 -1
  828. package/lib/useExposedProps-ChOIUaS4.js.map +0 -1
  829. package/lib/zudoku.openapi-worker.js +0 -16341
  830. package/lib/zudoku.openapi-worker.js.map +0 -1
  831. package/src/lib/components/DevPortal.tsx +0 -111
  832. package/src/lib/components/context/ThemeContext.tsx +0 -8
  833. package/src/lib/components/context/ThemeProvider.tsx +0 -27
  834. package/src/lib/plugins/openapi/client/createMemoryClient.ts +0 -51
  835. package/src/lib/plugins/openapi/client/createWorkerClient.ts +0 -75
  836. package/src/lib/plugins/openapi/client/interfaces.ts +0 -5
  837. package/src/lib/plugins/openapi/client/worker.ts +0 -30
  838. package/src/lib/plugins/openapi-worker.ts +0 -1
  839. package/src/lib/plugins/search-inkeep/InkeepCustomTrigger.tsx +0 -3
  840. package/src/lib/themeToggle.ts +0 -7
  841. package/src/lib/util/createWaitForNotify.ts +0 -18
  842. /package/dist/lib/plugins/openapi/{client/worker.d.ts → post-processors/removeExtensions.test.d.ts} +0 -0
@@ -1,19 +1,15 @@
1
- import { EraserIcon } from "lucide-react";
2
1
  import {
3
2
  Control,
4
3
  Controller,
5
4
  useFieldArray,
6
5
  useFormContext,
7
6
  } from "react-hook-form";
8
- import { Button } from "../../../ui/Button.js";
7
+ import { Card } from "zudoku/ui/Card.js";
8
+ import { Checkbox } from "zudoku/ui/Checkbox.js";
9
+ import { Autocomplete } from "../../../components/Autocomplete.js";
9
10
  import { Input } from "../../../ui/Input.js";
10
- import { cn } from "../../../util/cn.js";
11
11
  import { InlineInput } from "./InlineInput.js";
12
- import {
13
- NO_IDENTITY,
14
- type PlaygroundForm,
15
- type QueryParam,
16
- } from "./Playground.js";
12
+ import { type PlaygroundForm, type QueryParam } from "./Playground.js";
17
13
 
18
14
  export const QueryParams = ({
19
15
  control,
@@ -30,59 +26,68 @@ export const QueryParams = ({
30
26
 
31
27
  const requiredFields = queryParams.map((param) => Boolean(param.isRequired));
32
28
 
33
- const selectedIdentity = form.watch("identity");
34
- const hasSelectedIdentity = selectedIdentity !== NO_IDENTITY;
35
-
36
29
  return (
37
- <div className="">
38
- <table className="w-full [&_td]:border [&_td]:p-1.5 [&_td]:px-2">
39
- <tbody>
40
- {fields
41
- .filter(
42
- // TODO remove this hack for Accu or make it more generic
43
- (field) => !(hasSelectedIdentity && field.name === "apikey"),
44
- )
45
- .map((field, i) => (
46
- <tr key={field.id} className="hover:bg-accent/40">
47
- <td className="text-center">
48
- <Controller
49
- control={control}
50
- name={`queryParams.${i}.active`}
51
- render={({ field }) => (
52
- <input
53
- type="checkbox"
54
- id={`queryParams.${i}.active`}
55
- checked={field.value}
56
- onChange={field.onChange}
57
- />
58
- )}
30
+ <Card className="rounded-lg">
31
+ <div className="w-full ">
32
+ {fields.map((field, i) => {
33
+ const currentParam = queryParams.find(
34
+ (param) => param.name === field.name,
35
+ );
36
+ return (
37
+ <div
38
+ key={field.id}
39
+ className="hover:bg-accent/40 grid grid-cols-[min-content_1fr_1fr] gap-2 items-center px-3"
40
+ >
41
+ <Controller
42
+ control={control}
43
+ name={`queryParams.${i}.active`}
44
+ render={({ field }) => (
45
+ <Checkbox
46
+ variant="outline"
47
+ id={`queryParams.${i}.active`}
48
+ className="mr-2"
49
+ checked={field.value}
50
+ onCheckedChange={field.onChange}
59
51
  />
60
- </td>
61
- <td>
62
- <Controller
63
- control={control}
64
- render={({ field }) => (
65
- <InlineInput asChild>
66
- <label
67
- className="flex items-center cursor-pointer"
68
- htmlFor={`queryParams.${i}.active`}
69
- title={
70
- requiredFields[i] ? "Required field" : undefined
71
- }
72
- >
73
- {field.value}
74
- {requiredFields[i] && <sup>&nbsp;*</sup>}
75
- </label>
76
- </InlineInput>
77
- )}
78
- name={`queryParams.${i}.name`}
79
- />
80
- </td>
81
- <td>
82
- <div className="flex justify-between items-center">
83
- <Controller
84
- control={control}
85
- render={({ field }) => (
52
+ )}
53
+ />
54
+ <Controller
55
+ control={control}
56
+ render={({ field }) =>
57
+ !requiredFields[i] ? (
58
+ <Autocomplete
59
+ value={field.value}
60
+ options={queryParams.map((param) => param.name)}
61
+ onChange={(e) => {
62
+ field.onChange(e);
63
+ }}
64
+ className="border-0 font-mono text-xs bg-transparent hover:bg-transparent"
65
+ />
66
+ ) : (
67
+ <InlineInput asChild>
68
+ <label
69
+ className="flex items-center cursor-pointer gap-1"
70
+ htmlFor={`queryParams.${i}.active`}
71
+ title={requiredFields[i] ? "Required field" : undefined}
72
+ >
73
+ {field.value}
74
+ {requiredFields[i] && <sup>&nbsp;*</sup>}
75
+ </label>
76
+ </InlineInput>
77
+ )
78
+ }
79
+ name={`queryParams.${i}.name`}
80
+ />
81
+
82
+ <div className="flex justify-between items-center">
83
+ <Controller
84
+ control={control}
85
+ render={({ field }) => {
86
+ const hasEnum =
87
+ currentParam?.enum && currentParam.enum.length > 0;
88
+
89
+ if (!hasEnum) {
90
+ return (
86
91
  <Input
87
92
  {...field}
88
93
  onChange={(e) => {
@@ -94,37 +99,28 @@ export const QueryParams = ({
94
99
  placeholder="Enter value"
95
100
  className="w-full border-0 shadow-none text-xs font-mono"
96
101
  />
97
- )}
98
- name={`queryParams.${i}.value`}
99
- />
100
- <Controller
101
- control={control}
102
- render={({ field }) => (
103
- <Button
104
- size="icon"
105
- type="button"
106
- variant="ghost"
107
- aria-label="Clear value"
108
- className={cn(
109
- "ms-2",
110
- field.value.length === 0
111
- ? "opacity-0 pointer-events-none"
112
- : "opacity-100",
113
- )}
114
- title="Clear value"
115
- onClick={() => field.onChange("")}
116
- >
117
- <EraserIcon size={16} />
118
- </Button>
119
- )}
120
- name={`queryParams.${i}.value`}
121
- />
122
- </div>
123
- </td>
124
- </tr>
125
- ))}
126
- </tbody>
127
- </table>
128
- </div>
102
+ );
103
+ }
104
+
105
+ return (
106
+ <Autocomplete
107
+ value={field.value}
108
+ options={currentParam.enum ?? []}
109
+ onChange={(e) => {
110
+ field.onChange(e);
111
+ form.setValue(`queryParams.${i}.active`, true);
112
+ }}
113
+ className="font-mono text-xs border-0 ring-1 ring-ring"
114
+ />
115
+ );
116
+ }}
117
+ name={`queryParams.${i}.value`}
118
+ />
119
+ </div>
120
+ </div>
121
+ );
122
+ })}
123
+ </div>
124
+ </Card>
129
125
  );
130
126
  };
@@ -0,0 +1,202 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { removeExtensions } from "./removeExtensions.js";
3
+
4
+ const baseDoc = {
5
+ openapi: "3.1.0",
6
+ "x-root-ext": "remove me",
7
+ "x-zuplo-ext": "remove me too",
8
+ info: {
9
+ title: "Test API",
10
+ version: "1.0.0",
11
+ "x-info-ext": "remove me",
12
+ "x-zuplo-info": "remove me too",
13
+ },
14
+ paths: {
15
+ "/test": {
16
+ "x-path-ext": "remove me",
17
+ "x-zuplo-path": "remove me too",
18
+ parameters: [
19
+ {
20
+ name: "param1",
21
+ in: "query",
22
+ schema: { type: "string" },
23
+ "x-param-ext": "remove me",
24
+ "x-zuplo-param": "remove me too",
25
+ },
26
+ ],
27
+ get: {
28
+ "x-operation-ext": "remove me",
29
+ "x-zuplo-route": "remove me too",
30
+ responses: {
31
+ "200": {
32
+ description: "OK",
33
+ "x-response-ext": "remove me",
34
+ "x-zuplo-response": "remove me too",
35
+ },
36
+ },
37
+ parameters: [
38
+ {
39
+ name: "opParam1",
40
+ in: "header",
41
+ schema: { type: "string" },
42
+ "x-op-param-ext": "remove me",
43
+ "x-zuplo-param": "remove me too",
44
+ },
45
+ ],
46
+ },
47
+ },
48
+ },
49
+ tags: [
50
+ {
51
+ name: "example",
52
+ "x-tag-ext": "remove me",
53
+ "x-zuplo-tag": "remove me too",
54
+ },
55
+ ],
56
+ components: {
57
+ securitySchemes: {
58
+ ApiKeyAuth: {
59
+ type: "apiKey",
60
+ name: "api_key",
61
+ in: "header",
62
+ "x-security-ext": "remove me",
63
+ "x-zuplo-security": "remove me too",
64
+ },
65
+ },
66
+ },
67
+ };
68
+
69
+ describe("removeExtensions", () => {
70
+ it("removes all x- extensions by default", () => {
71
+ const processed = removeExtensions()(baseDoc);
72
+
73
+ const removedExtensions = [
74
+ "x-root-ext",
75
+ "info.x-info-ext",
76
+ "paths./test.x-path-ext",
77
+ "paths./test.parameters[0].x-param-ext",
78
+ "paths./test.get.x-operation-ext",
79
+ "paths./test.get.responses.200.x-response-ext",
80
+ "paths./test.get.parameters[0].x-op-param-ext",
81
+ "tags[0].x-tag-ext",
82
+ "components.securitySchemes.ApiKeyAuth.x-security-ext",
83
+ ];
84
+
85
+ removedExtensions.forEach((ext) => {
86
+ expect(processed).not.toHaveProperty(ext.split("."));
87
+ });
88
+
89
+ // Assert that non-x- fields remain unchanged
90
+ expect(processed.openapi).toBe("3.1.0");
91
+ expect(processed.info.title).toBe("Test API");
92
+ expect(processed).toHaveProperty(
93
+ ["paths", "/test", "get", "responses", "200", "description"],
94
+ "OK",
95
+ );
96
+ expect(processed.tags[0].name).toBe("example");
97
+ });
98
+
99
+ it("removes only specified x- extensions when names are provided", () => {
100
+ const docWithExtraExtensions = {
101
+ ...baseDoc,
102
+ info: { ...baseDoc.info, "x-other-ext": "keep me" },
103
+ };
104
+
105
+ const processed = removeExtensions({
106
+ keys: ["x-path-ext", "x-param-ext"],
107
+ })(docWithExtraExtensions);
108
+
109
+ // Assert specified extensions are removed
110
+ expect(processed.paths["/test"]["x-path-ext"]).toBeUndefined();
111
+ expect(
112
+ processed.paths["/test"].parameters[0]["x-param-ext"],
113
+ ).toBeUndefined();
114
+
115
+ // Assert other x- fields remain
116
+ expect(processed["x-root-ext"]).toBe("remove me");
117
+ expect(processed.info["x-info-ext"]).toBe("remove me");
118
+ expect(processed.info["x-other-ext"]).toBe("keep me");
119
+ });
120
+
121
+ it("handles deeply nested extensions", () => {
122
+ const deeplyNested = {
123
+ a: {
124
+ b: {
125
+ c: {
126
+ "x-deep-ext": "remove me",
127
+ d: {
128
+ e: "value",
129
+ "x-another-ext": "remove me",
130
+ },
131
+ },
132
+ },
133
+ },
134
+ };
135
+
136
+ const processed = removeExtensions()(deeplyNested);
137
+
138
+ expect(processed.a.b.c["x-deep-ext"]).toBeUndefined();
139
+ expect(processed.a.b.c.d["x-another-ext"]).toBeUndefined();
140
+ expect(processed.a.b.c.d.e).toBe("value");
141
+ });
142
+
143
+ it("does nothing if no x- extensions are present", () => {
144
+ const docWithoutExtensions = {
145
+ openapi: "3.1.0",
146
+ info: { title: "API without extensions" },
147
+ };
148
+
149
+ const processed = removeExtensions()(docWithoutExtensions);
150
+
151
+ expect(processed).toEqual(docWithoutExtensions);
152
+ });
153
+
154
+ it("removes extensions based on shouldRemove callback", () => {
155
+ const processed = removeExtensions({
156
+ shouldRemove: (key) => key.startsWith("x-zuplo"),
157
+ })(baseDoc);
158
+
159
+ // Should remove x-zuplo extensions
160
+ const removedExtensions = [
161
+ "x-zuplo-ext",
162
+ "info.x-zuplo-info",
163
+ "paths./test.x-zuplo-path",
164
+ "paths./test.parameters.0.x-zuplo-param",
165
+ "paths./test.get.x-zuplo-route",
166
+ "paths./test.get.responses.200.x-zuplo-response",
167
+ "paths./test.get.parameters.0.x-zuplo-param",
168
+ "tags.0.x-zuplo-tag",
169
+ "components.securitySchemes.ApiKeyAuth.x-zuplo-security",
170
+ ];
171
+
172
+ // Should keep other x- extensions
173
+ const keptExtensions = [
174
+ "x-root-ext",
175
+ "info.x-info-ext",
176
+ "paths./test.x-path-ext",
177
+ "paths./test.parameters.0.x-param-ext",
178
+ "paths./test.get.x-operation-ext",
179
+ "paths./test.get.responses.200.x-response-ext",
180
+ "paths./test.get.parameters.0.x-op-param-ext",
181
+ "tags.0.x-tag-ext",
182
+ "components.securitySchemes.ApiKeyAuth.x-security-ext",
183
+ ];
184
+
185
+ removedExtensions.forEach((ext) => {
186
+ expect(processed).not.toHaveProperty(ext.split("."));
187
+ });
188
+
189
+ keptExtensions.forEach((ext) => {
190
+ expect(processed).toHaveProperty(ext.split("."));
191
+ });
192
+
193
+ // Assert that non-x- fields remain unchanged
194
+ expect(processed).toHaveProperty("openapi", "3.1.0");
195
+ expect(processed).toHaveProperty("info.title", "Test API");
196
+ expect(processed).toHaveProperty(
197
+ "paths./test.get.responses.200.description",
198
+ "OK",
199
+ );
200
+ expect(processed).toHaveProperty("tags.0.name", "example");
201
+ });
202
+ });
@@ -0,0 +1,27 @@
1
+ import { type RecordAny, traverse } from "./traverse.js";
2
+
3
+ interface RemoveExtensionsOptions {
4
+ keys?: string[];
5
+ shouldRemove?: (key: string) => boolean;
6
+ }
7
+
8
+ // Remove all `x-` prefixed key/value pairs, or filter by names if provided
9
+ export const removeExtensions =
10
+ ({ keys, shouldRemove }: RemoveExtensionsOptions = {}) =>
11
+ (doc: RecordAny): RecordAny =>
12
+ traverse(doc, (spec) => {
13
+ const result: RecordAny = {};
14
+
15
+ for (const [key, value] of Object.entries(spec)) {
16
+ const isExtension = key.startsWith("x-");
17
+ const shouldBeRemoved =
18
+ isExtension &&
19
+ (keys === undefined || keys.includes(key)) &&
20
+ (!shouldRemove || shouldRemove(key));
21
+
22
+ if (shouldBeRemoved) continue;
23
+
24
+ result[key] = value;
25
+ }
26
+ return result;
27
+ });
@@ -0,0 +1,148 @@
1
+ import { type OpenAPIV3_1 } from "openapi-types";
2
+ import { describe, expect, it } from "vitest";
3
+ import { removeParameters } from "./removeParameters.js";
4
+
5
+ const baseDoc: OpenAPIV3_1.Document = {
6
+ openapi: "3.1.0",
7
+ info: {
8
+ title: "Test API",
9
+ version: "1.0.0",
10
+ },
11
+ components: {
12
+ parameters: {
13
+ commonParam: {
14
+ name: "commonParam",
15
+ in: "query",
16
+ schema: { type: "string" },
17
+ },
18
+ headerParam: {
19
+ name: "headerParam",
20
+ in: "header",
21
+ schema: { type: "string" },
22
+ },
23
+ },
24
+ },
25
+ paths: {
26
+ "/test": {
27
+ parameters: [
28
+ {
29
+ name: "pathParam",
30
+ in: "path",
31
+ schema: { type: "string" },
32
+ required: true,
33
+ },
34
+ {
35
+ name: "pathHeader",
36
+ in: "header",
37
+ schema: { type: "string" },
38
+ required: true,
39
+ },
40
+ ],
41
+ get: {
42
+ parameters: [
43
+ {
44
+ name: "opParam",
45
+ in: "query",
46
+ schema: { type: "string" },
47
+ required: true,
48
+ },
49
+ {
50
+ name: "opHeader",
51
+ in: "header",
52
+ schema: { type: "string" },
53
+ required: true,
54
+ },
55
+ ],
56
+ responses: {
57
+ "200": {
58
+ description: "OK",
59
+ },
60
+ },
61
+ },
62
+ },
63
+ },
64
+ };
65
+
66
+ describe("removeParameters", () => {
67
+ it("removes parameters by name", () => {
68
+ const processed = removeParameters({
69
+ names: ["pathParam", "opParam"],
70
+ })(baseDoc);
71
+
72
+ expect(processed.paths["/test"].parameters).toHaveLength(1);
73
+ expect(processed.paths["/test"].parameters[0].name).toBe("pathHeader");
74
+ expect(processed.paths["/test"].get.parameters).toHaveLength(1);
75
+ expect(processed.paths["/test"].get.parameters[0].name).toBe("opHeader");
76
+ });
77
+
78
+ it("removes parameters by location", () => {
79
+ const processed = removeParameters({
80
+ in: ["header"],
81
+ })(baseDoc);
82
+
83
+ expect(processed.paths["/test"].parameters).toHaveLength(1);
84
+ expect(processed.paths["/test"].parameters[0].in).toBe("path");
85
+ expect(processed.paths["/test"].get.parameters).toHaveLength(1);
86
+ expect(processed.paths["/test"].get.parameters[0].in).toBe("query");
87
+ });
88
+
89
+ it("removes parameters using shouldRemove callback", () => {
90
+ const processed = removeParameters({
91
+ shouldRemove: ({ parameter }) =>
92
+ parameter.in === "header" && parameter.name.includes("op"),
93
+ })(baseDoc);
94
+
95
+ expect(processed.paths["/test"].parameters).toHaveLength(2);
96
+ expect(processed.paths["/test"].get.parameters).toHaveLength(1);
97
+ expect(processed.paths["/test"].get.parameters[0].name).toBe("opParam");
98
+ });
99
+
100
+ it("combines multiple removal criteria", () => {
101
+ const processed = removeParameters({
102
+ in: ["query", "header"],
103
+ shouldRemove: ({ parameter }) => parameter.name === "pathHeader",
104
+ })(baseDoc);
105
+
106
+ expect(processed.paths["/test"].parameters).toHaveLength(1);
107
+ expect(processed.paths["/test"].parameters[0].name).toBe("pathParam");
108
+ expect(processed.paths["/test"].get.parameters).toHaveLength(0);
109
+ });
110
+
111
+ it("handles missing parameters arrays", () => {
112
+ const docWithoutParams = {
113
+ openapi: "3.1.0",
114
+ paths: {
115
+ "/test": {
116
+ get: {
117
+ summary: "Test endpoint",
118
+ },
119
+ },
120
+ },
121
+ };
122
+
123
+ const processed = removeParameters({
124
+ names: ["someParam"],
125
+ })(docWithoutParams);
126
+
127
+ expect(processed).toEqual(docWithoutParams);
128
+ });
129
+
130
+ it("preserves non-parameter properties", () => {
131
+ const processed = removeParameters({
132
+ names: ["globalParam"],
133
+ })(baseDoc);
134
+
135
+ expect(processed.openapi).toBe("3.1.0");
136
+ expect(processed.paths["/test"].get).toBeDefined();
137
+ });
138
+
139
+ it("removes parameters from components", () => {
140
+ const processed = removeParameters({
141
+ in: ["header"],
142
+ })(baseDoc);
143
+
144
+ expect(Object.keys(processed.components.parameters)).toHaveLength(1);
145
+ expect(processed.components.parameters.commonParam).toBeDefined();
146
+ expect(processed.components.parameters.headerParam).toBeUndefined();
147
+ });
148
+ });
@@ -0,0 +1,101 @@
1
+ import { type RecordAny, traverse } from "./traverse.js";
2
+
3
+ interface RemoveParametersOptions {
4
+ // Names of parameters to remove
5
+ names?: string[];
6
+ // Specific locations to remove parameters from ('query', 'header', 'path', 'cookie')
7
+ in?: string[];
8
+ // Custom filter function
9
+ shouldRemove?: ({ parameter }: { parameter: RecordAny }) => boolean;
10
+ }
11
+
12
+ export const removeParameters =
13
+ ({ names, in: locations, shouldRemove }: RemoveParametersOptions = {}) =>
14
+ (doc: RecordAny): RecordAny =>
15
+ traverse(doc, (spec) => {
16
+ // Helper function to filter parameters
17
+ const filterParameters = (parameters: RecordAny[]) =>
18
+ parameters.filter((p) => {
19
+ if (names?.includes(p.name)) return false;
20
+ if (locations?.includes(p.in)) return false;
21
+ if (shouldRemove?.({ parameter: p })) return false;
22
+ return true;
23
+ });
24
+
25
+ // Handle components.parameters
26
+ if (spec.components?.parameters) {
27
+ spec = {
28
+ ...spec,
29
+ components: {
30
+ ...spec.components,
31
+ parameters: Object.fromEntries(
32
+ Object.entries(spec.components.parameters).filter(
33
+ ([_, param]) => {
34
+ const p = param as RecordAny;
35
+ if (p.$ref) return true; // Skip references
36
+ return (
37
+ !names?.includes(p.name) &&
38
+ !locations?.includes(p.in) &&
39
+ !shouldRemove?.({ parameter: p })
40
+ );
41
+ },
42
+ ),
43
+ ),
44
+ },
45
+ };
46
+ }
47
+
48
+ // Handle paths
49
+ if (spec.paths) {
50
+ const updatedPaths: RecordAny = {};
51
+
52
+ for (const [path, pathItem] of Object.entries(spec.paths)) {
53
+ if (typeof pathItem !== "object" || pathItem === null) {
54
+ updatedPaths[path] = pathItem;
55
+ continue;
56
+ }
57
+
58
+ let updatedPathItem = { ...pathItem };
59
+
60
+ // Handle path-level parameters
61
+ if (
62
+ "parameters" in updatedPathItem &&
63
+ Array.isArray(updatedPathItem.parameters)
64
+ ) {
65
+ updatedPathItem.parameters = filterParameters(
66
+ updatedPathItem.parameters,
67
+ );
68
+ }
69
+
70
+ // Handle operation-level parameters
71
+ for (const method of Object.keys(updatedPathItem)) {
72
+ const pathItemWithMethods = updatedPathItem as Record<
73
+ string,
74
+ RecordAny
75
+ >;
76
+
77
+ if (
78
+ method === "parameters" ||
79
+ typeof pathItemWithMethods[method] !== "object"
80
+ ) {
81
+ continue;
82
+ }
83
+
84
+ const operation = pathItemWithMethods[method];
85
+ if (Array.isArray(operation.parameters)) {
86
+ pathItemWithMethods[method] = {
87
+ ...operation,
88
+ parameters: filterParameters(operation.parameters),
89
+ };
90
+ updatedPathItem = pathItemWithMethods;
91
+ }
92
+ }
93
+
94
+ updatedPaths[path] = updatedPathItem;
95
+ }
96
+
97
+ spec = { ...spec, paths: updatedPaths };
98
+ }
99
+
100
+ return spec;
101
+ });