zudoku 0.0.0-ec30b50 → 0.0.0-ee328ec

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 (958) hide show
  1. package/README.md +1 -1
  2. package/cli.js +3 -0
  3. package/dist/app/ZuploBuildConfig.d.ts +155 -0
  4. package/dist/app/ZuploBuildConfig.js +29 -0
  5. package/dist/app/ZuploBuildConfig.js.map +1 -0
  6. package/dist/app/entry.client.d.ts +5 -0
  7. package/dist/app/entry.client.js +37 -0
  8. package/dist/app/entry.client.js.map +1 -1
  9. package/dist/app/entry.server.d.ts +8 -6
  10. package/dist/app/entry.server.js +12 -8
  11. package/dist/app/entry.server.js.map +1 -1
  12. package/dist/app/env.d.ts +33 -0
  13. package/dist/app/env.js +29 -0
  14. package/dist/app/env.js.map +1 -0
  15. package/dist/app/main.js +12 -5
  16. package/dist/app/main.js.map +1 -1
  17. package/dist/app/tailwind.js +20 -0
  18. package/dist/app/tailwind.js.map +1 -1
  19. package/dist/cli/build/handler.d.ts +1 -3
  20. package/dist/cli/build/handler.js +9 -1
  21. package/dist/cli/build/handler.js.map +1 -1
  22. package/dist/cli/cli.js +17 -1
  23. package/dist/cli/cli.js.map +1 -1
  24. package/dist/cli/cmds/build.d.ts +11 -3
  25. package/dist/cli/cmds/build.js +20 -13
  26. package/dist/cli/cmds/build.js.map +1 -1
  27. package/dist/cli/cmds/dev.d.ts +1 -1
  28. package/dist/cli/cmds/dev.js.map +1 -1
  29. package/dist/cli/cmds/preview.d.ts +16 -0
  30. package/dist/cli/cmds/preview.js +25 -0
  31. package/dist/cli/cmds/preview.js.map +1 -0
  32. package/dist/cli/common/machine-id/lib.js +1 -0
  33. package/dist/cli/common/machine-id/lib.js.map +1 -1
  34. package/dist/cli/common/utils/ports.d.ts +1 -1
  35. package/dist/cli/common/utils/ports.js +16 -15
  36. package/dist/cli/common/utils/ports.js.map +1 -1
  37. package/dist/cli/dev/handler.js +10 -12
  38. package/dist/cli/dev/handler.js.map +1 -1
  39. package/dist/cli/preview/handler.d.ts +3 -0
  40. package/dist/cli/preview/handler.js +35 -0
  41. package/dist/cli/preview/handler.js.map +1 -0
  42. package/dist/config/common.d.ts +5 -3
  43. package/dist/config/config.d.ts +18 -16
  44. package/dist/config/loader.d.ts +5 -19
  45. package/dist/config/loader.js +25 -114
  46. package/dist/config/loader.js.map +1 -1
  47. package/dist/config/validators/BuildSchema.d.ts +60 -0
  48. package/dist/config/validators/BuildSchema.js +31 -0
  49. package/dist/config/validators/BuildSchema.js.map +1 -0
  50. package/dist/config/validators/InputSidebarSchema.d.ts +15 -15
  51. package/dist/config/validators/InputSidebarSchema.js +10 -1
  52. package/dist/config/validators/InputSidebarSchema.js.map +1 -1
  53. package/dist/config/validators/common.d.ts +3409 -685
  54. package/dist/config/validators/common.js +135 -21
  55. package/dist/config/validators/common.js.map +1 -1
  56. package/dist/config/validators/icon-types.d.ts +1 -1
  57. package/dist/config/validators/validate.d.ts +1266 -302
  58. package/dist/index.d.ts +2 -1
  59. package/dist/index.js +1 -0
  60. package/dist/index.js.map +1 -1
  61. package/dist/lib/MissingIcon.d.ts +2 -0
  62. package/dist/lib/MissingIcon.js +7 -0
  63. package/dist/lib/MissingIcon.js.map +1 -0
  64. package/dist/lib/authentication/authentication.d.ts +1 -0
  65. package/dist/lib/authentication/components/CallbackHandler.js +5 -1
  66. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  67. package/dist/lib/authentication/components/SignIn.d.ts +1 -1
  68. package/dist/lib/authentication/components/SignIn.js +5 -2
  69. package/dist/lib/authentication/components/SignIn.js.map +1 -1
  70. package/dist/lib/authentication/components/SignUp.d.ts +1 -1
  71. package/dist/lib/authentication/components/SignUp.js +4 -1
  72. package/dist/lib/authentication/components/SignUp.js.map +1 -1
  73. package/dist/lib/authentication/hook.d.ts +1 -0
  74. package/dist/lib/authentication/hook.js +11 -1
  75. package/dist/lib/authentication/hook.js.map +1 -1
  76. package/dist/lib/authentication/providers/auth0.d.ts +2 -2
  77. package/dist/lib/authentication/providers/auth0.js +2 -1
  78. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  79. package/dist/lib/authentication/providers/clerk.d.ts +2 -2
  80. package/dist/lib/authentication/providers/clerk.js +34 -7
  81. package/dist/lib/authentication/providers/clerk.js.map +1 -1
  82. package/dist/lib/authentication/providers/openid.d.ts +10 -9
  83. package/dist/lib/authentication/providers/openid.js +32 -24
  84. package/dist/lib/authentication/providers/openid.js.map +1 -1
  85. package/dist/lib/authentication/providers/supabase.d.ts +4 -0
  86. package/dist/lib/authentication/providers/supabase.js +117 -0
  87. package/dist/lib/authentication/providers/supabase.js.map +1 -0
  88. package/dist/lib/authentication/state.d.ts +0 -26
  89. package/dist/lib/authentication/state.js +9 -18
  90. package/dist/lib/authentication/state.js.map +1 -1
  91. package/dist/lib/components/AnchorLink.d.ts +2 -2
  92. package/dist/lib/components/AnchorLink.js +5 -4
  93. package/dist/lib/components/AnchorLink.js.map +1 -1
  94. package/dist/lib/components/Banner.js +1 -1
  95. package/dist/lib/components/Banner.js.map +1 -1
  96. package/dist/lib/components/Bootstrap.d.ts +2 -1
  97. package/dist/lib/components/Bootstrap.js +3 -2
  98. package/dist/lib/components/Bootstrap.js.map +1 -1
  99. package/dist/lib/components/BuildCheck.d.ts +4 -0
  100. package/dist/lib/components/BuildCheck.js +38 -0
  101. package/dist/lib/components/BuildCheck.js.map +1 -0
  102. package/dist/lib/components/Footer.d.ts +1 -0
  103. package/dist/lib/components/Footer.js +32 -0
  104. package/dist/lib/components/Footer.js.map +1 -0
  105. package/dist/lib/components/Header.js +4 -4
  106. package/dist/lib/components/Header.js.map +1 -1
  107. package/dist/lib/components/Heading.d.ts +3 -3
  108. package/dist/lib/components/Heading.js +1 -1
  109. package/dist/lib/components/Heading.js.map +1 -1
  110. package/dist/lib/components/InlineCode.d.ts +2 -1
  111. package/dist/lib/components/InlineCode.js +2 -9
  112. package/dist/lib/components/InlineCode.js.map +1 -1
  113. package/dist/lib/components/Layout.js +8 -28
  114. package/dist/lib/components/Layout.js.map +1 -1
  115. package/dist/lib/components/Main.d.ts +2 -0
  116. package/dist/lib/components/Main.js +18 -0
  117. package/dist/lib/components/Main.js.map +1 -0
  118. package/dist/lib/components/MobileTopNavigation.js +6 -3
  119. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  120. package/dist/lib/components/Pagination.d.ts +11 -0
  121. package/dist/lib/components/Pagination.js +10 -0
  122. package/dist/lib/components/Pagination.js.map +1 -0
  123. package/dist/lib/components/Search.js +7 -1
  124. package/dist/lib/components/Search.js.map +1 -1
  125. package/dist/lib/components/ThemeSwitch.js +8 -5
  126. package/dist/lib/components/ThemeSwitch.js.map +1 -1
  127. package/dist/lib/components/TopNavigation.d.ts +3 -2
  128. package/dist/lib/components/TopNavigation.js +28 -14
  129. package/dist/lib/components/TopNavigation.js.map +1 -1
  130. package/dist/lib/components/Zudoku.d.ts +1 -1
  131. package/dist/lib/components/Zudoku.js +13 -8
  132. package/dist/lib/components/Zudoku.js.map +1 -1
  133. package/dist/lib/components/cache.d.ts +7 -0
  134. package/dist/lib/components/cache.js +7 -0
  135. package/dist/lib/components/cache.js.map +1 -1
  136. package/dist/lib/components/context/BypassProtectedRoutesContext.d.ts +1 -0
  137. package/dist/lib/components/context/BypassProtectedRoutesContext.js +3 -0
  138. package/dist/lib/components/context/BypassProtectedRoutesContext.js.map +1 -0
  139. package/dist/lib/components/context/RouterEventsEmitter.d.ts +1 -0
  140. package/dist/lib/components/context/RouterEventsEmitter.js +17 -0
  141. package/dist/lib/components/context/RouterEventsEmitter.js.map +1 -0
  142. package/dist/lib/components/context/ViewportAnchorContext.d.ts +2 -4
  143. package/dist/lib/components/context/ViewportAnchorContext.js +13 -19
  144. package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
  145. package/dist/lib/components/context/ZudokuContext.d.ts +2 -2
  146. package/dist/lib/components/context/ZudokuContext.js +21 -9
  147. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  148. package/dist/lib/components/index.d.ts +11 -3
  149. package/dist/lib/components/index.js +4 -0
  150. package/dist/lib/components/index.js.map +1 -1
  151. package/dist/lib/components/navigation/PoweredByZudoku.d.ts +3 -0
  152. package/dist/lib/components/navigation/PoweredByZudoku.js +7 -0
  153. package/dist/lib/components/navigation/PoweredByZudoku.js.map +1 -0
  154. package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
  155. package/dist/lib/components/navigation/Sidebar.js +3 -12
  156. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  157. package/dist/lib/components/navigation/SidebarBadge.d.ts +2 -0
  158. package/dist/lib/components/navigation/SidebarBadge.js +3 -1
  159. package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
  160. package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
  161. package/dist/lib/components/navigation/SidebarCategory.js +18 -10
  162. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  163. package/dist/lib/components/navigation/SidebarItem.d.ts +1 -0
  164. package/dist/lib/components/navigation/SidebarItem.js +17 -12
  165. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  166. package/dist/lib/components/navigation/SidebarWrapper.d.ts +7 -6
  167. package/dist/lib/components/navigation/SidebarWrapper.js +18 -3
  168. package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
  169. package/dist/lib/{plugins/markdown → components/navigation}/Toc.js +6 -8
  170. package/dist/lib/components/navigation/Toc.js.map +1 -0
  171. package/dist/lib/components/navigation/ZudokuLogo.d.ts +6 -0
  172. package/dist/lib/components/navigation/ZudokuLogo.js +5 -0
  173. package/dist/lib/components/navigation/ZudokuLogo.js.map +1 -0
  174. package/dist/lib/components/navigation/ZuploLogo.d.ts +3 -0
  175. package/dist/lib/components/navigation/ZuploLogo.js +4 -0
  176. package/dist/lib/components/navigation/ZuploLogo.js.map +1 -0
  177. package/dist/lib/core/RouteGuard.d.ts +2 -1
  178. package/dist/lib/core/RouteGuard.js +35 -11
  179. package/dist/lib/core/RouteGuard.js.map +1 -1
  180. package/dist/lib/core/ZudokuContext.d.ts +34 -7
  181. package/dist/lib/core/ZudokuContext.js +29 -6
  182. package/dist/lib/core/ZudokuContext.js.map +1 -1
  183. package/dist/lib/core/plugins.d.ts +17 -7
  184. package/dist/lib/core/plugins.js +3 -0
  185. package/dist/lib/core/plugins.js.map +1 -1
  186. package/dist/lib/errors/ErrorAlert.js +6 -1
  187. package/dist/lib/errors/ErrorAlert.js.map +1 -1
  188. package/dist/lib/hooks/index.d.ts +3 -0
  189. package/dist/lib/hooks/index.js +5 -0
  190. package/dist/lib/hooks/index.js.map +1 -0
  191. package/dist/lib/hooks/useEvent.d.ts +11 -0
  192. package/dist/lib/hooks/useEvent.js +19 -0
  193. package/dist/lib/hooks/useEvent.js.map +1 -0
  194. package/dist/lib/hooks/useEvent.test.js +100 -0
  195. package/dist/lib/hooks/useEvent.test.js.map +1 -0
  196. package/dist/lib/icons.d.ts +1 -0
  197. package/dist/lib/icons.js +1 -0
  198. package/dist/lib/icons.js.map +1 -1
  199. package/dist/lib/oas/graphql/index.d.ts +17 -4
  200. package/dist/lib/oas/graphql/index.js +151 -38
  201. package/dist/lib/oas/graphql/index.js.map +1 -1
  202. package/dist/lib/oas/parser/dereference/index.js +2 -0
  203. package/dist/lib/oas/parser/dereference/index.js.map +1 -1
  204. package/dist/lib/oas/parser/index.d.ts +8 -3
  205. package/dist/lib/oas/parser/index.js +7 -23
  206. package/dist/lib/oas/parser/index.js.map +1 -1
  207. package/dist/lib/oas/parser/upgrade/index.d.ts +1 -0
  208. package/dist/lib/oas/parser/upgrade/index.js +76 -23
  209. package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
  210. package/dist/lib/plugins/api-catalog/Catalog.d.ts +4 -2
  211. package/dist/lib/plugins/api-catalog/Catalog.js +16 -26
  212. package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
  213. package/dist/lib/plugins/api-catalog/index.d.ts +1 -0
  214. package/dist/lib/plugins/api-catalog/index.js +39 -8
  215. package/dist/lib/plugins/api-catalog/index.js.map +1 -1
  216. package/dist/lib/plugins/api-keys/CreateApiKey.js +7 -3
  217. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  218. package/dist/lib/plugins/api-keys/index.d.ts +1 -0
  219. package/dist/lib/plugins/api-keys/index.js +1 -0
  220. package/dist/lib/plugins/api-keys/index.js.map +1 -1
  221. package/dist/lib/plugins/markdown/MdxPage.d.ts +1 -1
  222. package/dist/lib/plugins/markdown/MdxPage.js +3 -9
  223. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  224. package/dist/lib/plugins/markdown/resolver.d.ts +0 -6
  225. package/dist/lib/plugins/markdown/resolver.js +0 -29
  226. package/dist/lib/plugins/markdown/resolver.js.map +1 -1
  227. package/dist/lib/plugins/openapi/CollapsibleCode.js +1 -1
  228. package/dist/lib/plugins/openapi/ColorizedParam.js +1 -1
  229. package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
  230. package/dist/lib/plugins/openapi/Endpoint.js +1 -1
  231. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  232. package/dist/lib/plugins/openapi/{OpenApiRoute.d.ts → OasProvider.d.ts} +1 -2
  233. package/dist/lib/plugins/openapi/OasProvider.js +29 -0
  234. package/dist/lib/plugins/openapi/OasProvider.js.map +1 -0
  235. package/dist/lib/plugins/openapi/OperationList.d.ts +1 -1
  236. package/dist/lib/plugins/openapi/OperationList.js +67 -20
  237. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  238. package/dist/lib/plugins/openapi/OperationListItem.d.ts +1 -1
  239. package/dist/lib/plugins/openapi/OperationListItem.js +9 -12
  240. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  241. package/dist/lib/plugins/openapi/ParamInfos.d.ts +6 -0
  242. package/dist/lib/plugins/openapi/ParamInfos.js +43 -0
  243. package/dist/lib/plugins/openapi/ParamInfos.js.map +1 -0
  244. package/dist/lib/plugins/openapi/ParameterList.d.ts +2 -1
  245. package/dist/lib/plugins/openapi/ParameterList.js +3 -2
  246. package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
  247. package/dist/lib/plugins/openapi/ParameterListItem.js +16 -4
  248. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  249. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +1 -1
  250. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +3 -1
  251. package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
  252. package/dist/lib/plugins/openapi/SchemaList.d.ts +1 -0
  253. package/dist/lib/plugins/openapi/SchemaList.js +52 -0
  254. package/dist/lib/plugins/openapi/SchemaList.js.map +1 -0
  255. package/dist/lib/plugins/openapi/Sidecar.js +70 -11
  256. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  257. package/dist/lib/plugins/openapi/SidecarExamples.js +2 -2
  258. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
  259. package/dist/lib/plugins/openapi/SimpleSelect.js +1 -1
  260. package/dist/lib/plugins/openapi/SimpleSelect.js.map +1 -1
  261. package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +1 -1
  262. package/dist/lib/plugins/openapi/client/GraphQLClient.js +1 -1
  263. package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -1
  264. package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +11 -2
  265. package/dist/lib/plugins/openapi/client/useCreateQuery.js +14 -7
  266. package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -1
  267. package/dist/lib/plugins/openapi/components/ConstValue.d.ts +5 -0
  268. package/dist/lib/plugins/openapi/components/ConstValue.js +6 -0
  269. package/dist/lib/plugins/openapi/components/ConstValue.js.map +1 -0
  270. package/dist/lib/plugins/openapi/components/EnumValues.d.ts +5 -0
  271. package/dist/lib/plugins/openapi/components/EnumValues.js +15 -0
  272. package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -0
  273. package/dist/lib/plugins/openapi/components/SelectOnClick.d.ts +5 -0
  274. package/dist/lib/plugins/openapi/components/SelectOnClick.js +16 -0
  275. package/dist/lib/plugins/openapi/components/SelectOnClick.js.map +1 -0
  276. package/dist/lib/plugins/openapi/graphql/gql.d.ts +9 -5
  277. package/dist/lib/plugins/openapi/graphql/gql.js +5 -15
  278. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  279. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +108 -55
  280. package/dist/lib/plugins/openapi/graphql/graphql.js +59 -34
  281. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  282. package/dist/lib/plugins/openapi/index.d.ts +10 -8
  283. package/dist/lib/plugins/openapi/index.js +58 -142
  284. package/dist/lib/plugins/openapi/index.js.map +1 -1
  285. package/dist/lib/plugins/openapi/interfaces.d.ts +37 -10
  286. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +2 -2
  287. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -5
  288. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
  289. package/dist/lib/plugins/openapi/playground/Headers.js +3 -3
  290. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  291. package/dist/lib/plugins/openapi/playground/IdentityDialog.d.ts +11 -0
  292. package/dist/lib/plugins/openapi/playground/IdentityDialog.js +14 -0
  293. package/dist/lib/plugins/openapi/playground/IdentityDialog.js.map +1 -0
  294. package/dist/lib/plugins/openapi/playground/IdentitySelector.d.ts +7 -0
  295. package/dist/lib/plugins/openapi/playground/IdentitySelector.js +10 -0
  296. package/dist/lib/plugins/openapi/playground/IdentitySelector.js.map +1 -0
  297. package/dist/lib/plugins/openapi/playground/PathParams.d.ts +3 -2
  298. package/dist/lib/plugins/openapi/playground/PathParams.js +3 -2
  299. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  300. package/dist/lib/plugins/openapi/playground/Playground.d.ts +14 -3
  301. package/dist/lib/plugins/openapi/playground/Playground.js +84 -30
  302. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  303. package/dist/lib/plugins/openapi/playground/QueryParams.d.ts +1 -1
  304. package/dist/lib/plugins/openapi/playground/QueryParams.js +3 -3
  305. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  306. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.d.ts +7 -0
  307. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js +8 -0
  308. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js.map +1 -0
  309. package/dist/lib/plugins/openapi/playground/SubmitButton.d.ts +1 -1
  310. package/dist/lib/plugins/openapi/playground/SubmitButton.js +1 -1
  311. package/dist/lib/plugins/openapi/playground/rememberedIdentity.d.ts +17 -0
  312. package/dist/lib/plugins/openapi/playground/rememberedIdentity.js +11 -0
  313. package/dist/lib/plugins/openapi/playground/rememberedIdentity.js.map +1 -0
  314. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +1 -1
  315. package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +1 -1
  316. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +20 -14
  317. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
  318. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +6 -4
  319. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +4 -3
  320. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
  321. package/dist/lib/plugins/openapi/processors/removeExtensions.d.ts +8 -0
  322. package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.js +1 -1
  323. package/dist/lib/plugins/openapi/processors/removeExtensions.js.map +1 -0
  324. package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.js +26 -6
  325. package/dist/lib/plugins/openapi/processors/removeExtensions.test.js.map +1 -0
  326. package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.d.ts +3 -1
  327. package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.js +1 -1
  328. package/dist/lib/plugins/openapi/processors/removeParameters.js.map +1 -0
  329. package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.js +53 -25
  330. package/dist/lib/plugins/openapi/processors/removeParameters.test.js.map +1 -0
  331. package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.d.ts +3 -1
  332. package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.js +1 -1
  333. package/dist/lib/plugins/openapi/processors/removePaths.js.map +1 -0
  334. package/dist/lib/plugins/openapi/processors/removePaths.test.js +144 -0
  335. package/dist/lib/plugins/openapi/processors/removePaths.test.js.map +1 -0
  336. package/dist/lib/plugins/openapi/processors/traverse.js.map +1 -0
  337. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.d.ts +1 -2
  338. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.js +2 -2
  339. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.js.map +1 -1
  340. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.d.ts +2 -1
  341. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.js +2 -2
  342. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.js.map +1 -1
  343. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.d.ts +0 -1
  344. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.js +1 -1
  345. package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.js.map +1 -1
  346. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.d.ts +4 -0
  347. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +15 -0
  348. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -0
  349. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.d.ts +2 -4
  350. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +23 -14
  351. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
  352. package/dist/lib/plugins/openapi/schema/SchemaView.d.ts +1 -2
  353. package/dist/lib/plugins/openapi/schema/SchemaView.js +37 -49
  354. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  355. package/dist/lib/plugins/openapi/schema/utils.d.ts +2 -0
  356. package/dist/lib/plugins/openapi/schema/utils.js +6 -1
  357. package/dist/lib/plugins/openapi/schema/utils.js.map +1 -1
  358. package/dist/lib/plugins/openapi/state.d.ts +25 -0
  359. package/dist/lib/plugins/openapi/state.js +18 -0
  360. package/dist/lib/plugins/openapi/state.js.map +1 -0
  361. package/dist/lib/plugins/openapi/util/createSidebarCategory.d.ts +9 -0
  362. package/dist/lib/plugins/openapi/util/createSidebarCategory.js +23 -0
  363. package/dist/lib/plugins/openapi/util/createSidebarCategory.js.map +1 -0
  364. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +40 -0
  365. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  366. package/dist/lib/plugins/openapi/util/getRoutes.d.ts +10 -0
  367. package/dist/lib/plugins/openapi/util/getRoutes.js +117 -0
  368. package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -0
  369. package/dist/lib/plugins/openapi/util/methodColorMap.d.ts +2 -0
  370. package/dist/lib/plugins/openapi/util/methodColorMap.js +10 -0
  371. package/dist/lib/plugins/openapi/util/methodColorMap.js.map +1 -0
  372. package/dist/lib/plugins/search-pagefind/PagefindSearch.d.ts +6 -0
  373. package/dist/lib/plugins/search-pagefind/PagefindSearch.js +80 -0
  374. package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -0
  375. package/dist/lib/plugins/search-pagefind/ResultList.d.ts +8 -0
  376. package/dist/lib/plugins/search-pagefind/ResultList.js +32 -0
  377. package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -0
  378. package/dist/lib/plugins/search-pagefind/get-results.d.ts +10 -0
  379. package/dist/lib/plugins/search-pagefind/get-results.js +42 -0
  380. package/dist/lib/plugins/search-pagefind/get-results.js.map +1 -0
  381. package/dist/lib/plugins/search-pagefind/index.d.ts +6 -0
  382. package/dist/lib/plugins/search-pagefind/index.js +9 -0
  383. package/dist/lib/plugins/search-pagefind/index.js.map +1 -0
  384. package/dist/lib/plugins/search-pagefind/types.d.ts +85 -0
  385. package/dist/lib/plugins/search-pagefind/types.js +2 -0
  386. package/dist/lib/plugins/search-pagefind/types.js.map +1 -0
  387. package/dist/lib/ui/Badge.d.ts +1 -1
  388. package/dist/lib/ui/Button.d.ts +2 -2
  389. package/dist/lib/ui/Button.js +2 -1
  390. package/dist/lib/ui/Button.js.map +1 -1
  391. package/dist/lib/ui/Callout.d.ts +2 -1
  392. package/dist/lib/ui/Callout.js +3 -2
  393. package/dist/lib/ui/Callout.js.map +1 -1
  394. package/dist/lib/ui/Checkbox.d.ts +2 -8
  395. package/dist/lib/ui/Checkbox.js +1 -13
  396. package/dist/lib/ui/Checkbox.js.map +1 -1
  397. package/dist/lib/ui/Command.d.ts +7 -1
  398. package/dist/lib/ui/Command.js +2 -2
  399. package/dist/lib/ui/Command.js.map +1 -1
  400. package/dist/lib/ui/Form.d.ts +1 -1
  401. package/dist/lib/ui/Select.js +1 -1
  402. package/dist/lib/ui/Select.js.map +1 -1
  403. package/dist/lib/ui/Stepper.d.ts +3 -0
  404. package/dist/lib/ui/Stepper.js +7 -0
  405. package/dist/lib/ui/Stepper.js.map +1 -0
  406. package/dist/lib/ui/SyntaxHighlight.d.ts +15 -0
  407. package/dist/lib/ui/SyntaxHighlight.js +62 -0
  408. package/dist/lib/ui/SyntaxHighlight.js.map +1 -0
  409. package/dist/lib/ui/util.d.ts +2 -0
  410. package/dist/lib/ui/util.js +3 -0
  411. package/dist/lib/ui/util.js.map +1 -0
  412. package/dist/lib/util/MdxComponents.d.ts +6 -2
  413. package/dist/lib/util/MdxComponents.js +8 -3
  414. package/dist/lib/util/MdxComponents.js.map +1 -1
  415. package/dist/lib/util/detectOS.d.ts +1 -0
  416. package/dist/lib/util/detectOS.js +11 -0
  417. package/dist/lib/util/detectOS.js.map +1 -0
  418. package/dist/lib/util/ensureArray.d.ts +1 -0
  419. package/dist/lib/util/ensureArray.js +2 -0
  420. package/dist/lib/util/ensureArray.js.map +1 -0
  421. package/dist/lib/util/joinPath.d.ts +3 -0
  422. package/dist/lib/util/joinPath.js +3 -0
  423. package/dist/lib/util/joinPath.js.map +1 -1
  424. package/dist/lib/util/traverse.d.ts +3 -9
  425. package/dist/lib/util/traverse.js +7 -6
  426. package/dist/lib/util/traverse.js.map +1 -1
  427. package/dist/lib/util/types.d.ts +7 -0
  428. package/dist/lib/util/types.js +2 -0
  429. package/dist/lib/util/types.js.map +1 -0
  430. package/dist/lib/util/url.d.ts +4 -0
  431. package/dist/lib/util/url.js +13 -0
  432. package/dist/lib/util/url.js.map +1 -0
  433. package/dist/lib/util/url.test.d.ts +1 -0
  434. package/dist/lib/util/url.test.js +26 -0
  435. package/dist/lib/util/url.test.js.map +1 -0
  436. package/dist/lib/util/useLatest.d.ts +1 -0
  437. package/dist/lib/util/useLatest.js +15 -0
  438. package/dist/lib/util/useLatest.js.map +1 -0
  439. package/dist/lib/util/useOnScreen.d.ts +3 -2
  440. package/dist/lib/util/useOnScreen.js +3 -3
  441. package/dist/lib/util/useOnScreen.js.map +1 -1
  442. package/dist/lib/util/useScrollToAnchor.js +26 -20
  443. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  444. package/dist/vite/api/SchemaManager.d.ts +36 -0
  445. package/dist/vite/api/SchemaManager.js +122 -0
  446. package/dist/vite/api/SchemaManager.js.map +1 -0
  447. package/dist/vite/api/SchemaManager.test.d.ts +1 -0
  448. package/dist/vite/api/SchemaManager.test.js +106 -0
  449. package/dist/vite/api/SchemaManager.test.js.map +1 -0
  450. package/dist/vite/api/schema-codegen.d.ts +1 -1
  451. package/dist/vite/api/schema-codegen.js +34 -11
  452. package/dist/vite/api/schema-codegen.js.map +1 -1
  453. package/dist/vite/api/schema-codegen.test.js +66 -0
  454. package/dist/vite/api/schema-codegen.test.js.map +1 -1
  455. package/dist/vite/build.js +28 -16
  456. package/dist/vite/build.js.map +1 -1
  457. package/dist/vite/config.d.ts +2 -5
  458. package/dist/vite/config.js +67 -71
  459. package/dist/vite/config.js.map +1 -1
  460. package/dist/vite/config.test.js +1 -1
  461. package/dist/vite/config.test.js.map +1 -1
  462. package/dist/vite/create-pagefind-index.d.ts +4 -0
  463. package/dist/vite/create-pagefind-index.js +12 -0
  464. package/dist/vite/create-pagefind-index.js.map +1 -0
  465. package/dist/vite/css/plugin.d.ts +2 -2
  466. package/dist/vite/css/plugin.js.map +1 -1
  467. package/dist/vite/dev-server.d.ts +4 -2
  468. package/dist/vite/dev-server.js +47 -14
  469. package/dist/vite/dev-server.js.map +1 -1
  470. package/dist/vite/error-handler.d.ts +1 -1
  471. package/dist/vite/error-handler.js +1 -1
  472. package/dist/vite/error-handler.js.map +1 -1
  473. package/dist/vite/html.d.ts +6 -2
  474. package/dist/vite/html.js +11 -8
  475. package/dist/vite/html.js.map +1 -1
  476. package/dist/vite/output.d.ts +14 -2
  477. package/dist/vite/output.js +12 -14
  478. package/dist/vite/output.js.map +1 -1
  479. package/dist/vite/plugin-api-keys.d.ts +2 -2
  480. package/dist/vite/plugin-api-keys.js +5 -5
  481. package/dist/vite/plugin-api-keys.js.map +1 -1
  482. package/dist/vite/plugin-api.d.ts +2 -2
  483. package/dist/vite/plugin-api.js +73 -107
  484. package/dist/vite/plugin-api.js.map +1 -1
  485. package/dist/vite/plugin-auth.d.ts +2 -2
  486. package/dist/vite/plugin-auth.js +3 -3
  487. package/dist/vite/plugin-auth.js.map +1 -1
  488. package/dist/vite/plugin-component.d.ts +2 -2
  489. package/dist/vite/plugin-component.js +7 -2
  490. package/dist/vite/plugin-component.js.map +1 -1
  491. package/dist/vite/plugin-config-reload.d.ts +4 -3
  492. package/dist/vite/plugin-config-reload.js +13 -6
  493. package/dist/vite/plugin-config-reload.js.map +1 -1
  494. package/dist/vite/plugin-config.d.ts +2 -2
  495. package/dist/vite/plugin-config.js +9 -5
  496. package/dist/vite/plugin-config.js.map +1 -1
  497. package/dist/vite/plugin-custom-pages.d.ts +2 -2
  498. package/dist/vite/plugin-custom-pages.js +3 -3
  499. package/dist/vite/plugin-custom-pages.js.map +1 -1
  500. package/dist/vite/plugin-docs.d.ts +3 -3
  501. package/dist/vite/plugin-docs.js +23 -6
  502. package/dist/vite/plugin-docs.js.map +1 -1
  503. package/dist/vite/plugin-frontmatter.d.ts +2 -2
  504. package/dist/vite/plugin-frontmatter.js +5 -4
  505. package/dist/vite/plugin-frontmatter.js.map +1 -1
  506. package/dist/vite/plugin-mdx.d.ts +2 -2
  507. package/dist/vite/plugin-mdx.js +32 -27
  508. package/dist/vite/plugin-mdx.js.map +1 -1
  509. package/dist/vite/plugin-redirect.d.ts +2 -2
  510. package/dist/vite/plugin-redirect.js +3 -3
  511. package/dist/vite/plugin-redirect.js.map +1 -1
  512. package/dist/vite/plugin-search.d.ts +2 -2
  513. package/dist/vite/plugin-search.js +5 -1
  514. package/dist/vite/plugin-search.js.map +1 -1
  515. package/dist/vite/plugin-sidebar.d.ts +5 -3
  516. package/dist/vite/plugin-sidebar.js +21 -6
  517. package/dist/vite/plugin-sidebar.js.map +1 -1
  518. package/dist/vite/plugin-theme-css.d.ts +2 -2
  519. package/dist/vite/plugin-theme-css.js.map +1 -1
  520. package/dist/vite/plugin.d.ts +2 -2
  521. package/dist/vite/plugin.js.map +1 -1
  522. package/dist/vite/prerender/FileWritingResponse.d.ts +25 -0
  523. package/dist/vite/prerender/FileWritingResponse.js +51 -0
  524. package/dist/vite/prerender/FileWritingResponse.js.map +1 -0
  525. package/dist/vite/prerender/InMemoryResponse.d.ts +16 -0
  526. package/dist/vite/prerender/InMemoryResponse.js +32 -0
  527. package/dist/vite/prerender/InMemoryResponse.js.map +1 -0
  528. package/dist/vite/prerender/PrerenderResponse.d.ts +10 -0
  529. package/dist/vite/prerender/PrerenderResponse.js +2 -0
  530. package/dist/vite/prerender/PrerenderResponse.js.map +1 -0
  531. package/dist/vite/prerender/prerender.d.ts +15 -0
  532. package/dist/vite/prerender/prerender.js +109 -0
  533. package/dist/vite/prerender/prerender.js.map +1 -0
  534. package/dist/vite/prerender/worker.d.ts +13 -0
  535. package/dist/vite/prerender/worker.js +59 -0
  536. package/dist/vite/prerender/worker.js.map +1 -0
  537. package/dist/vite/reporter.d.ts +3 -0
  538. package/dist/vite/reporter.js +33 -0
  539. package/dist/vite/reporter.js.map +1 -0
  540. package/dist/vite/sitemap.js +2 -1
  541. package/dist/vite/sitemap.js.map +1 -1
  542. package/dist/zuplo/enrich-with-zuplo.d.ts +3 -3
  543. package/dist/zuplo/enrich-with-zuplo.js +18 -17
  544. package/dist/zuplo/enrich-with-zuplo.js.map +1 -1
  545. package/dist/zuplo/with-zuplo-processors.d.ts +2 -2
  546. package/dist/zuplo/with-zuplo-processors.js +7 -7
  547. package/dist/zuplo/with-zuplo-processors.js.map +1 -1
  548. package/dist/zuplo/with-zuplo.d.ts +4 -1
  549. package/dist/zuplo/with-zuplo.js +6 -5
  550. package/dist/zuplo/with-zuplo.js.map +1 -1
  551. package/lib/AuthenticationPlugin-Bqlq5kRN.js +99 -0
  552. package/lib/AuthenticationPlugin-Bqlq5kRN.js.map +1 -0
  553. package/lib/Button-BBNrKpQd.js +49 -0
  554. package/lib/Button-BBNrKpQd.js.map +1 -0
  555. package/lib/Callout-D3Ja4OPX.js +230 -0
  556. package/lib/Callout-D3Ja4OPX.js.map +1 -0
  557. package/lib/Card-BtheiD7j.js +61 -0
  558. package/lib/Card-BtheiD7j.js.map +1 -0
  559. package/lib/{CategoryHeading-MYL1u_6K.js → CategoryHeading-D06WK_Wo.js} +3 -3
  560. package/lib/{CategoryHeading-MYL1u_6K.js.map → CategoryHeading-D06WK_Wo.js.map} +1 -1
  561. package/lib/Dialog-ByYz4ABw.js +98 -0
  562. package/lib/Dialog-ByYz4ABw.js.map +1 -0
  563. package/lib/Drawer-CEwbkLDb.js +1133 -0
  564. package/lib/Drawer-CEwbkLDb.js.map +1 -0
  565. package/lib/{Markdown-8mv9nhGd.js → Markdown-DvdVn1O7.js} +8023 -6085
  566. package/lib/Markdown-DvdVn1O7.js.map +1 -0
  567. package/lib/MdxPage-_8H25sEU.js +85 -0
  568. package/lib/MdxPage-_8H25sEU.js.map +1 -0
  569. package/lib/OasProvider-hBA9fTDC.js +33 -0
  570. package/lib/OasProvider-hBA9fTDC.js.map +1 -0
  571. package/lib/OperationList-0n_9nYIg.js +5147 -0
  572. package/lib/OperationList-0n_9nYIg.js.map +1 -0
  573. package/lib/Pagination-B4iXKAzG.js +48 -0
  574. package/lib/Pagination-B4iXKAzG.js.map +1 -0
  575. package/lib/{index.esm-9-TF9KQB.js → RouteGuard-D2gX29iI.js} +196 -144
  576. package/lib/RouteGuard-D2gX29iI.js.map +1 -0
  577. package/lib/SchemaList-DGOmVkot.js +147 -0
  578. package/lib/SchemaList-DGOmVkot.js.map +1 -0
  579. package/lib/SchemaView-DBar2RLi.js +365 -0
  580. package/lib/SchemaView-DBar2RLi.js.map +1 -0
  581. package/lib/{Select-BcAbBUmk.js → Select-CYaEBIYK.js} +71 -71
  582. package/lib/{Select-BcAbBUmk.js.map → Select-CYaEBIYK.js.map} +1 -1
  583. package/lib/SlotletProvider-wWbHYqWf.js +340 -0
  584. package/lib/SlotletProvider-wWbHYqWf.js.map +1 -0
  585. package/lib/Spinner-mNLZ6awP.js +7 -0
  586. package/lib/Spinner-mNLZ6awP.js.map +1 -0
  587. package/lib/{SyntaxHighlight-B0L4SC_N.js → SyntaxHighlight-o7q0acut.js} +514 -610
  588. package/lib/SyntaxHighlight-o7q0acut.js.map +1 -0
  589. package/lib/Toc-BnN4zBb3.js +92 -0
  590. package/lib/Toc-BnN4zBb3.js.map +1 -0
  591. package/lib/{_commonjsHelpers-BkfeUUK-.js → _commonjsHelpers-B4e78b8K.js} +2 -2
  592. package/lib/_commonjsHelpers-B4e78b8K.js.map +1 -0
  593. package/lib/{chunk-SYFQ2XB5-QijJrSf0.js → chunk-BAXFHI7N-BLTsN6tl.js} +767 -742
  594. package/lib/chunk-BAXFHI7N-BLTsN6tl.js.map +1 -0
  595. package/lib/{circular-DxaIIlWD.js → circular-WY7p7GWq.js} +3195 -3678
  596. package/lib/circular-WY7p7GWq.js.map +1 -0
  597. package/lib/{createServer-E3cXjB0P.js → createServer-D3RtEIGE.js} +5326 -5283
  598. package/lib/createServer-D3RtEIGE.js.map +1 -0
  599. package/lib/hook-8GM2HXNM.js +1478 -0
  600. package/lib/hook-8GM2HXNM.js.map +1 -0
  601. package/lib/index-B1CQk2lf.js +3208 -0
  602. package/lib/index-B1CQk2lf.js.map +1 -0
  603. package/lib/index-Bn6Lc9tq.js +9 -0
  604. package/lib/index-Bn6Lc9tq.js.map +1 -0
  605. package/lib/index-CPNSgwSb.js +36 -0
  606. package/lib/{index-Djenk2Hj.js.map → index-CPNSgwSb.js.map} +1 -1
  607. package/lib/index-CuBIgTKC.js +316 -0
  608. package/lib/index-CuBIgTKC.js.map +1 -0
  609. package/lib/{index-Dl3Yl0yb.js → index-DcHeSvkE.js} +51 -38
  610. package/lib/index-DcHeSvkE.js.map +1 -0
  611. package/lib/index-Dh-bWAb8.js +5039 -0
  612. package/lib/index-Dh-bWAb8.js.map +1 -0
  613. package/lib/index-DwT-v3zK.js +86 -0
  614. package/lib/index-DwT-v3zK.js.map +1 -0
  615. package/lib/{index-CjJS0l4l.js → index-LNp6rxyU.js} +2 -2
  616. package/lib/{index-CjJS0l4l.js.map → index-LNp6rxyU.js.map} +1 -1
  617. package/lib/index.esm-D2ZUREQN.js +1216 -0
  618. package/lib/index.esm-D2ZUREQN.js.map +1 -0
  619. package/lib/jsx-runtime-C5mzlN2N.js +285 -0
  620. package/lib/jsx-runtime-C5mzlN2N.js.map +1 -0
  621. package/lib/mutation-Bq5bn7Hf.js +211 -0
  622. package/lib/mutation-Bq5bn7Hf.js.map +1 -0
  623. package/lib/objectEntries-yMIkr2mI.js +5 -0
  624. package/lib/objectEntries-yMIkr2mI.js.map +1 -0
  625. package/lib/prism-bash.min-HHIMdNJ_.js.map +1 -1
  626. package/lib/{prism-csharp.min-bQAo2pmx.js → prism-csharp.min-C43x1RY2.js} +2 -2
  627. package/lib/{prism-csharp.min-bQAo2pmx.js.map → prism-csharp.min-C43x1RY2.js.map} +1 -1
  628. package/lib/{prism-java.min-BpvsOuIa.js → prism-java.min-CQzr40NQ.js} +2 -2
  629. package/lib/{prism-java.min-BpvsOuIa.js.map → prism-java.min-CQzr40NQ.js.map} +1 -1
  630. package/lib/prism-javascript.min-CEqHqgbm.js.map +1 -1
  631. package/lib/prism-json.min-B1GJqK1k.js.map +1 -1
  632. package/lib/prism-jsstacktrace.min-BfobCF2F.js +2 -0
  633. package/lib/prism-jsstacktrace.min-BfobCF2F.js.map +1 -0
  634. package/lib/prism-markdown.min-C0Qn0m-5.js.map +1 -1
  635. package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
  636. package/lib/prism-objectivec.min-BXSWqpJJ.js.map +1 -1
  637. package/lib/{prism-ruby.min-Dx9KO9ds.js → prism-ruby.min-L9OdQ6tU.js} +2 -2
  638. package/lib/{prism-ruby.min-Dx9KO9ds.js.map → prism-ruby.min-L9OdQ6tU.js.map} +1 -1
  639. package/lib/{prism-typescript.min-CD7H2IYQ.js → prism-typescript.min-qTySPvCh.js} +2 -2
  640. package/lib/{prism-typescript.min-CD7H2IYQ.js.map → prism-typescript.min-qTySPvCh.js.map} +1 -1
  641. package/lib/processors/removeExtensions.js +11 -0
  642. package/lib/processors/removeExtensions.js.map +1 -0
  643. package/lib/{post-processors → processors}/removeParameters.js +1 -1
  644. package/lib/processors/removeParameters.js.map +1 -0
  645. package/lib/{post-processors → processors}/removePaths.js +1 -1
  646. package/lib/processors/removePaths.js.map +1 -0
  647. package/lib/processors/traverse.js +17 -0
  648. package/lib/processors/traverse.js.map +1 -0
  649. package/lib/ui/Accordion.js +1 -1
  650. package/lib/ui/ActionButton.js +11 -10
  651. package/lib/ui/ActionButton.js.map +1 -1
  652. package/lib/ui/Alert.js +2 -2
  653. package/lib/ui/AlertDialog.js +1 -1
  654. package/lib/ui/Badge.js +2 -2
  655. package/lib/ui/Breadcrumb.js +4 -4
  656. package/lib/ui/Button.js +13 -12
  657. package/lib/ui/Button.js.map +1 -1
  658. package/lib/ui/Callout.js +40 -21
  659. package/lib/ui/Callout.js.map +1 -1
  660. package/lib/ui/Card.js +1 -1
  661. package/lib/ui/Carousel.js +207 -207
  662. package/lib/ui/Carousel.js.map +1 -1
  663. package/lib/ui/Checkbox.js +16 -26
  664. package/lib/ui/Checkbox.js.map +1 -1
  665. package/lib/ui/Command.js +105 -78
  666. package/lib/ui/Command.js.map +1 -1
  667. package/lib/ui/Dialog.js +1 -1
  668. package/lib/ui/Drawer.js +14 -1151
  669. package/lib/ui/Drawer.js.map +1 -1
  670. package/lib/ui/DropdownMenu.js +1 -1
  671. package/lib/ui/Form.js +5 -5
  672. package/lib/ui/HoverCard.js +1 -1
  673. package/lib/ui/Input.js +1 -1
  674. package/lib/ui/Label.js +2 -2
  675. package/lib/ui/Pagination.js +10 -10
  676. package/lib/ui/Popover.js +1 -1
  677. package/lib/ui/Progress.js +1 -1
  678. package/lib/ui/RadioGroup.js +1 -1
  679. package/lib/ui/ScrollArea.js +1 -1
  680. package/lib/ui/Select.js +2 -2
  681. package/lib/ui/Select.js.map +1 -1
  682. package/lib/ui/Skeleton.js +1 -1
  683. package/lib/ui/Slider.js +1 -1
  684. package/lib/ui/Stepper.js +6 -0
  685. package/lib/ui/Stepper.js.map +1 -0
  686. package/lib/ui/Switch.js +1 -1
  687. package/lib/ui/SyntaxHighlight.js +11 -0
  688. package/lib/ui/SyntaxHighlight.js.map +1 -0
  689. package/lib/ui/Tabs.js +1 -1
  690. package/lib/ui/Textarea.js +1 -1
  691. package/lib/ui/Toggle.js +2 -2
  692. package/lib/ui/ToggleGroup.js +1 -1
  693. package/lib/ui/Tooltip.js +1 -1
  694. package/lib/ui/util.js +6 -0
  695. package/lib/ui/util.js.map +1 -0
  696. package/lib/{useExposedProps-Bbf99zic.js → useExposedProps-DmTJxEXG.js} +2 -2
  697. package/lib/{useExposedProps-Bbf99zic.js.map → useExposedProps-DmTJxEXG.js.map} +1 -1
  698. package/lib/useLatest-hmRS46UF.js +11 -0
  699. package/lib/useLatest-hmRS46UF.js.map +1 -0
  700. package/lib/zudoku.auth-auth0.js +18 -17
  701. package/lib/zudoku.auth-auth0.js.map +1 -1
  702. package/lib/zudoku.auth-clerk.js +69 -51
  703. package/lib/zudoku.auth-clerk.js.map +1 -1
  704. package/lib/zudoku.auth-openid.js +388 -415
  705. package/lib/zudoku.auth-openid.js.map +1 -1
  706. package/lib/zudoku.components.js +33 -1303
  707. package/lib/zudoku.components.js.map +1 -1
  708. package/lib/zudoku.hooks.js +19 -0
  709. package/lib/zudoku.hooks.js.map +1 -0
  710. package/lib/zudoku.icons.js +10 -0
  711. package/lib/zudoku.icons.js.map +1 -1
  712. package/lib/zudoku.plugin-api-catalog.js +106 -112
  713. package/lib/zudoku.plugin-api-catalog.js.map +1 -1
  714. package/lib/zudoku.plugin-api-keys.js +108 -106
  715. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  716. package/lib/zudoku.plugin-custom-pages.js +3 -3
  717. package/lib/zudoku.plugin-markdown.js +23 -44
  718. package/lib/zudoku.plugin-markdown.js.map +1 -1
  719. package/lib/zudoku.plugin-openapi.js +7 -7
  720. package/lib/zudoku.plugin-openapi.js.map +1 -1
  721. package/lib/zudoku.plugin-redirect.js +1 -1
  722. package/lib/zudoku.plugin-search-inkeep.js +9 -9
  723. package/lib/zudoku.plugin-search-pagefind.js +233 -0
  724. package/lib/zudoku.plugin-search-pagefind.js.map +1 -0
  725. package/lib/zudoku.plugins.js +14 -0
  726. package/lib/zudoku.plugins.js.map +1 -0
  727. package/package.json +103 -76
  728. package/src/app/ZuploBuildConfig.ts +33 -0
  729. package/src/app/demo.html +1 -1
  730. package/src/app/entry.client.tsx +51 -0
  731. package/src/app/entry.server.tsx +23 -13
  732. package/src/app/env.ts +35 -0
  733. package/src/app/main.css +108 -59
  734. package/src/app/main.tsx +19 -2
  735. package/src/app/tailwind.ts +20 -0
  736. package/src/lib/MissingIcon.tsx +22 -0
  737. package/src/lib/authentication/authentication.ts +2 -0
  738. package/src/lib/authentication/components/CallbackHandler.tsx +11 -1
  739. package/src/lib/authentication/components/SignIn.tsx +35 -2
  740. package/src/lib/authentication/components/SignUp.tsx +35 -1
  741. package/src/lib/authentication/hook.ts +12 -1
  742. package/src/lib/authentication/providers/auth0.tsx +4 -3
  743. package/src/lib/authentication/providers/clerk.tsx +38 -10
  744. package/src/lib/authentication/providers/openid.tsx +45 -36
  745. package/src/lib/authentication/providers/supabase.tsx +157 -0
  746. package/src/lib/authentication/state.ts +9 -37
  747. package/src/lib/components/AnchorLink.tsx +9 -7
  748. package/src/lib/components/Banner.tsx +2 -1
  749. package/src/lib/components/Bootstrap.tsx +13 -6
  750. package/src/lib/components/BuildCheck.tsx +75 -0
  751. package/src/lib/components/Footer.tsx +139 -0
  752. package/src/lib/components/Header.tsx +13 -9
  753. package/src/lib/components/Heading.tsx +3 -3
  754. package/src/lib/components/InlineCode.tsx +13 -16
  755. package/src/lib/components/Layout.tsx +27 -68
  756. package/src/lib/components/Main.tsx +51 -0
  757. package/src/lib/components/MobileTopNavigation.tsx +29 -20
  758. package/src/lib/components/Pagination.tsx +50 -0
  759. package/src/lib/components/Search.tsx +14 -3
  760. package/src/lib/components/ThemeSwitch.tsx +28 -8
  761. package/src/lib/components/TopNavigation.tsx +51 -24
  762. package/src/lib/components/Zudoku.tsx +18 -7
  763. package/src/lib/components/cache.ts +8 -0
  764. package/src/lib/components/context/BypassProtectedRoutesContext.ts +3 -0
  765. package/src/lib/components/context/RouterEventsEmitter.tsx +19 -0
  766. package/src/lib/components/context/ViewportAnchorContext.tsx +14 -30
  767. package/src/lib/components/context/ZudokuContext.ts +30 -10
  768. package/src/lib/components/index.ts +4 -0
  769. package/src/lib/components/navigation/PoweredByZudoku.tsx +33 -0
  770. package/src/lib/components/navigation/Sidebar.tsx +37 -44
  771. package/src/lib/components/navigation/SidebarBadge.tsx +4 -1
  772. package/src/lib/components/navigation/SidebarCategory.tsx +24 -17
  773. package/src/lib/components/navigation/SidebarItem.tsx +22 -30
  774. package/src/lib/components/navigation/SidebarWrapper.tsx +42 -23
  775. package/src/lib/{plugins/markdown → components/navigation}/Toc.tsx +9 -18
  776. package/src/lib/components/navigation/ZudokuLogo.tsx +25 -0
  777. package/src/lib/components/navigation/ZuploLogo.tsx +14 -0
  778. package/src/lib/core/RouteGuard.tsx +73 -12
  779. package/src/lib/core/ZudokuContext.ts +65 -13
  780. package/src/lib/core/plugins.ts +29 -7
  781. package/src/lib/errors/ErrorAlert.tsx +24 -17
  782. package/src/lib/hooks/index.ts +5 -0
  783. package/src/lib/hooks/useEvent.test.tsx +149 -0
  784. package/src/lib/hooks/useEvent.ts +41 -0
  785. package/src/lib/icons.ts +1 -0
  786. package/src/lib/oas/graphql/index.ts +206 -54
  787. package/src/lib/oas/parser/dereference/index.ts +2 -0
  788. package/src/lib/oas/parser/index.ts +14 -30
  789. package/src/lib/oas/parser/upgrade/index.ts +97 -26
  790. package/src/lib/plugins/api-catalog/Catalog.tsx +50 -100
  791. package/src/lib/plugins/api-catalog/index.tsx +66 -15
  792. package/src/lib/plugins/api-keys/CreateApiKey.tsx +7 -3
  793. package/src/lib/plugins/api-keys/index.tsx +3 -0
  794. package/src/lib/plugins/markdown/MdxPage.tsx +15 -47
  795. package/src/lib/plugins/markdown/resolver.ts +0 -33
  796. package/src/lib/plugins/openapi/CollapsibleCode.tsx +2 -2
  797. package/src/lib/plugins/openapi/ColorizedParam.tsx +1 -1
  798. package/src/lib/plugins/openapi/Endpoint.tsx +1 -1
  799. package/src/lib/plugins/openapi/OasProvider.tsx +51 -0
  800. package/src/lib/plugins/openapi/OperationList.tsx +185 -83
  801. package/src/lib/plugins/openapi/OperationListItem.tsx +127 -104
  802. package/src/lib/plugins/openapi/ParamInfos.tsx +88 -0
  803. package/src/lib/plugins/openapi/ParameterList.tsx +4 -0
  804. package/src/lib/plugins/openapi/ParameterListItem.tsx +65 -23
  805. package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +8 -1
  806. package/src/lib/plugins/openapi/SchemaList.tsx +151 -0
  807. package/src/lib/plugins/openapi/Sidecar.tsx +84 -15
  808. package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -2
  809. package/src/lib/plugins/openapi/SimpleSelect.tsx +1 -1
  810. package/src/lib/plugins/openapi/client/GraphQLClient.tsx +1 -1
  811. package/src/lib/plugins/openapi/client/useCreateQuery.ts +34 -7
  812. package/src/lib/plugins/openapi/components/ConstValue.tsx +24 -0
  813. package/src/lib/plugins/openapi/components/EnumValues.tsx +58 -0
  814. package/src/lib/plugins/openapi/components/SelectOnClick.tsx +29 -0
  815. package/src/lib/plugins/openapi/graphql/gql.ts +34 -17
  816. package/src/lib/plugins/openapi/graphql/graphql.ts +172 -86
  817. package/src/lib/plugins/openapi/index.tsx +83 -177
  818. package/src/lib/plugins/openapi/interfaces.ts +45 -15
  819. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +30 -32
  820. package/src/lib/plugins/openapi/playground/Headers.tsx +2 -3
  821. package/src/lib/plugins/openapi/playground/IdentityDialog.tsx +74 -0
  822. package/src/lib/plugins/openapi/playground/IdentitySelector.tsx +54 -0
  823. package/src/lib/plugins/openapi/playground/PathParams.tsx +8 -2
  824. package/src/lib/plugins/openapi/playground/Playground.tsx +203 -114
  825. package/src/lib/plugins/openapi/playground/QueryParams.tsx +4 -5
  826. package/src/lib/plugins/openapi/playground/RequestLoginDialog.tsx +51 -0
  827. package/src/lib/plugins/openapi/playground/SubmitButton.tsx +2 -2
  828. package/src/lib/plugins/openapi/playground/rememberedIdentity.ts +26 -0
  829. package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +3 -3
  830. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +26 -6
  831. package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +67 -45
  832. package/src/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.ts +29 -9
  833. package/src/lib/plugins/openapi/{post-processors → processors}/removeExtensions.ts +5 -3
  834. package/src/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.ts +67 -33
  835. package/src/lib/plugins/openapi/{post-processors → processors}/removeParameters.ts +5 -3
  836. package/src/lib/plugins/openapi/processors/removePaths.test.ts +167 -0
  837. package/src/lib/plugins/openapi/{post-processors → processors}/removePaths.ts +5 -3
  838. package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.tsx +1 -8
  839. package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.tsx +3 -0
  840. package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.tsx +6 -3
  841. package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +39 -0
  842. package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +55 -52
  843. package/src/lib/plugins/openapi/schema/SchemaView.tsx +94 -137
  844. package/src/lib/plugins/openapi/schema/utils.ts +12 -1
  845. package/src/lib/plugins/openapi/state.ts +36 -0
  846. package/src/lib/plugins/openapi/util/createSidebarCategory.tsx +37 -0
  847. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +45 -0
  848. package/src/lib/plugins/openapi/util/getRoutes.tsx +198 -0
  849. package/src/lib/plugins/openapi/util/methodColorMap.tsx +11 -0
  850. package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +164 -0
  851. package/src/lib/plugins/search-pagefind/ResultList.tsx +105 -0
  852. package/src/lib/plugins/search-pagefind/get-results.tsx +75 -0
  853. package/src/lib/plugins/search-pagefind/index.tsx +21 -0
  854. package/src/lib/plugins/search-pagefind/types.ts +118 -0
  855. package/src/lib/ui/Button.tsx +4 -2
  856. package/src/lib/ui/Callout.tsx +29 -10
  857. package/src/lib/ui/Checkbox.tsx +8 -24
  858. package/src/lib/ui/Command.tsx +25 -3
  859. package/src/lib/ui/Select.tsx +1 -1
  860. package/src/lib/ui/Stepper.tsx +8 -0
  861. package/src/lib/ui/SyntaxHighlight.tsx +186 -0
  862. package/src/lib/ui/util.tsx +3 -0
  863. package/src/lib/util/MdxComponents.tsx +9 -4
  864. package/src/lib/util/detectOS.ts +9 -0
  865. package/src/lib/util/ensureArray.ts +3 -0
  866. package/src/lib/util/joinPath.tsx +3 -0
  867. package/src/lib/util/traverse.ts +12 -13
  868. package/src/lib/util/types.ts +7 -0
  869. package/src/lib/util/url.test.ts +51 -0
  870. package/src/lib/util/url.ts +18 -0
  871. package/src/lib/util/useLatest.ts +18 -0
  872. package/src/lib/util/useOnScreen.ts +6 -4
  873. package/src/lib/util/useScrollToAnchor.ts +30 -20
  874. package/client.d.ts +0 -8
  875. package/dist/lib/components/SyntaxHighlight.d.ts +0 -12
  876. package/dist/lib/components/SyntaxHighlight.js +0 -53
  877. package/dist/lib/components/SyntaxHighlight.js.map +0 -1
  878. package/dist/lib/components/context/PluginSystem.js +0 -2
  879. package/dist/lib/components/context/PluginSystem.js.map +0 -1
  880. package/dist/lib/plugins/markdown/Toc.js.map +0 -1
  881. package/dist/lib/plugins/openapi/OpenApiRoute.js +0 -25
  882. package/dist/lib/plugins/openapi/OpenApiRoute.js.map +0 -1
  883. package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +0 -7
  884. package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +0 -1
  885. package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +0 -1
  886. package/dist/lib/plugins/openapi/post-processors/removeParameters.js.map +0 -1
  887. package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js.map +0 -1
  888. package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +0 -1
  889. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +0 -104
  890. package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +0 -1
  891. package/dist/lib/plugins/openapi/post-processors/traverse.js.map +0 -1
  892. package/dist/vite/prerender.d.ts +0 -22
  893. package/dist/vite/prerender.js +0 -89
  894. package/dist/vite/prerender.js.map +0 -1
  895. package/dist/zuplo/env.d.ts +0 -7
  896. package/dist/zuplo/env.js +0 -12
  897. package/dist/zuplo/env.js.map +0 -1
  898. package/lib/AuthenticationPlugin-DeEA69mE.js +0 -58
  899. package/lib/AuthenticationPlugin-DeEA69mE.js.map +0 -1
  900. package/lib/Markdown-8mv9nhGd.js.map +0 -1
  901. package/lib/MdxPage-BalfwlsD.js +0 -193
  902. package/lib/MdxPage-BalfwlsD.js.map +0 -1
  903. package/lib/OpenApiRoute-ULLXjfro.js +0 -36
  904. package/lib/OpenApiRoute-ULLXjfro.js.map +0 -1
  905. package/lib/OperationList-B3VX94x4.js +0 -5179
  906. package/lib/OperationList-B3VX94x4.js.map +0 -1
  907. package/lib/SlotletProvider-D0mFmGJu.js +0 -221
  908. package/lib/SlotletProvider-D0mFmGJu.js.map +0 -1
  909. package/lib/Spinner-BlzrEEk1.js +0 -51
  910. package/lib/Spinner-BlzrEEk1.js.map +0 -1
  911. package/lib/SyntaxHighlight-B0L4SC_N.js.map +0 -1
  912. package/lib/ZudokuContext-dUyBGMap.js +0 -1229
  913. package/lib/ZudokuContext-dUyBGMap.js.map +0 -1
  914. package/lib/__vite-browser-external-BYRIRx8p.js +0 -9
  915. package/lib/__vite-browser-external-BYRIRx8p.js.map +0 -1
  916. package/lib/_commonjsHelpers-BkfeUUK-.js.map +0 -1
  917. package/lib/chunk-SYFQ2XB5-QijJrSf0.js.map +0 -1
  918. package/lib/circular-DxaIIlWD.js.map +0 -1
  919. package/lib/context-rwLGh-6_.js +0 -22
  920. package/lib/context-rwLGh-6_.js.map +0 -1
  921. package/lib/createServer-E3cXjB0P.js.map +0 -1
  922. package/lib/hook-NIpDSpau.js +0 -227
  923. package/lib/hook-NIpDSpau.js.map +0 -1
  924. package/lib/index-B7mqiOei.js +0 -509
  925. package/lib/index-B7mqiOei.js.map +0 -1
  926. package/lib/index-Djenk2Hj.js +0 -36
  927. package/lib/index-Dl3Yl0yb.js.map +0 -1
  928. package/lib/index-P0YUtHIb.js +0 -2065
  929. package/lib/index-P0YUtHIb.js.map +0 -1
  930. package/lib/index.esm-9-TF9KQB.js.map +0 -1
  931. package/lib/index.esm-CrSoEshU.js +0 -1207
  932. package/lib/index.esm-CrSoEshU.js.map +0 -1
  933. package/lib/joinUrl-nLx9pD-Z.js +0 -20
  934. package/lib/joinUrl-nLx9pD-Z.js.map +0 -1
  935. package/lib/jsx-runtime-Bdg6XQ1m.js +0 -446
  936. package/lib/jsx-runtime-Bdg6XQ1m.js.map +0 -1
  937. package/lib/post-processors/removeExtensions.js +0 -11
  938. package/lib/post-processors/removeExtensions.js.map +0 -1
  939. package/lib/post-processors/removeParameters.js.map +0 -1
  940. package/lib/post-processors/removePaths.js.map +0 -1
  941. package/lib/post-processors/traverse.js +0 -15
  942. package/lib/post-processors/traverse.js.map +0 -1
  943. package/lib/state-bfQxaDxU.js +0 -211
  944. package/lib/state-bfQxaDxU.js.map +0 -1
  945. package/lib/useScrollToAnchor-BVCQSeKB.js +0 -286
  946. package/lib/useScrollToAnchor-BVCQSeKB.js.map +0 -1
  947. package/src/lib/components/SyntaxHighlight.tsx +0 -171
  948. package/src/lib/components/context/PluginSystem.ts +0 -0
  949. package/src/lib/plugins/openapi/OpenApiRoute.tsx +0 -51
  950. package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +0 -126
  951. /package/dist/lib/{plugins/markdown → components/navigation}/Toc.d.ts +0 -0
  952. /package/dist/lib/{components/context/PluginSystem.d.ts → hooks/useEvent.test.d.ts} +0 -0
  953. /package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.d.ts +0 -0
  954. /package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.d.ts +0 -0
  955. /package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.test.d.ts +0 -0
  956. /package/dist/lib/plugins/openapi/{post-processors → processors}/traverse.d.ts +0 -0
  957. /package/dist/lib/plugins/openapi/{post-processors → processors}/traverse.js +0 -0
  958. /package/src/lib/plugins/openapi/{post-processors → processors}/traverse.ts +0 -0
