zudoku 0.0.0-reset-hash-value.ac516c6d → 0.0.0-z179c4f85

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 (818) hide show
  1. package/client.d.ts +8 -0
  2. package/dist/app/entry.server.js +14 -1
  3. package/dist/app/entry.server.js.map +1 -1
  4. package/dist/app/main.d.ts +91 -1
  5. package/dist/app/main.js +5 -1
  6. package/dist/app/main.js.map +1 -1
  7. package/dist/app/sentry.js +1 -1
  8. package/dist/cli/common/version-check.js +12 -3
  9. package/dist/cli/common/version-check.js.map +1 -1
  10. package/dist/config/config.d.ts +15 -44
  11. package/dist/config/validators/BuildSchema.d.ts +5 -4
  12. package/dist/config/validators/BuildSchema.js +23 -5
  13. package/dist/config/validators/BuildSchema.js.map +1 -1
  14. package/dist/config/validators/InputNavigationSchema.d.ts +83 -81
  15. package/dist/config/validators/InputNavigationSchema.js +1 -0
  16. package/dist/config/validators/InputNavigationSchema.js.map +1 -1
  17. package/dist/config/validators/NavigationSchema.js +8 -5
  18. package/dist/config/validators/NavigationSchema.js.map +1 -1
  19. package/dist/config/validators/ProtectedRoutesSchema.d.ts +1 -1
  20. package/dist/config/validators/validate.d.ts +243 -20
  21. package/dist/config/validators/validate.js +52 -10
  22. package/dist/config/validators/validate.js.map +1 -1
  23. package/dist/config/validators/validate.test.js +43 -0
  24. package/dist/config/validators/validate.test.js.map +1 -1
  25. package/dist/flat-config.d.ts +39 -4
  26. package/dist/index.d.ts +2 -1
  27. package/dist/index.js +2 -1
  28. package/dist/index.js.map +1 -1
  29. package/dist/lib/auth/issuer.js +3 -0
  30. package/dist/lib/auth/issuer.js.map +1 -1
  31. package/dist/lib/authentication/authentication.d.ts +19 -10
  32. package/dist/lib/authentication/components/CallbackHandler.js +1 -1
  33. package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
  34. package/dist/lib/authentication/components/OAuthErrorPage.js +1 -1
  35. package/dist/lib/authentication/components/OAuthErrorPage.js.map +1 -1
  36. package/dist/lib/authentication/components/SignIn.js +8 -5
  37. package/dist/lib/authentication/components/SignIn.js.map +1 -1
  38. package/dist/lib/authentication/components/SignOut.js +6 -6
  39. package/dist/lib/authentication/components/SignOut.js.map +1 -1
  40. package/dist/lib/authentication/components/SignUp.js +7 -5
  41. package/dist/lib/authentication/components/SignUp.js.map +1 -1
  42. package/dist/lib/authentication/hook.d.ts +5 -2
  43. package/dist/lib/authentication/hook.js +22 -8
  44. package/dist/lib/authentication/hook.js.map +1 -1
  45. package/dist/lib/authentication/providers/auth0.js +18 -9
  46. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  47. package/dist/lib/authentication/providers/azureb2c.d.ts +4 -4
  48. package/dist/lib/authentication/providers/azureb2c.js +3 -3
  49. package/dist/lib/authentication/providers/azureb2c.js.map +1 -1
  50. package/dist/lib/authentication/providers/clerk.js +2 -24
  51. package/dist/lib/authentication/providers/clerk.js.map +1 -1
  52. package/dist/lib/authentication/providers/firebase.d.ts +4 -0
  53. package/dist/lib/authentication/providers/firebase.js +273 -0
  54. package/dist/lib/authentication/providers/firebase.js.map +1 -0
  55. package/dist/lib/authentication/providers/openid.d.ts +7 -7
  56. package/dist/lib/authentication/providers/openid.js +3 -3
  57. package/dist/lib/authentication/providers/openid.js.map +1 -1
  58. package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.d.ts +8 -0
  59. package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.js +39 -0
  60. package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.js.map +1 -0
  61. package/dist/lib/authentication/providers/supabase.js +36 -46
  62. package/dist/lib/authentication/providers/supabase.js.map +1 -1
  63. package/dist/lib/authentication/state.d.ts +1 -5
  64. package/dist/lib/authentication/state.js +2 -14
  65. package/dist/lib/authentication/state.js.map +1 -1
  66. package/dist/lib/authentication/ui/EmailVerificationUi.d.ts +4 -0
  67. package/dist/lib/authentication/ui/EmailVerificationUi.js +34 -0
  68. package/dist/lib/authentication/ui/EmailVerificationUi.js.map +1 -0
  69. package/dist/lib/authentication/ui/ZudokuAuthUi.d.ts +29 -0
  70. package/dist/lib/authentication/ui/ZudokuAuthUi.js +160 -0
  71. package/dist/lib/authentication/ui/ZudokuAuthUi.js.map +1 -0
  72. package/dist/lib/authentication/ui/icons/Apple.d.ts +3 -0
  73. package/dist/lib/authentication/ui/icons/Apple.js +4 -0
  74. package/dist/lib/authentication/ui/icons/Apple.js.map +1 -0
  75. package/dist/lib/authentication/ui/icons/Facebook.d.ts +3 -0
  76. package/dist/lib/authentication/ui/icons/Facebook.js +4 -0
  77. package/dist/lib/authentication/ui/icons/Facebook.js.map +1 -0
  78. package/dist/lib/authentication/ui/icons/Github.d.ts +3 -0
  79. package/dist/lib/authentication/ui/icons/Github.js +4 -0
  80. package/dist/lib/authentication/ui/icons/Github.js.map +1 -0
  81. package/dist/lib/authentication/ui/icons/Google.d.ts +3 -0
  82. package/dist/lib/authentication/ui/icons/Google.js +4 -0
  83. package/dist/lib/authentication/ui/icons/Google.js.map +1 -0
  84. package/dist/lib/authentication/ui/icons/Microsoft.d.ts +3 -0
  85. package/dist/lib/authentication/ui/icons/Microsoft.js +4 -0
  86. package/dist/lib/authentication/ui/icons/Microsoft.js.map +1 -0
  87. package/dist/lib/authentication/ui/icons/X.d.ts +3 -0
  88. package/dist/lib/authentication/ui/icons/X.js +4 -0
  89. package/dist/lib/authentication/ui/icons/X.js.map +1 -0
  90. package/dist/lib/authentication/utils/relativeRedirectUrl.d.ts +1 -0
  91. package/dist/lib/authentication/utils/relativeRedirectUrl.js +8 -0
  92. package/dist/lib/authentication/utils/relativeRedirectUrl.js.map +1 -0
  93. package/dist/lib/components/Autocomplete.d.ts +3 -1
  94. package/dist/lib/components/Autocomplete.js +6 -2
  95. package/dist/lib/components/Autocomplete.js.map +1 -1
  96. package/dist/lib/components/Heading.d.ts +1 -1
  97. package/dist/lib/components/Layout.js +3 -2
  98. package/dist/lib/components/Layout.js.map +1 -1
  99. package/dist/lib/components/Mermaid.d.ts +7 -0
  100. package/dist/lib/components/Mermaid.js +42 -0
  101. package/dist/lib/components/Mermaid.js.map +1 -0
  102. package/dist/lib/components/PagefindSearchMeta.d.ts +8 -0
  103. package/dist/lib/components/PagefindSearchMeta.js +7 -0
  104. package/dist/lib/components/PagefindSearchMeta.js.map +1 -0
  105. package/dist/lib/components/Pagination.js +2 -2
  106. package/dist/lib/components/Pagination.js.map +1 -1
  107. package/dist/lib/components/Zudoku.js +5 -8
  108. package/dist/lib/components/Zudoku.js.map +1 -1
  109. package/dist/lib/components/index.d.ts +7 -2
  110. package/dist/lib/components/index.js +4 -0
  111. package/dist/lib/components/index.js.map +1 -1
  112. package/dist/lib/components/navigation/NavigationItem.js +4 -4
  113. package/dist/lib/components/navigation/NavigationItem.js.map +1 -1
  114. package/dist/lib/components/navigation/Toc.js +1 -1
  115. package/dist/lib/components/navigation/Toc.js.map +1 -1
  116. package/dist/lib/core/RouteGuard.d.ts +1 -1
  117. package/dist/lib/core/RouteGuard.js +22 -25
  118. package/dist/lib/core/RouteGuard.js.map +1 -1
  119. package/dist/lib/core/ZudokuContext.d.ts +1 -0
  120. package/dist/lib/core/ZudokuContext.js +2 -0
  121. package/dist/lib/core/ZudokuContext.js.map +1 -1
  122. package/dist/lib/core/__internal.d.ts +1 -1
  123. package/dist/lib/core/plugins.d.ts +3 -3
  124. package/dist/lib/core/react-query.d.ts +1 -0
  125. package/dist/lib/core/react-query.js +2 -0
  126. package/dist/lib/core/react-query.js.map +1 -0
  127. package/dist/lib/errors/ErrorAlert.js +1 -1
  128. package/dist/lib/errors/ErrorMessage.d.ts +3 -0
  129. package/dist/lib/errors/ErrorMessage.js +16 -0
  130. package/dist/lib/errors/ErrorMessage.js.map +1 -0
  131. package/dist/lib/errors/RouterError.d.ts +3 -1
  132. package/dist/lib/errors/RouterError.js +3 -2
  133. package/dist/lib/errors/RouterError.js.map +1 -1
  134. package/dist/lib/hooks/index.d.ts +4 -2
  135. package/dist/lib/oas/graphql/circular.d.ts +2 -0
  136. package/dist/lib/oas/graphql/circular.js +32 -10
  137. package/dist/lib/oas/graphql/circular.js.map +1 -1
  138. package/dist/lib/oas/graphql/circular.test.d.ts +1 -0
  139. package/dist/lib/oas/graphql/circular.test.js +152 -0
  140. package/dist/lib/oas/graphql/circular.test.js.map +1 -0
  141. package/dist/lib/oas/graphql/index.js +7 -3
  142. package/dist/lib/oas/graphql/index.js.map +1 -1
  143. package/dist/lib/oas/parser/index.d.ts +1 -0
  144. package/dist/lib/oas/parser/index.js +7 -3
  145. package/dist/lib/oas/parser/index.js.map +1 -1
  146. package/dist/lib/plugins/api-keys/ProtectedRoute.js +4 -1
  147. package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
  148. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +9 -172
  149. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
  150. package/dist/lib/plugins/api-keys/index.d.ts +11 -4
  151. package/dist/lib/plugins/api-keys/index.js +36 -22
  152. package/dist/lib/plugins/api-keys/index.js.map +1 -1
  153. package/dist/lib/plugins/api-keys/settings/ApiKeyItem.d.ts +12 -0
  154. package/dist/lib/plugins/api-keys/settings/ApiKeyItem.js +133 -0
  155. package/dist/lib/plugins/api-keys/settings/ApiKeyItem.js.map +1 -0
  156. package/dist/lib/plugins/api-keys/settings/ApiKeyList.d.ts +4 -0
  157. package/dist/lib/plugins/api-keys/settings/ApiKeyList.js +33 -0
  158. package/dist/lib/plugins/api-keys/settings/ApiKeyList.js.map +1 -0
  159. package/dist/lib/plugins/api-keys/settings/RevealApiKey.d.ts +6 -0
  160. package/dist/lib/plugins/api-keys/settings/RevealApiKey.js +39 -0
  161. package/dist/lib/plugins/api-keys/settings/RevealApiKey.js.map +1 -0
  162. package/dist/lib/plugins/markdown/MdxPage.d.ts +2 -1
  163. package/dist/lib/plugins/markdown/MdxPage.js +3 -2
  164. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  165. package/dist/lib/plugins/markdown/index.d.ts +1 -0
  166. package/dist/lib/plugins/markdown/index.js +1 -1
  167. package/dist/lib/plugins/markdown/index.js.map +1 -1
  168. package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +1 -0
  169. package/dist/lib/plugins/openapi/CollapsibleCode.js +2 -1
  170. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -1
  171. package/dist/lib/plugins/openapi/DownloadSchemaButton.d.ts +3 -0
  172. package/dist/lib/plugins/openapi/DownloadSchemaButton.js +47 -0
  173. package/dist/lib/plugins/openapi/DownloadSchemaButton.js.map +1 -0
  174. package/dist/lib/plugins/openapi/Endpoint.js +3 -6
  175. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  176. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.d.ts +5 -0
  177. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js +10 -0
  178. package/dist/lib/plugins/openapi/GeneratedExampleSidecarBox.js.map +1 -0
  179. package/dist/lib/plugins/openapi/OasProvider.js +22 -13
  180. package/dist/lib/plugins/openapi/OasProvider.js.map +1 -1
  181. package/dist/lib/plugins/openapi/OperationList.js +20 -6
  182. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  183. package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
  184. package/dist/lib/plugins/openapi/OperationListItem.js +4 -3
  185. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  186. package/dist/lib/plugins/openapi/ParamInfos.js +1 -0
  187. package/dist/lib/plugins/openapi/ParamInfos.js.map +1 -1
  188. package/dist/lib/plugins/openapi/ParameterList.js +7 -4
  189. package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
  190. package/dist/lib/plugins/openapi/ParameterListItem.js +17 -6
  191. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  192. package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +9 -2
  193. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +5 -2
  194. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  195. package/dist/lib/plugins/openapi/ResponsesSidecarBox.d.ts +4 -2
  196. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +26 -4
  197. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  198. package/dist/lib/plugins/openapi/SchemaList.js +2 -1
  199. package/dist/lib/plugins/openapi/SchemaList.js.map +1 -1
  200. package/dist/lib/plugins/openapi/Sidecar.d.ts +2 -2
  201. package/dist/lib/plugins/openapi/Sidecar.js +64 -28
  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 -2
  206. package/dist/lib/plugins/openapi/SidecarExamples.js +24 -43
  207. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
  208. package/dist/lib/plugins/openapi/components/ConstValue.js +1 -1
  209. package/dist/lib/plugins/openapi/components/ConstValue.js.map +1 -1
  210. package/dist/lib/plugins/openapi/components/EnumValues.js +1 -1
  211. package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -1
  212. package/dist/lib/plugins/openapi/components/NonHighlightedCode.d.ts +4 -0
  213. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js +5 -0
  214. package/dist/lib/plugins/openapi/components/NonHighlightedCode.js.map +1 -0
  215. package/dist/lib/plugins/openapi/components/ResponseContent.js +5 -6
  216. package/dist/lib/plugins/openapi/components/ResponseContent.js.map +1 -1
  217. package/dist/lib/plugins/openapi/index.js +15 -14
  218. package/dist/lib/plugins/openapi/index.js.map +1 -1
  219. package/dist/lib/plugins/openapi/interfaces.d.ts +29 -13
  220. package/dist/lib/plugins/openapi/playground/BodyPanel.js +67 -15
  221. package/dist/lib/plugins/openapi/playground/BodyPanel.js.map +1 -1
  222. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js +2 -2
  223. package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js.map +1 -1
  224. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -1
  225. package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
  226. package/dist/lib/plugins/openapi/playground/Headers.js +23 -83
  227. package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
  228. package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +10 -2
  229. package/dist/lib/plugins/openapi/playground/ParamsGrid.js +8 -1
  230. package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -1
  231. package/dist/lib/plugins/openapi/playground/PathParams.js +2 -3
  232. package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
  233. package/dist/lib/plugins/openapi/playground/Playground.d.ts +7 -0
  234. package/dist/lib/plugins/openapi/playground/Playground.js +70 -28
  235. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  236. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +3 -2
  237. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  238. package/dist/lib/plugins/openapi/playground/QueryParams.js +16 -40
  239. package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
  240. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.d.ts +2 -1
  241. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js +10 -2
  242. package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js.map +1 -1
  243. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.d.ts +8 -0
  244. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js +19 -0
  245. package/dist/lib/plugins/openapi/playground/request-panel/MultipartField.js.map +1 -0
  246. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js +1 -1
  247. package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js.map +1 -1
  248. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.d.ts +1 -0
  249. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js +540 -0
  250. package/dist/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.js.map +1 -0
  251. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.d.ts +40 -0
  252. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js +205 -0
  253. package/dist/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.js.map +1 -0
  254. package/dist/lib/plugins/openapi/playground/result-panel/Highlight.d.ts +1 -1
  255. package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js +1 -1
  256. package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js.map +1 -1
  257. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +23 -21
  258. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
  259. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +1 -1
  260. package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
  261. package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js +2 -0
  262. package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js.map +1 -1
  263. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +1 -1
  264. package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -1
  265. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +17 -8
  266. package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
  267. package/dist/lib/plugins/openapi/schema/SchemaView.d.ts +1 -1
  268. package/dist/lib/plugins/openapi/schema/SchemaView.js +31 -16
  269. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  270. package/dist/lib/plugins/openapi/schema/UnionView.js +2 -5
  271. package/dist/lib/plugins/openapi/schema/UnionView.js.map +1 -1
  272. package/dist/lib/plugins/openapi/schema/union-helpers.js +0 -1
  273. package/dist/lib/plugins/openapi/schema/union-helpers.js.map +1 -1
  274. package/dist/lib/plugins/openapi/schema/utils.d.ts +2 -2
  275. package/dist/lib/plugins/openapi/schema/utils.js +11 -3
  276. package/dist/lib/plugins/openapi/schema/utils.js.map +1 -1
  277. package/dist/lib/plugins/openapi/util/createHttpSnippet.js +24 -1
  278. package/dist/lib/plugins/openapi/util/createHttpSnippet.js.map +1 -1
  279. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +9 -11
  280. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  281. package/dist/lib/plugins/openapi/util/getRoutes.d.ts +6 -1
  282. package/dist/lib/plugins/openapi/util/getRoutes.js +29 -2
  283. package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -1
  284. package/dist/lib/plugins/search-pagefind/IndexingDialog.d.ts +3 -0
  285. package/dist/lib/plugins/search-pagefind/IndexingDialog.js +64 -0
  286. package/dist/lib/plugins/search-pagefind/IndexingDialog.js.map +1 -0
  287. package/dist/lib/plugins/search-pagefind/PagefindSearch.js +22 -5
  288. package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -1
  289. package/dist/lib/plugins/search-pagefind/ResultList.js +5 -4
  290. package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -1
  291. package/dist/lib/shiki.d.ts +2 -2
  292. package/dist/lib/shiki.js +31 -14
  293. package/dist/lib/shiki.js.map +1 -1
  294. package/dist/lib/ui/Badge.d.ts +3 -3
  295. package/dist/lib/ui/Badge.js +9 -7
  296. package/dist/lib/ui/Badge.js.map +1 -1
  297. package/dist/lib/ui/Button.d.ts +2 -2
  298. package/dist/lib/ui/Button.js +10 -8
  299. package/dist/lib/ui/Button.js.map +1 -1
  300. package/dist/lib/ui/ButtonGroup.d.ts +11 -0
  301. package/dist/lib/ui/ButtonGroup.js +28 -0
  302. package/dist/lib/ui/ButtonGroup.js.map +1 -0
  303. package/dist/lib/ui/Callout.d.ts +5 -5
  304. package/dist/lib/ui/Callout.js +5 -5
  305. package/dist/lib/ui/Callout.js.map +1 -1
  306. package/dist/lib/ui/Checkbox.d.ts +2 -2
  307. package/dist/lib/ui/Checkbox.js +4 -4
  308. package/dist/lib/ui/Checkbox.js.map +1 -1
  309. package/dist/lib/ui/CodeBlock.d.ts +0 -1
  310. package/dist/lib/ui/CodeBlock.js +1 -1
  311. package/dist/lib/ui/CodeBlock.js.map +1 -1
  312. package/dist/lib/ui/Collapsible.d.ts +4 -4
  313. package/dist/lib/ui/Collapsible.js +11 -4
  314. package/dist/lib/ui/Collapsible.js.map +1 -1
  315. package/dist/lib/ui/Command.d.ts +3 -3
  316. package/dist/lib/ui/Command.js +2 -2
  317. package/dist/lib/ui/Command.js.map +1 -1
  318. package/dist/lib/ui/Dialog.d.ts +12 -18
  319. package/dist/lib/ui/Dialog.js +30 -17
  320. package/dist/lib/ui/Dialog.js.map +1 -1
  321. package/dist/lib/ui/DropdownMenu.d.ts +21 -23
  322. package/dist/lib/ui/DropdownMenu.js +47 -32
  323. package/dist/lib/ui/DropdownMenu.js.map +1 -1
  324. package/dist/lib/ui/EmbeddedCodeBlock.d.ts +3 -2
  325. package/dist/lib/ui/EmbeddedCodeBlock.js +4 -3
  326. package/dist/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  327. package/dist/lib/ui/Frame.d.ts +8 -0
  328. package/dist/lib/ui/Frame.js +22 -0
  329. package/dist/lib/ui/Frame.js.map +1 -0
  330. package/dist/lib/ui/Item.d.ts +23 -0
  331. package/dist/lib/ui/Item.js +67 -0
  332. package/dist/lib/ui/Item.js.map +1 -0
  333. package/dist/lib/ui/Kbd.d.ts +3 -0
  334. package/dist/lib/ui/Kbd.js +10 -0
  335. package/dist/lib/ui/Kbd.js.map +1 -0
  336. package/dist/lib/ui/NativeSelect.d.ts +5 -0
  337. package/dist/lib/ui/NativeSelect.js +14 -0
  338. package/dist/lib/ui/NativeSelect.js.map +1 -0
  339. package/dist/lib/ui/ReactComponentDoc.d.ts +1 -1
  340. package/dist/lib/ui/ReactComponentDoc.js +2 -2
  341. package/dist/lib/ui/ReactComponentDoc.js.map +1 -1
  342. package/dist/lib/ui/Select.d.ts +13 -11
  343. package/dist/lib/ui/Select.js +34 -23
  344. package/dist/lib/ui/Select.js.map +1 -1
  345. package/dist/lib/ui/Separator.d.ts +4 -0
  346. package/dist/lib/ui/Separator.js +8 -0
  347. package/dist/lib/ui/Separator.js.map +1 -0
  348. package/dist/lib/ui/SyntaxHighlight.d.ts +1 -0
  349. package/dist/lib/ui/SyntaxHighlight.js.map +1 -1
  350. package/dist/lib/ui/Tooltip.d.ts +7 -7
  351. package/dist/lib/ui/Tooltip.js +16 -10
  352. package/dist/lib/ui/Tooltip.js.map +1 -1
  353. package/dist/lib/util/MdxComponents.d.ts +3 -1
  354. package/dist/lib/util/MdxComponents.js +5 -2
  355. package/dist/lib/util/MdxComponents.js.map +1 -1
  356. package/dist/lib/util/createVariantComponent.d.ts +5 -2
  357. package/dist/lib/util/createVariantComponent.js +5 -2
  358. package/dist/lib/util/createVariantComponent.js.map +1 -1
  359. package/dist/lib/util/flattenAllOf.d.ts +4 -0
  360. package/dist/lib/util/flattenAllOf.js +88 -0
  361. package/dist/lib/util/flattenAllOf.js.map +1 -0
  362. package/dist/lib/util/flattenAllOf.test.d.ts +1 -0
  363. package/dist/lib/util/flattenAllOf.test.js +587 -0
  364. package/dist/lib/util/flattenAllOf.test.js.map +1 -0
  365. package/dist/lib/util/invariant.d.ts +1 -1
  366. package/dist/lib/util/invariant.js +2 -2
  367. package/dist/lib/util/invariant.js.map +1 -1
  368. package/dist/lib/util/readFrontmatter.d.ts +6 -0
  369. package/dist/lib/util/readFrontmatter.js +12 -0
  370. package/dist/lib/util/readFrontmatter.js.map +1 -0
  371. package/dist/lib/util/syncZustandState.d.ts +5 -0
  372. package/dist/lib/util/syncZustandState.js +14 -0
  373. package/dist/lib/util/syncZustandState.js.map +1 -0
  374. package/dist/vite/api/SchemaManager.d.ts +9 -1
  375. package/dist/vite/api/SchemaManager.js +58 -21
  376. package/dist/vite/api/SchemaManager.js.map +1 -1
  377. package/dist/vite/api/SchemaManager.test.js +69 -2
  378. package/dist/vite/api/SchemaManager.test.js.map +1 -1
  379. package/dist/vite/config.js +13 -1
  380. package/dist/vite/config.js.map +1 -1
  381. package/dist/vite/dev-server.js +25 -0
  382. package/dist/vite/dev-server.js.map +1 -1
  383. package/dist/vite/error-handler.js +1 -5
  384. package/dist/vite/error-handler.js.map +1 -1
  385. package/dist/vite/mdx/remark-last-modified.js +57 -3
  386. package/dist/vite/mdx/remark-last-modified.js.map +1 -1
  387. package/dist/vite/mdx/remark-link-rewrite.js +1 -1
  388. package/dist/vite/pagefind-dev-index.d.ts +16 -0
  389. package/dist/vite/pagefind-dev-index.js +68 -0
  390. package/dist/vite/pagefind-dev-index.js.map +1 -0
  391. package/dist/vite/plugin-api-keys.js +5 -1
  392. package/dist/vite/plugin-api-keys.js.map +1 -1
  393. package/dist/vite/plugin-api.js +55 -8
  394. package/dist/vite/plugin-api.js.map +1 -1
  395. package/dist/vite/plugin-docs.js +1 -1
  396. package/dist/vite/plugin-docs.js.map +1 -1
  397. package/dist/vite/plugin-frontmatter.js +3 -5
  398. package/dist/vite/plugin-frontmatter.js.map +1 -1
  399. package/dist/vite/plugin-markdown-export.js +8 -7
  400. package/dist/vite/plugin-markdown-export.js.map +1 -1
  401. package/dist/vite/plugin-mdx.js +36 -30
  402. package/dist/vite/plugin-mdx.js.map +1 -1
  403. package/dist/vite/plugin-theme.js +10 -1
  404. package/dist/vite/plugin-theme.js.map +1 -1
  405. package/dist/vite/prerender/prerender.js +1 -19
  406. package/dist/vite/prerender/prerender.js.map +1 -1
  407. package/dist/vite/prerender/utils.d.ts +2 -0
  408. package/dist/vite/prerender/utils.js +30 -0
  409. package/dist/vite/prerender/utils.js.map +1 -0
  410. package/dist/vite/prerender/worker.js +3 -0
  411. package/dist/vite/prerender/worker.js.map +1 -1
  412. package/dist/vite/zuplo.d.ts +13 -0
  413. package/dist/vite/zuplo.js +15 -0
  414. package/dist/vite/zuplo.js.map +1 -0
  415. package/lib/ActionButton-B0CXL1Lq.js +25 -0
  416. package/lib/ActionButton-B0CXL1Lq.js.map +1 -0
  417. package/lib/Button-GUVe7pmt.js +54 -0
  418. package/lib/Button-GUVe7pmt.js.map +1 -0
  419. package/lib/{Card-KFniaZn5.js → Card-DCdq37aA.js} +2 -2
  420. package/lib/{Card-KFniaZn5.js.map → Card-DCdq37aA.js.map} +1 -1
  421. package/lib/ClaudeLogo-DHxJUhN_.js +69 -0
  422. package/lib/ClaudeLogo-DHxJUhN_.js.map +1 -0
  423. package/lib/{Command-CJY6q3PF.js → Command-N6VujV30.js} +26 -26
  424. package/lib/Command-N6VujV30.js.map +1 -0
  425. package/lib/Dialog-hlvmmQ_c.js +144 -0
  426. package/lib/Dialog-hlvmmQ_c.js.map +1 -0
  427. package/lib/{Drawer-Ci7XwhqT.js → Drawer-Ch7927PF.js} +7 -7
  428. package/lib/{Drawer-Ci7XwhqT.js.map → Drawer-Ch7927PF.js.map} +1 -1
  429. package/lib/DropdownMenu-DN0jNrjj.js +104 -0
  430. package/lib/DropdownMenu-DN0jNrjj.js.map +1 -0
  431. package/lib/Frame-DKlOmSkU.js +205 -0
  432. package/lib/Frame-DKlOmSkU.js.map +1 -0
  433. package/lib/HydrationBoundary-CNF2ZV3E.js +601 -0
  434. package/lib/HydrationBoundary-CNF2ZV3E.js.map +1 -0
  435. package/lib/IndexingDialog-D0YdGfbn.js +100 -0
  436. package/lib/IndexingDialog-D0YdGfbn.js.map +1 -0
  437. package/lib/Input-Cx-GeKoF.js +22 -0
  438. package/lib/Input-Cx-GeKoF.js.map +1 -0
  439. package/lib/MdxPage-CD36PJ17.js +210 -0
  440. package/lib/MdxPage-CD36PJ17.js.map +1 -0
  441. package/lib/Mermaid-Koc3z8mU.js +102 -0
  442. package/lib/Mermaid-Koc3z8mU.js.map +1 -0
  443. package/lib/{OAuthErrorPage-DJUOdr6Q.js → OAuthErrorPage-4mN5DA86.js} +16 -16
  444. package/lib/OAuthErrorPage-4mN5DA86.js.map +1 -0
  445. package/lib/OasProvider-DSe-hk5Y.js +40 -0
  446. package/lib/OasProvider-DSe-hk5Y.js.map +1 -0
  447. package/lib/OperationList-CaknPbvq.js +5823 -0
  448. package/lib/OperationList-CaknPbvq.js.map +1 -0
  449. package/lib/RouteGuard--A04ESy8.js +77 -0
  450. package/lib/RouteGuard--A04ESy8.js.map +1 -0
  451. package/lib/{SchemaList-1eLKXqn8.js → SchemaList-Dw3-CJPb.js} +28 -27
  452. package/lib/SchemaList-Dw3-CJPb.js.map +1 -0
  453. package/lib/SchemaView-DyJkiQkD.js +438 -0
  454. package/lib/SchemaView-DyJkiQkD.js.map +1 -0
  455. package/lib/Secret-BDBqq4p3.js +243 -0
  456. package/lib/Secret-BDBqq4p3.js.map +1 -0
  457. package/lib/Separator-BXt1LYnm.js +27 -0
  458. package/lib/Separator-BXt1LYnm.js.map +1 -0
  459. package/lib/SignUp-DRvN-8cq.js +50 -0
  460. package/lib/SignUp-DRvN-8cq.js.map +1 -0
  461. package/lib/{SyntaxHighlight-B0laqAqK.js → SyntaxHighlight-klTH8c6-.js} +1781 -1697
  462. package/lib/SyntaxHighlight-klTH8c6-.js.map +1 -0
  463. package/lib/{Toc-KzXCRqrX.js → Toc-PbuF-u9x.js} +6 -6
  464. package/lib/Toc-PbuF-u9x.js.map +1 -0
  465. package/lib/ZudokuContext-BZB1TWdT.js +387 -0
  466. package/lib/ZudokuContext-BZB1TWdT.js.map +1 -0
  467. package/lib/___vite-browser-external_commonjs-proxy-BttVsNON.js +9 -0
  468. package/lib/___vite-browser-external_commonjs-proxy-BttVsNON.js.map +1 -0
  469. package/lib/chunk-EPOLDU6W-C6C8jAwd.js +8558 -0
  470. package/lib/chunk-EPOLDU6W-C6C8jAwd.js.map +1 -0
  471. package/lib/{circular-D6wbrxuf.js → circular-DFquXeY2.js} +6459 -6030
  472. package/lib/circular-DFquXeY2.js.map +1 -0
  473. package/lib/{cn-dYga0KKN.js → cn-5-Gd1Dss.js} +531 -498
  474. package/lib/cn-5-Gd1Dss.js.map +1 -0
  475. package/lib/createServer-BXZ0CAUn.js +16693 -0
  476. package/lib/createServer-BXZ0CAUn.js.map +1 -0
  477. package/lib/createVariantComponent-Dc0vtOvr.js +18 -0
  478. package/lib/createVariantComponent-Dc0vtOvr.js.map +1 -0
  479. package/lib/{errors-XqO6MsfU.js → errors-rWHkzVTd.js} +3 -3
  480. package/lib/{errors-XqO6MsfU.js.map → errors-rWHkzVTd.js.map} +1 -1
  481. package/lib/firebase-BmGU1FuD.js +7614 -0
  482. package/lib/firebase-BmGU1FuD.js.map +1 -0
  483. package/lib/hook-BGlHBdET.js +52 -0
  484. package/lib/hook-BGlHBdET.js.map +1 -0
  485. package/lib/{ErrorAlert-VBJ8aHH7.js → index-BDsEwofZ.js} +5503 -4505
  486. package/lib/index-BDsEwofZ.js.map +1 -0
  487. package/lib/index-BQB9hb6n.js +3677 -0
  488. package/lib/index-BQB9hb6n.js.map +1 -0
  489. package/lib/index-CrcNWbel.js.map +1 -1
  490. package/lib/index-DBjOT2H1.js +133 -0
  491. package/lib/index-DBjOT2H1.js.map +1 -0
  492. package/lib/{index-C5L4favO.js → index-DRBOFufT.js} +2 -2
  493. package/lib/{index-C5L4favO.js.map → index-DRBOFufT.js.map} +1 -1
  494. package/lib/index.esm-BYObtETB.js.map +1 -1
  495. package/lib/{index.esm-BnYHxCYC.js → index.esm-B_0dvNjB.js} +20 -20
  496. package/lib/{index.esm-BnYHxCYC.js.map → index.esm-B_0dvNjB.js.map} +1 -1
  497. package/lib/index.esm-Cx8B1YJQ.js +34 -0
  498. package/lib/index.esm-Cx8B1YJQ.js.map +1 -0
  499. package/lib/{invariant-Bm-FVUQE.js → invariant-BJAl77rw.js} +6 -6
  500. package/lib/invariant-BJAl77rw.js.map +1 -0
  501. package/lib/jsx-runtime-BzflLqGi.js.map +1 -1
  502. package/lib/{mutation-CdGPxHNX.js → mutation-BISOc7OM.js} +70 -44
  503. package/lib/mutation-BISOc7OM.js.map +1 -0
  504. package/lib/ui/Accordion.js +1 -1
  505. package/lib/ui/ActionButton.js +2 -2
  506. package/lib/ui/Alert.js +1 -1
  507. package/lib/ui/AlertDialog.js +1 -1
  508. package/lib/ui/Badge.js +27 -13
  509. package/lib/ui/Badge.js.map +1 -1
  510. package/lib/ui/Breadcrumb.js +1 -1
  511. package/lib/ui/Button.js +28 -25
  512. package/lib/ui/Button.js.map +1 -1
  513. package/lib/ui/ButtonGroup.js +77 -0
  514. package/lib/ui/ButtonGroup.js.map +1 -0
  515. package/lib/ui/Callout.js +19 -19
  516. package/lib/ui/Callout.js.map +1 -1
  517. package/lib/ui/Card.js +1 -1
  518. package/lib/ui/Carousel.js +1 -1
  519. package/lib/ui/Carousel.js.map +1 -1
  520. package/lib/ui/Checkbox.js +29 -26
  521. package/lib/ui/Checkbox.js.map +1 -1
  522. package/lib/ui/CodeBlock.js +217 -7
  523. package/lib/ui/CodeBlock.js.map +1 -1
  524. package/lib/ui/Collapsible.js +32 -5
  525. package/lib/ui/Collapsible.js.map +1 -1
  526. package/lib/ui/Command.js +5 -5
  527. package/lib/ui/Command.js.map +1 -1
  528. package/lib/ui/Dialog.js +136 -106
  529. package/lib/ui/Dialog.js.map +1 -1
  530. package/lib/ui/Drawer.js +3 -3
  531. package/lib/ui/DropdownMenu.js +227 -140
  532. package/lib/ui/DropdownMenu.js.map +1 -1
  533. package/lib/ui/EmbeddedCodeBlock.js +36 -32
  534. package/lib/ui/EmbeddedCodeBlock.js.map +1 -1
  535. package/lib/ui/Form.js +1 -1
  536. package/lib/ui/Frame.js +81 -0
  537. package/lib/ui/Frame.js.map +1 -0
  538. package/lib/ui/HoverCard.js +1 -1
  539. package/lib/ui/Input.js +1 -1
  540. package/lib/ui/Item.js +188 -0
  541. package/lib/ui/Item.js.map +1 -0
  542. package/lib/ui/Kbd.js +32 -0
  543. package/lib/ui/Kbd.js.map +1 -0
  544. package/lib/ui/Label.js +1 -1
  545. package/lib/ui/NativeSelect.js +57 -0
  546. package/lib/ui/NativeSelect.js.map +1 -0
  547. package/lib/ui/Pagination.js +1 -1
  548. package/lib/ui/Popover.js +1 -1
  549. package/lib/ui/Progress.js +1 -1
  550. package/lib/ui/RadioGroup.js +1 -1
  551. package/lib/ui/ReactComponentDoc.js +13 -13
  552. package/lib/ui/ReactComponentDoc.js.map +1 -1
  553. package/lib/ui/ScrollArea.js +1 -1
  554. package/lib/ui/Secret.js +1 -1
  555. package/lib/ui/Select.js +166 -116
  556. package/lib/ui/Select.js.map +1 -1
  557. package/lib/ui/Separator.js +27 -0
  558. package/lib/ui/Separator.js.map +1 -0
  559. package/lib/ui/Skeleton.js +1 -1
  560. package/lib/ui/Slider.js +1 -1
  561. package/lib/ui/Switch.js +1 -1
  562. package/lib/ui/SyntaxHighlight.js +4 -4
  563. package/lib/ui/Tabs.js +11 -11
  564. package/lib/ui/Textarea.js +1 -1
  565. package/lib/ui/Toggle.js +1 -1
  566. package/lib/ui/ToggleGroup.js +1 -1
  567. package/lib/ui/Tooltip.js +55 -28
  568. package/lib/ui/Tooltip.js.map +1 -1
  569. package/lib/ui/Value.js +1 -1
  570. package/lib/ui/util.js +1 -1
  571. package/lib/useMutation-CFMGlAMW.js +119 -0
  572. package/lib/useMutation-CFMGlAMW.js.map +1 -0
  573. package/lib/useSuspenseQuery-CSB_rVek.js +1226 -0
  574. package/lib/useSuspenseQuery-CSB_rVek.js.map +1 -0
  575. package/lib/zudoku.__internal.js +826 -1325
  576. package/lib/zudoku.__internal.js.map +1 -1
  577. package/lib/zudoku.auth-auth0.js +19 -19
  578. package/lib/zudoku.auth-auth0.js.map +1 -1
  579. package/lib/zudoku.auth-azureb2c.js +28 -28
  580. package/lib/zudoku.auth-azureb2c.js.map +1 -1
  581. package/lib/zudoku.auth-clerk.js +41 -64
  582. package/lib/zudoku.auth-clerk.js.map +1 -1
  583. package/lib/zudoku.auth-firebase.js +10 -0
  584. package/lib/zudoku.auth-firebase.js.map +1 -0
  585. package/lib/zudoku.auth-openid.js +52 -55
  586. package/lib/zudoku.auth-openid.js.map +1 -1
  587. package/lib/zudoku.auth-supabase.js +107 -60
  588. package/lib/zudoku.auth-supabase.js.map +1 -1
  589. package/lib/zudoku.components.js +23 -21
  590. package/lib/zudoku.hooks.js +11 -24
  591. package/lib/zudoku.hooks.js.map +1 -1
  592. package/lib/zudoku.mermaid.js +10 -0
  593. package/lib/zudoku.mermaid.js.map +1 -0
  594. package/lib/zudoku.plugin-api-catalog.js +8 -8
  595. package/lib/zudoku.plugin-api-keys.js +607 -543
  596. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  597. package/lib/zudoku.plugin-custom-pages.js +1 -1
  598. package/lib/zudoku.plugin-markdown.js +10 -9
  599. package/lib/zudoku.plugin-markdown.js.map +1 -1
  600. package/lib/zudoku.plugin-openapi.js +6 -7
  601. package/lib/zudoku.plugin-openapi.js.map +1 -1
  602. package/lib/zudoku.plugin-redirect.js +1 -1
  603. package/lib/zudoku.plugin-search-pagefind.js +185 -226
  604. package/lib/zudoku.plugin-search-pagefind.js.map +1 -1
  605. package/lib/zudoku.plugins.js.map +1 -1
  606. package/lib/zudoku.react-query.js +440 -0
  607. package/lib/zudoku.react-query.js.map +1 -0
  608. package/lib/zudoku.router.js +1130 -1404
  609. package/lib/zudoku.router.js.map +1 -1
  610. package/package.json +76 -45
  611. package/src/app/entry.server.tsx +16 -6
  612. package/src/app/main.css +61 -9
  613. package/src/app/main.tsx +5 -1
  614. package/src/app/sentry.ts +1 -1
  615. package/src/lib/auth/issuer.ts +3 -0
  616. package/src/lib/authentication/authentication.ts +29 -5
  617. package/src/lib/authentication/components/CallbackHandler.tsx +1 -1
  618. package/src/lib/authentication/components/OAuthErrorPage.tsx +1 -1
  619. package/src/lib/authentication/components/SignIn.tsx +10 -5
  620. package/src/lib/authentication/components/SignOut.tsx +7 -6
  621. package/src/lib/authentication/components/SignUp.tsx +8 -8
  622. package/src/lib/authentication/hook.ts +37 -10
  623. package/src/lib/authentication/providers/auth0.tsx +23 -11
  624. package/src/lib/authentication/providers/azureb2c.tsx +10 -3
  625. package/src/lib/authentication/providers/clerk.tsx +9 -28
  626. package/src/lib/authentication/providers/firebase.tsx +376 -0
  627. package/src/lib/authentication/providers/openid.tsx +18 -15
  628. package/src/lib/authentication/providers/supabase/SupabaseAuthUI.tsx +75 -0
  629. package/src/lib/authentication/providers/supabase.tsx +61 -59
  630. package/src/lib/authentication/state.ts +3 -23
  631. package/src/lib/authentication/ui/EmailVerificationUi.tsx +129 -0
  632. package/src/lib/authentication/ui/ZudokuAuthUi.tsx +477 -0
  633. package/src/lib/authentication/ui/icons/Apple.tsx +10 -0
  634. package/src/lib/authentication/ui/icons/Facebook.tsx +15 -0
  635. package/src/lib/authentication/ui/icons/Github.tsx +16 -0
  636. package/src/lib/authentication/ui/icons/Google.tsx +16 -0
  637. package/src/lib/authentication/ui/icons/Microsoft.tsx +12 -0
  638. package/src/lib/authentication/ui/icons/X.tsx +10 -0
  639. package/src/lib/authentication/utils/relativeRedirectUrl.ts +12 -0
  640. package/src/lib/components/Autocomplete.tsx +11 -2
  641. package/src/lib/components/Layout.tsx +3 -2
  642. package/src/lib/components/Mermaid.tsx +68 -0
  643. package/src/lib/components/PagefindSearchMeta.tsx +14 -0
  644. package/src/lib/components/Pagination.tsx +4 -5
  645. package/src/lib/components/Zudoku.tsx +7 -10
  646. package/src/lib/components/index.ts +4 -0
  647. package/src/lib/components/navigation/NavigationItem.tsx +16 -23
  648. package/src/lib/components/navigation/Toc.tsx +3 -3
  649. package/src/lib/core/RouteGuard.tsx +69 -43
  650. package/src/lib/core/ZudokuContext.ts +3 -0
  651. package/src/lib/core/plugins.ts +2 -2
  652. package/src/lib/core/react-query.ts +1 -0
  653. package/src/lib/errors/ErrorAlert.tsx +1 -1
  654. package/src/lib/errors/ErrorMessage.tsx +38 -0
  655. package/src/lib/errors/RouterError.tsx +7 -2
  656. package/src/lib/oas/graphql/circular.test.ts +186 -0
  657. package/src/lib/oas/graphql/circular.ts +49 -10
  658. package/src/lib/oas/graphql/index.ts +7 -3
  659. package/src/lib/oas/parser/index.ts +10 -3
  660. package/src/lib/plugins/api-keys/ProtectedRoute.tsx +11 -7
  661. package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +36 -476
  662. package/src/lib/plugins/api-keys/index.tsx +76 -32
  663. package/src/lib/plugins/api-keys/settings/ApiKeyItem.tsx +342 -0
  664. package/src/lib/plugins/api-keys/settings/ApiKeyList.tsx +67 -0
  665. package/src/lib/plugins/api-keys/settings/RevealApiKey.tsx +124 -0
  666. package/src/lib/plugins/markdown/MdxPage.tsx +4 -1
  667. package/src/lib/plugins/markdown/index.tsx +2 -0
  668. package/src/lib/plugins/openapi/CollapsibleCode.tsx +5 -3
  669. package/src/lib/plugins/openapi/DownloadSchemaButton.tsx +115 -0
  670. package/src/lib/plugins/openapi/Endpoint.tsx +20 -27
  671. package/src/lib/plugins/openapi/GeneratedExampleSidecarBox.tsx +52 -0
  672. package/src/lib/plugins/openapi/OasProvider.tsx +30 -17
  673. package/src/lib/plugins/openapi/OperationList.tsx +51 -21
  674. package/src/lib/plugins/openapi/OperationListItem.tsx +15 -12
  675. package/src/lib/plugins/openapi/ParamInfos.tsx +1 -0
  676. package/src/lib/plugins/openapi/ParameterList.tsx +37 -23
  677. package/src/lib/plugins/openapi/ParameterListItem.tsx +105 -54
  678. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +48 -7
  679. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +101 -33
  680. package/src/lib/plugins/openapi/SchemaList.tsx +4 -0
  681. package/src/lib/plugins/openapi/Sidecar.tsx +148 -67
  682. package/src/lib/plugins/openapi/SidecarBox.tsx +26 -4
  683. package/src/lib/plugins/openapi/SidecarExamples.tsx +91 -79
  684. package/src/lib/plugins/openapi/components/ConstValue.tsx +1 -1
  685. package/src/lib/plugins/openapi/components/EnumValues.tsx +2 -2
  686. package/src/lib/plugins/openapi/components/NonHighlightedCode.tsx +22 -0
  687. package/src/lib/plugins/openapi/components/ResponseContent.tsx +63 -53
  688. package/src/lib/plugins/openapi/index.tsx +25 -36
  689. package/src/lib/plugins/openapi/interfaces.ts +28 -7
  690. package/src/lib/plugins/openapi/playground/BodyPanel.tsx +246 -30
  691. package/src/lib/plugins/openapi/playground/CollapsibleHeader.tsx +10 -6
  692. package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +3 -2
  693. package/src/lib/plugins/openapi/playground/Headers.tsx +103 -219
  694. package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +33 -1
  695. package/src/lib/plugins/openapi/playground/PathParams.tsx +26 -34
  696. package/src/lib/plugins/openapi/playground/Playground.tsx +88 -35
  697. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +10 -31
  698. package/src/lib/plugins/openapi/playground/QueryParams.tsx +82 -136
  699. package/src/lib/plugins/openapi/playground/RequestLoginDialog.tsx +20 -1
  700. package/src/lib/plugins/openapi/playground/request-panel/MultipartField.tsx +91 -0
  701. package/src/lib/plugins/openapi/playground/request-panel/UrlQueryParams.tsx +1 -1
  702. package/src/lib/plugins/openapi/playground/request-panel/fieldManager/useKeyValueFieldManager.test.tsx +872 -0
  703. package/src/lib/plugins/openapi/playground/request-panel/useKeyValueFieldManager.ts +349 -0
  704. package/src/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.tsx +2 -2
  705. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +102 -62
  706. package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +1 -1
  707. package/src/lib/plugins/openapi/playground/useRememberSkipLoginDialog.tsx +3 -0
  708. package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +1 -1
  709. package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +89 -55
  710. package/src/lib/plugins/openapi/schema/SchemaView.tsx +100 -60
  711. package/src/lib/plugins/openapi/schema/UnionView.tsx +6 -17
  712. package/src/lib/plugins/openapi/schema/union-helpers.ts +0 -1
  713. package/src/lib/plugins/openapi/schema/utils.ts +20 -6
  714. package/src/lib/plugins/openapi/util/createHttpSnippet.ts +29 -1
  715. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +11 -11
  716. package/src/lib/plugins/openapi/util/getRoutes.tsx +35 -3
  717. package/src/lib/plugins/search-pagefind/IndexingDialog.tsx +163 -0
  718. package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +61 -22
  719. package/src/lib/plugins/search-pagefind/ResultList.tsx +8 -3
  720. package/src/lib/shiki.ts +37 -14
  721. package/src/lib/ui/Badge.tsx +21 -12
  722. package/src/lib/ui/Button.tsx +11 -9
  723. package/src/lib/ui/ButtonGroup.tsx +82 -0
  724. package/src/lib/ui/Callout.tsx +10 -5
  725. package/src/lib/ui/Checkbox.tsx +23 -24
  726. package/src/lib/ui/CodeBlock.tsx +3 -4
  727. package/src/lib/ui/Collapsible.tsx +26 -4
  728. package/src/lib/ui/Command.tsx +3 -3
  729. package/src/lib/ui/Dialog.tsx +112 -106
  730. package/src/lib/ui/DropdownMenu.tsx +226 -170
  731. package/src/lib/ui/EmbeddedCodeBlock.tsx +24 -19
  732. package/src/lib/ui/Frame.tsx +81 -0
  733. package/src/lib/ui/Item.tsx +192 -0
  734. package/src/lib/ui/Kbd.tsx +28 -0
  735. package/src/lib/ui/NativeSelect.tsx +47 -0
  736. package/src/lib/ui/ReactComponentDoc.tsx +17 -17
  737. package/src/lib/ui/Select.tsx +153 -126
  738. package/src/lib/ui/Separator.tsx +25 -0
  739. package/src/lib/ui/SyntaxHighlight.tsx +6 -1
  740. package/src/lib/ui/Tooltip.tsx +54 -32
  741. package/src/lib/util/MdxComponents.tsx +5 -5
  742. package/src/lib/util/createVariantComponent.tsx +31 -5
  743. package/src/lib/util/flattenAllOf.test.ts +689 -0
  744. package/src/lib/util/flattenAllOf.ts +122 -0
  745. package/src/lib/util/invariant.ts +2 -1
  746. package/src/lib/util/readFrontmatter.ts +13 -0
  747. package/src/lib/util/syncZustandState.ts +22 -0
  748. package/src/shiki/langs/markdown-nix.js +1 -0
  749. package/src/shiki/langs/openscad.js +1 -0
  750. package/dist/lib/plugins/openapi/playground/InlineInput.d.ts +0 -4
  751. package/dist/lib/plugins/openapi/playground/InlineInput.js +0 -3
  752. package/dist/lib/plugins/openapi/playground/InlineInput.js.map +0 -1
  753. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.d.ts +0 -5
  754. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js +0 -7
  755. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.js.map +0 -1
  756. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.d.ts +0 -4
  757. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js +0 -10
  758. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.js.map +0 -1
  759. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.d.ts +0 -5
  760. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js +0 -16
  761. package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js.map +0 -1
  762. package/dist/vite/create-pagefind-index.d.ts +0 -4
  763. package/dist/vite/create-pagefind-index.js +0 -12
  764. package/dist/vite/create-pagefind-index.js.map +0 -1
  765. package/lib/Button-DmS4u8Lj.js +0 -51
  766. package/lib/Button-DmS4u8Lj.js.map +0 -1
  767. package/lib/CodeBlock-CanTUJLl.js +0 -221
  768. package/lib/CodeBlock-CanTUJLl.js.map +0 -1
  769. package/lib/Command-CJY6q3PF.js.map +0 -1
  770. package/lib/Dialog-BOl0QB3n.js +0 -114
  771. package/lib/Dialog-BOl0QB3n.js.map +0 -1
  772. package/lib/DropdownMenu-BZ2NKQ3K.js +0 -126
  773. package/lib/DropdownMenu-BZ2NKQ3K.js.map +0 -1
  774. package/lib/ErrorAlert-VBJ8aHH7.js.map +0 -1
  775. package/lib/MdxPage-DFRNwSsc.js +0 -239
  776. package/lib/MdxPage-DFRNwSsc.js.map +0 -1
  777. package/lib/OAuthErrorPage-DJUOdr6Q.js.map +0 -1
  778. package/lib/OasProvider-BMUgPYQU.js +0 -36
  779. package/lib/OasProvider-BMUgPYQU.js.map +0 -1
  780. package/lib/OperationList-DVig5I94.js +0 -5446
  781. package/lib/OperationList-DVig5I94.js.map +0 -1
  782. package/lib/Pagination-CT4VUR6u.js +0 -37
  783. package/lib/Pagination-CT4VUR6u.js.map +0 -1
  784. package/lib/RouteGuard-BPWQlxy5.js +0 -56
  785. package/lib/RouteGuard-BPWQlxy5.js.map +0 -1
  786. package/lib/RouterError-fm21cqlj.js +0 -41
  787. package/lib/RouterError-fm21cqlj.js.map +0 -1
  788. package/lib/SchemaList-1eLKXqn8.js.map +0 -1
  789. package/lib/SchemaView-fq3uKfOA.js +0 -458
  790. package/lib/SchemaView-fq3uKfOA.js.map +0 -1
  791. package/lib/Select-CPoGZU_V.js +0 -372
  792. package/lib/Select-CPoGZU_V.js.map +0 -1
  793. package/lib/SignUp-BraHuRN_.js +0 -56
  794. package/lib/SignUp-BraHuRN_.js.map +0 -1
  795. package/lib/SyntaxHighlight-B0laqAqK.js.map +0 -1
  796. package/lib/Toc-KzXCRqrX.js.map +0 -1
  797. package/lib/ZudokuContext-BXTZApgy.js +0 -1506
  798. package/lib/ZudokuContext-BXTZApgy.js.map +0 -1
  799. package/lib/chunk-PVWAREVJ-BO6B-RAk.js +0 -7965
  800. package/lib/chunk-PVWAREVJ-BO6B-RAk.js.map +0 -1
  801. package/lib/circular-D6wbrxuf.js.map +0 -1
  802. package/lib/cn-dYga0KKN.js.map +0 -1
  803. package/lib/createServer-C5aY10Bc.js +0 -12559
  804. package/lib/createServer-C5aY10Bc.js.map +0 -1
  805. package/lib/hook-CAebs2rv.js +0 -31
  806. package/lib/hook-CAebs2rv.js.map +0 -1
  807. package/lib/index-BPSpOxTK.js +0 -1058
  808. package/lib/index-BPSpOxTK.js.map +0 -1
  809. package/lib/index-Bb9AsFlk.js +0 -3318
  810. package/lib/index-Bb9AsFlk.js.map +0 -1
  811. package/lib/invariant-Bm-FVUQE.js.map +0 -1
  812. package/lib/mutation-CdGPxHNX.js.map +0 -1
  813. package/lib/useExposedProps-Cd7Yg_uG.js +0 -113
  814. package/lib/useExposedProps-Cd7Yg_uG.js.map +0 -1
  815. package/src/lib/plugins/openapi/playground/InlineInput.tsx +0 -6
  816. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupConnector.tsx +0 -36
  817. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupItem.tsx +0 -25
  818. package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.tsx +0 -42
