zudoku 0.0.0-f9d5b02 → 0.0.0-fabd0c1

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 (580) hide show
  1. package/client.d.ts +7 -0
  2. package/dist/app/demo.js +1 -1
  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 +2 -2
  9. package/dist/app/entry.server.js.map +1 -1
  10. package/dist/app/main.d.ts +1 -1
  11. package/dist/app/main.js +2 -1
  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 -1
  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/common/logger.js +9 -0
  26. package/dist/cli/common/logger.js.map +1 -1
  27. package/dist/cli/common/outdated.js +2 -1
  28. package/dist/cli/common/outdated.js.map +1 -1
  29. package/dist/config/common.d.ts +8 -0
  30. package/dist/config/common.js +2 -0
  31. package/dist/config/common.js.map +1 -0
  32. package/dist/config/config.d.ts +3 -2
  33. package/dist/config/loader.d.ts +20 -0
  34. package/dist/config/loader.js +154 -0
  35. package/dist/config/loader.js.map +1 -0
  36. package/dist/config/validators/InputSidebarSchema.d.ts +14 -13
  37. package/dist/config/validators/InputSidebarSchema.js.map +1 -1
  38. package/dist/config/validators/common.d.ts +4945 -0
  39. package/dist/config/validators/common.js +280 -0
  40. package/dist/config/validators/common.js.map +1 -0
  41. package/dist/config/validators/icon-types.d.ts +1 -0
  42. package/dist/config/validators/icon-types.js +2 -0
  43. package/dist/config/validators/icon-types.js.map +1 -0
  44. package/dist/config/validators/validate.d.ts +800 -530
  45. package/dist/config/validators/validate.js +9 -228
  46. package/dist/config/validators/validate.js.map +1 -1
  47. package/dist/lib/authentication/AuthenticationPlugin.d.ts +4 -2
  48. package/dist/lib/authentication/AuthenticationPlugin.js +3 -0
  49. package/dist/lib/authentication/AuthenticationPlugin.js.map +1 -1
  50. package/dist/lib/authentication/authentication.d.ts +1 -1
  51. package/dist/lib/authentication/components/CallbackHandler.js +1 -1
  52. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  53. package/dist/lib/authentication/components/SignIn.js +1 -1
  54. package/dist/lib/authentication/components/SignIn.js.map +1 -1
  55. package/dist/lib/authentication/components/SignOut.js +1 -1
  56. package/dist/lib/authentication/components/SignOut.js.map +1 -1
  57. package/dist/lib/authentication/hook.d.ts +5 -4
  58. package/dist/lib/authentication/hook.js +1 -3
  59. package/dist/lib/authentication/hook.js.map +1 -1
  60. package/dist/lib/authentication/providers/auth0.js +2 -2
  61. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  62. package/dist/lib/authentication/providers/openid.d.ts +7 -1
  63. package/dist/lib/authentication/providers/openid.js +18 -27
  64. package/dist/lib/authentication/providers/openid.js.map +1 -1
  65. package/dist/lib/authentication/state.d.ts +25 -4
  66. package/dist/lib/authentication/state.js +28 -5
  67. package/dist/lib/authentication/state.js.map +1 -1
  68. package/dist/lib/components/AnchorLink.d.ts +1 -1
  69. package/dist/lib/components/AnchorLink.js +1 -1
  70. package/dist/lib/components/AnchorLink.js.map +1 -1
  71. package/dist/lib/components/Bootstrap.d.ts +1 -2
  72. package/dist/lib/components/Bootstrap.js +11 -7
  73. package/dist/lib/components/Bootstrap.js.map +1 -1
  74. package/dist/lib/components/Header.js +14 -6
  75. package/dist/lib/components/Header.js.map +1 -1
  76. package/dist/lib/components/Heading.d.ts +4 -4
  77. package/dist/lib/components/Heading.js +1 -1
  78. package/dist/lib/components/Heading.js.map +1 -1
  79. package/dist/lib/components/Layout.js +14 -5
  80. package/dist/lib/components/Layout.js.map +1 -1
  81. package/dist/lib/components/Markdown.js +1 -1
  82. package/dist/lib/components/Markdown.js.map +1 -1
  83. package/dist/lib/components/MobileTopNavigation.js +5 -7
  84. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  85. package/dist/lib/components/NotFoundPage.js +1 -1
  86. package/dist/lib/components/NotFoundPage.js.map +1 -1
  87. package/dist/lib/components/ReactMarkdown.d.ts +29 -0
  88. package/dist/lib/components/ReactMarkdown.js +182 -0
  89. package/dist/lib/components/ReactMarkdown.js.map +1 -0
  90. package/dist/lib/components/Search.d.ts +3 -1
  91. package/dist/lib/components/Search.js +3 -3
  92. package/dist/lib/components/Search.js.map +1 -1
  93. package/dist/lib/components/SlotletProvider.d.ts +2 -2
  94. package/dist/lib/components/SyntaxHighlight.js +2 -6
  95. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  96. package/dist/lib/components/ThemeSwitch.js +5 -3
  97. package/dist/lib/components/ThemeSwitch.js.map +1 -1
  98. package/dist/lib/components/TopNavigation.d.ts +2 -0
  99. package/dist/lib/components/TopNavigation.js +13 -7
  100. package/dist/lib/components/TopNavigation.js.map +1 -1
  101. package/dist/lib/components/Zudoku.js +1 -1
  102. package/dist/lib/components/Zudoku.js.map +1 -1
  103. package/dist/lib/components/context/ZudokuContext.js +1 -1
  104. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  105. package/dist/lib/components/index.d.ts +15 -5
  106. package/dist/lib/components/index.js +1 -1
  107. package/dist/lib/components/index.js.map +1 -1
  108. package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
  109. package/dist/lib/components/navigation/Sidebar.js +2 -2
  110. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  111. package/dist/lib/components/navigation/SidebarBadge.d.ts +0 -9
  112. package/dist/lib/components/navigation/SidebarBadge.js +0 -9
  113. package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
  114. package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
  115. package/dist/lib/components/navigation/SidebarCategory.js +4 -5
  116. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  117. package/dist/lib/components/navigation/SidebarItem.d.ts +2 -4
  118. package/dist/lib/components/navigation/SidebarItem.js +6 -11
  119. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  120. package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
  121. package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
  122. package/dist/lib/components/navigation/utils.js +1 -1
  123. package/dist/lib/components/navigation/utils.js.map +1 -1
  124. package/dist/lib/core/ZudokuContext.d.ts +1 -1
  125. package/dist/lib/core/plugins.d.ts +5 -1
  126. package/dist/lib/core/plugins.js.map +1 -1
  127. package/dist/lib/errors/RouterError.js +1 -1
  128. package/dist/lib/errors/RouterError.js.map +1 -1
  129. package/dist/lib/oas/graphql/index.js +4 -1
  130. package/dist/lib/oas/graphql/index.js.map +1 -1
  131. package/dist/lib/oas/parser/upgrade/index.d.ts +2 -2
  132. package/dist/lib/oas/parser/upgrade/index.js +3 -20
  133. package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
  134. package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -0
  135. package/dist/lib/plugins/api-catalog/Catalog.js +36 -0
  136. package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -0
  137. package/dist/lib/plugins/api-catalog/index.d.ts +30 -0
  138. package/dist/lib/plugins/api-catalog/index.js +15 -0
  139. package/dist/lib/plugins/api-catalog/index.js.map +1 -0
  140. package/dist/lib/plugins/api-keys/CreateApiKey.js +1 -1
  141. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  142. package/dist/lib/plugins/api-keys/ProtectedRoute.js +1 -1
  143. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  144. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +1 -1
  145. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
  146. package/dist/lib/plugins/api-keys/index.js +3 -0
  147. package/dist/lib/plugins/api-keys/index.js.map +1 -1
  148. package/dist/lib/plugins/markdown/MdxPage.d.ts +9 -1
  149. package/dist/lib/plugins/markdown/MdxPage.js +16 -3
  150. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  151. package/dist/lib/plugins/markdown/index.d.ts +3 -1
  152. package/dist/lib/plugins/markdown/index.js +1 -1
  153. package/dist/lib/plugins/markdown/index.js.map +1 -1
  154. package/dist/lib/plugins/markdown/resolver.js.map +1 -1
  155. package/dist/lib/plugins/openapi/ColorizedParam.js +2 -2
  156. package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
  157. package/dist/lib/plugins/openapi/OperationList.js +24 -3
  158. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  159. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  160. package/dist/lib/plugins/openapi/OperationListItem.js +14 -4
  161. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  162. package/dist/lib/plugins/openapi/Route.d.ts +4 -2
  163. package/dist/lib/plugins/openapi/Route.js +25 -2
  164. package/dist/lib/plugins/openapi/Route.js.map +1 -1
  165. package/dist/lib/plugins/openapi/Sidecar.js +3 -13
  166. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  167. package/dist/lib/plugins/openapi/client/GraphQLClient.js +12 -0
  168. package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -1
  169. package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +1 -1
  170. package/dist/lib/plugins/openapi/client/useCreateQuery.js +4 -2
  171. package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -1
  172. package/dist/lib/plugins/openapi/context.d.ts +3 -3
  173. package/dist/lib/plugins/openapi/graphql/gql.d.ts +1 -1
  174. package/dist/lib/plugins/openapi/graphql/gql.js +1 -1
  175. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  176. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +2 -0
  177. package/dist/lib/plugins/openapi/graphql/graphql.js +1 -0
  178. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  179. package/dist/lib/plugins/openapi/index.js +13 -13
  180. package/dist/lib/plugins/openapi/index.js.map +1 -1
  181. package/dist/lib/plugins/openapi/interfaces.d.ts +20 -1
  182. package/dist/lib/plugins/openapi/playground/PathParams.js +1 -1
  183. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  184. package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +6 -0
  185. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +14 -0
  186. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -0
  187. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.d.ts +1 -0
  188. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +125 -0
  189. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -0
  190. package/dist/lib/plugins/openapi/post-processors/removePaths.d.ts +11 -0
  191. package/dist/lib/plugins/openapi/post-processors/removePaths.js +33 -0
  192. package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +1 -0
  193. package/dist/lib/plugins/openapi/post-processors/removePaths.test.d.ts +1 -0
  194. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +104 -0
  195. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +1 -0
  196. package/dist/lib/plugins/openapi/post-processors/traverse.d.ts +1 -0
  197. package/dist/lib/plugins/openapi/post-processors/traverse.js +2 -0
  198. package/dist/lib/plugins/openapi/post-processors/traverse.js.map +1 -0
  199. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  200. package/dist/lib/plugins/openapi/util/methodToColor.d.ts +20 -0
  201. package/dist/lib/plugins/openapi/util/methodToColor.js +24 -0
  202. package/dist/lib/plugins/openapi/util/methodToColor.js.map +1 -0
  203. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.d.ts +1 -0
  204. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js +27 -0
  205. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js.map +1 -0
  206. package/dist/lib/plugins/redirect/index.d.ts +1 -1
  207. package/dist/lib/plugins/redirect/index.js +1 -1
  208. package/dist/lib/plugins/redirect/index.js.map +1 -1
  209. package/dist/lib/plugins/search-inkeep/index.d.ts +22 -3
  210. package/dist/lib/plugins/search-inkeep/index.js +41 -5
  211. package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
  212. package/dist/lib/plugins/search-inkeep/inkeep.d.ts +3 -4
  213. package/dist/lib/plugins/search-inkeep/inkeep.js.map +1 -1
  214. package/dist/lib/ui/Button.d.ts +1 -1
  215. package/dist/lib/ui/Command.d.ts +1 -1
  216. package/dist/lib/util/MdxComponents.d.ts +18 -19
  217. package/dist/lib/util/MdxComponents.js +1 -3
  218. package/dist/lib/util/MdxComponents.js.map +1 -1
  219. package/dist/lib/util/createVariantComponent.d.ts +2 -2
  220. package/dist/lib/util/traverse.d.ts +2 -0
  221. package/dist/lib/util/traverse.js +18 -0
  222. package/dist/lib/util/traverse.js.map +1 -0
  223. package/dist/lib/util/useExposedProps.js +1 -1
  224. package/dist/lib/util/useExposedProps.js.map +1 -1
  225. package/dist/lib/util/useOnScreen.d.ts +1 -1
  226. package/dist/lib/util/useScrollToAnchor.js +1 -1
  227. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  228. package/dist/lib/util/useScrollToTop.js +1 -1
  229. package/dist/lib/util/useScrollToTop.js.map +1 -1
  230. package/dist/vite/build.js +15 -3
  231. package/dist/vite/build.js.map +1 -1
  232. package/dist/vite/config.d.ts +6 -4
  233. package/dist/vite/config.js +70 -23
  234. package/dist/vite/config.js.map +1 -1
  235. package/dist/vite/config.test.js +7 -5
  236. package/dist/vite/config.test.js.map +1 -1
  237. package/dist/vite/css/collect.d.ts +2 -0
  238. package/dist/vite/css/collect.js +27 -0
  239. package/dist/vite/css/collect.js.map +1 -0
  240. package/dist/vite/css/plugin.d.ts +5 -0
  241. package/dist/vite/css/plugin.js +79 -0
  242. package/dist/vite/css/plugin.js.map +1 -0
  243. package/dist/vite/dev-server.js +19 -6
  244. package/dist/vite/dev-server.js.map +1 -1
  245. package/dist/vite/output.d.ts +1 -1
  246. package/dist/vite/output.js +39 -10
  247. package/dist/vite/output.js.map +1 -1
  248. package/dist/vite/plugin-api.js +93 -20
  249. package/dist/vite/plugin-api.js.map +1 -1
  250. package/dist/vite/plugin-component.js +15 -19
  251. package/dist/vite/plugin-component.js.map +1 -1
  252. package/dist/vite/plugin-config-reload.d.ts +1 -2
  253. package/dist/vite/plugin-config-reload.js.map +1 -1
  254. package/dist/vite/plugin-config.js +20 -0
  255. package/dist/vite/plugin-config.js.map +1 -1
  256. package/dist/vite/plugin-docs.test.js +15 -23
  257. package/dist/vite/plugin-docs.test.js.map +1 -1
  258. package/dist/vite/plugin-mdx.js +60 -4
  259. package/dist/vite/plugin-mdx.js.map +1 -1
  260. package/dist/vite/{plugin-custom-css.d.ts → plugin-theme-css.d.ts} +2 -2
  261. package/dist/vite/{plugin-custom-css.js → plugin-theme-css.js} +10 -3
  262. package/dist/vite/plugin-theme-css.js.map +1 -0
  263. package/dist/vite/plugin.d.ts +1 -2
  264. package/dist/vite/plugin.js +6 -2
  265. package/dist/vite/plugin.js.map +1 -1
  266. package/dist/vite/prerender.d.ts +2 -1
  267. package/dist/vite/prerender.js +2 -2
  268. package/dist/vite/prerender.js.map +1 -1
  269. package/dist/vite/remarkStaticGeneration.js +5 -5
  270. package/dist/vite/remarkStaticGeneration.js.map +1 -1
  271. package/dist/vite/sitemap.d.ts +1 -1
  272. package/dist/zuplo/env.d.ts +6 -0
  273. package/dist/zuplo/env.js +9 -0
  274. package/dist/zuplo/env.js.map +1 -0
  275. package/dist/zuplo/with-zuplo.d.ts +3 -0
  276. package/dist/zuplo/with-zuplo.js +28 -0
  277. package/dist/zuplo/with-zuplo.js.map +1 -0
  278. package/lib/AnchorLink-DFZZbmvr.js +34 -0
  279. package/lib/AnchorLink-DFZZbmvr.js.map +1 -0
  280. package/lib/{AuthenticationPlugin-DeGDVa1r.js → AuthenticationPlugin-fB7viE7A.js} +23 -21
  281. package/lib/AuthenticationPlugin-fB7viE7A.js.map +1 -0
  282. package/lib/{Button-jK0EsymC.js → Button-DeAoTouo.js} +4 -4
  283. package/lib/{Button-jK0EsymC.js.map → Button-DeAoTouo.js.map} +1 -1
  284. package/lib/{CategoryHeading-Bb9dqxD3.js → CategoryHeading-CBconmtI.js} +3 -3
  285. package/lib/{CategoryHeading-Bb9dqxD3.js.map → CategoryHeading-CBconmtI.js.map} +1 -1
  286. package/lib/ClientOnly-E7hGysn1.js.map +1 -1
  287. package/lib/{Dialog-k70Qfukb.js → Dialog-Bxv1yEIg.js} +3 -3
  288. package/lib/{Dialog-k70Qfukb.js.map → Dialog-Bxv1yEIg.js.map} +1 -1
  289. package/lib/{Markdown-BorQdbxW.js → Markdown-CZDLNOFc.js} +13227 -13217
  290. package/lib/Markdown-CZDLNOFc.js.map +1 -0
  291. package/lib/MdxPage-CPBw4_lf.js +188 -0
  292. package/lib/MdxPage-CPBw4_lf.js.map +1 -0
  293. package/lib/OperationList-n4U_BHmO.js +5062 -0
  294. package/lib/OperationList-n4U_BHmO.js.map +1 -0
  295. package/lib/Route-C8nwd9A2.js +37 -0
  296. package/lib/Route-C8nwd9A2.js.map +1 -0
  297. package/lib/{Select-DP74t8Yy.js → Select-D3XuKKuH.js} +5 -5
  298. package/lib/{Select-DP74t8Yy.js.map → Select-D3XuKKuH.js.map} +1 -1
  299. package/lib/SlotletProvider-pfc9oejW.js +221 -0
  300. package/lib/SlotletProvider-pfc9oejW.js.map +1 -0
  301. package/lib/{Spinner-3cQDBVGr.js → Spinner-DuxJLLNE.js} +2 -2
  302. package/lib/{Spinner-3cQDBVGr.js.map → Spinner-DuxJLLNE.js.map} +1 -1
  303. package/lib/StaggeredRender-DgsamH_G.js +17 -0
  304. package/lib/StaggeredRender-DgsamH_G.js.map +1 -0
  305. package/lib/{SyntaxHighlight-CBmwwKoM.js → SyntaxHighlight-Bz-lOJtH.js} +9 -13
  306. package/lib/{SyntaxHighlight-CBmwwKoM.js.map → SyntaxHighlight-Bz-lOJtH.js.map} +1 -1
  307. package/lib/assets/{index-B_Jk_Yzp.js → index-C7jnHK4b.js} +218 -197
  308. package/lib/assets/index-C7jnHK4b.js.map +1 -0
  309. package/lib/assets/{worker-CPsGZsve.js → worker-D2kRl-cG.js} +5326 -4949
  310. package/lib/assets/worker-D2kRl-cG.js.map +1 -0
  311. package/lib/chunk-D52XG6IA-Dl7HLe6j.js +1823 -0
  312. package/lib/chunk-D52XG6IA-Dl7HLe6j.js.map +1 -0
  313. package/lib/{cn-BmFQLtkS.js → cn-qaFjX9_3.js} +2 -2
  314. package/lib/cn-qaFjX9_3.js.map +1 -0
  315. package/lib/{context-D1nXWxm7.js → context-h_UkBLvr.js} +2 -2
  316. package/lib/context-h_UkBLvr.js.map +1 -0
  317. package/lib/{createServer-DK-g7kbB.js → createServer-69sLlmQA.js} +5350 -5760
  318. package/lib/createServer-69sLlmQA.js.map +1 -0
  319. package/lib/{hook-Diu0rqp-.js → hook-DgGeo5iL.js} +12 -14
  320. package/lib/{hook-Diu0rqp-.js.map → hook-DgGeo5iL.js.map} +1 -1
  321. package/lib/{index-CkwDvuPt.js → index-CBXSgjaE.js} +259 -238
  322. package/lib/index-CBXSgjaE.js.map +1 -0
  323. package/lib/index-CPNSgwSb.js +36 -0
  324. package/lib/index-CPNSgwSb.js.map +1 -0
  325. package/lib/index-DStSNvP-.js +1284 -0
  326. package/lib/index-DStSNvP-.js.map +1 -0
  327. package/lib/index-LNp6rxyU.js.map +1 -1
  328. package/lib/index.esm-BSV1C092.js +692 -0
  329. package/lib/index.esm-BSV1C092.js.map +1 -0
  330. package/lib/index.esm-BnnBRKJX.js +1214 -0
  331. package/lib/index.esm-BnnBRKJX.js.map +1 -0
  332. package/lib/invariant-Caa8-XvF.js.map +1 -1
  333. package/lib/jsx-runtime-Dx-03ztt.js +446 -0
  334. package/lib/jsx-runtime-Dx-03ztt.js.map +1 -0
  335. package/lib/object_hash-BNWPnMN9.js +787 -0
  336. package/lib/object_hash-BNWPnMN9.js.map +1 -0
  337. package/lib/post-processors/removeExtensions.js +11 -0
  338. package/lib/post-processors/removeExtensions.js.map +1 -0
  339. package/lib/post-processors/removePaths.js +28 -0
  340. package/lib/post-processors/removePaths.js.map +1 -0
  341. package/lib/post-processors/traverse.js +12 -0
  342. package/lib/post-processors/traverse.js.map +1 -0
  343. package/lib/prism-csharp.min-DUwvItt4.js +63 -0
  344. package/lib/{prism-csharp.min-Yizuc34Y.js.map → prism-csharp.min-DUwvItt4.js.map} +1 -1
  345. package/lib/prism-java.min-BtgBR4yd.js +35 -0
  346. package/lib/{prism-java.min-d5iT_mOd.js.map → prism-java.min-BtgBR4yd.js.map} +1 -1
  347. package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
  348. package/lib/prism-ruby.min-DeDXCp1r.js +38 -0
  349. package/lib/{prism-ruby.min-C7LwcKyz.js.map → prism-ruby.min-DeDXCp1r.js.map} +1 -1
  350. package/lib/prism-typescript.min-CD7H2IYQ.js +34 -0
  351. package/lib/{prism-typescript.min-oSVeWCAd.js.map → prism-typescript.min-CD7H2IYQ.js.map} +1 -1
  352. package/lib/state-CFQsUZUP.js +202 -0
  353. package/lib/state-CFQsUZUP.js.map +1 -0
  354. package/lib/ui/Accordion.js +2 -2
  355. package/lib/ui/Accordion.js.map +1 -1
  356. package/lib/ui/ActionButton.js +4 -4
  357. package/lib/ui/ActionButton.js.map +1 -1
  358. package/lib/ui/Alert.js +3 -3
  359. package/lib/ui/Alert.js.map +1 -1
  360. package/lib/ui/AlertDialog.js +2 -2
  361. package/lib/ui/AlertDialog.js.map +1 -1
  362. package/lib/ui/Badge.js +3 -3
  363. package/lib/ui/Badge.js.map +1 -1
  364. package/lib/ui/Breadcrumb.js +2 -2
  365. package/lib/ui/Breadcrumb.js.map +1 -1
  366. package/lib/ui/Button.js +3 -3
  367. package/lib/ui/Button.js.map +1 -1
  368. package/lib/ui/Callout.js +2 -2
  369. package/lib/ui/Callout.js.map +1 -1
  370. package/lib/ui/Card.js +2 -2
  371. package/lib/ui/Card.js.map +1 -1
  372. package/lib/ui/Carousel.js +407 -401
  373. package/lib/ui/Carousel.js.map +1 -1
  374. package/lib/ui/Checkbox.js +2 -2
  375. package/lib/ui/Checkbox.js.map +1 -1
  376. package/lib/ui/Command.js +111 -108
  377. package/lib/ui/Command.js.map +1 -1
  378. package/lib/ui/Dialog.js +2 -2
  379. package/lib/ui/Dialog.js.map +1 -1
  380. package/lib/ui/Drawer.js +81 -81
  381. package/lib/ui/Drawer.js.map +1 -1
  382. package/lib/ui/DropdownMenu.js +2 -2
  383. package/lib/ui/DropdownMenu.js.map +1 -1
  384. package/lib/ui/Form.js +3 -3
  385. package/lib/ui/Form.js.map +1 -1
  386. package/lib/ui/HoverCard.js +2 -2
  387. package/lib/ui/Input.js +2 -2
  388. package/lib/ui/Input.js.map +1 -1
  389. package/lib/ui/Label.js +3 -3
  390. package/lib/ui/Pagination.js +2 -2
  391. package/lib/ui/Pagination.js.map +1 -1
  392. package/lib/ui/Popover.js +2 -2
  393. package/lib/ui/Popover.js.map +1 -1
  394. package/lib/ui/Progress.js +2 -2
  395. package/lib/ui/Progress.js.map +1 -1
  396. package/lib/ui/RadioGroup.js +2 -2
  397. package/lib/ui/RadioGroup.js.map +1 -1
  398. package/lib/ui/ScrollArea.js +2 -2
  399. package/lib/ui/ScrollArea.js.map +1 -1
  400. package/lib/ui/Select.js +2 -2
  401. package/lib/ui/Select.js.map +1 -1
  402. package/lib/ui/Skeleton.js +2 -2
  403. package/lib/ui/Skeleton.js.map +1 -1
  404. package/lib/ui/Slider.js +2 -2
  405. package/lib/ui/Switch.js +2 -2
  406. package/lib/ui/Switch.js.map +1 -1
  407. package/lib/ui/Tabs.js +2 -2
  408. package/lib/ui/Textarea.js +2 -2
  409. package/lib/ui/Textarea.js.map +1 -1
  410. package/lib/ui/Toggle.js +3 -3
  411. package/lib/ui/Toggle.js.map +1 -1
  412. package/lib/ui/ToggleGroup.js +2 -2
  413. package/lib/ui/ToggleGroup.js.map +1 -1
  414. package/lib/ui/Tooltip.js +2 -2
  415. package/lib/useExposedProps-DE9lR6MF.js +9 -0
  416. package/lib/useExposedProps-DE9lR6MF.js.map +1 -0
  417. package/lib/{utils-DcpDOncX.js → utils-B4O1uet5.js} +35 -36
  418. package/lib/{utils-DcpDOncX.js.map → utils-B4O1uet5.js.map} +1 -1
  419. package/lib/zudoku.auth-auth0.js +9 -8
  420. package/lib/zudoku.auth-auth0.js.map +1 -1
  421. package/lib/zudoku.auth-clerk.js +2 -2
  422. package/lib/zudoku.auth-clerk.js.map +1 -1
  423. package/lib/zudoku.auth-openid.js +365 -371
  424. package/lib/zudoku.auth-openid.js.map +1 -1
  425. package/lib/zudoku.components.js +814 -967
  426. package/lib/zudoku.components.js.map +1 -1
  427. package/lib/zudoku.openapi-worker.js +1 -1
  428. package/lib/zudoku.openapi-worker.js.map +1 -1
  429. package/lib/zudoku.plugin-api-catalog.js +123 -0
  430. package/lib/zudoku.plugin-api-catalog.js.map +1 -0
  431. package/lib/zudoku.plugin-api-keys.js +40 -39
  432. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  433. package/lib/zudoku.plugin-custom-pages.js +4 -4
  434. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  435. package/lib/zudoku.plugin-markdown.js +16 -15
  436. package/lib/zudoku.plugin-markdown.js.map +1 -1
  437. package/lib/zudoku.plugin-openapi.js +5 -5
  438. package/lib/zudoku.plugin-redirect.js +1 -1
  439. package/lib/zudoku.plugin-redirect.js.map +1 -1
  440. package/lib/zudoku.plugin-search-inkeep.js +53 -24
  441. package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
  442. package/package.json +74 -51
  443. package/src/app/demo.tsx +1 -1
  444. package/src/app/entry.client.tsx +16 -1
  445. package/src/app/entry.server.tsx +3 -2
  446. package/src/app/main.tsx +6 -2
  447. package/src/app/sentry.ts +24 -0
  448. package/src/app/standalone.tsx +1 -1
  449. package/src/app/tailwind.ts +67 -52
  450. package/src/lib/authentication/AuthenticationPlugin.tsx +4 -1
  451. package/src/lib/authentication/authentication.ts +1 -1
  452. package/src/lib/authentication/components/CallbackHandler.tsx +1 -1
  453. package/src/lib/authentication/components/SignIn.tsx +1 -1
  454. package/src/lib/authentication/components/SignOut.tsx +1 -1
  455. package/src/lib/authentication/hook.ts +1 -3
  456. package/src/lib/authentication/providers/auth0.tsx +3 -2
  457. package/src/lib/authentication/providers/openid.tsx +22 -33
  458. package/src/lib/authentication/state.ts +44 -10
  459. package/src/lib/components/AnchorLink.tsx +1 -1
  460. package/src/lib/components/Bootstrap.tsx +25 -20
  461. package/src/lib/components/Header.tsx +44 -11
  462. package/src/lib/components/Heading.tsx +13 -13
  463. package/src/lib/components/Layout.tsx +55 -38
  464. package/src/lib/components/Markdown.tsx +1 -1
  465. package/src/lib/components/MobileTopNavigation.tsx +26 -33
  466. package/src/lib/components/NotFoundPage.tsx +1 -1
  467. package/src/lib/components/ReactMarkdown.license.txt +21 -0
  468. package/src/lib/components/ReactMarkdown.tsx +264 -0
  469. package/src/lib/components/Search.tsx +3 -3
  470. package/src/lib/components/SlotletProvider.tsx +1 -1
  471. package/src/lib/components/SyntaxHighlight.tsx +3 -6
  472. package/src/lib/components/ThemeSwitch.tsx +6 -4
  473. package/src/lib/components/TopNavigation.tsx +26 -18
  474. package/src/lib/components/Zudoku.tsx +1 -1
  475. package/src/lib/components/context/ZudokuContext.ts +1 -1
  476. package/src/lib/components/index.ts +1 -1
  477. package/src/lib/components/navigation/Sidebar.tsx +18 -8
  478. package/src/lib/components/navigation/SidebarBadge.tsx +0 -10
  479. package/src/lib/components/navigation/SidebarCategory.tsx +11 -10
  480. package/src/lib/components/navigation/SidebarItem.tsx +11 -14
  481. package/src/lib/components/navigation/SidebarWrapper.tsx +1 -1
  482. package/src/lib/components/navigation/utils.ts +1 -1
  483. package/src/lib/core/ZudokuContext.ts +1 -1
  484. package/src/lib/core/plugins.ts +5 -1
  485. package/src/lib/errors/RouterError.tsx +1 -1
  486. package/src/lib/oas/graphql/index.ts +4 -1
  487. package/src/lib/oas/parser/upgrade/index.ts +4 -27
  488. package/src/lib/plugins/api-catalog/Catalog.tsx +123 -0
  489. package/src/lib/plugins/api-catalog/index.tsx +64 -0
  490. package/src/lib/plugins/api-keys/CreateApiKey.tsx +1 -1
  491. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +1 -1
  492. package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +1 -1
  493. package/src/lib/plugins/api-keys/index.tsx +4 -1
  494. package/src/lib/plugins/custom-pages/index.tsx +1 -1
  495. package/src/lib/plugins/markdown/MdxPage.tsx +28 -2
  496. package/src/lib/plugins/markdown/index.tsx +5 -2
  497. package/src/lib/plugins/markdown/resolver.ts +2 -4
  498. package/src/lib/plugins/openapi/ColorizedParam.tsx +2 -2
  499. package/src/lib/plugins/openapi/OperationList.tsx +64 -8
  500. package/src/lib/plugins/openapi/OperationListItem.tsx +31 -2
  501. package/src/lib/plugins/openapi/Route.tsx +45 -9
  502. package/src/lib/plugins/openapi/Sidecar.tsx +3 -17
  503. package/src/lib/plugins/openapi/client/GraphQLClient.tsx +17 -0
  504. package/src/lib/plugins/openapi/client/useCreateQuery.ts +5 -2
  505. package/src/lib/plugins/openapi/context.tsx +2 -2
  506. package/src/lib/plugins/openapi/graphql/gql.ts +2 -2
  507. package/src/lib/plugins/openapi/graphql/graphql.ts +3 -0
  508. package/src/lib/plugins/openapi/index.tsx +35 -28
  509. package/src/lib/plugins/openapi/interfaces.ts +22 -1
  510. package/src/lib/plugins/openapi/playground/PathParams.tsx +1 -0
  511. package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +144 -0
  512. package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +24 -0
  513. package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +126 -0
  514. package/src/lib/plugins/openapi/post-processors/removePaths.ts +55 -0
  515. package/src/lib/plugins/openapi/post-processors/traverse.ts +1 -0
  516. package/src/lib/plugins/openapi/schema/SchemaView.tsx +1 -1
  517. package/src/lib/plugins/openapi/util/methodToColor.ts +27 -0
  518. package/src/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.tsx +32 -0
  519. package/src/lib/plugins/redirect/index.tsx +2 -2
  520. package/src/lib/plugins/search-inkeep/index.tsx +78 -23
  521. package/src/lib/plugins/search-inkeep/inkeep.ts +3 -9
  522. package/src/lib/util/MdxComponents.tsx +3 -8
  523. package/src/lib/util/createVariantComponent.tsx +2 -2
  524. package/src/lib/util/traverse.ts +25 -0
  525. package/src/lib/util/useExposedProps.tsx +1 -1
  526. package/src/lib/util/useScrollToAnchor.ts +1 -1
  527. package/src/lib/util/useScrollToTop.ts +1 -1
  528. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.d.ts +0 -2
  529. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js +0 -3
  530. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js.map +0 -1
  531. package/dist/vite/plugin-custom-css.js.map +0 -1
  532. package/lib/AnchorLink-CDlhr8gL.js +0 -706
  533. package/lib/AnchorLink-CDlhr8gL.js.map +0 -1
  534. package/lib/AuthenticationPlugin-DeGDVa1r.js.map +0 -1
  535. package/lib/InkeepCustomTrigger-CE5-K5ex.js +0 -6
  536. package/lib/InkeepCustomTrigger-CE5-K5ex.js.map +0 -1
  537. package/lib/Markdown-BorQdbxW.js.map +0 -1
  538. package/lib/MdxPage-DFlbtJWi.js +0 -174
  539. package/lib/MdxPage-DFlbtJWi.js.map +0 -1
  540. package/lib/OperationList-KshJrrLL.js +0 -4691
  541. package/lib/OperationList-KshJrrLL.js.map +0 -1
  542. package/lib/Route-DlG_HTMu.js +0 -11
  543. package/lib/Route-DlG_HTMu.js.map +0 -1
  544. package/lib/SidebarBadge-DxFJcJ6V.js +0 -51
  545. package/lib/SidebarBadge-DxFJcJ6V.js.map +0 -1
  546. package/lib/SlotletProvider-D2v6rJy1.js +0 -252
  547. package/lib/SlotletProvider-D2v6rJy1.js.map +0 -1
  548. package/lib/assets/index-B_Jk_Yzp.js.map +0 -1
  549. package/lib/assets/worker-CPsGZsve.js.map +0 -1
  550. package/lib/cn-BmFQLtkS.js.map +0 -1
  551. package/lib/context-D1nXWxm7.js.map +0 -1
  552. package/lib/createServer-DK-g7kbB.js.map +0 -1
  553. package/lib/index-BcesIHH4.js +0 -1273
  554. package/lib/index-BcesIHH4.js.map +0 -1
  555. package/lib/index-BuAyrJe3.js +0 -46
  556. package/lib/index-BuAyrJe3.js.map +0 -1
  557. package/lib/index-CkwDvuPt.js.map +0 -1
  558. package/lib/index-Czzd9rjU.js +0 -899
  559. package/lib/index-Czzd9rjU.js.map +0 -1
  560. package/lib/index-Yn8c3UWE.js +0 -921
  561. package/lib/index-Yn8c3UWE.js.map +0 -1
  562. package/lib/index.esm-C5mr_sKO.js +0 -1193
  563. package/lib/index.esm-C5mr_sKO.js.map +0 -1
  564. package/lib/jsx-runtime-B6kdoens.js +0 -635
  565. package/lib/jsx-runtime-B6kdoens.js.map +0 -1
  566. package/lib/prism-csharp.min-Yizuc34Y.js +0 -35
  567. package/lib/prism-java.min-d5iT_mOd.js +0 -7
  568. package/lib/prism-markup-templating-DZrrEs0A.js +0 -62
  569. package/lib/prism-markup-templating-DZrrEs0A.js.map +0 -1
  570. package/lib/prism-php.min-o7FpoMP_.js +0 -11
  571. package/lib/prism-php.min-o7FpoMP_.js.map +0 -1
  572. package/lib/prism-ruby.min-C7LwcKyz.js +0 -10
  573. package/lib/prism-typescript.min-oSVeWCAd.js +0 -6
  574. package/lib/router-lfyopgBI.js +0 -3024
  575. package/lib/router-lfyopgBI.js.map +0 -1
  576. package/lib/state-BsPrOUAh.js +0 -252
  577. package/lib/state-BsPrOUAh.js.map +0 -1
  578. package/lib/useExposedProps-CTPtylCV.js +0 -10
  579. package/lib/useExposedProps-CTPtylCV.js.map +0 -1
  580. package/src/lib/plugins/search-inkeep/InkeepCustomTrigger.tsx +0 -3