@@ -1,18 +1,19 @@
1
1
  import logger from "loglevel";
2
2
  import * as oauth from "oauth4webapi";
3
- import { OpenIDAuthenticationConfig } from "../../../config/config.js";
3
+ import { type OpenIDAuthenticationConfig } from "../../../config/config.js";
4
4
  import { ClientOnly } from "../../components/ClientOnly.js";
5
5
  import { joinUrl } from "../../util/joinUrl.js";
6
6
  import {
7
- AuthenticationProvider,
8
- AuthenticationProviderInitializer,
7
+ type AuthenticationProvider,
8
+ type AuthenticationProviderInitializer,
9
9
  } from "../authentication.js";
10
10
  import { AuthenticationPlugin } from "../AuthenticationPlugin.js";
11
11
  import { CallbackHandler } from "../components/CallbackHandler.js";
12
12
  import { AuthorizationError, OAuthAuthorizationError } from "../errors.js";
13
- import { useAuthState, UserProfile } from "../state.js";
13
+ import { useAuthState, type UserProfile } from "../state.js";
14
14
 
15
15
  const CODE_VERIFIER_KEY = "code-verifier";
16
+ const STATE_KEY = "oauth-state";
16
17
 
17
18
  export interface OpenIdProviderData {
18
19
  accessToken: string;
@@ -22,18 +23,17 @@ export interface OpenIdProviderData {
22
23
  tokenType: string;
23
24
  }
24
25
 
26
+ export const OPENID_CALLBACK_PATH = "/oauth/callback";
27
+
25
28
  class OpenIdAuthPlugin extends AuthenticationPlugin {
26
- constructor(
27
- private callbackUrlPath: string,
28
- private handleCallback: () => Promise<string>,
29
- ) {
29
+ constructor(private handleCallback: () => Promise<string>) {
30
30
  super();
31
31
  }
32
32
  getRoutes() {
33
33
  return [
34
34
  ...super.getRoutes(),
35
35
  {
36
- path: this.callbackUrlPath,
36
+ path: OPENID_CALLBACK_PATH,
37
37
  element: (
38
38
  <ClientOnly>
39
39
  <CallbackHandler handleCallback={this.handleCallback} />
@@ -47,19 +47,20 @@ class OpenIdAuthPlugin extends AuthenticationPlugin {
47
47
  export class OpenIDAuthenticationProvider implements AuthenticationProvider {
48
48
  protected client: oauth.Client;
49
49
  protected issuer: string;
50
-
51
50
  protected authorizationServer: oauth.AuthorizationServer | undefined;
52
51
 
53
52
  protected callbackUrlPath: string;
54
- protected logoutRedirectUrlPath: string;
53
+
55
54
  protected onAuthorizationUrl?: (
56
55
  authorizationUrl: URL,
57
56
  options: { isSignIn: boolean; isSignUp: boolean },
58
57
  ) => void;
59
- private readonly redirectToAfterSignUp: string;
60
- private readonly redirectToAfterSignIn: string;
61
- private readonly redirectToAfterSignOut: string;
58
+
59
+ protected readonly redirectToAfterSignUp: string | undefined;
60
+ protected readonly redirectToAfterSignIn: string | undefined;
61
+ protected readonly redirectToAfterSignOut: string;
62
62
  private readonly audience?: string;
63
+ private readonly scopes: string[];
63
64
 
64
65
  constructor({
65
66
  issuer,
@@ -67,8 +68,9 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
67
68
  clientId,
68
69
  redirectToAfterSignUp,
69
70
  redirectToAfterSignIn,
70
- redirectToAfterSignOut,
71
+ redirectToAfterSignOut = "/",
71
72
  basePath,
73
+ scopes,
72
74
  }: OpenIDAuthenticationConfig) {
73
75
  this.client = {
74
76
  client_id: clientId,
@@ -76,14 +78,13 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
76
78
  };
77
79
  this.audience = audience;
78
80
  this.issuer = issuer;
79
- this.callbackUrlPath = joinUrl(basePath, "/oauth/callback");
80
-
81
- const root = joinUrl(basePath, "/");
81
+ // This is the callback URL for the OAuth provider. So it needs the base path.
82
+ this.callbackUrlPath = joinUrl(basePath, OPENID_CALLBACK_PATH);
83
+ this.scopes = scopes ?? ["openid", "profile", "email"];
82
84
 
83
- this.logoutRedirectUrlPath = root;
84
- this.redirectToAfterSignUp = redirectToAfterSignUp ?? root;
85
- this.redirectToAfterSignIn = redirectToAfterSignIn ?? root;
86
- this.redirectToAfterSignOut = redirectToAfterSignOut ?? root;
85
+ this.redirectToAfterSignUp = redirectToAfterSignUp;
86
+ this.redirectToAfterSignIn = redirectToAfterSignIn;
87
+ this.redirectToAfterSignOut = redirectToAfterSignOut;
87
88
  }
88
89
 
89
90
  protected async getAuthServer() {
@@ -129,14 +130,14 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
129
130
 
130
131
  async signUp({ redirectTo }: { redirectTo?: string } = {}) {
131
132
  return this.authorize({
132
- redirectTo: redirectTo ?? this.redirectToAfterSignUp,
133
+ redirectTo: this.redirectToAfterSignUp ?? redirectTo ?? "/",
133
134
  isSignUp: true,
134
135
  });
135
136
  }
136
137
 
137
138
  async signIn({ redirectTo }: { redirectTo?: string } = {}) {
138
139
  return this.authorize({
139
- redirectTo: redirectTo ?? this.redirectToAfterSignIn,
140
+ redirectTo: this.redirectToAfterSignIn ?? redirectTo ?? "/",
140
141
  });
141
142
  }
142
143
 
@@ -178,7 +179,7 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
178
179
  authorizationUrl.searchParams.set("client_id", this.client.client_id);
179
180
  authorizationUrl.searchParams.set("redirect_uri", redirectUrl.toString());
180
181
  authorizationUrl.searchParams.set("response_type", "code");
181
- authorizationUrl.searchParams.set("scope", "openid profile email");
182
+ authorizationUrl.searchParams.set("scope", this.scopes.join(" "));
182
183
  authorizationUrl.searchParams.set("code_challenge", codeChallenge);
183
184
  authorizationUrl.searchParams.set(
184
185
  "code_challenge_method",
@@ -194,16 +195,12 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
194
195
  });
195
196
 
196
197
  /**
197
- * We cannot be sure the AS supports PKCE so we're going to use state too. Use of PKCE is
198
- * backwards compatible even if the AS doesn't support it which is why we're using it regardless.
198
+ * The state parameter is used to prevent CSRF attacks and should be used in all authorization requests.
199
+ * It is independent of PKCE and should be used regardless of PKCE support.
199
200
  */
200
- if (
201
- authorizationServer.code_challenge_methods_supported?.includes("S256") !==
202
- true
203
- ) {
204
- const state = oauth.generateRandomState();
205
- authorizationUrl.searchParams.set("state", state);
206
- }
201
+ const state = oauth.generateRandomState();
202
+ sessionStorage.setItem(STATE_KEY, state);
203
+ authorizationUrl.searchParams.set("state", state);
207
204
 
208
205
  // now redirect the user to authorizationUrl.href
209
206
  location.href = authorizationUrl.href;
@@ -251,6 +248,12 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
251
248
  }
252
249
  }
253
250
 
251
+ signRequest = async (request: Request): Promise<Request> => {
252
+ const accessToken = await this.getAccessToken();
253
+ request.headers.set("Authorization", `Bearer ${accessToken}`);
254
+ return request;
255
+ };
256
+
254
257
  signOut = async () => {
255
258
  useAuthState.setState({
256
259
  isAuthenticated: false,
@@ -264,7 +267,7 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
264
267
  const redirectUrl = new URL(
265
268
  window.location.origin + this.redirectToAfterSignOut,
266
269
  );
267
- redirectUrl.pathname = this.logoutRedirectUrlPath;
270
+ redirectUrl.pathname = this.callbackUrlPath;
268
271
 
269
272
  let logoutUrl: URL;
270
273
  // The endSessionEndpoint is set, the IdP supports some form of logout,
@@ -288,6 +291,12 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
288
291
  handleCallback = async () => {
289
292
  const url = new URL(window.location.href);
290
293
  const state = url.searchParams.get("state");
294
+ const storedState = sessionStorage.getItem(STATE_KEY);
295
+ sessionStorage.removeItem(STATE_KEY);
296
+
297
+ if (state !== storedState) {
298
+ throw new AuthorizationError("Invalid state parameter");
299
+ }
291
300
 
292
301
  // one eternity later, the user lands back on the redirect_uri
293
302
  // Authorization Code Grant Request & Response
@@ -372,7 +381,7 @@ export class OpenIDAuthenticationProvider implements AuthenticationProvider {
372
381
  getAuthenticationPlugin() {
373
382
  // TODO: This API is a bit messy, we need to refactor auth plugins/providers
374
383
  // to remove the extra layers of abstraction.
375
- return new OpenIdAuthPlugin(this.callbackUrlPath, this.handleCallback);
384
+ return new OpenIdAuthPlugin(this.handleCallback);
376
385
  }
377
386
  }
378
387
 
@@ -0,0 +1,157 @@
1
+ import {
2
+ createClient,
3
+ type Provider,
4
+ type Session,
5
+ type SupabaseClient,
6
+ } from "@supabase/supabase-js";
7
+ import { type SupabaseAuthenticationConfig } from "../../../config/config.js";
8
+ import {
9
+ type AuthenticationProvider,
10
+ type AuthenticationProviderInitializer,
11
+ } from "../authentication.js";
12
+ import { AuthenticationPlugin } from "../AuthenticationPlugin.js";
13
+ import { AuthorizationError } from "../errors.js";
14
+ import { useAuthState, type UserProfile } from "../state.js";
15
+
16
+ class SupabaseAuthPlugin extends AuthenticationPlugin {}
17
+
18
+ class SupabaseAuthenticationProvider implements AuthenticationProvider {
19
+ private readonly client: SupabaseClient;
20
+ private readonly provider: Provider;
21
+ private readonly redirectToAfterSignUp: string;
22
+ private readonly redirectToAfterSignIn: string;
23
+ private readonly redirectToAfterSignOut: string;
24
+
25
+ constructor({
26
+ supabaseUrl,
27
+ supabaseKey,
28
+ provider,
29
+ redirectToAfterSignUp,
30
+ redirectToAfterSignIn,
31
+ redirectToAfterSignOut,
32
+ basePath,
33
+ }: SupabaseAuthenticationConfig) {
34
+ this.provider = provider;
35
+ this.client = createClient(supabaseUrl, supabaseKey, {
36
+ auth: {
37
+ autoRefreshToken: true,
38
+ persistSession: true,
39
+ },
40
+ });
41
+
42
+ const root = basePath ?? "/";
43
+
44
+ this.redirectToAfterSignUp = redirectToAfterSignUp ?? root;
45
+ this.redirectToAfterSignIn = redirectToAfterSignIn ?? root;
46
+ this.redirectToAfterSignOut = redirectToAfterSignOut ?? root;
47
+
48
+ this.client.auth.onAuthStateChange(async (event, session) => {
49
+ if (session && (event === "SIGNED_IN" || event === "TOKEN_REFRESHED")) {
50
+ await this.updateUserState(session);
51
+ } else if (event === "SIGNED_OUT") {
52
+ useAuthState.setState({
53
+ isAuthenticated: false,
54
+ isPending: false,
55
+ profile: undefined,
56
+ providerData: undefined,
57
+ });
58
+ }
59
+ });
60
+ }
61
+
62
+ private async updateUserState(session: Session) {
63
+ const { user } = session;
64
+
65
+ const profile: UserProfile = {
66
+ sub: user.id,
67
+ email: user.email,
68
+ name: user.user_metadata.full_name || user.user_metadata.name,
69
+ emailVerified: user.email_confirmed_at != null,
70
+ pictureUrl: user.user_metadata.avatar_url,
71
+ };
72
+
73
+ useAuthState.setState({
74
+ isAuthenticated: true,
75
+ isPending: false,
76
+ profile,
77
+ providerData: { session },
78
+ });
79
+ }
80
+
81
+ async getAccessToken(): Promise<string> {
82
+ const { data, error } = await this.client.auth.getSession();
83
+
84
+ if (error || !data.session) {
85
+ throw new AuthorizationError("User is not authenticated");
86
+ }
87
+
88
+ return data.session.access_token;
89
+ }
90
+
91
+ async signRequest(request: Request): Promise<Request> {
92
+ const accessToken = await this.getAccessToken();
93
+ request.headers.set("Authorization", `Bearer ${accessToken}`);
94
+ return request;
95
+ }
96
+
97
+ signUp = async ({ redirectTo }: { redirectTo?: string }) => {
98
+ const finalRedirectTo = redirectTo ?? this.redirectToAfterSignUp;
99
+
100
+ // Open Supabase Auth UI in a new window
101
+ await this.client.auth.signInWithOAuth({
102
+ provider: this.provider,
103
+ options: {
104
+ redirectTo: window.location.origin + finalRedirectTo,
105
+ },
106
+ });
107
+ };
108
+
109
+ signIn = async ({ redirectTo }: { redirectTo?: string }) => {
110
+ const finalRedirectTo = redirectTo ?? this.redirectToAfterSignIn;
111
+
112
+ await this.client.auth.signInWithOAuth({
113
+ provider: this.provider,
114
+ options: {
115
+ redirectTo: window.location.origin + finalRedirectTo,
116
+ queryParams: {
117
+ access_type: "offline",
118
+ prompt: "consent",
119
+ },
120
+ },
121
+ });
122
+ };
123
+
124
+ signOut = async () => {
125
+ await new Promise<void>((resolve) => {
126
+ const { data } = this.client.auth.onAuthStateChange(async (event) => {
127
+ if (event !== "SIGNED_OUT") return;
128
+ data.subscription.unsubscribe();
129
+ resolve();
130
+ });
131
+ void this.client.auth.signOut();
132
+ });
133
+
134
+ useAuthState.setState({
135
+ isAuthenticated: false,
136
+ isPending: false,
137
+ profile: undefined,
138
+ providerData: undefined,
139
+ });
140
+ };
141
+
142
+ getAuthenticationPlugin = () => new SupabaseAuthPlugin();
143
+
144
+ onPageLoad = async () => {
145
+ const { data, error } = await this.client.auth.getSession();
146
+
147
+ if (!error && data.session) {
148
+ await this.updateUserState(data.session);
149
+ }
150
+ };
151
+ }
152
+
153
+ const supabaseAuth: AuthenticationProviderInitializer<
154
+ SupabaseAuthenticationConfig
155
+ > = (options) => new SupabaseAuthenticationProvider(options);
156
+
157
+ export default supabaseAuth;
@@ -1,4 +1,3 @@
1
- import { useMemo } from "react";
2
1
  import { create, type Mutate, type StoreApi } from "zustand";
3
2
  import { createJSONStorage, persist } from "zustand/middleware";
4
3
 
@@ -20,7 +19,7 @@ export type StoreWithPersist<T> = Mutate<
20
19
  [["zustand/persist", unknown]]
21
20
  >;
22
21
 
23
- export const withStorageDOMEvents = <T>(store: StoreWithPersist<T>) => {
22
+ const withStorageDOMEvents = <T>(store: StoreWithPersist<T>) => {
24
23
  const storageEventCallback = (e: StorageEvent) => {
25
24
  if (e.key === store.persist.getOptions().name && e.newValue) {
26
25
  void store.persist.rehydrate();
@@ -38,14 +37,20 @@ export const useAuthState = create<AuthState>()(
38
37
  persist(
39
38
  (state) => ({
40
39
  isAuthenticated: false,
41
- isPending: false,
40
+ isPending: true,
42
41
  profile: null,
43
42
  providerData: null,
44
43
  }),
45
44
  {
45
+ merge: (persistedState, currentState) => {
46
+ return {
47
+ ...currentState,
48
+ isPending: false,
49
+ ...(typeof persistedState === "object" ? persistedState : {}),
50
+ };
51
+ },
46
52
  name: "auth-state",
47
53
  storage: createJSONStorage(() => localStorage),
48
- // partialize: (s) => ({ state: s }),
49
54
  },
50
55
  ),
51
56
  );
@@ -62,36 +67,3 @@ export interface UserProfile {
62
67
  pictureUrl: string | undefined;
63
68
  [key: string]: string | boolean | undefined;
64
69
  }
65
-
66
- interface SelectedServerState {
67
- selectedServer?: string;
68
- setSelectedServer: (newServer: string) => void;
69
- }
70
-
71
- export const useSelectedServerStore = create<SelectedServerState>()(
72
- persist(
73
- (set) => ({
74
- selectedServer: undefined,
75
- setSelectedServer: (newServer: string) =>
76
- set({ selectedServer: newServer }),
77
- }),
78
- { name: "zudoku-selected-server" },
79
- ),
80
- );
81
-
82
- /**
83
- * Simple wrapper for `useSelectedServerStore` to fall back to first of the provided servers
84
- */
85
- export const useSelectedServer = (servers: Array<{ url: string }>) => {
86
- const { selectedServer, setSelectedServer } = useSelectedServerStore();
87
-
88
- const finalSelectedServer = useMemo(
89
- () =>
90
- selectedServer && servers.some((s) => s.url === selectedServer)
91
- ? selectedServer
92
- : (servers.at(0)?.url ?? ""),
93
- [selectedServer, servers],
94
- );
95
-
96
- return { selectedServer: finalSelectedServer, setSelectedServer };
97
- };
@@ -1,22 +1,24 @@
1
- import React from "react";
2
- import { Link, type LinkProps, useLocation } from "react-router";
1
+ import { type MouseEvent } from "react";
2
+ import { NavLink, type NavLinkProps, useHref, useLocation } from "react-router";
3
3
  import { useScrollToHash } from "../util/useScrollToAnchor.js";
4
4
 
5
5
  /**
6
6
  * Link that scrolls to anchor even if the hash is already set in the URL.
7
7
  */
8
- export const AnchorLink = (props: LinkProps) => {
8
+ export const AnchorLink = (props: NavLinkProps) => {
9
9
  const location = useLocation();
10
10
  const scrollToHash = useScrollToHash();
11
- const hash = typeof props.to === "string" ? props.to : props.to.hash;
11
+ const href = useHref(props.to);
12
+ const [pathname, hash] = href.split("#");
12
13
 
13
- const handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {
14
+ const handleClick = (event: MouseEvent<HTMLAnchorElement>) => {
14
15
  props.onClick?.(event);
15
- if (!hash?.startsWith("#") || hash !== location.hash) return;
16
+ if (hash !== location.hash.slice(1) || pathname !== location.pathname)
17
+ return;
16
18
 
17
19
  event.preventDefault();
18
20
  scrollToHash(hash);
19
21
  };
20
22
 
21
- return <Link {...props} onClick={handleClick} />;
23
+ return <NavLink {...props} onClick={handleClick} />;
22
24
  };
@@ -34,13 +34,14 @@ export const Banner = () => {
34
34
  "relative text-primary-foreground text-sm font-medium px-4 py-2 flex gap-2 items-center",
35
35
  mappedColor,
36
36
  )}
37
+ data-pagefind-ignore="all"
37
38
  style={style}
38
39
  >
39
40
  <div className="w-full">{page.banner.message}</div>
40
41
  {page.banner.dismissible && (
41
42
  <button
42
43
  type="button"
43
- className="md:absolute md:right-4 -m-1.5 p-1.5 hover:bg-accent-foreground/10 rounded-md"
44
+ className="md:absolute md:end-4 -m-1.5 p-1.5 hover:bg-accent-foreground/10 rounded-md"
44
45
  onClick={() => setIsBannerOpen(false)}
45
46
  >
46
47
  <CircleXIcon size={16} />
@@ -13,6 +13,7 @@ import {
13
13
  } from "react-router";
14
14
  import { RouterProvider } from "react-router/dom";
15
15
  import { StaggeredRenderContext } from "../plugins/openapi/StaggeredRender.js";
16
+ import { BypassProtectedRoutesContext } from "./context/BypassProtectedRoutesContext.js";
16
17
 
17
18
  const queryClient = new QueryClient({
18
19
  defaultOptions: {
@@ -32,11 +33,13 @@ const Bootstrap = ({
32
33
  <StrictMode>
33
34
  <QueryClientProvider client={queryClient}>
34
35
  <HydrationBoundary state={hydrate ? (window as any).DATA : undefined}>
35
- <HelmetProvider>
36
- <StaggeredRenderContext.Provider value={{ stagger: !hydrate }}>
37
- <RouterProvider router={router} />
38
- </StaggeredRenderContext.Provider>
39
- </HelmetProvider>
36
+ <BypassProtectedRoutesContext value={false}>
37
+ <HelmetProvider>
38
+ <StaggeredRenderContext.Provider value={{ stagger: !hydrate }}>
39
+ <RouterProvider router={router} />
40
+ </StaggeredRenderContext.Provider>
41
+ </HelmetProvider>
42
+ </BypassProtectedRoutesContext>
40
43
  </HydrationBoundary>
41
44
  </QueryClientProvider>
42
45
  </StrictMode>
@@ -47,16 +50,20 @@ const BootstrapStatic = ({
47
50
  context,
48
51
  queryClient,
49
52
  helmetContext,
53
+ bypassProtection = false,
50
54
  }: {
51
55
  helmetContext: HelmetData["context"];
52
56
  context: StaticHandlerContext;
53
57
  queryClient: QueryClient;
54
58
  router: ReturnType<typeof createStaticRouter>;
59
+ bypassProtection?: boolean;
55
60
  }) => (
56
61
  <StrictMode>
57
62
  <QueryClientProvider client={queryClient}>
58
63
  <HelmetProvider context={helmetContext}>
59
- <StaticRouterProvider router={router} context={context} />
64
+ <BypassProtectedRoutesContext value={bypassProtection}>
65
+ <StaticRouterProvider router={router} context={context} />
66
+ </BypassProtectedRoutesContext>
60
67
  </HelmetProvider>
61
68
  </QueryClientProvider>
62
69
  </StrictMode>
@@ -0,0 +1,75 @@
1
+ import { useQuery } from "@tanstack/react-query";
2
+ import { CircleFadingArrowUpIcon, LoaderCircleIcon } from "lucide-react";
3
+ import { z } from "zod";
4
+ import { Button } from "../ui/Button.js";
5
+
6
+ const BuildStatusSchema = z.object({
7
+ buildId: z.string(),
8
+ timestamp: z.string(),
9
+ status: z.enum(["in-progress", "success", "failed"]),
10
+ });
11
+
12
+ export const BuildCheck = ({
13
+ buildId,
14
+ endpoint = "/__zuplo/docs",
15
+ }: {
16
+ buildId?: string;
17
+ endpoint?: string;
18
+ }) => {
19
+ const buildStatusQuery = useQuery({
20
+ queryKey: ["zuplo-build-check", buildId, endpoint],
21
+ refetchInterval: 3000,
22
+ enabled:
23
+ typeof buildId !== "undefined" &&
24
+ import.meta.env.ZUPLO_ENVIRONMENT_TYPE === "WORKING_COPY",
25
+ retry: false,
26
+ queryFn: () =>
27
+ fetch(endpoint, { signal: AbortSignal.timeout(2000) })
28
+ .then((res) => {
29
+ if (!res.ok) throw new Error("Failed to fetch build status");
30
+ return res.json();
31
+ })
32
+ .then((data) => BuildStatusSchema.parse(data)),
33
+ });
34
+
35
+ if (
36
+ buildStatusQuery.isError ||
37
+ !buildStatusQuery.data ||
38
+ buildStatusQuery.data.buildId === buildId
39
+ ) {
40
+ return null;
41
+ }
42
+
43
+ const isCompleted = buildStatusQuery.data.status === "success";
44
+
45
+ return (
46
+ <div className="fixed flex flex-col gap-3 p-4 rounded-xl w-96 border z-20 bg-background left-0 right-0 top-4 mx-auto shadow-lg">
47
+ {isCompleted ? (
48
+ <div className="flex flex-row items-center gap-2">
49
+ <CircleFadingArrowUpIcon size={16} />
50
+ <span className="text-sm">New version available</span>
51
+ </div>
52
+ ) : (
53
+ <div className="flex flex-row items-center gap-2">
54
+ <LoaderCircleIcon size={16} className="animate-spin" />
55
+ <span className="text-sm">Building new version...</span>
56
+ </div>
57
+ )}
58
+ <span className="text-xs">
59
+ {!isCompleted
60
+ ? "A new version of the developer portal will be available soon."
61
+ : "To see the new version, reload the page now."}
62
+ </span>
63
+ <Button
64
+ variant="outline"
65
+ size="sm"
66
+ className="w-full"
67
+ onClick={() => {
68
+ window.location.reload();
69
+ }}
70
+ >
71
+ Reload
72
+ </Button>
73
+ </div>
74
+ );
75
+ };