@@ -1,5 +1,7 @@
1
1
  import type { Auth0AuthenticationConfig } from "../../../config/config.js";
2
+ import { joinUrl } from "../../util/joinUrl.js";
2
3
  import type {
4
+ AuthActionContext,
3
5
  AuthenticationPlugin,
4
6
  AuthenticationProviderInitializer,
5
7
  } from "../authentication.js";
@@ -27,17 +29,25 @@ class Auth0AuthenticationProvider
27
29
  url: URL,
28
30
  { isSignUp }: { isSignUp: boolean },
29
31
  ) => {
30
- if (this.options?.alwaysPromptLogin !== false) {
32
+ if (this.options?.prompt !== undefined) {
33
+ if (this.options.prompt !== "") {
34
+ url.searchParams.set("prompt", this.options.prompt);
35
+ }
36
+ } else if (this.options?.alwaysPromptLogin !== false) {
31
37
  url.searchParams.set("prompt", "login");
32
38
  }
39
+
33
40
  if (isSignUp) {
34
41
  url.searchParams.set("screen_hint", "signup");
35
42
  }
36
43
  };
37
44
 
38
- signOut = async (): Promise<void> => {
45
+ signOut = async (_: AuthActionContext): Promise<void> => {
39
46
  const as = await this.getAuthServer();
40
- const idToken = await this.getAccessToken();
47
+
48
+ // biome-ignore lint/suspicious/noExplicitAny: We don't have a good way for typing provider-data yet.
49
+ const providerData = useAuthState.getState().providerData as any;
50
+ const idToken = providerData?.idToken;
41
51
 
42
52
  useAuthState.setState({
43
53
  isAuthenticated: false,
@@ -47,15 +57,18 @@ class Auth0AuthenticationProvider
47
57
  });
48
58
 
49
59
  const redirectUrl = new URL(window.location.origin);
50
- redirectUrl.pathname = this.redirectToAfterSignOut;
60
+ redirectUrl.pathname = joinUrl(
61
+ import.meta.env.BASE_URL,
62
+ this.redirectToAfterSignOut,
63
+ );
51
64
 
52
65
  // SEE: https://auth0.com/docs/authenticate/login/logout/log-users-out-of-auth0
53
66
  // For Auth0 tenants created on or after 14 November 2023, RP-Initiated
54
67
  // Logout End Session Endpoint Discovery is enabled by default.
55
68
  // Otherwise we fallback to the old non-compliant logout
56
69
 
57
- // The endSessionEndpoint is set, the IdP supports some form of logout,
58
- // so we use the IdP logout. Otherwise, just redirect the user to home
70
+ // The end_session_endpoint is set, the IdP supports some form of logout,
71
+ // so we use auth0 logout. Otherwise, just redirect the user to home
59
72
  if (as.end_session_endpoint) {
60
73
  const logoutUrl = new URL(as.end_session_endpoint);
61
74
  if (idToken) {
@@ -66,12 +79,11 @@ class Auth0AuthenticationProvider
66
79
  redirectUrl.toString(),
67
80
  );
68
81
 
69
- // window.location.href = logoutUrl.toString();
82
+ window.location.href = logoutUrl.toString();
70
83
  } else {
71
- const _logoutUrl = new URL(
72
- `${this.issuer.replace(/\/$/, "")}/oidc/logout`,
73
- );
74
- // window.location.href = logoutUrl.toString();
84
+ // const logoutUrl = new URL(`${this.issuer.replace(/\/$/, "")}/v2/logout`);
85
+ // logoutUrl.searchParams.set("returnTo", redirectUrl.toString());
86
+ // don't support the deprecated logout today
75
87
  }
76
88
  };
77
89
  }
@@ -6,6 +6,7 @@ import { ClientOnly } from "../../components/ClientOnly.js";
6
6
  import { joinUrl } from "../../util/joinUrl.js";
7
7
  import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
8
8
  import type {
9
+ AuthActionContext,
9
10
  AuthenticationPlugin,
10
11
  AuthenticationProviderInitializer,
11
12
  } from "../authentication.js";
@@ -106,7 +107,10 @@ export class AzureB2CAuthPlugin
106
107
  });
