zudoku 0.0.0-fb7d300 → 0.0.0-fc93837

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 (760) hide show
  1. package/client.d.ts +7 -0
  2. package/dist/app/demo.js +1 -2
  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 -15
  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 +2 -2
  11. package/dist/app/main.js +21 -8
  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 -2
  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/config/common.d.ts +8 -0
  35. package/dist/config/common.js +2 -0
  36. package/dist/config/common.js.map +1 -0
  37. package/dist/config/config.d.ts +4 -2
  38. package/dist/config/loader.d.ts +20 -0
  39. package/dist/config/loader.js +154 -0
  40. package/dist/config/loader.js.map +1 -0
  41. package/dist/config/validators/InputSidebarSchema.d.ts +29 -13
  42. package/dist/config/validators/InputSidebarSchema.js +1 -0
  43. package/dist/config/validators/InputSidebarSchema.js.map +1 -1
  44. package/dist/config/validators/common.d.ts +5034 -0
  45. package/dist/config/validators/common.js +287 -0
  46. package/dist/config/validators/common.js.map +1 -0
  47. package/dist/config/validators/icon-types.d.ts +1 -0
  48. package/dist/config/validators/icon-types.js +2 -0
  49. package/dist/config/validators/icon-types.js.map +1 -0
  50. package/dist/config/validators/validate.d.ts +835 -526
  51. package/dist/config/validators/validate.js +9 -228
  52. package/dist/config/validators/validate.js.map +1 -1
  53. package/dist/lib/authentication/components/CallbackHandler.js +1 -1
  54. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  55. package/dist/lib/authentication/components/SignIn.js +1 -1
  56. package/dist/lib/authentication/components/SignIn.js.map +1 -1
  57. package/dist/lib/authentication/components/SignOut.js +2 -2
  58. package/dist/lib/authentication/components/SignOut.js.map +1 -1
  59. package/dist/lib/authentication/providers/auth0.js +1 -1
  60. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  61. package/dist/lib/authentication/providers/clerk.js +29 -6
  62. package/dist/lib/authentication/providers/clerk.js.map +1 -1
  63. package/dist/lib/authentication/providers/openid.d.ts +8 -1
  64. package/dist/lib/authentication/providers/openid.js +21 -10
  65. package/dist/lib/authentication/providers/openid.js.map +1 -1
  66. package/dist/lib/components/AnchorLink.d.ts +1 -1
  67. package/dist/lib/components/AnchorLink.js +6 -3
  68. package/dist/lib/components/AnchorLink.js.map +1 -1
  69. package/dist/lib/components/Autocomplete.d.ts +12 -0
  70. package/dist/lib/components/Autocomplete.js +47 -0
  71. package/dist/lib/components/Autocomplete.js.map +1 -0
  72. package/dist/lib/components/Bootstrap.d.ts +1 -2
  73. package/dist/lib/components/Bootstrap.js +3 -3
  74. package/dist/lib/components/Bootstrap.js.map +1 -1
  75. package/dist/lib/components/Header.js +15 -15
  76. package/dist/lib/components/Header.js.map +1 -1
  77. package/dist/lib/components/Heading.d.ts +4 -4
  78. package/dist/lib/components/Heading.js +1 -1
  79. package/dist/lib/components/Heading.js.map +1 -1
  80. package/dist/lib/components/Layout.js +4 -3
  81. package/dist/lib/components/Layout.js.map +1 -1
  82. package/dist/lib/components/Markdown.d.ts +2 -2
  83. package/dist/lib/components/Markdown.js +4 -2
  84. package/dist/lib/components/Markdown.js.map +1 -1
  85. package/dist/lib/components/MobileTopNavigation.js +1 -1
  86. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  87. package/dist/lib/components/NotFoundPage.js +1 -1
  88. package/dist/lib/components/NotFoundPage.js.map +1 -1
  89. package/dist/lib/components/ReactMarkdown.d.ts +29 -0
  90. package/dist/lib/components/ReactMarkdown.js +182 -0
  91. package/dist/lib/components/ReactMarkdown.js.map +1 -0
  92. package/dist/lib/components/Search.d.ts +3 -1
  93. package/dist/lib/components/Search.js +3 -3
  94. package/dist/lib/components/Search.js.map +1 -1
  95. package/dist/lib/components/SlotletProvider.d.ts +2 -2
  96. package/dist/lib/components/StatusPage.d.ts +7 -0
  97. package/dist/lib/components/StatusPage.js +71 -0
  98. package/dist/lib/components/StatusPage.js.map +1 -0
  99. package/dist/lib/components/SyntaxHighlight.d.ts +2 -1
  100. package/dist/lib/components/SyntaxHighlight.js +2 -6
  101. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  102. package/dist/lib/components/ThemeSwitch.js +4 -4
  103. package/dist/lib/components/ThemeSwitch.js.map +1 -1
  104. package/dist/lib/components/TopNavigation.d.ts +1 -1
  105. package/dist/lib/components/TopNavigation.js +3 -3
  106. package/dist/lib/components/TopNavigation.js.map +1 -1
  107. package/dist/lib/components/Zudoku.js +1 -1
  108. package/dist/lib/components/Zudoku.js.map +1 -1
  109. package/dist/lib/components/cache.d.ts +6 -0
  110. package/dist/lib/components/cache.js +13 -0
  111. package/dist/lib/components/cache.js.map +1 -0
  112. package/dist/lib/components/context/ViewportAnchorContext.js +16 -4
  113. package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
  114. package/dist/lib/components/context/ZudokuContext.js +3 -2
  115. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  116. package/dist/lib/components/index.d.ts +26 -15
  117. package/dist/lib/components/index.js +10 -3
  118. package/dist/lib/components/index.js.map +1 -1
  119. package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
  120. package/dist/lib/components/navigation/Sidebar.js +2 -2
  121. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  122. package/dist/lib/components/navigation/SidebarBadge.d.ts +4 -3
  123. package/dist/lib/components/navigation/SidebarBadge.js +11 -11
  124. package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
  125. package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
  126. package/dist/lib/components/navigation/SidebarCategory.js +5 -6
  127. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  128. package/dist/lib/components/navigation/SidebarItem.d.ts +2 -4
  129. package/dist/lib/components/navigation/SidebarItem.js +7 -12
  130. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  131. package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
  132. package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
  133. package/dist/lib/components/navigation/utils.js +1 -1
  134. package/dist/lib/components/navigation/utils.js.map +1 -1
  135. package/dist/lib/core/RouteGuard.d.ts +1 -0
  136. package/dist/lib/core/RouteGuard.js +28 -0
  137. package/dist/lib/core/RouteGuard.js.map +1 -0
  138. package/dist/lib/core/ZudokuContext.d.ts +5 -3
  139. package/dist/lib/core/ZudokuContext.js +9 -7
  140. package/dist/lib/core/ZudokuContext.js.map +1 -1
  141. package/dist/lib/core/plugins.d.ts +3 -5
  142. package/dist/lib/core/plugins.js.map +1 -1
  143. package/dist/lib/errors/RouterError.js +1 -1
  144. package/dist/lib/errors/RouterError.js.map +1 -1
  145. package/dist/lib/oas/graphql/circular.d.ts +3 -0
  146. package/dist/lib/oas/graphql/circular.js +27 -0
  147. package/dist/lib/oas/graphql/circular.js.map +1 -0
  148. package/dist/lib/oas/graphql/index.d.ts +3 -0
  149. package/dist/lib/oas/graphql/index.js +37 -23
  150. package/dist/lib/oas/graphql/index.js.map +1 -1
  151. package/dist/lib/oas/parser/dereference/index.js +6 -3
  152. package/dist/lib/oas/parser/dereference/index.js.map +1 -1
  153. package/dist/lib/oas/parser/upgrade/index.d.ts +2 -2
  154. package/dist/lib/oas/parser/upgrade/index.js +19 -22
  155. package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
  156. package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -0
  157. package/dist/lib/plugins/api-catalog/Catalog.js +36 -0
  158. package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -0
  159. package/dist/lib/plugins/api-catalog/index.d.ts +30 -0
  160. package/dist/lib/plugins/api-catalog/index.js +15 -0
  161. package/dist/lib/plugins/api-catalog/index.js.map +1 -0
  162. package/dist/lib/plugins/api-keys/CreateApiKey.js +1 -1
  163. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  164. package/dist/lib/plugins/api-keys/ProtectedRoute.js +1 -1
  165. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  166. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +1 -1
  167. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
  168. package/dist/lib/plugins/markdown/MdxPage.d.ts +9 -1
  169. package/dist/lib/plugins/markdown/MdxPage.js +22 -3
  170. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  171. package/dist/lib/plugins/markdown/index.d.ts +3 -1
  172. package/dist/lib/plugins/markdown/index.js +1 -1
  173. package/dist/lib/plugins/markdown/index.js.map +1 -1
  174. package/dist/lib/plugins/markdown/resolver.js.map +1 -1
  175. package/dist/lib/plugins/openapi/CollapsibleCode.js +2 -1
  176. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -1
  177. package/dist/lib/plugins/openapi/ColorizedParam.d.ts +10 -2
  178. package/dist/lib/plugins/openapi/ColorizedParam.js +16 -7
  179. package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
  180. package/dist/lib/plugins/openapi/Endpoint.d.ts +1 -1
  181. package/dist/lib/plugins/openapi/Endpoint.js +3 -1
  182. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  183. package/dist/lib/plugins/openapi/OperationList.js +27 -3
  184. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  185. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  186. package/dist/lib/plugins/openapi/OperationListItem.js +14 -4
  187. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  188. package/dist/lib/plugins/openapi/ParameterListItem.js +3 -2
  189. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  190. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +3 -1
  191. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +5 -2
  192. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
  193. package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +4 -5
  194. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +4 -14
  195. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  196. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +7 -13
  197. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  198. package/dist/lib/plugins/openapi/Route.d.ts +4 -2
  199. package/dist/lib/plugins/openapi/Route.js +22 -2
  200. package/dist/lib/plugins/openapi/Route.js.map +1 -1
  201. package/dist/lib/plugins/openapi/Sidecar.js +14 -21
  202. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  203. package/dist/lib/plugins/openapi/SidecarBox.js +4 -4
  204. package/dist/lib/plugins/openapi/SidecarBox.js.map +1 -1
  205. package/dist/lib/plugins/openapi/SidecarExamples.d.ts +9 -0
  206. package/dist/lib/plugins/openapi/SidecarExamples.js +65 -0
  207. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -0
  208. package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +1 -1
  209. package/dist/lib/plugins/openapi/client/GraphQLClient.js +22 -81
  210. package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -1
  211. package/dist/lib/plugins/openapi/client/createServer.d.ts +2 -1
  212. package/dist/lib/plugins/openapi/client/createServer.js +5 -2
  213. package/dist/lib/plugins/openapi/client/createServer.js.map +1 -1
  214. package/dist/lib/plugins/openapi/context.d.ts +3 -3
  215. package/dist/lib/plugins/openapi/graphql/gql.d.ts +1 -1
  216. package/dist/lib/plugins/openapi/graphql/gql.js +1 -1
  217. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  218. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +2 -0
  219. package/dist/lib/plugins/openapi/graphql/graphql.js +1 -0
  220. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  221. package/dist/lib/plugins/openapi/index.d.ts +2 -1
  222. package/dist/lib/plugins/openapi/index.js +23 -28
  223. package/dist/lib/plugins/openapi/index.js.map +1 -1
  224. package/dist/lib/plugins/openapi/interfaces.d.ts +26 -2
  225. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +6 -0
  226. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +12 -0
  227. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -0
  228. package/dist/lib/plugins/openapi/playground/Headers.js +67 -4
  229. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  230. package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +5 -0
  231. package/dist/lib/plugins/openapi/playground/ParamsGrid.js +4 -0
  232. package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -0
  233. package/dist/lib/plugins/openapi/playground/PathParams.js +4 -7
  234. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  235. package/dist/lib/plugins/openapi/playground/Playground.d.ts +21 -1
  236. package/dist/lib/plugins/openapi/playground/Playground.js +57 -41
  237. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  238. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
  239. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  240. package/dist/lib/plugins/openapi/playground/QueryParams.js +20 -14
  241. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  242. package/dist/lib/plugins/openapi/playground/SubmitButton.d.ts +7 -0
  243. package/dist/lib/plugins/openapi/playground/SubmitButton.js +22 -0
  244. package/dist/lib/plugins/openapi/playground/SubmitButton.js.map +1 -0
  245. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.d.ts +7 -0
  246. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +11 -0
  247. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +1 -0
  248. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.d.ts +8 -0
  249. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +95 -0
  250. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -0
  251. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +7 -0
  252. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +16 -0
  253. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -0
  254. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.d.ts +10 -0
  255. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.js +32 -0
  256. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.js.map +1 -0
  257. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.d.ts +1 -0
  258. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.js +56 -0
  259. package/dist/lib/plugins/openapi/playground/result-panel/convertToTypes.test.js.map +1 -0
  260. package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +7 -0
  261. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +16 -0
  262. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -0
  263. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.d.ts +1 -0
  264. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +174 -0
  265. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -0
  266. package/dist/lib/plugins/openapi/post-processors/removeParameters.d.ts +10 -0
  267. package/dist/lib/plugins/openapi/post-processors/removeParameters.js +66 -0
  268. package/dist/lib/plugins/openapi/post-processors/removeParameters.js.map +1 -0
  269. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.d.ts +1 -0
  270. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js +131 -0
  271. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js.map +1 -0
  272. package/dist/lib/plugins/openapi/post-processors/removePaths.d.ts +11 -0
  273. package/dist/lib/plugins/openapi/post-processors/removePaths.js +33 -0
  274. package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +1 -0
  275. package/dist/lib/plugins/openapi/post-processors/removePaths.test.d.ts +1 -0
  276. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +104 -0
  277. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +1 -0
  278. package/dist/lib/plugins/openapi/post-processors/traverse.d.ts +1 -0
  279. package/dist/lib/plugins/openapi/post-processors/traverse.js +2 -0
  280. package/dist/lib/plugins/openapi/post-processors/traverse.js.map +1 -0
  281. package/dist/lib/plugins/openapi/schema/SchemaComponents.js +9 -2
  282. package/dist/lib/plugins/openapi/schema/SchemaComponents.js.map +1 -1
  283. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +19 -11
  284. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  285. package/dist/lib/plugins/openapi/util/methodToColor.d.ts +20 -0
  286. package/dist/lib/plugins/openapi/util/methodToColor.js +24 -0
  287. package/dist/lib/plugins/openapi/util/methodToColor.js.map +1 -0
  288. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.d.ts +1 -0
  289. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js +27 -0
  290. package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js.map +1 -0
  291. package/dist/lib/plugins/redirect/index.d.ts +1 -1
  292. package/dist/lib/plugins/redirect/index.js +1 -1
  293. package/dist/lib/plugins/redirect/index.js.map +1 -1
  294. package/dist/lib/plugins/search-inkeep/index.d.ts +22 -3
  295. package/dist/lib/plugins/search-inkeep/index.js +41 -5
  296. package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
  297. package/dist/lib/plugins/search-inkeep/inkeep.d.ts +3 -4
  298. package/dist/lib/plugins/search-inkeep/inkeep.js.map +1 -1
  299. package/dist/lib/ui/Badge.d.ts +1 -1
  300. package/dist/lib/ui/Badge.js +2 -1
  301. package/dist/lib/ui/Badge.js.map +1 -1
  302. package/dist/lib/ui/Button.d.ts +1 -1
  303. package/dist/lib/ui/Card.js +1 -1
  304. package/dist/lib/ui/Card.js.map +1 -1
  305. package/dist/lib/ui/Checkbox.d.ts +8 -2
  306. package/dist/lib/ui/Checkbox.js +13 -1
  307. package/dist/lib/ui/Checkbox.js.map +1 -1
  308. package/dist/lib/ui/Command.d.ts +10 -2
  309. package/dist/lib/ui/Command.js +5 -1
  310. package/dist/lib/ui/Command.js.map +1 -1
  311. package/dist/lib/ui/Select.js +2 -2
  312. package/dist/lib/ui/Select.js.map +1 -1
  313. package/dist/lib/util/MdxComponents.d.ts +18 -19
  314. package/dist/lib/util/MdxComponents.js +3 -5
  315. package/dist/lib/util/MdxComponents.js.map +1 -1
  316. package/dist/lib/util/createVariantComponent.d.ts +2 -2
  317. package/dist/lib/util/joinUrl.d.ts +1 -0
  318. package/dist/lib/util/joinUrl.js +40 -0
  319. package/dist/lib/util/joinUrl.js.map +1 -0
  320. package/dist/lib/util/traverse.d.ts +9 -0
  321. package/dist/lib/util/traverse.js +22 -0
  322. package/dist/lib/util/traverse.js.map +1 -0
  323. package/dist/lib/util/useExposedProps.js +1 -1
  324. package/dist/lib/util/useExposedProps.js.map +1 -1
  325. package/dist/lib/util/useOnScreen.d.ts +1 -1
  326. package/dist/lib/util/useScrollToAnchor.d.ts +1 -0
  327. package/dist/lib/util/useScrollToAnchor.js +27 -16
  328. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  329. package/dist/lib/util/useScrollToTop.js +1 -1
  330. package/dist/lib/util/useScrollToTop.js.map +1 -1
  331. package/dist/vite/api/schema-codegen.d.ts +12 -0
  332. package/dist/vite/api/schema-codegen.js +62 -0
  333. package/dist/vite/api/schema-codegen.js.map +1 -0
  334. package/dist/vite/api/schema-codegen.test.d.ts +1 -0
  335. package/dist/vite/api/schema-codegen.test.js +247 -0
  336. package/dist/vite/api/schema-codegen.test.js.map +1 -0
  337. package/dist/vite/build.js +24 -10
  338. package/dist/vite/build.js.map +1 -1
  339. package/dist/vite/config.d.ts +6 -4
  340. package/dist/vite/config.js +83 -30
  341. package/dist/vite/config.js.map +1 -1
  342. package/dist/vite/config.test.js +11 -5
  343. package/dist/vite/config.test.js.map +1 -1
  344. package/dist/vite/css/collect.d.ts +2 -0
  345. package/dist/vite/css/collect.js +27 -0
  346. package/dist/vite/css/collect.js.map +1 -0
  347. package/dist/vite/css/plugin.d.ts +5 -0
  348. package/dist/vite/css/plugin.js +79 -0
  349. package/dist/vite/css/plugin.js.map +1 -0
  350. package/dist/vite/dev-server.d.ts +1 -0
  351. package/dist/vite/dev-server.js +26 -6
  352. package/dist/vite/dev-server.js.map +1 -1
  353. package/dist/vite/output.d.ts +1 -1
  354. package/dist/vite/output.js +39 -10
  355. package/dist/vite/output.js.map +1 -1
  356. package/dist/vite/plugin-api.d.ts +1 -1
  357. package/dist/vite/plugin-api.js +154 -22
  358. package/dist/vite/plugin-api.js.map +1 -1
  359. package/dist/vite/plugin-auth.js +4 -1
  360. package/dist/vite/plugin-auth.js.map +1 -1
  361. package/dist/vite/plugin-component.js +14 -19
  362. package/dist/vite/plugin-component.js.map +1 -1
  363. package/dist/vite/plugin-config-reload.d.ts +1 -2
  364. package/dist/vite/plugin-config-reload.js.map +1 -1
  365. package/dist/vite/plugin-config.js +20 -0
  366. package/dist/vite/plugin-config.js.map +1 -1
  367. package/dist/vite/plugin-docs.test.js +15 -23
  368. package/dist/vite/plugin-docs.test.js.map +1 -1
  369. package/dist/vite/plugin-mdx.js +69 -8
  370. package/dist/vite/plugin-mdx.js.map +1 -1
  371. package/dist/vite/{plugin-custom-css.d.ts → plugin-theme-css.d.ts} +2 -2
  372. package/dist/vite/plugin-theme-css.js +114 -0
  373. package/dist/vite/plugin-theme-css.js.map +1 -0
  374. package/dist/vite/plugin.d.ts +1 -2
  375. package/dist/vite/plugin.js +6 -2
  376. package/dist/vite/plugin.js.map +1 -1
  377. package/dist/vite/prerender.d.ts +3 -2
  378. package/dist/vite/prerender.js +6 -5
  379. package/dist/vite/prerender.js.map +1 -1
  380. package/dist/vite/sitemap.d.ts +1 -1
  381. package/dist/zuplo/enrich-with-zuplo.d.ts +5 -0
  382. package/dist/zuplo/enrich-with-zuplo.js +184 -0
  383. package/dist/zuplo/enrich-with-zuplo.js.map +1 -0
  384. package/dist/zuplo/env.d.ts +7 -0
  385. package/dist/zuplo/env.js +12 -0
  386. package/dist/zuplo/env.js.map +1 -0
  387. package/dist/zuplo/policy-types.d.ts +33 -0
  388. package/dist/zuplo/policy-types.js +8 -0
  389. package/dist/zuplo/policy-types.js.map +1 -0
  390. package/dist/zuplo/with-zuplo-processors.d.ts +3 -0
  391. package/dist/zuplo/with-zuplo-processors.js +26 -0
  392. package/dist/zuplo/with-zuplo-processors.js.map +1 -0
  393. package/dist/zuplo/with-zuplo.d.ts +3 -0
  394. package/dist/zuplo/with-zuplo.js +9 -0
  395. package/dist/zuplo/with-zuplo.js.map +1 -0
  396. package/lib/AuthenticationPlugin-CO_YCd2x.js +58 -0
  397. package/lib/AuthenticationPlugin-CO_YCd2x.js.map +1 -0
  398. package/lib/{CategoryHeading-Bb9dqxD3.js → CategoryHeading-MYL1u_6K.js} +3 -3
  399. package/lib/{CategoryHeading-Bb9dqxD3.js.map → CategoryHeading-MYL1u_6K.js.map} +1 -1
  400. package/lib/ClientOnly-E7hGysn1.js.map +1 -1
  401. package/lib/{Markdown-ievDDhFT.js → Markdown-B8o9Qz4q.js} +13430 -13409
  402. package/lib/Markdown-B8o9Qz4q.js.map +1 -0
  403. package/lib/MdxPage-BxRt3Ly7.js +193 -0
  404. package/lib/MdxPage-BxRt3Ly7.js.map +1 -0
  405. package/lib/OperationList-DH-zIgtq.js +5160 -0
  406. package/lib/OperationList-DH-zIgtq.js.map +1 -0
  407. package/lib/Route-DJ0ZlVq1.js +35 -0
  408. package/lib/Route-DJ0ZlVq1.js.map +1 -0
  409. package/lib/Select-B7UXR0SB.js +223 -0
  410. package/lib/Select-B7UXR0SB.js.map +1 -0
  411. package/lib/SlotletProvider-CtIp8rP3.js +221 -0
  412. package/lib/SlotletProvider-CtIp8rP3.js.map +1 -0
  413. package/lib/{Button-jK0EsymC.js → Spinner-BlzrEEk1.js} +17 -14
  414. package/lib/Spinner-BlzrEEk1.js.map +1 -0
  415. package/lib/StaggeredRender-DgsamH_G.js +17 -0
  416. package/lib/StaggeredRender-DgsamH_G.js.map +1 -0
  417. package/lib/{SyntaxHighlight-DkLOsjHS.js → SyntaxHighlight-C1w1QPdY.js} +385 -388
  418. package/lib/{SyntaxHighlight-DkLOsjHS.js.map → SyntaxHighlight-C1w1QPdY.js.map} +1 -1
  419. package/lib/{utils-DcpDOncX.js → ZudokuContext-8jts0fF3.js} +487 -476
  420. package/lib/ZudokuContext-8jts0fF3.js.map +1 -0
  421. package/lib/chunk-SYFQ2XB5-BPvC-soB.js +1821 -0
  422. package/lib/chunk-SYFQ2XB5-BPvC-soB.js.map +1 -0
  423. package/lib/circular-Dgpd6AN-.js +15397 -0
  424. package/lib/circular-Dgpd6AN-.js.map +1 -0
  425. package/lib/{cn-BmFQLtkS.js → cn-qaFjX9_3.js} +2 -2
  426. package/lib/cn-qaFjX9_3.js.map +1 -0
  427. package/lib/context-rwLGh-6_.js +22 -0
  428. package/lib/context-rwLGh-6_.js.map +1 -0
  429. package/lib/createServer-BV0tHzLK.js +12590 -0
  430. package/lib/createServer-BV0tHzLK.js.map +1 -0
  431. package/lib/{hook-hEqe7fPB.js → hook-BG02esyv.js} +17 -17
  432. package/lib/{hook-hEqe7fPB.js.map → hook-BG02esyv.js.map} +1 -1
  433. package/lib/index-B7mqiOei.js +509 -0
  434. package/lib/index-B7mqiOei.js.map +1 -0
  435. package/lib/index-Djenk2Hj.js +36 -0
  436. package/lib/index-Djenk2Hj.js.map +1 -0
  437. package/lib/{index-CkwDvuPt.js → index-Dl3Yl0yb.js} +303 -286
  438. package/lib/index-Dl3Yl0yb.js.map +1 -0
  439. package/lib/index-DmqsUPcm.js +1915 -0
  440. package/lib/index-DmqsUPcm.js.map +1 -0
  441. package/lib/index-LNp6rxyU.js.map +1 -1
  442. package/lib/index.esm-9-TF9KQB.js +692 -0
  443. package/lib/index.esm-9-TF9KQB.js.map +1 -0
  444. package/lib/index.esm-CrSoEshU.js +1207 -0
  445. package/lib/index.esm-CrSoEshU.js.map +1 -0
  446. package/lib/invariant-Caa8-XvF.js.map +1 -1
  447. package/lib/joinUrl-BTy9bvoK.js +20 -0
  448. package/lib/joinUrl-BTy9bvoK.js.map +1 -0
  449. package/lib/jsx-runtime-Bdg6XQ1m.js +446 -0
  450. package/lib/jsx-runtime-Bdg6XQ1m.js.map +1 -0
  451. package/lib/post-processors/removeExtensions.js +11 -0
  452. package/lib/post-processors/removeExtensions.js.map +1 -0
  453. package/lib/post-processors/removeParameters.js +48 -0
  454. package/lib/post-processors/removeParameters.js.map +1 -0
  455. package/lib/post-processors/removePaths.js +28 -0
  456. package/lib/post-processors/removePaths.js.map +1 -0
  457. package/lib/post-processors/traverse.js +15 -0
  458. package/lib/post-processors/traverse.js.map +1 -0
  459. package/lib/{prism-bash.min-DadFsM4Z.js → prism-bash.min-HHIMdNJ_.js} +4 -4
  460. package/lib/{prism-bash.min-DadFsM4Z.js.map → prism-bash.min-HHIMdNJ_.js.map} +1 -1
  461. package/lib/prism-csharp.min-bQAo2pmx.js +63 -0
  462. package/lib/{prism-csharp.min-Yizuc34Y.js.map → prism-csharp.min-bQAo2pmx.js.map} +1 -1
  463. package/lib/prism-java.min-BpvsOuIa.js +35 -0
  464. package/lib/{prism-java.min-d5iT_mOd.js.map → prism-java.min-BpvsOuIa.js.map} +1 -1
  465. package/lib/{prism-markdown.min-F3U-vPBi.js → prism-markdown.min-C0Qn0m-5.js} +30 -30
  466. package/lib/{prism-markdown.min-F3U-vPBi.js.map → prism-markdown.min-C0Qn0m-5.js.map} +1 -1
  467. package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
  468. package/lib/prism-ruby.min-Dx9KO9ds.js +38 -0
  469. package/lib/{prism-ruby.min-C7LwcKyz.js.map → prism-ruby.min-Dx9KO9ds.js.map} +1 -1
  470. package/lib/prism-typescript.min-CD7H2IYQ.js +34 -0
  471. package/lib/{prism-typescript.min-oSVeWCAd.js.map → prism-typescript.min-CD7H2IYQ.js.map} +1 -1
  472. package/lib/state-mM7uaXTW.js +202 -0
  473. package/lib/state-mM7uaXTW.js.map +1 -0
  474. package/lib/ui/Accordion.js +2 -2
  475. package/lib/ui/Accordion.js.map +1 -1
  476. package/lib/ui/ActionButton.js +10 -11
  477. package/lib/ui/ActionButton.js.map +1 -1
  478. package/lib/ui/Alert.js +3 -3
  479. package/lib/ui/Alert.js.map +1 -1
  480. package/lib/ui/AlertDialog.js +2 -2
  481. package/lib/ui/AlertDialog.js.map +1 -1
  482. package/lib/ui/Badge.js +5 -4
  483. package/lib/ui/Badge.js.map +1 -1
  484. package/lib/ui/Breadcrumb.js +2 -2
  485. package/lib/ui/Breadcrumb.js.map +1 -1
  486. package/lib/ui/Button.js +3 -3
  487. package/lib/ui/Button.js.map +1 -1
  488. package/lib/ui/Callout.js +2 -2
  489. package/lib/ui/Callout.js.map +1 -1
  490. package/lib/ui/Card.js +9 -9
  491. package/lib/ui/Card.js.map +1 -1
  492. package/lib/ui/Carousel.js +408 -402
  493. package/lib/ui/Carousel.js.map +1 -1
  494. package/lib/ui/Checkbox.js +26 -15
  495. package/lib/ui/Checkbox.js.map +1 -1
  496. package/lib/ui/Command.js +80 -501
  497. package/lib/ui/Command.js.map +1 -1
  498. package/lib/ui/Dialog.js +2 -2
  499. package/lib/ui/Dialog.js.map +1 -1
  500. package/lib/ui/Drawer.js +515 -514
  501. package/lib/ui/Drawer.js.map +1 -1
  502. package/lib/ui/DropdownMenu.js +2 -2
  503. package/lib/ui/DropdownMenu.js.map +1 -1
  504. package/lib/ui/Form.js +3 -3
  505. package/lib/ui/Form.js.map +1 -1
  506. package/lib/ui/HoverCard.js +2 -2
  507. package/lib/ui/Input.js +2 -2
  508. package/lib/ui/Input.js.map +1 -1
  509. package/lib/ui/Label.js +3 -3
  510. package/lib/ui/Pagination.js +8 -8
  511. package/lib/ui/Pagination.js.map +1 -1
  512. package/lib/ui/Popover.js +2 -2
  513. package/lib/ui/Popover.js.map +1 -1
  514. package/lib/ui/Progress.js +2 -2
  515. package/lib/ui/Progress.js.map +1 -1
  516. package/lib/ui/RadioGroup.js +2 -2
  517. package/lib/ui/RadioGroup.js.map +1 -1
  518. package/lib/ui/ScrollArea.js +2 -2
  519. package/lib/ui/ScrollArea.js.map +1 -1
  520. package/lib/ui/Select.js +4 -4
  521. package/lib/ui/Select.js.map +1 -1
  522. package/lib/ui/Skeleton.js +2 -2
  523. package/lib/ui/Skeleton.js.map +1 -1
  524. package/lib/ui/Slider.js +2 -2
  525. package/lib/ui/Switch.js +2 -2
  526. package/lib/ui/Switch.js.map +1 -1
  527. package/lib/ui/Tabs.js +2 -2
  528. package/lib/ui/Textarea.js +2 -2
  529. package/lib/ui/Textarea.js.map +1 -1
  530. package/lib/ui/Toggle.js +3 -3
  531. package/lib/ui/Toggle.js.map +1 -1
  532. package/lib/ui/ToggleGroup.js +2 -2
  533. package/lib/ui/ToggleGroup.js.map +1 -1
  534. package/lib/ui/Tooltip.js +2 -2
  535. package/lib/useExposedProps-BLKFBylA.js +9 -0
  536. package/lib/useExposedProps-BLKFBylA.js.map +1 -0
  537. package/lib/useScrollToAnchor-Bl6mz9_x.js +288 -0
  538. package/lib/useScrollToAnchor-Bl6mz9_x.js.map +1 -0
  539. package/lib/zudoku.auth-auth0.js +8 -10
  540. package/lib/zudoku.auth-auth0.js.map +1 -1
  541. package/lib/zudoku.auth-clerk.js +79 -51
  542. package/lib/zudoku.auth-clerk.js.map +1 -1
  543. package/lib/zudoku.auth-openid.js +398 -385
  544. package/lib/zudoku.auth-openid.js.map +1 -1
  545. package/lib/zudoku.components.js +808 -1245
  546. package/lib/zudoku.components.js.map +1 -1
  547. package/lib/zudoku.plugin-api-catalog.js +123 -0
  548. package/lib/zudoku.plugin-api-catalog.js.map +1 -0
  549. package/lib/zudoku.plugin-api-keys.js +15 -16
  550. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  551. package/lib/zudoku.plugin-custom-pages.js +4 -4
  552. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  553. package/lib/zudoku.plugin-markdown.js +16 -15
  554. package/lib/zudoku.plugin-markdown.js.map +1 -1
  555. package/lib/zudoku.plugin-openapi.js +5 -5
  556. package/lib/zudoku.plugin-redirect.js +1 -1
  557. package/lib/zudoku.plugin-redirect.js.map +1 -1
  558. package/lib/zudoku.plugin-search-inkeep.js +53 -24
  559. package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
  560. package/package.json +101 -84
  561. package/src/app/demo.tsx +1 -2
  562. package/src/app/entry.client.tsx +16 -15
  563. package/src/app/entry.server.tsx +3 -2
  564. package/src/app/main.css +57 -44
  565. package/src/app/main.tsx +32 -9
  566. package/src/app/sentry.ts +24 -0
  567. package/src/app/standalone.tsx +1 -2
  568. package/src/app/tailwind.ts +67 -52
  569. package/src/lib/authentication/components/CallbackHandler.tsx +1 -1
  570. package/src/lib/authentication/components/SignIn.tsx +1 -1
  571. package/src/lib/authentication/components/SignOut.tsx +3 -2
  572. package/src/lib/authentication/providers/auth0.tsx +1 -4
  573. package/src/lib/authentication/providers/clerk.tsx +38 -7
  574. package/src/lib/authentication/providers/openid.tsx +31 -12
  575. package/src/lib/components/AnchorLink.tsx +6 -3
  576. package/src/lib/components/Autocomplete.tsx +111 -0
  577. package/src/lib/components/Bootstrap.tsx +4 -6
  578. package/src/lib/components/Header.tsx +14 -10
  579. package/src/lib/components/Heading.tsx +13 -13
  580. package/src/lib/components/Layout.tsx +10 -5
  581. package/src/lib/components/Markdown.tsx +15 -16
  582. package/src/lib/components/MobileTopNavigation.tsx +18 -18
  583. package/src/lib/components/NotFoundPage.tsx +1 -1
  584. package/src/lib/components/ReactMarkdown.license.txt +21 -0
  585. package/src/lib/components/ReactMarkdown.tsx +264 -0
  586. package/src/lib/components/Search.tsx +3 -3
  587. package/src/lib/components/SlotletProvider.tsx +1 -1
  588. package/src/lib/components/StatusPage.tsx +91 -0
  589. package/src/lib/components/SyntaxHighlight.tsx +14 -4
  590. package/src/lib/components/ThemeSwitch.tsx +14 -15
  591. package/src/lib/components/TopNavigation.tsx +4 -4
  592. package/src/lib/components/Zudoku.tsx +1 -1
  593. package/src/lib/components/cache.ts +15 -0
  594. package/src/lib/components/context/ViewportAnchorContext.tsx +20 -6
  595. package/src/lib/components/context/ZudokuContext.ts +4 -2
  596. package/src/lib/components/index.ts +15 -4
  597. package/src/lib/components/navigation/Sidebar.tsx +18 -8
  598. package/src/lib/components/navigation/SidebarBadge.tsx +13 -11
  599. package/src/lib/components/navigation/SidebarCategory.tsx +8 -11
  600. package/src/lib/components/navigation/SidebarItem.tsx +12 -15
  601. package/src/lib/components/navigation/SidebarWrapper.tsx +3 -2
  602. package/src/lib/components/navigation/utils.ts +1 -1
  603. package/src/lib/core/RouteGuard.tsx +35 -0
  604. package/src/lib/core/ZudokuContext.ts +10 -9
  605. package/src/lib/core/plugins.ts +3 -7
  606. package/src/lib/errors/RouterError.tsx +1 -1
  607. package/src/lib/oas/graphql/circular.ts +29 -0
  608. package/src/lib/oas/graphql/index.ts +48 -32
  609. package/src/lib/oas/parser/dereference/index.ts +8 -4
  610. package/src/lib/oas/parser/upgrade/index.ts +22 -30
  611. package/src/lib/plugins/api-catalog/Catalog.tsx +123 -0
  612. package/src/lib/plugins/api-catalog/index.tsx +64 -0
  613. package/src/lib/plugins/api-keys/CreateApiKey.tsx +1 -1
  614. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +1 -1
  615. package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +1 -1
  616. package/src/lib/plugins/api-keys/index.tsx +1 -1
  617. package/src/lib/plugins/custom-pages/index.tsx +1 -1
  618. package/src/lib/plugins/markdown/MdxPage.tsx +36 -2
  619. package/src/lib/plugins/markdown/index.tsx +5 -2
  620. package/src/lib/plugins/markdown/resolver.ts +2 -4
  621. package/src/lib/plugins/openapi/CollapsibleCode.tsx +10 -7
  622. package/src/lib/plugins/openapi/ColorizedParam.tsx +29 -12
  623. package/src/lib/plugins/openapi/Endpoint.tsx +3 -3
  624. package/src/lib/plugins/openapi/OperationList.tsx +68 -8
  625. package/src/lib/plugins/openapi/OperationListItem.tsx +33 -4
  626. package/src/lib/plugins/openapi/ParameterListItem.tsx +6 -7
  627. package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +7 -0
  628. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +14 -39
  629. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +46 -63
  630. package/src/lib/plugins/openapi/Route.tsx +41 -9
  631. package/src/lib/plugins/openapi/Sidecar.tsx +23 -30
  632. package/src/lib/plugins/openapi/SidecarBox.tsx +4 -16
  633. package/src/lib/plugins/openapi/SidecarExamples.tsx +163 -0
  634. package/src/lib/plugins/openapi/client/GraphQLClient.tsx +28 -103
  635. package/src/lib/plugins/openapi/client/createServer.ts +6 -2
  636. package/src/lib/plugins/openapi/context.tsx +2 -2
  637. package/src/lib/plugins/openapi/graphql/gql.ts +2 -2
  638. package/src/lib/plugins/openapi/graphql/graphql.ts +3 -0
  639. package/src/lib/plugins/openapi/index.tsx +49 -44
  640. package/src/lib/plugins/openapi/interfaces.ts +31 -2
  641. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +54 -0
  642. package/src/lib/plugins/openapi/playground/Headers.tsx +137 -39
  643. package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +8 -0
  644. package/src/lib/plugins/openapi/playground/PathParams.tsx +30 -61
  645. package/src/lib/plugins/openapi/playground/Playground.tsx +244 -189
  646. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +2 -2
  647. package/src/lib/plugins/openapi/playground/QueryParams.tsx +77 -80
  648. package/src/lib/plugins/openapi/playground/SubmitButton.tsx +75 -0
  649. package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +73 -0
  650. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +210 -0
  651. package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +101 -0
  652. package/src/lib/plugins/openapi/playground/result-panel/convertToTypes.test.ts +64 -0
  653. package/src/lib/plugins/openapi/playground/result-panel/convertToTypes.ts +36 -0
  654. package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +202 -0
  655. package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +27 -0
  656. package/src/lib/plugins/openapi/post-processors/removeParameters.test.ts +148 -0
  657. package/src/lib/plugins/openapi/post-processors/removeParameters.ts +101 -0
  658. package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +126 -0
  659. package/src/lib/plugins/openapi/post-processors/removePaths.ts +55 -0
  660. package/src/lib/plugins/openapi/post-processors/traverse.ts +1 -0
  661. package/src/lib/plugins/openapi/schema/SchemaComponents.tsx +29 -8
  662. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +26 -11
  663. package/src/lib/plugins/openapi/util/methodToColor.ts +27 -0
  664. package/src/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.tsx +32 -0
  665. package/src/lib/plugins/redirect/index.tsx +2 -2
  666. package/src/lib/plugins/search-inkeep/index.tsx +78 -23
  667. package/src/lib/plugins/search-inkeep/inkeep.ts +3 -9
  668. package/src/lib/ui/Badge.tsx +2 -1
  669. package/src/lib/ui/Card.tsx +1 -1
  670. package/src/lib/ui/Checkbox.tsx +24 -7
  671. package/src/lib/ui/Command.tsx +20 -0
  672. package/src/lib/ui/Select.tsx +1 -1
  673. package/src/lib/util/MdxComponents.tsx +5 -9
  674. package/src/lib/util/createVariantComponent.tsx +2 -2
  675. package/src/lib/util/joinUrl.ts +57 -0
  676. package/src/lib/util/traverse.ts +35 -0
  677. package/src/lib/util/useExposedProps.tsx +1 -1
  678. package/src/lib/util/useScrollToAnchor.ts +33 -16
  679. package/src/lib/util/useScrollToTop.ts +1 -1
  680. package/dist/lib/plugins/openapi/client/worker.d.ts +0 -4
  681. package/dist/lib/plugins/openapi/client/worker.js +0 -29
  682. package/dist/lib/plugins/openapi/client/worker.js.map +0 -1
  683. package/dist/lib/plugins/openapi/playground/ResponseTab.d.ts +0 -4
  684. package/dist/lib/plugins/openapi/playground/ResponseTab.js +0 -42
  685. package/dist/lib/plugins/openapi/playground/ResponseTab.js.map +0 -1
  686. package/dist/lib/plugins/openapi-worker.d.ts +0 -1
  687. package/dist/lib/plugins/openapi-worker.js +0 -8
  688. package/dist/lib/plugins/openapi-worker.js.map +0 -1
  689. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.d.ts +0 -2
  690. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js +0 -3
  691. package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js.map +0 -1
  692. package/dist/vite/plugin-custom-css.js +0 -55
  693. package/dist/vite/plugin-custom-css.js.map +0 -1
  694. package/lib/AnchorLink-CDlhr8gL.js +0 -706
  695. package/lib/AnchorLink-CDlhr8gL.js.map +0 -1
  696. package/lib/AuthenticationPlugin-D0Em0SwR.js +0 -59
  697. package/lib/AuthenticationPlugin-D0Em0SwR.js.map +0 -1
  698. package/lib/Button-jK0EsymC.js.map +0 -1
  699. package/lib/Dialog-k70Qfukb.js +0 -67
  700. package/lib/Dialog-k70Qfukb.js.map +0 -1
  701. package/lib/InkeepCustomTrigger-CE5-K5ex.js +0 -6
  702. package/lib/InkeepCustomTrigger-CE5-K5ex.js.map +0 -1
  703. package/lib/Markdown-ievDDhFT.js.map +0 -1
  704. package/lib/MdxPage-Bwn-VSsH.js +0 -174
  705. package/lib/MdxPage-Bwn-VSsH.js.map +0 -1
  706. package/lib/OperationList-BwBl1xrD.js +0 -4691
  707. package/lib/OperationList-BwBl1xrD.js.map +0 -1
  708. package/lib/Route-DlG_HTMu.js +0 -11
  709. package/lib/Route-DlG_HTMu.js.map +0 -1
  710. package/lib/Select-O9ZM3ZgX.js +0 -223
  711. package/lib/Select-O9ZM3ZgX.js.map +0 -1
  712. package/lib/SidebarBadge-DxFJcJ6V.js +0 -51
  713. package/lib/SidebarBadge-DxFJcJ6V.js.map +0 -1
  714. package/lib/SlotletProvider-DyomlzGx.js +0 -252
  715. package/lib/SlotletProvider-DyomlzGx.js.map +0 -1
  716. package/lib/Spinner-3cQDBVGr.js +0 -7
  717. package/lib/Spinner-3cQDBVGr.js.map +0 -1
  718. package/lib/assets/index-B_Jk_Yzp.js +0 -4820
  719. package/lib/assets/index-B_Jk_Yzp.js.map +0 -1
  720. package/lib/assets/worker-CPsGZsve.js +0 -18201
  721. package/lib/assets/worker-CPsGZsve.js.map +0 -1
  722. package/lib/cn-BmFQLtkS.js.map +0 -1
  723. package/lib/context-D1nXWxm7.js +0 -22
  724. package/lib/context-D1nXWxm7.js.map +0 -1
  725. package/lib/createServer-DK-g7kbB.js +0 -16089
  726. package/lib/createServer-DK-g7kbB.js.map +0 -1
  727. package/lib/index-BuAyrJe3.js +0 -46
  728. package/lib/index-BuAyrJe3.js.map +0 -1
  729. package/lib/index-CkwDvuPt.js.map +0 -1
  730. package/lib/index-Czzd9rjU.js +0 -899
  731. package/lib/index-Czzd9rjU.js.map +0 -1
  732. package/lib/index-DNxQ_rCt.js +0 -1273
  733. package/lib/index-DNxQ_rCt.js.map +0 -1
  734. package/lib/index-Yn8c3UWE.js +0 -921
  735. package/lib/index-Yn8c3UWE.js.map +0 -1
  736. package/lib/index.esm-C5mr_sKO.js +0 -1193
  737. package/lib/index.esm-C5mr_sKO.js.map +0 -1
  738. package/lib/jsx-runtime-B6kdoens.js +0 -635
  739. package/lib/jsx-runtime-B6kdoens.js.map +0 -1
  740. package/lib/prism-csharp.min-Yizuc34Y.js +0 -35
  741. package/lib/prism-java.min-d5iT_mOd.js +0 -7
  742. package/lib/prism-markup-templating-DZrrEs0A.js +0 -62
  743. package/lib/prism-markup-templating-DZrrEs0A.js.map +0 -1
  744. package/lib/prism-php.min-o7FpoMP_.js +0 -11
  745. package/lib/prism-php.min-o7FpoMP_.js.map +0 -1
  746. package/lib/prism-ruby.min-C7LwcKyz.js +0 -10
  747. package/lib/prism-typescript.min-oSVeWCAd.js +0 -6
  748. package/lib/router-lfyopgBI.js +0 -3024
  749. package/lib/router-lfyopgBI.js.map +0 -1
  750. package/lib/state-tsXBLONe.js +0 -203
  751. package/lib/state-tsXBLONe.js.map +0 -1
  752. package/lib/useExposedProps-CTPtylCV.js +0 -10
  753. package/lib/useExposedProps-CTPtylCV.js.map +0 -1
  754. package/lib/utils-DcpDOncX.js.map +0 -1
  755. package/lib/zudoku.openapi-worker.js +0 -15
  756. package/lib/zudoku.openapi-worker.js.map +0 -1
  757. package/src/lib/plugins/openapi/client/worker.ts +0 -44
  758. package/src/lib/plugins/openapi/playground/ResponseTab.tsx +0 -76
  759. package/src/lib/plugins/openapi-worker.ts +0 -11
  760. package/src/lib/plugins/search-inkeep/InkeepCustomTrigger.tsx +0 -3