@@ -0,0 +1,144 @@
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
+ info: {
8
+ title: "Test API",
9
+ version: "1.0.0",
10
+ "x-info-ext": "remove me",
11
+ },
12
+ paths: {
13
+ "/test": {
14
+ "x-path-ext": "remove me",
15
+ parameters: [
16
+ {
17
+ name: "param1",
18
+ in: "query",
19
+ schema: { type: "string" },
20
+ "x-param-ext": "remove me",
21
+ },
22
+ ],
23
+ get: {
24
+ "x-operation-ext": "remove me",
25
+ responses: {
26
+ "200": {
27
+ description: "OK",
28
+ "x-response-ext": "remove me",
29
+ },
30
+ },
31
+ parameters: [
32
+ {
33
+ name: "opParam1",
34
+ in: "header",
35
+ schema: { type: "string" },
36
+ "x-op-param-ext": "remove me",
37
+ },
38
+ ],
39
+ },
40
+ },
41
+ },
42
+ tags: [
43
+ {
44
+ name: "example",
45
+ "x-tag-ext": "remove me",
46
+ },
47
+ ],
48
+ components: {
49
+ securitySchemes: {
50
+ ApiKeyAuth: {
51
+ type: "apiKey",
52
+ name: "api_key",
53
+ in: "header",
54
+ "x-security-ext": "remove me",
55
+ },
56
+ },
57
+ },
58
+ };
59
+
60
+ describe("removeExtensions", () => {
61
+ it("removes all x- extensions by default", () => {
62
+ const processed = removeExtensions()(baseDoc);
63
+
64
+ const removedExtensions = [
65
+ "x-root-ext",
66
+ "info.x-info-ext",
67
+ "paths./test.x-path-ext",
68
+ "paths./test.parameters[0].x-param-ext",
69
+ "paths./test.get.x-operation-ext",
70
+ "paths./test.get.responses.200.x-response-ext",
71
+ "paths./test.get.parameters[0].x-op-param-ext",
72
+ "tags[0].x-tag-ext",
73
+ "components.securitySchemes.ApiKeyAuth.x-security-ext",
74
+ ];
75
+
76
+ removedExtensions.forEach((ext) => {
77
+ expect(processed).not.toHaveProperty(ext.split("."));
78
+ });
79
+
80
+ // Assert that non-x- fields remain unchanged
81
+ expect(processed.openapi).toBe("3.1.0");
82
+ expect(processed.info.title).toBe("Test API");
83
+ expect(processed).toHaveProperty(
84
+ ["paths", "/test", "get", "responses", "200", "description"],
85
+ "OK",
86
+ );
87
+ expect(processed.tags[0].name).toBe("example");
88
+ });
89
+
90
+ it("removes only specified x- extensions when names are provided", () => {
91
+ const docWithExtraExtensions = {
92
+ ...baseDoc,
93
+ info: { ...baseDoc.info, "x-other-ext": "keep me" },
94
+ };
95
+
96
+ const processed = removeExtensions({
97
+ keys: ["x-path-ext", "x-param-ext"],
98
+ })(docWithExtraExtensions);
99
+
100
+ // Assert specified extensions are removed
101
+ expect(processed.paths["/test"]["x-path-ext"]).toBeUndefined();
102
+ expect(
103
+ processed.paths["/test"].parameters[0]["x-param-ext"],
104
+ ).toBeUndefined();
105
+
106
+ // Assert other x- fields remain
107
+ expect(processed["x-root-ext"]).toBe("remove me");
108
+ expect(processed.info["x-info-ext"]).toBe("remove me");
109
+ expect(processed.info["x-other-ext"]).toBe("keep me");
110
+ });
111
+
112
+ it("handles deeply nested extensions", () => {
113
+ const deeplyNested = {
114
+ a: {
115
+ b: {
116
+ c: {
117
+ "x-deep-ext": "remove me",
118
+ d: {
119
+ e: "value",
120
+ "x-another-ext": "remove me",
121
+ },
122
+ },
123
+ },
124
+ },
125
+ };
126
+
127
+ const processed = removeExtensions()(deeplyNested);
128
+
129
+ expect(processed.a.b.c["x-deep-ext"]).toBeUndefined();
130
+ expect(processed.a.b.c.d["x-another-ext"]).toBeUndefined();
131
+ expect(processed.a.b.c.d.e).toBe("value");
132
+ });
133
+
134
+ it("does nothing if no x- extensions are present", () => {
135
+ const docWithoutExtensions = {
136
+ openapi: "3.1.0",
137
+ info: { title: "API without extensions" },
138
+ };
139
+
140
+ const processed = removeExtensions()(docWithoutExtensions);
141
+
142
+ expect(processed).toEqual(docWithoutExtensions);
143
+ });
144
+ });
@@ -0,0 +1,24 @@
1
+ import { type RecordAny, traverse } from "./traverse.js";
2
+
3
+ interface RemoveExtensionsOptions {
4
+ keys?: string[];
5
+ }
6
+
7
+ // Remove all `x-` prefixed key/value pairs, or filter by names if provided
8
+ export const removeExtensions =
9
+ ({ keys }: RemoveExtensionsOptions = {}) =>
10
+ (doc: RecordAny): RecordAny =>
11
+ traverse(doc, (spec) => {
12
+ const result: RecordAny = {};
13
+
14
+ for (const [key, value] of Object.entries(spec)) {
15
+ const isExtension = key.startsWith("x-");
16
+ const shouldRemove =
17
+ isExtension && (keys === undefined || keys.includes(key));
18
+
19
+ if (shouldRemove) continue;
20
+
21
+ result[key] = value;
22
+ }
23
+ return result;
24
+ });
@@ -0,0 +1,126 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { removePaths } from "./removePaths.js";
3
+
4
+ const baseDoc = {
5
+ openapi: "3.0.3",
6
+ paths: {
7
+ "/example": {
8
+ get: { summary: "Get example" },
9
+ post: { summary: "Post example" },
10
+ },
11
+ "/remove-me": {
12
+ delete: { summary: "Delete example" },
13
+ },
14
+ "/another": {
15
+ get: { summary: "Another example" },
16
+ },
17
+ },
18
+ };
19
+
20
+ describe("removePaths", () => {
21
+ it("removes paths specified in the paths option", () => {
22
+ const processed = removePaths({
23
+ paths: {
24
+ "/remove-me": true,
25
+ },
26
+ })(baseDoc);
27
+
28
+ expect(processed.paths["/remove-me"]).toBeUndefined();
29
+ expect(processed.paths["/example"]).toBeDefined();
30
+ expect(processed.paths["/another"]).toBeDefined();
31
+ });
32
+
33
+ it("removes specific methods in the paths option", () => {
34
+ const processed = removePaths({
35
+ paths: {
36
+ "/example": ["get"],
37
+ },
38
+ })(baseDoc);
39
+
40
+ expect(processed.paths["/example"].get).toBeUndefined();
41
+ expect(processed.paths["/example"].post).toBeDefined();
42
+ expect(processed.paths["/remove-me"]).toBeDefined();
43
+ });
44
+
45
+ it("removes paths and methods using paths and shouldRemove together", () => {
46
+ const processed = removePaths({
47
+ paths: {
48
+ "/example": ["post"],
49
+ },
50
+ shouldRemove: ({ path }) => path.startsWith("/remove"),
51
+ })(baseDoc);
52
+
53
+ expect(processed.paths["/remove-me"]).toBeUndefined();
54
+ expect(processed.paths["/example"].get).toBeDefined();
55
+ expect(processed.paths["/example"].post).toBeUndefined();
56
+ expect(processed.paths["/another"]).toBeDefined();
57
+ });
58
+
59
+ it("removes paths based on shouldRemove callback", () => {
60
+ const processed = removePaths({
61
+ shouldRemove: ({ path }) => path.startsWith("/remove"),
62
+ })(baseDoc);
63
+
64
+ expect(processed.paths["/remove-me"]).toBeUndefined();
65
+ expect(processed.paths["/example"]).toBeDefined();
66
+ expect(processed.paths["/another"]).toBeDefined();
67
+ });
68
+
69
+ it("removes methods based on shouldRemove callback", () => {
70
+ const processed = removePaths({
71
+ shouldRemove: ({ method }) => method === "post",
72
+ })(baseDoc);
73
+
74
+ expect(processed.paths["/example"].post).toBeUndefined();
75
+ expect(processed.paths["/example"].get).toBeDefined();
76
+ expect(processed.paths["/remove-me"]).toBeDefined();
77
+ });
78
+
79
+ it("removes both paths and methods based on shouldRemove callback", () => {
80
+ const processed = removePaths({
81
+ shouldRemove: ({ path, method }) =>
82
+ path.startsWith("/remove") || method === "post",
83
+ })(baseDoc);
84
+
85
+ expect(processed.paths["/remove-me"]).toBeUndefined();
86
+ expect(processed.paths["/example"].post).toBeUndefined();
87
+ expect(processed.paths["/example"].get).toBeDefined();
88
+ expect(processed.paths["/another"]).toBeDefined();
89
+ });
90
+
91
+ it("does nothing if shouldRemove always returns false", () => {
92
+ const processed = removePaths({
93
+ shouldRemove: () => false,
94
+ })(baseDoc);
95
+
96
+ expect(processed).toEqual(baseDoc);
97
+ });
98
+
99
+ it("removes everything if shouldRemove always returns true", () => {
100
+ const processed = removePaths({
101
+ shouldRemove: () => true,
102
+ })(baseDoc);
103
+
104
+ expect(processed.paths).toEqual({});
105
+ });
106
+
107
+ it("removes entire paths via shouldRemove callback", () => {
108
+ const processed = removePaths({
109
+ shouldRemove: ({ path, method }) =>
110
+ method === true && path === "/remove-me",
111
+ })(baseDoc);
112
+
113
+ expect(processed.paths["/remove-me"]).toBeUndefined();
114
+ expect(processed.paths["/example"]).toBeDefined();
115
+ expect(processed.paths["/another"]).toBeDefined();
116
+ });
117
+
118
+ it("removes specific methods while keeping paths", () => {
119
+ const processed = removePaths({
120
+ shouldRemove: ({ method }) => method === "delete",
121
+ })(baseDoc);
122
+
123
+ expect(processed.paths["/remove-me"]).toBeDefined();
124
+ expect(processed.paths["/remove-me"].delete).toBeUndefined();
125
+ });
126
+ });
@@ -0,0 +1,55 @@
1
+ import { type RecordAny, traverse } from "./traverse.js";
2
+
3
+ interface RemovePathsOptions {
4
+ // Path definitions, e.g., { '/path': true, '/path-2': ['get'] }
5
+ paths?: Record<string, true | string[]>;
6
+ shouldRemove?: (options: {
7
+ path: string;
8
+ method: true | string;
9
+ operation: RecordAny;
10
+ }) => boolean;
11
+ }
12
+
13
+ export const removePaths =
14
+ ({ paths = {}, shouldRemove }: RemovePathsOptions) =>
15
+ (doc: RecordAny): RecordAny =>
16
+ traverse(doc, (spec) => {
17
+ if (!spec.paths) return spec;
18
+
19
+ const updatedPaths: RecordAny = {};
20
+
21
+ for (const [path, methods] of Object.entries(spec.paths)) {
22
+ const operations = spec.paths[path];
23
+
24
+ // If the path is explicitly marked for removal in `paths`
25
+ if (paths[path] === true) continue;
26
+
27
+ // If the path should be removed via `shouldRemove`
28
+ if (shouldRemove?.({ path, method: true, operation: operations }))
29
+ continue;
30
+
31
+ if (typeof methods === "object" && methods !== null) {
32
+ const filteredPath = Object.fromEntries(
33
+ Object.entries(methods).filter(([method]) => {
34
+ const operations = spec.paths[path][method];
35
+ const isMethodToRemove =
36
+ Array.isArray(paths[path]) && paths[path].includes(method);
37
+
38
+ const isMethodFiltered = shouldRemove?.({
39
+ path,
40
+ method,
41
+ operation: operations,
42
+ });
43
+
44
+ return !isMethodToRemove && !isMethodFiltered;
45
+ }),
46
+ );
47
+
48
+ updatedPaths[path] = filteredPath;
49
+ } else {
50
+ updatedPaths[path] = methods;
51
+ }
52
+ }
53
+
54
+ return { ...spec, paths: updatedPaths };
55
+ });
@@ -0,0 +1 @@
1
+ export { traverse, type RecordAny } from "../../../util/traverse.js";
@@ -73,7 +73,7 @@ export const SchemaView = ({
73
73
  ) {
74
74
  return (
75
75
  <Card className="p-4 flex gap-2 items-center">
76
- {"name" in schema && <>{schema.name}</>}
76
+ {"name" in schema && <>{schema.name as string}</>}
77
77
  <span className="text-sm text-muted-foreground">object</span>
78
78
  {schema.description && (
79
79
  <Markdown
@@ -0,0 +1,27 @@
1
+ export const TextColorMap = {
2
+ green: "text-green-600",
3
+ blue: "text-sky-600",
4
+ yellow: "text-yellow-600",
5
+ red: "text-red-600",
6
+ purple: "text-purple-600",
7
+ indigo: "text-indigo-600",
8
+ gray: "text-gray-600",
9
+ };
10
+
11
+ export const methodToColor = {
12
+ get: TextColorMap.green,
13
+ post: TextColorMap.blue,
14
+ put: TextColorMap.yellow,
15
+ delete: TextColorMap.red,
16
+ patch: TextColorMap.purple,
17
+ options: TextColorMap.indigo,
18
+ head: TextColorMap.gray,
19
+ trace: TextColorMap.gray,
20
+ };
21
+
22
+ export const methodForColor = (method: string) => {
23
+ return (
24
+ methodToColor[method.toLocaleLowerCase() as keyof typeof methodToColor] ??
25
+ TextColorMap.gray
26
+ );
27
+ };
@@ -0,0 +1,32 @@
1
+ export function sanitizeMarkdownForMetatag(
2
+ description: string,
3
+ maxLength: number = 160,
4
+ ): string {
5
+ if (!description) {
6
+ return "";
7
+ }
8
+
9
+ return (
10
+ description
11
+ // Replace Markdown links [text](url) with just "text"
12
+ .replace(/\[([^\]]+)\]\([^)]+\)/g, "$1")
13
+ // Remove Markdown image syntax: ![alt](url)
14
+ .replace(/!\[.*?\]\(.*?\)/g, "")
15
+ // Remove other Markdown syntax (e.g., **bold**, _italic_, `code`)
16
+ .replace(/[_*`~]/g, "")
17
+ // Remove headings (# Heading), blockquotes (> Quote), and horizontal rules (--- or ***)
18
+ .replace(/^(?:>|\s*#+|-{3,}|\*{3,})/gm, "")
19
+ // Remove any remaining formatting characters
20
+ .replace(/[|>{}[\]]/g, "")
21
+ // Collapse multiple spaces and trim the text
22
+ .replace(/\s+/g, " ")
23
+ .trim()
24
+ // Limit to the specified maximum length
25
+ .substring(0, maxLength)
26
+ .replace(/&/g, "&amp;")
27
+ .replace(/</g, "&lt;")
28
+ .replace(/>/g, "&gt;")
29
+ .replace(/"/g, "&quot;")
30
+ .replace(/'/g, "&#039;")
31
+ );
32
+ }
@@ -1,5 +1,5 @@
1
- import { redirect } from "react-router-dom";
2
- import { ZudokuRedirect } from "../../../config/validators/validate.js";
1
+ import { redirect } from "react-router";
2
+ import { ZudokuRedirect } from "../../../config/validators/common.js";
3
3
  import type { ZudokuPlugin } from "../../core/plugins.js";
4
4
 
5
5
  export const redirectPlugin = (options: {
@@ -1,22 +1,31 @@
1
- import type { InkeepWidgetBaseSettings } from "@inkeep/widgets";
2
- import { lazy } from "react";
1
+ import { useEffect, useMemo, useRef, useState } from "react";
3
2
  import { ClientOnly } from "../../components/ClientOnly.js";
4
3
  import type { ZudokuPlugin } from "../../core/plugins.js";
5
4
  import { aiChatSettings, baseSettings } from "./inkeep.js";
6
5
 
7
- type PickedPluginInkeepBaseSettings =
8
- | "apiKey"
9
- | "integrationId"
10
- | "organizationId"
11
- | "primaryBrandColor"
12
- | "organizationDisplayName";
6
+ interface PluginInkeepBaseSettings {
7
+ apiKey?: string;
8
+ integrationId: string;
9
+ organizationId: string;
10
+ organizationDisplayName?: string;
11
+ primaryBrandColor: string;
12
+ }
13
13
 
14
- type PluginInkeepBaseSettings = Pick<
15
- InkeepWidgetBaseSettings,
16
- PickedPluginInkeepBaseSettings
17
- >;
14
+ interface InkeepEmbedConfig {
15
+ componentType: string;
16
+ targetElement: HTMLElement;
17
+ properties: unknown;
18
+ }
18
19
 
19
- const Inkeep = lazy(() => import("./InkeepCustomTrigger.js"));
20
+ interface InkeepWidget {
21
+ render: (config: InkeepEmbedConfig & { isOpen: boolean }) => void;
22
+ }
23
+
24
+ declare global {
25
+ let Inkeep: () => {
26
+ embed: (config: InkeepEmbedConfig) => InkeepWidget;
27
+ };
28
+ }
20
29
 
21
30
  const InkeepSearch = ({
22
31
  prefilledQuery,
@@ -29,23 +38,69 @@ const InkeepSearch = ({
29
38
  prefilledQuery?: string | null;
30
39
  settings: PluginInkeepBaseSettings;
31
40
  }) => {
32
- return (
33
- <Inkeep
34
- isOpen={isOpen}
35
- onClose={onClose}
36
- baseSettings={{ ...baseSettings, ...settings }}
37
- aiChatSettings={aiChatSettings}
38
- searchSettings={{
39
- prefilledQuery: prefilledQuery || undefined,
40
- }}
41
- />
41
+ const ref = useRef<HTMLDivElement>(null);
42
+ const widgetRef = useRef<InkeepWidget | null>(null);
43
+ const [isInkeepAvailable, setIsInkeepAvailable] = useState(
44
+ typeof Inkeep !== "undefined",
45
+ );
46
+
47
+ const config: InkeepEmbedConfig = useMemo(
48
+ () => ({
49
+ componentType: "CustomTrigger",
50
+ targetElement: ref.current!,
51
+ properties: {
52
+ isOpen,
53
+ onClose,
54
+ onOpen: undefined,
55
+ baseSettings: { ...baseSettings, ...settings },
56
+ searchSettings: {
57
+ prefilledQuery: prefilledQuery || undefined,
58
+ },
59
+ aiChatSettings,
60
+ },
61
+ }),
62
+ [isOpen, onClose, prefilledQuery, settings, ref],
42
63
  );
64
+
65
+ useEffect(() => {
66
+ if (isInkeepAvailable) return;
67
+
68
+ const checkInkeep = setInterval(() => {
69
+ if (typeof Inkeep !== "undefined") {
70
+ setIsInkeepAvailable(true);
71
+ clearInterval(checkInkeep);
72
+ }
73
+ }, 100);
74
+
75
+ return () => clearInterval(checkInkeep);
76
+ }, [isInkeepAvailable]);
77
+
78
+ useEffect(() => {
79
+ if (!isInkeepAvailable || widgetRef.current) return;
80
+
81
+ widgetRef.current = Inkeep().embed(config);
82
+ }, [config, isInkeepAvailable]);
83
+
84
+ useEffect(() => {
85
+ widgetRef.current?.render({ ...config, isOpen });
86
+ }, [config, isOpen]);
87
+
88
+ return <div ref={ref} />;
43
89
  };
44
90
 
45
91
  export const inkeepSearchPlugin = (
46
92
  settings: PluginInkeepBaseSettings,
47
93
  ): ZudokuPlugin => {
48
94
  return {
95
+ getHead: () => {
96
+ return (
97
+ <script
98
+ type="module"
99
+ src="https://unpkg.com/@inkeep/uikit-js@0.3.19/dist/embed.js"
100
+ defer
101
+ />
102
+ );
103
+ },
49
104
  renderSearch: ({
50
105
  isOpen,
51
106
  onClose,
@@ -1,9 +1,3 @@
1
- import {
2
- InkeepAIChatSettings,
3
- InkeepModalSettings,
4
- InkeepSearchSettings,
5
- } from "@inkeep/widgets";
6
-
7
1
  const baseSettings = {
8
2
  theme: {
9
3
  components: {
@@ -23,10 +17,10 @@ const baseSettings = {
23
17
  },
24
18
  } as const;
25
19
 
26
- const modalSettings: InkeepModalSettings = {};
20
+ const modalSettings = {};
27
21
 
28
- const searchSettings: InkeepSearchSettings = {};
22
+ const searchSettings = {};
29
23
 
30
- const aiChatSettings: InkeepAIChatSettings = {};
24
+ const aiChatSettings = {};
31
25
 
32
26
  export { aiChatSettings, baseSettings, modalSettings, searchSettings };
@@ -1,17 +1,13 @@
1
- import { MDXProvider } from "@mdx-js/react";
2
- import type { ComponentProps } from "react";
3
- import { Link } from "react-router-dom";
1
+ import { MDXComponents } from "mdx/types.js";
2
+ import { Link } from "react-router";
4
3
  import { Heading } from "../components/Heading.js";
5
4
  import { InlineCode } from "../components/InlineCode.js";
6
5
  import { SyntaxHighlight } from "../components/SyntaxHighlight.js";
7
6
  import { Callout } from "../ui/Callout.js";
8
7
 
9
- export type MdxComponentsType = ComponentProps<
10
- typeof MDXProvider
11
- >["components"];
8
+ export type MdxComponentsType = Readonly<MDXComponents> | null | undefined;
12
9
 
13
10
  export const MdxComponents = {
14
- // @ts-expect-error Node is not in types but still gets passed
15
11
  img: ({ node, ...props }) => {
16
12
  if (/\.(mp4|webm|mov|avi)$/.test(props.src ?? "")) {
17
13
  return <video src={props.src} controls playsInline autoPlay loop />;
@@ -48,7 +44,6 @@ export const MdxComponents = {
48
44
  {children}
49
45
  </Heading>
50
46
  ),
51
- // @ts-expect-error Node is not in types but still gets passed
52
47
  a: ({ href, node, ...props }) =>
53
48
  href && !href.startsWith("http") ? (
54
49
  <Link to={href} relative="path" {...props} />
@@ -2,11 +2,11 @@ import { Slot } from "@radix-ui/react-slot";
2
2
  import { cva } from "class-variance-authority";
3
3
  import type { ClassValue } from "clsx";
4
4
  import * as React from "react";
5
- import type { JSX } from "react/jsx-runtime";
5
+ import { type HTMLElementType, type JSX } from "react";
6
6
  import { cn } from "./cn.js";
7
7
 
8
8
  const createVariantComponent = <
9
- E extends keyof React.ReactHTML,
9
+ E extends HTMLElementType,
10
10
  C extends ReturnType<typeof cva>,
11
11
  >(
12
12
  tag: E,
@@ -0,0 +1,25 @@
1
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
2
+ export type RecordAny = Record<string, any>;
3
+
4
+ export const traverse = (
5
+ specification: RecordAny,
6
+ transform: (specification: RecordAny) => RecordAny,
7
+ ) => {
8
+ const result: RecordAny = {};
9
+
10
+ for (const [key, value] of Object.entries(specification)) {
11
+ if (Array.isArray(value)) {
12
+ result[key] = value.map((item) =>
13
+ typeof item === "object" && item !== null
14
+ ? traverse(item, transform)
15
+ : item,
16
+ );
17
+ } else if (typeof value === "object" && value !== null) {
18
+ result[key] = traverse(value, transform);
19
+ } else {
20
+ result[key] = value;
21
+ }
22
+ }
23
+
24
+ return transform(result);
25
+ };
@@ -3,7 +3,7 @@ import {
3
3
  useNavigate,
4
4
  useParams,
5
5
  useSearchParams,
6
- } from "react-router-dom";
6
+ } from "react-router";
7
7
  import type { ExposedComponentProps } from "../components/SlotletProvider.js";
8
8
 
9
9
  export const useExposedProps = (): ExposedComponentProps => {
@@ -1,5 +1,5 @@
1
1
  import { useEffect } from "react";
2
- import { useLocation } from "react-router-dom";
2
+ import { useLocation } from "react-router";
3
3
  import { useViewportAnchor } from "../components/context/ViewportAnchorContext.js";
4
4
  import { DATA_ANCHOR_ATTR } from "../components/navigation/SidebarItem.js";
5
5
 
@@ -1,5 +1,5 @@
1
1
  import { useEffect, useRef } from "react";
2
- import { useLocation } from "react-router-dom";
2
+ import { useLocation } from "react-router";
3
3
 
4
4
  export const useScrollToTop = () => {
5
5
  const location = useLocation();
@@ -1,2 +0,0 @@
1
- import { InkeepCustomTrigger } from "@inkeep/widgets";
2
- export default InkeepCustomTrigger;