107
108
  }
108
109
 
109
- async signUp({ redirectTo }: { redirectTo?: string } = {}) {
110
+ async signUp(
111
+ _: AuthActionContext,
112
+ { redirectTo }: { redirectTo?: string } = {},
113
+ ) {
110
114
  const redirectUri = this.redirectToAfterSignUp ?? redirectTo ?? "/";
111
115
  sessionStorage.setItem("redirect-to", redirectUri);
112
116
 
@@ -116,7 +120,10 @@ export class AzureB2CAuthPlugin
116
120
  });
117
121
  }
118
122
 
119
- async signIn({ redirectTo }: { redirectTo?: string } = {}) {
123
+ async signIn(
124
+ _: AuthActionContext,
125
+ { redirectTo }: { redirectTo?: string } = {},
126
+ ) {
120
127
  const redirectUri = this.redirectToAfterSignIn ?? redirectTo ?? "/";
121
128
  sessionStorage.setItem("redirect-to", redirectUri);
122
129
 
@@ -156,7 +163,7 @@ export class AzureB2CAuthPlugin
156
163
  return request;
157
164
  };
158
165
 
159
- signOut = async () => {
166
+ signOut = async (_: AuthActionContext) => {
160
167
  const account = this.msalInstance.getAllAccounts()[0];
161
168
  if (account) {
162
169
  await this.msalInstance.logoutRedirect({
@@ -3,6 +3,7 @@ import { LogOutIcon } from "lucide-react";
3
3
  import type { ZudokuPlugin } from "zudoku/plugins";
4
4
  import type { ClerkAuthenticationConfig } from "../../../config/config.js";
5
5
  import type {
6
+ AuthActionContext,
6
7
  AuthenticationPlugin,
7
8
  AuthenticationProviderInitializer,
8
9
  } from "../authentication.js";
@@ -28,32 +29,6 @@ const clerkAuth: AuthenticationProviderInitializer<
28
29
 
29
30
  await clerkApi.load();
30
31
 
31
- if (clerkApi.user) {
32
- const verifiedEmail = clerkApi.user.emailAddresses.find(
33
- (email) => email.verification.status === "verified",
34
- );
35
- useAuthState.getState().setLoggedIn({
36
- profile: {
37
- sub: clerkApi.user.id,
38
- name: clerkApi.user.fullName ?? undefined,
39
- email:
40
- verifiedEmail?.emailAddress ??
41
- clerkApi.user.emailAddresses[0]?.emailAddress,
42
- emailVerified: verifiedEmail !== undefined,
43
- pictureUrl: clerkApi.user.imageUrl,
44
- },
45
- providerData: {
46
- user: {
47
- publicMetadata: clerkApi.user.publicMetadata,
48
- id: clerkApi.user.id,
49
- emailAddresses: clerkApi.user.emailAddresses,
50
- imageUrl: clerkApi.user.imageUrl,
51
- fullName: clerkApi.user.fullName,
52
- },
53
- },
54
- });
55
- }
56
-
57
32
  return clerkApi;
58
33
  })();
59
34
 
@@ -147,7 +122,10 @@ const clerkAuth: AuthenticationProviderInitializer<
147
122
  });
148
123
  useAuthState.getState().setLoggedOut();
149
124
  },
150
- signIn: async ({ redirectTo }: { redirectTo?: string } = {}) => {
125
+ signIn: async (
126
+ _: AuthActionContext,
127
+ { redirectTo }: { redirectTo?: string } = {},
128
+ ) => {
151
129
  await ensureLoaded;
152
130
  await clerkApi?.redirectToSignIn({
153
131
  signInForceRedirectUrl: redirectToAfterSignIn
@@ -158,7 +136,10 @@ const clerkAuth: AuthenticationProviderInitializer<
158
136
  : redirectTo,
159
137
  });
160
138
  },
161
- signUp: async ({ redirectTo }: { redirectTo?: string } = {}) => {
139
+ signUp: async (
140
+ _: AuthActionContext,
141
+ { redirectTo }: { redirectTo?: string } = {},
142
+ ) => {
162
143
  await ensureLoaded;
163
144
  await clerkApi?.redirectToSignUp({
164
145
  signInForceRedirectUrl: redirectToAfterSignIn
@@ -0,0 +1,376 @@
1
+ import { type FirebaseApp, initializeApp } from "firebase/app";
2
+ import {
3
+ type Auth,
4
+ createUserWithEmailAndPassword,
5
+ getAuth,
6
+ sendEmailVerification,
7
+ sendPasswordResetEmail,
8
+ signInWithEmailAndPassword,
9
+ signInWithPopup,
10
+ signOut,
11
+ type User,
12
+ } from "firebase/auth";
13
+ import type { FirebaseAuthenticationConfig } from "../../../config/config.js";
14
+ import { ZudokuError } from "../../util/invariant.js";
15
+ import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
16
+ import type {
17
+ AuthActionContext,
18
+ AuthActionOptions,
19
+ AuthenticationPlugin,
20
+ AuthenticationProviderInitializer,
21
+ } from "../authentication.js";
22
+ import { SignOut } from "../components/SignOut.js";
23
+ import { AuthorizationError } from "../errors.js";
24
+ import { useAuthState } from "../state.js";
25
+ import { EmailVerificationUi } from "../ui/EmailVerificationUi.js";
26
+ import {
27
+ ZudokuPasswordResetUi,
28
+ ZudokuSignInUi,
29
+ ZudokuSignUpUi,
30
+ } from "../ui/ZudokuAuthUi.js";
31
+
32
+ class FirebaseAuthenticationProvider
33
+ extends CoreAuthenticationPlugin
34
+ implements AuthenticationPlugin
35
+ {
36
+ private readonly app: FirebaseApp;
37
+ private readonly auth: Auth;
38
+ private readonly providers: string[];
39
+ private readonly enableUsernamePassword: boolean;
40
+
41
+ constructor(config: FirebaseAuthenticationConfig) {
42
+ super();
43
+
44
+ this.app = initializeApp({
45
+ apiKey: config.apiKey,
46
+ authDomain: config.authDomain,
47
+ projectId: config.projectId,
48
+ storageBucket: config.storageBucket,
49
+ messagingSenderId: config.messagingSenderId,
50
+ appId: config.appId,
51
+ measurementId: config.measurementId,
52
+ });
53
+ this.auth = getAuth(this.app);
54
+ this.providers = config.providers?.filter((p) => p !== "password") ?? [];
55
+ this.enableUsernamePassword =
56
+ config.providers?.includes("password") ?? false;
57
+ }
58
+
59
+ async initialize() {
60
+ await this.auth.authStateReady();
61
+ }
62
+
63
+ async signRequest(request: Request): Promise<Request> {
64
+ const accessToken = await this.auth.currentUser?.getIdToken();
65
+ if (!accessToken) {
66
+ throw new AuthorizationError("User is not authenticated");
67
+ }
68
+ request.headers.set("Authorization", `Bearer ${accessToken}`);
69
+ return request;
70
+ }
71
+
72
+ signUp = async (
73
+ { navigate }: AuthActionContext,
74
+ { redirectTo }: AuthActionOptions,
75
+ ) => {
76
+ void navigate(
77
+ redirectTo
78
+ ? `/signup?redirectTo=${encodeURIComponent(redirectTo)}`
79
+ : `/signup`,
80
+ );
81
+ };
82
+
83
+ signIn = async (
84
+ { navigate }: AuthActionContext,
85
+ { redirectTo }: AuthActionOptions,
86
+ ) => {
87
+ void navigate(
88
+ redirectTo
89
+ ? `/signin?redirectTo=${encodeURIComponent(redirectTo)}`
90
+ : `/signin`,
91
+ );
92
+ };
93
+
94
+ requestEmailVerification = async (
95
+ { navigate }: AuthActionContext,
96
+ { redirectTo }: AuthActionOptions,
97
+ ) => {
98
+ if (!this.auth.currentUser) {
99
+ throw new ZudokuError("User is not authenticated", {
100
+ title: "User not authenticated",
101
+ });
102
+ }
103
+
104
+ await sendEmailVerification(this.auth.currentUser);
105
+ void navigate(
106
+ redirectTo
107
+ ? `/verify-email?redirectTo=${encodeURIComponent(redirectTo)}`
108
+ : `/verify-email`,
109
+ );
110
+ };
111
+
112
+ getRoutes = () => {
113
+ return [
114
+ {
115
+ path: "/verify-email",
116
+ element: (
117
+ <EmailVerificationUi
118
+ onResendVerification={async () => {
119
+ if (!this.auth.currentUser) {
120
+ throw new ZudokuError("User is not authenticated", {
121
+ title: "User not authenticated",
122
+ });
123
+ }
124
+ await sendEmailVerification(this.auth.currentUser);
125
+ }}
126
+ onCheckVerification={async () => {
127
+ if (!this.auth.currentUser) {
128
+ throw new ZudokuError("User is not authenticated", {
129
+ title: "User not authenticated",
130
+ });
131
+ }
132
+ await this.auth.currentUser.reload();
133
+ const isVerified = this.auth.currentUser.emailVerified;
134
+
135
+ if (isVerified) {
136
+ await this.auth.currentUser.getIdToken(true);
137
+ await this.setUserLoggedIn(this.auth.currentUser);
138
+ }
139
+
140
+ return isVerified;
141
+ }}
142
+ />
143
+ ),
144
+ },
145
+ {
146
+ path: "/reset-password",
147
+ element: (
148
+ <ZudokuPasswordResetUi
149
+ onPasswordReset={async (email: string) => {
150
+ try {
151
+ await sendPasswordResetEmail(this.auth, email);
152
+ } catch (error) {
153
+ throw Error(getFirebaseErrorMessage(error), { cause: error });
154
+ }
155
+ }}
156
+ />
157
+ ),
158
+ },
159
+ {
160
+ path: "/signin",
161
+ element: (
162
+ <ZudokuSignInUi
163
+ providers={this.providers}
164
+ enableUsernamePassword={this.enableUsernamePassword}
165
+ onOAuthSignIn={async (providerId: string) => {
166
+ useAuthState.setState({ isPending: true });
167
+ const provider = await getProviderForId(providerId);
168
+ if (!provider) {
169
+ throw new AuthorizationError(
170
+ `Provider ${providerId} not found`,
171
+ );
172
+ }
173
+ const result = await signInWithPopup(this.auth, provider);
174
+ useAuthState.setState({ isPending: false });
175
+ useAuthState.getState().setLoggedIn({
176
+ providerData: { user: result.user },
177
+ profile: {
178
+ sub: result.user.uid,
179
+ email: result.user.email ?? undefined,
180
+ name: result.user.displayName ?? undefined,
181
+ emailVerified: result.user.emailVerified,
182
+ pictureUrl: result.user.photoURL ?? undefined,
183
+ },
184
+ });
185
+ }}
186
+ onUsernamePasswordSignIn={async (
187
+ email: string,
188
+ password: string,
189
+ ) => {
190
+ try {
191
+ useAuthState.setState({ isPending: false });
192
+ const result = await signInWithEmailAndPassword(
193
+ this.auth,
194
+ email,
195
+ password,
196
+ );
197
+ await this.setUserLoggedIn(result.user);
198
+ } catch (error) {
199
+ throw Error(getFirebaseErrorMessage(error), { cause: error });
200
+ }
201
+ }}
202
+ />
203
+ ),
204
+ },
205
+ {
206
+ path: "/signup",
207
+ element: (
208
+ <ZudokuSignUpUi
209
+ providers={this.providers}
210
+ enableUsernamePassword={this.enableUsernamePassword}
211
+ onOAuthSignUp={async (providerId: string) => {
212
+ const provider = await getProviderForId(providerId);
213
+ if (!provider) {
214
+ throw new AuthorizationError(
215
+ `Provider ${providerId} not found`,
216
+ );
217
+ }
218
+ await signInWithPopup(this.auth, provider);
219
+ }}
220
+ onUsernamePasswordSignUp={async (
221
+ email: string,
222
+ password: string,
223
+ ) => {
224
+ useAuthState.setState({ isPending: true });
225
+ const createUser = await createUserWithEmailAndPassword(
226
+ this.auth,
227
+ email,
228
+ password,
229
+ );
230
+ await this.setUserLoggedIn(createUser.user);
231
+ }}
232
+ />
233
+ ),
234
+ },
235
+ {
236
+ path: "/signout",
237
+ element: <SignOut />,
238
+ },
239
+ ];
240
+ };
241
+
242
+ signOut = async () => {
243
+ await signOut(this.auth);
244
+
245
+ useAuthState.setState({
246
+ isAuthenticated: false,
247
+ isPending: false,
248
+ profile: undefined,
249
+ providerData: undefined,
250
+ });
251
+ };
252
+
253
+ onPageLoad = async () => {
254
+ const user = this.auth.currentUser;
255
+
256
+ if (user) {
257
+ await this.setUserLoggedIn(user);
258
+ } else {
259
+ useAuthState.setState({ isPending: false });
260
+ }
261
+ };
262
+
263
+ private async setUserLoggedIn(user: User) {
264
+ useAuthState.getState().setLoggedIn({
265
+ profile: {
266
+ sub: user.uid,
267
+ email: user.email ?? undefined,
268
+ name: user.displayName ?? undefined,
269
+ emailVerified: user.emailVerified,
270
+ pictureUrl: user.photoURL ?? undefined,
271
+ },
272
+ providerData: { user },
273
+ });
274
+ }
275
+ }
276
+
277
+ const supabaseAuth: AuthenticationProviderInitializer<
278
+ FirebaseAuthenticationConfig
279
+ > = (options) => new FirebaseAuthenticationProvider(options);
280
+
281
+ export default supabaseAuth;
282
+
283
+ const getProviderForId = async (providerId: string) => {
284
+ switch (providerId) {
285
+ case "google": {
286
+ const { GoogleAuthProvider } = await import("firebase/auth");
287
+ return new GoogleAuthProvider();
288
+ }
289
+ case "github": {
290
+ const { GithubAuthProvider } = await import("firebase/auth");
291
+ return new GithubAuthProvider();
292
+ }
293
+ case "facebook": {
294
+ const { FacebookAuthProvider } = await import("firebase/auth");
295
+ return new FacebookAuthProvider();
296
+ }
297
+ case "twitter": {
298
+ const { TwitterAuthProvider } = await import("firebase/auth");
299
+ return new TwitterAuthProvider();
300
+ }
301
+ case "microsoft": {
302
+ const { OAuthProvider } = await import("firebase/auth");
303
+ return new OAuthProvider("microsoft.com");
304
+ }
305
+ case "apple": {
306
+ const { OAuthProvider } = await import("firebase/auth");
307
+ return new OAuthProvider("apple.com");
308
+ }
309
+ case "yahoo": {
310
+ const { OAuthProvider } = await import("firebase/auth");
311
+ return new OAuthProvider("yahoo.com");
312
+ }
313
+ }
314
+
315
+ throw new AuthorizationError(`Provider ${providerId} not found`);
316
+ };
317
+
318
+ const getFirebaseErrorMessage = (error: unknown): string => {
319
+ if (!(error instanceof Error)) {
320
+ return "An unexpected error occurred. Please try again.";
321
+ }
322
+
323
+ const errorCode = (error as { code?: string }).code;
324
+
325
+ switch (errorCode) {
326
+ case "auth/email-already-in-use":
327
+ return "The email address is already used by another account.";
328
+ case "auth/invalid-email":
329
+ return "That email address isn't correct.";
330
+ case "auth/operation-not-allowed":
331
+ return "This sign-in method is not enabled. Please contact support.";
332
+ case "auth/weak-password":
333
+ return "The password must be at least 6 characters long.";
334
+ case "auth/user-disabled":
335
+ return "This account has been disabled. Please contact support.";
336
+ case "auth/user-not-found":
337
+ return "That email address doesn't match an existing account.";
338
+ case "auth/wrong-password":
339
+ return "The email and password you entered don't match.";
340
+ case "auth/too-many-requests":
341
+ return "You have entered an incorrect password too many times. Please try again in a few minutes.";
342
+ case "auth/popup-blocked":
343
+ return "The sign-in popup was blocked by your browser. Please allow popups and try again.";
344
+ case "auth/popup-closed-by-user":
345
+ return "The sign-in popup was closed before completing. Please try again.";
346
+ case "auth/network-request-failed":
347
+ return "A network error has occurred. Please check your connection and try again.";
348
+ case "auth/requires-recent-login":
349
+ return "Please login again to perform this operation.";
350
+ case "auth/invalid-credential":
351
+ return "The credential is invalid or has expired. Please try again.";
352
+ case "auth/account-exists-with-different-credential":
353
+ return "An account already exists with the same email address but different sign-in credentials.";
354
+ case "auth/credential-already-in-use":
355
+ return "This credential is already associated with a different user account.";
356
+ case "auth/invalid-verification-code":
357
+ return "Wrong code. Try again.";
358
+ case "auth/invalid-verification-id":
359
+ return "The verification ID is invalid.";
360
+ case "auth/missing-verification-code":
361
+ return "Please enter the verification code.";
362
+ case "auth/user-cancelled":
363
+ return "Please authorize the required permissions to sign in.";
364
+ case "auth/expired-action-code":
365
+ return "This code has expired.";
366
+ case "auth/invalid-action-code":
367
+ return "The action code is invalid. This can happen if the code is malformed or has already been used.";
368
+ case "auth/unauthorized-domain":
369
+ return "This domain is not authorized for OAuth operations.";
370
+ default:
371
+ return (
372
+ error.message ||
373
+ "An error occurred during authentication. Please try again."
374
+ );
375
+ }
376
+ };
@@ -1,11 +1,14 @@
1
1
  import logger from "loglevel";
2
2
  import * as oauth from "oauth4webapi";
3
3
  import { ErrorBoundary } from "react-error-boundary";
4
+ import type { NavigateFunction } from "react-router";
4
5
  import type { OpenIDAuthenticationConfig } from "../../../config/config.js";
5
6
  import { ClientOnly } from "../../components/ClientOnly.js";
6
7
  import { joinUrl } from "../../util/joinUrl.js";
7
8
  import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
8
9
  import type {
10
+ AuthActionContext,
11
+ AuthActionOptions,
9
12
  AuthenticationPlugin,
10
13
  AuthenticationProviderInitializer,
11
14
  } from "../authentication.js";
@@ -115,13 +118,16 @@ export class OpenIDAuthenticationProvider
115
118
  });
116
119
  }
117
120
 
118
- async signUp({
119
- redirectTo,
120
- replace = false,
121
- }: {
122
- redirectTo?: string;
123
- replace?: boolean;
124
- } = {}) {
121
+ async signUp(
122
+ _: { navigate: NavigateFunction },
123
+ {
124
+ redirectTo,
125
+ replace = false,
126
+ }: {
127
+ redirectTo?: string;
128
+ replace?: boolean;
129
+ } = {},
130
+ ) {
125
131
  return this.authorize({
126
132
  redirectTo: this.redirectToAfterSignUp ?? redirectTo ?? "/",
127
133
  replace,
@@ -129,13 +135,10 @@ export class OpenIDAuthenticationProvider
129
135
  });
130
136
  }
131
137
 
132
- async signIn({
133
- redirectTo,
134
- replace = false,
135
- }: {
136
- redirectTo?: string;
137
- replace?: boolean;
138
- } = {}) {
138
+ async signIn(
139
+ _: AuthActionContext,
140
+ { redirectTo, replace = false }: AuthActionOptions,
141
+ ) {
139
142
  return this.authorize({
140
143
  redirectTo: this.redirectToAfterSignIn ?? redirectTo ?? "/",
141
144
  replace,
@@ -261,7 +264,7 @@ export class OpenIDAuthenticationProvider
261
264
  return request;
262
265
  };
263
266
 
264
- signOut = async () => {
267
+ signOut = async (_: AuthActionContext) => {
265
268
  useAuthState.setState({
266
269
  isAuthenticated: false,
267
270
  isPending: false,
@@ -0,0 +1,75 @@
1
+ import { Auth } from "@supabase/auth-ui-react";
2
+ import {
3
+ ThemeSupa,
4
+ type ThemeVariables,
5
+ type ViewType,
6
+ } from "@supabase/auth-ui-shared";
7
+ import type { SupabaseClient } from "@supabase/supabase-js";
8
+ import { useSearchParams } from "react-router";
9
+ import type { SupabaseAuthenticationConfig } from "../../../../config/config.js";
10
+ import { Heading } from "../../../components/Heading.js";
11
+
12
+ export const SupabaseAuthUI = ({
13
+ client,
14
+ config,
15
+ view = "sign_in",
16
+ }: {
17
+ client: SupabaseClient;
18
+ config: SupabaseAuthenticationConfig;
19
+ view: ViewType;
20
+ }) => {
21
+ const [searchParams] = useSearchParams();
22
+ const redirectTo = searchParams.get("redirectTo");
23
+ const providers = config.provider ? [config.provider] : config.providers;
24
+ const root = config.basePath ?? "/";
25
+ const redirectToAfterSignUp =
26
+ redirectTo ?? config.redirectToAfterSignUp ?? root;
27
+ const redirectToAfterSignIn =
28
+ redirectTo ?? config.redirectToAfterSignIn ?? root;
29
+ const redirectToAfterSignOut =
30
+ redirectTo ?? config.redirectToAfterSignOut ?? root;
31
+
32
+ return (
33
+ <div className="flex items-center justify-center">
34
+ <div className="max-w-md w-full mt-10">
35
+ <Heading level={1}>
36
+ {view === "sign_in" ? "Sign in" : "Sign up"}
37
+ </Heading>
38
+ <Auth
39
+ view={view}
40
+ redirectToAfterSignIn={redirectToAfterSignIn}
41
+ redirectToAfterSignUp={redirectToAfterSignUp}
42
+ redirectToAfterSignOut={redirectToAfterSignOut}
43
+ supabaseClient={client}
44
+ onlyThirdPartyProviders={config.onlyThirdPartyProviders}
45
+ appearance={{
46
+ theme: ThemeSupa,
47
+ variables: {
48
+ default: {
49
+ colors: {
50
+ dividerBackground: "var(--border)",
51
+ brand: "var(--primary)",
52
+ brandAccent: "hsla(from var(--primary) h s l / 0.8)",
53
+ brandButtonText: "var(--primary-foreground)",
54
+ defaultButtonBorder: "var(--border)",
55
+ inputBorder: "var(--border)",
56
+ inputText: "var(--foreground)",
57
+ inputBorderHover: "var(--accent)",
58
+ defaultButtonBackground: "var(--secondary)",
59
+ defaultButtonBackgroundHover: "var(--accent)",
60
+ },
61
+ radii: {
62
+ borderRadiusButton: "var(--radius)",
63
+ buttonBorderRadius: "var(--radius)",
64
+ inputBorderRadius: "var(--radius)",
65
+ },
66
+ } satisfies ThemeVariables,
67
+ },
68
+ }}
69
+ providers={providers}
70
+ redirectTo={config.redirectToAfterSignIn ?? "/"}
71
+ />
72
+ </div>
73
+ </div>
74
+ );
75
+ };