@@ -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";
@@ -1,7 +1,9 @@
1
1
  import * as Collapsible from "@radix-ui/react-collapsible";
2
- import { ListPlusIcon } from "lucide-react";
2
+ import { ListPlusIcon, RefreshCcwDotIcon } from "lucide-react";
3
3
  import { useCallback, useState } from "react";
4
+ import { Badge } from "zudoku/ui/Badge.js";
4
5
  import { Markdown, ProseClasses } from "../../../components/Markdown.js";
6
+ import { CIRCULAR_REF } from "../../../oas/graphql/circular.js";
5
7
  import type { SchemaObject } from "../../../oas/parser/index.js";
6
8
  import { Button } from "../../../ui/Button.js";
7
9
  import { cn } from "../../../util/cn.js";
@@ -39,6 +41,16 @@ export const SchemaLogicalGroup = ({
39
41
  }
40
42
  };
41
43
 
44
+ const isCircularRef = (schema: unknown): schema is string =>
45
+ schema === CIRCULAR_REF;
46
+
47
+ const RecursiveIndicator = () => (
48
+ <div className="flex items-center gap-2 italic text-sm text-muted-foreground font-mono bg-muted px-2 py-0.5 rounded-md">
49
+ <RefreshCcwDotIcon size={16} />
50
+ <span>recursive</span>
51
+ </div>
52
+ );
53
+
42
54
  export const SchemaPropertyItem = ({
43
55
  name,
44
56
  schema,
@@ -56,12 +68,25 @@ export const SchemaPropertyItem = ({
56
68
  }) => {
57
69
  const [isOpen, setIsOpen] = useState(defaultOpen);
58
70
 
71
+ if (isCircularRef(schema)) {
72
+ return (
73
+ <li className="p-4 bg-border/20 hover:bg-border/30">
74
+ <div className="flex flex-col gap-1 justify-between text-sm">
75
+ <div className="flex gap-2 items-center">
76
+ <code>{name}</code>
77
+ <RecursiveIndicator />
78
+ </div>
79
+ </div>
80
+ </li>
81
+ );
82
+ }
83
+
59
84
  return (
60
85
  <li className="p-4 bg-border/20 hover:bg-border/30">
61
86
  <div className="flex flex-col gap-1 justify-between text-sm">
62
87
  <div className="flex gap-2 items-center">
63
88
  <code>{name}</code>
64
- <span className="text-muted-foreground">
89
+ <Badge variant="muted">
65
90
  {schema.type === "array" && schema.items.type ? (
66
91
  <span>{schema.items.type}[]</span>
67
92
  ) : Array.isArray(schema.type) ? (
@@ -69,12 +94,8 @@ export const SchemaPropertyItem = ({
69
94
  ) : (
70
95
  <span>{schema.type}</span>
71
96
  )}
72
- </span>
73
- {group === "optional" && (
74
- <span className="py-px px-1.5 font-medium border rounded-lg">
75
- optional
76
- </span>
77
- )}
97
+ </Badge>
98
+ {group === "optional" && <Badge variant="outline">optional</Badge>}
78
99
  </div>
79
100
 
80
101
  {schema.description && (
@@ -5,24 +5,35 @@ export const generateSchemaExample = (
5
5
  name?: string,
6
6
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
7
7
  ): any => {
8
- // Directly return the example or default if they exist
8
+ // Check for schema-level example first
9
9
  if (schema.example !== undefined) {
10
10
  return schema.example;
11
- } else if (schema.examples) {
12
- return Object.values(schema.examples)[0];
13
- } else if (schema.default !== undefined) {
14
- return schema.default;
15
11
  }
16
12
 
17
- if (schema.properties || schema.type === "object") {
18
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
19
- const example: any = {};
13
+ // Then check for schema-level examples
14
+ if (
15
+ schema.examples &&
16
+ typeof schema.examples === "object" &&
17
+ "default" in schema.examples
18
+ ) {
19
+ const defaultExample = schema.examples.default;
20
+ if (defaultExample !== null) {
21
+ return typeof defaultExample === "object" && "value" in defaultExample
22
+ ? defaultExample.value
23
+ : defaultExample;
24
+ }
25
+ }
26
+
27
+ // For object schemas with properties
28
+ if (schema.type === "object" && schema.properties) {
29
+ const example: Record<string, any> = {};
20
30
 
21
- if (schema.properties) {
22
- for (const [key, propSchema] of Object.entries(schema.properties)) {
31
+ for (const [key, propSchema] of Object.entries(schema.properties)) {
32
+ if (typeof propSchema === "object") {
23
33
  example[key] = generateSchemaExample(propSchema as SchemaObject, key);
24
34
  }
25
35
  }
36
+
26
37
  return example;
27
38
  }
28
39
 
@@ -31,7 +42,9 @@ export const generateSchemaExample = (
31
42
  return schema.items.map((itemSchema) =>
32
43
  generateSchemaExample(itemSchema as SchemaObject),
33
44
  );
34
- } else if (schema.items) {
45
+ }
46
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- OpenAPI schemas don't always adhere to spec
47
+ if (schema.items) {
35
48
  return [generateSchemaExample(schema.items as SchemaObject)];
36
49
  }
37
50
  return [];
@@ -51,6 +64,8 @@ export const generateSchemaExample = (
51
64
  return true;
52
65
  case "null":
53
66
  return null;
67
+ case "object":
68
+ return {};
54
69
  case undefined:
55
70
  default:
56
71
  return {};
@@ -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 };
@@ -4,7 +4,7 @@ import * as React from "react";
4
4
  import { cn } from "../util/cn.js";
5
5
 
6
6
  const badgeVariants = cva(
7
- "inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",
7
+ "inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",
8
8
  {
9
9
  variants: {
10
10
  variant: {
@@ -12,6 +12,7 @@ const badgeVariants = cva(
12
12
  "border-transparent bg-primary text-primary-foreground hover:bg-primary/80",
13
13
  secondary:
14
14
  "border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",
15
+ muted: "bg-muted text-muted-foreground ",
15
16
  destructive:
16
17
  "border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80",
17
18
  outline: "text-foreground",
@@ -8,7 +8,7 @@ const Card = React.forwardRef<
8
8
  <div
9
9
  ref={ref}
10
10
  className={cn(
11
- "rounded-xl border bg-card text-card-foreground shadow",
11
+ "rounded-xl border bg-card text-card-foreground shadow-sm",
12
12
  className,
13
13
  )}
14
14
  {...props}
@@ -1,19 +1,36 @@
1
1
  import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
2
+ import { cva, type VariantProps } from "class-variance-authority";
2
3
  import { Check } from "lucide-react";
3
4
  import * as React from "react";
4
5
 
5
6
  import { cn } from "../util/cn.js";
6
7
 
8
+ const checkboxVariants = cva(
9
+ "peer h-4 w-4 shrink-0 rounded-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:text-primary",
10
+ {
11
+ variants: {
12
+ variant: {
13
+ default: "border border-primary data-[state=checked]:bg-primary",
14
+ outline: "border border-input data-[state=checked]:bg-accent",
15
+ },
16
+ },
17
+ defaultVariants: {
18
+ variant: "default",
19
+ },
20
+ },
21
+ );
22
+
23
+ interface CheckboxProps
24
+ extends React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>,
25
+ VariantProps<typeof checkboxVariants> {}
26
+
7
27
  const Checkbox = React.forwardRef<
8
28
  React.ElementRef<typeof CheckboxPrimitive.Root>,
9
- React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>
10
- >(({ className, ...props }, ref) => (
29
+ CheckboxProps
30
+ >(({ className, variant, ...props }, ref) => (
11
31
  <CheckboxPrimitive.Root
12
32
  ref={ref}
13
- className={cn(
14
- "peer h-4 w-4 shrink-0 rounded-sm border border-primary ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground",
15
- className,
16
- )}
33
+ className={cn(checkboxVariants({ variant, className }))}
17
34
  {...props}
18
35
  >
19
36
  <CheckboxPrimitive.Indicator
@@ -25,4 +42,4 @@ const Checkbox = React.forwardRef<
25
42
  ));
26
43
  Checkbox.displayName = CheckboxPrimitive.Root.displayName;
27
44
 
28
- export { Checkbox };
45
+ export { Checkbox, type CheckboxProps };
@@ -52,6 +52,25 @@ const CommandInput = React.forwardRef<
52
52
 
53
53
  CommandInput.displayName = CommandPrimitive.Input.displayName;
54
54
 
55
+ const CommandInlineInput = React.forwardRef<
56
+ React.ElementRef<typeof CommandPrimitive.Input>,
57
+ React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>
58
+ >(({ className, ...props }, ref) => (
59
+ // eslint-disable-next-line react/no-unknown-property
60
+ <div className="flex items-center" cmdk-input-wrapper="">
61
+ <CommandPrimitive.Input
62
+ ref={ref}
63
+ className={cn(
64
+ "flex h-9 w-full rounded-md border border-input bg-transparent px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none disabled:cursor-not-allowed disabled:opacity-50",
65
+ "focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring",
66
+ className,
67
+ )}
68
+ {...props}
69
+ />
70
+ </div>
71
+ ));
72
+
73
+ CommandInlineInput.displayName = CommandPrimitive.Input.displayName;
55
74
  const CommandList = React.forwardRef<
56
75
  React.ElementRef<typeof CommandPrimitive.List>,
57
76
  React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>
@@ -143,6 +162,7 @@ export {
143
162
  CommandDialog,
144
163
  CommandEmpty,
145
164
  CommandGroup,
165
+ CommandInlineInput,
146
166
  CommandInput,
147
167
  CommandItem,
148
168
  CommandList,
@@ -83,9 +83,9 @@ const SelectContent = React.forwardRef<
83
83
  <SelectScrollUpButton />
84
84
  <SelectPrimitive.Viewport
85
85
  className={cn(
86
- "p-1",
87
86
  position === "popper" &&
88
87
  "h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)]",
88
+ "divide-y",
89
89
  )}
90
90
  >
91
91
  {children}