zudoku 0.0.0-f417aae → 0.0.0-f49e3ea

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 (649) hide show
  1. package/cli.js +2 -2
  2. package/dist/app/demo.js +0 -2
  3. package/dist/app/demo.js.map +1 -1
  4. package/dist/app/entry.client.js +16 -2
  5. package/dist/app/entry.client.js.map +1 -1
  6. package/dist/app/entry.server.js +9 -6
  7. package/dist/app/entry.server.js.map +1 -1
  8. package/dist/app/main.d.ts +2 -1
  9. package/dist/app/main.js +9 -24
  10. package/dist/app/main.js.map +1 -1
  11. package/dist/app/standalone.js +0 -2
  12. package/dist/app/standalone.js.map +1 -1
  13. package/dist/cli/cli.js +1 -2
  14. package/dist/cli/cli.js.map +1 -1
  15. package/dist/cli/common/machine-id/lib.js.map +1 -1
  16. package/dist/cli/common/outdated.js.map +1 -1
  17. package/dist/cli/common/utils/box.js.map +1 -1
  18. package/dist/codegen.d.ts +3 -0
  19. package/dist/codegen.js +45 -0
  20. package/dist/codegen.js.map +1 -0
  21. package/dist/config/validators/InputSidebarSchema.d.ts +12 -12
  22. package/dist/config/validators/SidebarSchema.d.ts +24 -1
  23. package/dist/config/validators/SidebarSchema.js +76 -39
  24. package/dist/config/validators/SidebarSchema.js.map +1 -1
  25. package/dist/config/validators/validate.d.ts +335 -259
  26. package/dist/config/validators/validate.js +13 -11
  27. package/dist/config/validators/validate.js.map +1 -1
  28. package/dist/index.d.ts +4 -1
  29. package/dist/index.js +1 -1
  30. package/dist/index.js.map +1 -1
  31. package/dist/lib/authentication/authentication.d.ts +2 -2
  32. package/dist/lib/authentication/hook.d.ts +5 -4
  33. package/dist/lib/authentication/hook.js +1 -3
  34. package/dist/lib/authentication/hook.js.map +1 -1
  35. package/dist/lib/authentication/providers/auth0.js +12 -11
  36. package/dist/lib/authentication/providers/auth0.js.map +1 -1
  37. package/dist/lib/authentication/providers/openid.d.ts +0 -1
  38. package/dist/lib/authentication/providers/openid.js +11 -26
  39. package/dist/lib/authentication/providers/openid.js.map +1 -1
  40. package/dist/lib/authentication/state.d.ts +25 -4
  41. package/dist/lib/authentication/state.js +28 -3
  42. package/dist/lib/authentication/state.js.map +1 -1
  43. package/dist/lib/authentication/use-broadcast/shared.d.ts +48 -0
  44. package/dist/lib/authentication/use-broadcast/shared.js +243 -0
  45. package/dist/lib/authentication/use-broadcast/shared.js.map +1 -0
  46. package/dist/lib/authentication/use-broadcast/useBroadcast.d.ts +24 -0
  47. package/dist/lib/authentication/use-broadcast/useBroadcast.js +106 -0
  48. package/dist/lib/authentication/use-broadcast/useBroadcast.js.map +1 -0
  49. package/dist/lib/components/Bootstrap.d.ts +3 -1
  50. package/dist/lib/components/Bootstrap.js +11 -3
  51. package/dist/lib/components/Bootstrap.js.map +1 -1
  52. package/dist/lib/components/ClientOnly.d.ts +4 -2
  53. package/dist/lib/components/ClientOnly.js +1 -1
  54. package/dist/lib/components/ClientOnly.js.map +1 -1
  55. package/dist/lib/components/DeveloperHint.js +2 -1
  56. package/dist/lib/components/DeveloperHint.js.map +1 -1
  57. package/dist/lib/components/Header.js +10 -7
  58. package/dist/lib/components/Header.js.map +1 -1
  59. package/dist/lib/components/Heading.d.ts +1 -1
  60. package/dist/lib/components/Layout.js +6 -3
  61. package/dist/lib/components/Layout.js.map +1 -1
  62. package/dist/lib/components/MobileTopNavigation.js +6 -7
  63. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  64. package/dist/lib/components/SlotletProvider.d.ts +2 -1
  65. package/dist/lib/components/SlotletProvider.js.map +1 -1
  66. package/dist/lib/components/SyntaxHighlight.js +19 -12
  67. package/dist/lib/components/SyntaxHighlight.js.map +1 -1
  68. package/dist/lib/components/ThemeSwitch.d.ts +1 -0
  69. package/dist/lib/components/ThemeSwitch.js +13 -0
  70. package/dist/lib/components/ThemeSwitch.js.map +1 -0
  71. package/dist/lib/components/TopNavigation.d.ts +2 -0
  72. package/dist/lib/components/TopNavigation.js +36 -5
  73. package/dist/lib/components/TopNavigation.js.map +1 -1
  74. package/dist/lib/components/{DevPortal.d.ts → Zudoku.d.ts} +3 -3
  75. package/dist/lib/components/{DevPortal.js → Zudoku.js} +13 -14
  76. package/dist/lib/components/Zudoku.js.map +1 -0
  77. package/dist/lib/components/context/ZudokuContext.d.ts +10 -16
  78. package/dist/lib/components/context/ZudokuContext.js +27 -26
  79. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  80. package/dist/lib/components/context/ZudokuProvider.d.ts +2 -2
  81. package/dist/lib/components/context/ZudokuProvider.js.map +1 -1
  82. package/dist/lib/components/index.d.ts +18 -10
  83. package/dist/lib/components/index.js +2 -3
  84. package/dist/lib/components/index.js.map +1 -1
  85. package/dist/lib/components/navigation/Sidebar.js +3 -3
  86. package/dist/lib/components/navigation/Sidebar.js.map +1 -1
  87. package/dist/lib/components/navigation/SidebarCategory.js +2 -4
  88. package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
  89. package/dist/lib/components/navigation/SidebarItem.js +1 -3
  90. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  91. package/dist/lib/components/navigation/utils.js +10 -14
  92. package/dist/lib/components/navigation/utils.js.map +1 -1
  93. package/dist/lib/core/{DevPortalContext.d.ts → ZudokuContext.d.ts} +6 -14
  94. package/dist/lib/core/{DevPortalContext.js → ZudokuContext.js} +2 -7
  95. package/dist/lib/core/ZudokuContext.js.map +1 -0
  96. package/dist/lib/core/plugins.d.ts +13 -12
  97. package/dist/lib/core/plugins.js.map +1 -1
  98. package/dist/lib/errors/ErrorAlert.js +1 -1
  99. package/dist/lib/errors/ErrorAlert.js.map +1 -1
  100. package/dist/lib/oas/graphql/index.js +4 -4
  101. package/dist/lib/oas/graphql/index.js.map +1 -1
  102. package/dist/lib/oas/parser/upgrade/index.js +3 -1
  103. package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
  104. package/dist/lib/plugins/api-keys/CreateApiKey.js +1 -1
  105. package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
  106. package/dist/lib/plugins/api-keys/index.d.ts +9 -9
  107. package/dist/lib/plugins/api-keys/index.js.map +1 -1
  108. package/dist/lib/plugins/custom-pages/CustomPage.js +2 -2
  109. package/dist/lib/plugins/custom-pages/index.d.ts +2 -2
  110. package/dist/lib/plugins/custom-pages/index.js.map +1 -1
  111. package/dist/lib/plugins/markdown/index.d.ts +6 -7
  112. package/dist/lib/plugins/markdown/index.js +31 -3
  113. package/dist/lib/plugins/markdown/index.js.map +1 -1
  114. package/dist/lib/plugins/markdown/resolver.d.ts +38 -0
  115. package/dist/lib/plugins/markdown/resolver.js +75 -0
  116. package/dist/lib/plugins/markdown/resolver.js.map +1 -0
  117. package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +5 -0
  118. package/dist/lib/plugins/openapi/CollapsibleCode.js +24 -0
  119. package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -0
  120. package/dist/lib/plugins/openapi/ColorizedParam.js +13 -9
  121. package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
  122. package/dist/lib/plugins/openapi/Endpoint.d.ts +1 -1
  123. package/dist/lib/plugins/openapi/Endpoint.js +5 -9
  124. package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
  125. package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
  126. package/dist/lib/plugins/openapi/OperationList.js +21 -22
  127. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  128. package/dist/lib/plugins/openapi/ParameterListItem.js +6 -1
  129. package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
  130. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +7 -3
  131. package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
  132. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +9 -2
  133. package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
  134. package/dist/lib/plugins/openapi/Route.d.ts +4 -4
  135. package/dist/lib/plugins/openapi/Route.js +2 -4
  136. package/dist/lib/plugins/openapi/Route.js.map +1 -1
  137. package/dist/lib/plugins/openapi/Sidecar.d.ts +1 -1
  138. package/dist/lib/plugins/openapi/Sidecar.js +35 -33
  139. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  140. package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +8 -0
  141. package/dist/lib/plugins/openapi/client/GraphQLClient.js +102 -0
  142. package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -0
  143. package/dist/lib/plugins/openapi/client/GraphQLContext.d.ts +7 -0
  144. package/dist/lib/plugins/openapi/client/GraphQLContext.js +5 -0
  145. package/dist/lib/plugins/openapi/client/GraphQLContext.js.map +1 -0
  146. package/dist/lib/plugins/openapi/client/createServer.d.ts +1 -0
  147. package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +5 -0
  148. package/dist/lib/plugins/openapi/client/useCreateQuery.js +13 -0
  149. package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -0
  150. package/dist/lib/plugins/openapi/client/worker.d.ts +4 -1
  151. package/dist/lib/plugins/openapi/client/worker.js +23 -14
  152. package/dist/lib/plugins/openapi/client/worker.js.map +1 -1
  153. package/dist/lib/plugins/openapi/graphql/fragment-masking.d.ts +3 -3
  154. package/dist/lib/plugins/openapi/graphql/fragment-masking.js +3 -4
  155. package/dist/lib/plugins/openapi/graphql/fragment-masking.js.map +1 -1
  156. package/dist/lib/plugins/openapi/graphql/gql.d.ts +5 -51
  157. package/dist/lib/plugins/openapi/graphql/gql.js +4 -2
  158. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  159. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +32 -8
  160. package/dist/lib/plugins/openapi/graphql/graphql.js +194 -662
  161. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  162. package/dist/lib/plugins/openapi/index.d.ts +2 -2
  163. package/dist/lib/plugins/openapi/index.js +40 -53
  164. package/dist/lib/plugins/openapi/index.js.map +1 -1
  165. package/dist/lib/plugins/openapi/playground/Playground.js +1 -1
  166. package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
  167. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
  168. package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
  169. package/dist/lib/plugins/openapi/schema/SchemaView.js +2 -1
  170. package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
  171. package/dist/lib/plugins/openapi/util/generateSchemaExample.d.ts +0 -1
  172. package/dist/lib/plugins/openapi/util/generateSchemaExample.js +25 -36
  173. package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
  174. package/dist/lib/plugins/openapi-worker.d.ts +1 -1
  175. package/dist/lib/plugins/openapi-worker.js +7 -1
  176. package/dist/lib/plugins/openapi-worker.js.map +1 -1
  177. package/dist/lib/plugins/redirect/index.d.ts +4 -7
  178. package/dist/lib/plugins/redirect/index.js +1 -1
  179. package/dist/lib/plugins/redirect/index.js.map +1 -1
  180. package/dist/lib/plugins/search-inkeep/index.d.ts +2 -2
  181. package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
  182. package/dist/lib/ui/Accordion.d.ts +7 -0
  183. package/dist/lib/ui/Accordion.js +14 -0
  184. package/dist/lib/ui/Accordion.js.map +1 -0
  185. package/dist/lib/ui/ActionButton.d.ts +4 -0
  186. package/dist/lib/ui/ActionButton.js +10 -0
  187. package/dist/lib/ui/ActionButton.js.map +1 -0
  188. package/dist/lib/ui/Alert.d.ts +8 -0
  189. package/dist/lib/ui/Alert.js +23 -0
  190. package/dist/lib/ui/Alert.js.map +1 -0
  191. package/dist/lib/ui/AlertDialog.d.ts +20 -0
  192. package/dist/lib/ui/AlertDialog.js +27 -0
  193. package/dist/lib/ui/AlertDialog.js.map +1 -0
  194. package/dist/lib/ui/AspectRatio.d.ts +3 -0
  195. package/dist/lib/ui/AspectRatio.js +4 -0
  196. package/dist/lib/ui/AspectRatio.js.map +1 -0
  197. package/dist/lib/ui/Badge.d.ts +9 -0
  198. package/dist/lib/ui/Badge.js +21 -0
  199. package/dist/lib/ui/Badge.js.map +1 -0
  200. package/dist/lib/ui/Breadcrumb.d.ts +19 -0
  201. package/dist/lib/ui/Breadcrumb.js +24 -0
  202. package/dist/lib/ui/Breadcrumb.js.map +1 -0
  203. package/dist/lib/ui/Button.d.ts +2 -3
  204. package/dist/lib/ui/Button.js +1 -1
  205. package/dist/lib/ui/Button.js.map +1 -1
  206. package/dist/lib/ui/Carousel.d.ts +18 -0
  207. package/dist/lib/ui/Carousel.js +99 -0
  208. package/dist/lib/ui/Carousel.js.map +1 -0
  209. package/dist/lib/ui/Checkbox.d.ts +4 -0
  210. package/dist/lib/ui/Checkbox.js +9 -0
  211. package/dist/lib/ui/Checkbox.js.map +1 -0
  212. package/dist/lib/ui/Collapsible.d.ts +5 -0
  213. package/dist/lib/ui/Collapsible.js +6 -0
  214. package/dist/lib/ui/Collapsible.js.map +1 -0
  215. package/dist/lib/ui/Command.d.ts +80 -0
  216. package/dist/lib/ui/Command.js +31 -0
  217. package/dist/lib/ui/Command.js.map +1 -0
  218. package/dist/lib/{components → ui}/Dialog.js +2 -2
  219. package/dist/lib/ui/Dialog.js.map +1 -0
  220. package/dist/lib/ui/Form.d.ts +23 -0
  221. package/dist/lib/ui/Form.js +63 -0
  222. package/dist/lib/ui/Form.js.map +1 -0
  223. package/dist/lib/ui/HoverCard.d.ts +6 -0
  224. package/dist/lib/ui/HoverCard.js +10 -0
  225. package/dist/lib/ui/HoverCard.js.map +1 -0
  226. package/dist/lib/ui/Label.d.ts +5 -0
  227. package/dist/lib/ui/Label.js +10 -0
  228. package/dist/lib/ui/Label.js.map +1 -0
  229. package/dist/lib/ui/Pagination.d.ts +28 -0
  230. package/dist/lib/ui/Pagination.js +24 -0
  231. package/dist/lib/ui/Pagination.js.map +1 -0
  232. package/dist/lib/ui/Popover.d.ts +6 -0
  233. package/dist/lib/ui/Popover.js +10 -0
  234. package/dist/lib/ui/Popover.js.map +1 -0
  235. package/dist/lib/ui/Progress.d.ts +4 -0
  236. package/dist/lib/ui/Progress.js +8 -0
  237. package/dist/lib/ui/Progress.js.map +1 -0
  238. package/dist/lib/ui/RadioGroup.d.ts +5 -0
  239. package/dist/lib/ui/RadioGroup.js +15 -0
  240. package/dist/lib/ui/RadioGroup.js.map +1 -0
  241. package/dist/lib/ui/ScrollArea.d.ts +5 -0
  242. package/dist/lib/ui/ScrollArea.js +12 -0
  243. package/dist/lib/ui/ScrollArea.js.map +1 -0
  244. package/dist/lib/ui/Select.js.map +1 -0
  245. package/dist/lib/ui/Skeleton.d.ts +2 -0
  246. package/dist/lib/ui/Skeleton.js +7 -0
  247. package/dist/lib/ui/Skeleton.js.map +1 -0
  248. package/dist/lib/ui/Slider.d.ts +4 -0
  249. package/dist/lib/ui/Slider.js +8 -0
  250. package/dist/lib/ui/Slider.js.map +1 -0
  251. package/dist/lib/ui/Switch.d.ts +4 -0
  252. package/dist/lib/ui/Switch.js +8 -0
  253. package/dist/lib/ui/Switch.js.map +1 -0
  254. package/dist/lib/ui/Textarea.d.ts +4 -0
  255. package/dist/lib/ui/Textarea.js +9 -0
  256. package/dist/lib/ui/Textarea.js.map +1 -0
  257. package/dist/lib/ui/Toggle.d.ts +12 -0
  258. package/dist/lib/ui/Toggle.js +26 -0
  259. package/dist/lib/ui/Toggle.js.map +1 -0
  260. package/dist/lib/ui/ToggleGroup.d.ts +12 -0
  261. package/dist/lib/ui/ToggleGroup.js +21 -0
  262. package/dist/lib/ui/ToggleGroup.js.map +1 -0
  263. package/dist/lib/ui/Tooltip.d.ts +7 -0
  264. package/dist/lib/ui/Tooltip.js +11 -0
  265. package/dist/lib/ui/Tooltip.js.map +1 -0
  266. package/dist/lib/util/MdxComponents.d.ts +1 -1
  267. package/dist/lib/util/MdxComponents.js.map +1 -1
  268. package/dist/lib/util/useExposedProps.js +3 -2
  269. package/dist/lib/util/useExposedProps.js.map +1 -1
  270. package/dist/lib/util/useIsomorphicLayoutEffect.d.ts +3 -0
  271. package/dist/lib/util/useIsomorphicLayoutEffect.js +4 -0
  272. package/dist/lib/util/useIsomorphicLayoutEffect.js.map +1 -0
  273. package/dist/lib/util/useOnScreen.d.ts +4 -0
  274. package/dist/lib/util/useOnScreen.js +19 -0
  275. package/dist/lib/util/useOnScreen.js.map +1 -0
  276. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  277. package/dist/vite/build.js +12 -3
  278. package/dist/vite/build.js.map +1 -1
  279. package/dist/vite/config.d.ts +2 -8
  280. package/dist/vite/config.js +24 -60
  281. package/dist/vite/config.js.map +1 -1
  282. package/dist/vite/debug.d.ts +1 -0
  283. package/dist/vite/debug.js +10 -0
  284. package/dist/vite/debug.js.map +1 -0
  285. package/dist/vite/html.js +0 -2
  286. package/dist/vite/html.js.map +1 -1
  287. package/dist/vite/output.d.ts +101 -0
  288. package/dist/vite/output.js +33 -0
  289. package/dist/vite/output.js.map +1 -0
  290. package/dist/vite/plugin-component.js +17 -7
  291. package/dist/vite/plugin-component.js.map +1 -1
  292. package/dist/vite/plugin-config-reload.js +0 -2
  293. package/dist/vite/plugin-config-reload.js.map +1 -1
  294. package/dist/vite/plugin-config.d.ts +2 -3
  295. package/dist/vite/plugin-config.js +2 -3
  296. package/dist/vite/plugin-config.js.map +1 -1
  297. package/dist/vite/plugin-docs.js +37 -26
  298. package/dist/vite/plugin-docs.js.map +1 -1
  299. package/dist/vite/plugin-frontmatter.d.ts +2 -1
  300. package/dist/vite/plugin-frontmatter.js +27 -24
  301. package/dist/vite/plugin-frontmatter.js.map +1 -1
  302. package/dist/vite/plugin-mdx.d.ts +0 -6
  303. package/dist/vite/plugin-mdx.js +3 -2
  304. package/dist/vite/plugin-mdx.js.map +1 -1
  305. package/dist/vite/plugin-sidebar.js +7 -6
  306. package/dist/vite/plugin-sidebar.js.map +1 -1
  307. package/dist/vite/plugin.js +2 -4
  308. package/dist/vite/plugin.js.map +1 -1
  309. package/dist/vite/prerender.d.ts +5 -1
  310. package/dist/vite/prerender.js +7 -5
  311. package/dist/vite/prerender.js.map +1 -1
  312. package/dist/vite/remarkStaticGeneration.d.ts +3 -0
  313. package/dist/vite/remarkStaticGeneration.js +125 -0
  314. package/dist/vite/remarkStaticGeneration.js.map +1 -0
  315. package/lib/{utils-G5XSiZc9.js → AnchorLink-CDlhr8gL.js} +232 -275
  316. package/lib/AnchorLink-CDlhr8gL.js.map +1 -0
  317. package/lib/{AuthenticationPlugin-tBvLKsFg.js → AuthenticationPlugin-DeGDVa1r.js} +6 -5
  318. package/lib/{AuthenticationPlugin-tBvLKsFg.js.map → AuthenticationPlugin-DeGDVa1r.js.map} +1 -1
  319. package/lib/Button-jK0EsymC.js +48 -0
  320. package/lib/Button-jK0EsymC.js.map +1 -0
  321. package/lib/{CategoryHeading-D2WS6sRI.js → CategoryHeading-Bb9dqxD3.js} +4 -4
  322. package/lib/{CategoryHeading-D2WS6sRI.js.map → CategoryHeading-Bb9dqxD3.js.map} +1 -1
  323. package/lib/{ClientOnly-CVN6leDu.js → ClientOnly-E7hGysn1.js} +4 -4
  324. package/lib/ClientOnly-E7hGysn1.js.map +1 -0
  325. package/lib/Dialog-k70Qfukb.js +67 -0
  326. package/lib/Dialog-k70Qfukb.js.map +1 -0
  327. package/lib/Markdown-ievDDhFT.js +15192 -0
  328. package/lib/Markdown-ievDDhFT.js.map +1 -0
  329. package/lib/{MdxPage-tWI_P8wP.js → MdxPage-Bwn-VSsH.js} +32 -30
  330. package/lib/{MdxPage-tWI_P8wP.js.map → MdxPage-Bwn-VSsH.js.map} +1 -1
  331. package/lib/OperationList-BwBl1xrD.js +4691 -0
  332. package/lib/OperationList-BwBl1xrD.js.map +1 -0
  333. package/lib/Route-DlG_HTMu.js +11 -0
  334. package/lib/Route-DlG_HTMu.js.map +1 -0
  335. package/lib/Select-O9ZM3ZgX.js +223 -0
  336. package/lib/Select-O9ZM3ZgX.js.map +1 -0
  337. package/lib/SidebarBadge-DxFJcJ6V.js +51 -0
  338. package/lib/SidebarBadge-DxFJcJ6V.js.map +1 -0
  339. package/lib/SlotletProvider-DyomlzGx.js +252 -0
  340. package/lib/SlotletProvider-DyomlzGx.js.map +1 -0
  341. package/lib/Spinner-3cQDBVGr.js +7 -0
  342. package/lib/Spinner-3cQDBVGr.js.map +1 -0
  343. package/lib/SyntaxHighlight-DkLOsjHS.js +2983 -0
  344. package/lib/SyntaxHighlight-DkLOsjHS.js.map +1 -0
  345. package/lib/__vite-browser-external-BYRIRx8p.js +9 -0
  346. package/lib/__vite-browser-external-BYRIRx8p.js.map +1 -0
  347. package/lib/assets/{worker-Bf8vjASY.js → worker-CPsGZsve.js} +565 -561
  348. package/lib/assets/{worker-Bf8vjASY.js.map → worker-CPsGZsve.js.map} +1 -1
  349. package/lib/cn-BmFQLtkS.js +2279 -0
  350. package/lib/cn-BmFQLtkS.js.map +1 -0
  351. package/lib/context-D1nXWxm7.js +22 -0
  352. package/lib/context-D1nXWxm7.js.map +1 -0
  353. package/lib/createServer-DK-g7kbB.js +16089 -0
  354. package/lib/createServer-DK-g7kbB.js.map +1 -0
  355. package/lib/hook-hEqe7fPB.js +227 -0
  356. package/lib/hook-hEqe7fPB.js.map +1 -0
  357. package/lib/index-BuAyrJe3.js +46 -0
  358. package/lib/index-BuAyrJe3.js.map +1 -0
  359. package/lib/index-Czzd9rjU.js +899 -0
  360. package/lib/index-Czzd9rjU.js.map +1 -0
  361. package/lib/index-DNxQ_rCt.js +1273 -0
  362. package/lib/index-DNxQ_rCt.js.map +1 -0
  363. package/lib/index-Yn8c3UWE.js +921 -0
  364. package/lib/index-Yn8c3UWE.js.map +1 -0
  365. package/lib/index.esm-C5mr_sKO.js +1193 -0
  366. package/lib/index.esm-C5mr_sKO.js.map +1 -0
  367. package/lib/{router-BsfSoK2j.js → router-lfyopgBI.js} +23 -23
  368. package/lib/{router-BsfSoK2j.js.map → router-lfyopgBI.js.map} +1 -1
  369. package/lib/state-tsXBLONe.js +203 -0
  370. package/lib/{state-CsuHT8ZO.js.map → state-tsXBLONe.js.map} +1 -1
  371. package/lib/ui/Accordion.js +47 -0
  372. package/lib/ui/Accordion.js.map +1 -0
  373. package/lib/ui/ActionButton.js +25 -0
  374. package/lib/ui/ActionButton.js.map +1 -0
  375. package/lib/ui/Alert.js +51 -0
  376. package/lib/ui/Alert.js.map +1 -0
  377. package/lib/ui/AlertDialog.js +114 -0
  378. package/lib/ui/AlertDialog.js.map +1 -0
  379. package/lib/ui/AspectRatio.js +6 -0
  380. package/lib/ui/AspectRatio.js.map +1 -0
  381. package/lib/ui/Badge.js +27 -0
  382. package/lib/ui/Badge.js.map +1 -0
  383. package/lib/ui/Breadcrumb.js +94 -0
  384. package/lib/ui/Breadcrumb.js.map +1 -0
  385. package/lib/ui/Button.js +49 -0
  386. package/lib/ui/Button.js.map +1 -0
  387. package/lib/ui/Callout.js +77 -0
  388. package/lib/ui/Callout.js.map +1 -0
  389. package/lib/ui/Card.js +62 -0
  390. package/lib/ui/Card.js.map +1 -0
  391. package/lib/ui/Carousel.js +1410 -0
  392. package/lib/ui/Carousel.js.map +1 -0
  393. package/lib/ui/Checkbox.js +28 -0
  394. package/lib/ui/Checkbox.js.map +1 -0
  395. package/lib/ui/Collapsible.js +8 -0
  396. package/lib/ui/Collapsible.js.map +1 -0
  397. package/lib/ui/Command.js +550 -0
  398. package/lib/ui/Command.js.map +1 -0
  399. package/lib/ui/Dialog.js +101 -0
  400. package/lib/ui/Dialog.js.map +1 -0
  401. package/lib/ui/Drawer.js +1153 -0
  402. package/lib/ui/Drawer.js.map +1 -0
  403. package/lib/ui/DropdownMenu.js +145 -0
  404. package/lib/ui/DropdownMenu.js.map +1 -0
  405. package/lib/ui/Form.js +95 -0
  406. package/lib/ui/Form.js.map +1 -0
  407. package/lib/ui/HoverCard.js +24 -0
  408. package/lib/ui/HoverCard.js.map +1 -0
  409. package/lib/ui/Input.js +22 -0
  410. package/lib/ui/Input.js.map +1 -0
  411. package/lib/ui/Label.js +20 -0
  412. package/lib/ui/Label.js.map +1 -0
  413. package/lib/ui/Pagination.js +106 -0
  414. package/lib/ui/Pagination.js.map +1 -0
  415. package/lib/ui/Popover.js +24 -0
  416. package/lib/ui/Popover.js.map +1 -0
  417. package/lib/ui/Progress.js +27 -0
  418. package/lib/ui/Progress.js.map +1 -0
  419. package/lib/ui/RadioGroup.js +32 -0
  420. package/lib/ui/RadioGroup.js.map +1 -0
  421. package/lib/ui/ScrollArea.js +39 -0
  422. package/lib/ui/ScrollArea.js.map +1 -0
  423. package/lib/ui/Select.js +122 -0
  424. package/lib/ui/Select.js.map +1 -0
  425. package/lib/ui/Skeleton.js +18 -0
  426. package/lib/ui/Skeleton.js.map +1 -0
  427. package/lib/ui/Slider.js +24 -0
  428. package/lib/ui/Slider.js.map +1 -0
  429. package/lib/ui/Switch.js +28 -0
  430. package/lib/ui/Switch.js.map +1 -0
  431. package/lib/ui/Tabs.js +47 -0
  432. package/lib/ui/Tabs.js.map +1 -0
  433. package/lib/ui/Textarea.js +21 -0
  434. package/lib/ui/Textarea.js.map +1 -0
  435. package/lib/ui/Toggle.js +38 -0
  436. package/lib/ui/Toggle.js.map +1 -0
  437. package/lib/ui/ToggleGroup.js +42 -0
  438. package/lib/ui/ToggleGroup.js.map +1 -0
  439. package/lib/ui/Tooltip.js +24 -0
  440. package/lib/ui/Tooltip.js.map +1 -0
  441. package/lib/useExposedProps-CTPtylCV.js +10 -0
  442. package/lib/useExposedProps-CTPtylCV.js.map +1 -0
  443. package/lib/{ZudokuContext-DEoP3GGJ.js → utils-DcpDOncX.js} +455 -410
  444. package/lib/utils-DcpDOncX.js.map +1 -0
  445. package/lib/zudoku.auth-auth0.js +24 -18
  446. package/lib/zudoku.auth-auth0.js.map +1 -1
  447. package/lib/zudoku.auth-clerk.js +2 -2
  448. package/lib/zudoku.auth-openid.js +124 -138
  449. package/lib/zudoku.auth-openid.js.map +1 -1
  450. package/lib/zudoku.components.js +1128 -2987
  451. package/lib/zudoku.components.js.map +1 -1
  452. package/lib/zudoku.openapi-worker.js +10 -16336
  453. package/lib/zudoku.openapi-worker.js.map +1 -1
  454. package/lib/zudoku.plugin-api-keys.js +24 -21
  455. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  456. package/lib/zudoku.plugin-custom-pages.js +9 -8
  457. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  458. package/lib/zudoku.plugin-markdown.js +93 -27
  459. package/lib/zudoku.plugin-markdown.js.map +1 -1
  460. package/lib/zudoku.plugin-openapi.js +6 -10
  461. package/lib/zudoku.plugin-openapi.js.map +1 -1
  462. package/lib/zudoku.plugin-redirect.js +2 -2
  463. package/lib/zudoku.plugin-redirect.js.map +1 -1
  464. package/lib/zudoku.plugin-search-inkeep.js +1 -1
  465. package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
  466. package/package.json +43 -11
  467. package/src/app/demo.tsx +0 -3
  468. package/src/app/entry.client.tsx +18 -2
  469. package/src/app/entry.server.tsx +60 -50
  470. package/src/app/main.css +5 -1
  471. package/src/app/main.tsx +14 -30
  472. package/src/app/standalone.tsx +1 -4
  473. package/src/lib/authentication/authentication.ts +2 -2
  474. package/src/lib/authentication/hook.ts +1 -3
  475. package/src/lib/authentication/providers/auth0.tsx +17 -11
  476. package/src/lib/authentication/providers/openid.tsx +12 -30
  477. package/src/lib/authentication/state.ts +50 -9
  478. package/{LICENSE.md → src/lib/authentication/use-broadcast/LICENSE.md} +2 -2
  479. package/src/lib/authentication/use-broadcast/shared.ts +372 -0
  480. package/src/lib/authentication/use-broadcast/useBroadcast.ts +146 -0
  481. package/src/lib/components/Bootstrap.tsx +36 -9
  482. package/src/lib/components/ClientOnly.tsx +6 -3
  483. package/src/lib/components/DeveloperHint.tsx +6 -1
  484. package/src/lib/components/Header.tsx +50 -40
  485. package/src/lib/components/Layout.tsx +43 -36
  486. package/src/lib/components/MobileTopNavigation.tsx +15 -18
  487. package/src/lib/components/SlotletProvider.tsx +2 -0
  488. package/src/lib/components/SyntaxHighlight.tsx +85 -46
  489. package/src/lib/components/ThemeSwitch.tsx +26 -0
  490. package/src/lib/components/TopNavigation.tsx +66 -24
  491. package/src/lib/components/Zudoku.tsx +108 -0
  492. package/src/lib/components/context/ZudokuContext.ts +33 -30
  493. package/src/lib/components/context/ZudokuProvider.tsx +2 -2
  494. package/src/lib/components/index.ts +2 -3
  495. package/src/lib/components/navigation/Sidebar.tsx +5 -5
  496. package/src/lib/components/navigation/SidebarCategory.tsx +2 -4
  497. package/src/lib/components/navigation/SidebarItem.tsx +1 -3
  498. package/src/lib/components/navigation/utils.ts +11 -16
  499. package/src/lib/core/{DevPortalContext.ts → ZudokuContext.ts} +6 -18
  500. package/src/lib/core/plugins.ts +14 -16
  501. package/src/lib/errors/ErrorAlert.tsx +2 -1
  502. package/src/lib/oas/graphql/index.ts +4 -4
  503. package/src/lib/oas/parser/upgrade/index.ts +3 -1
  504. package/src/lib/plugins/api-keys/CreateApiKey.tsx +2 -2
  505. package/src/lib/plugins/api-keys/index.tsx +9 -9
  506. package/src/lib/plugins/custom-pages/CustomPage.tsx +2 -2
  507. package/src/lib/plugins/custom-pages/index.tsx +2 -2
  508. package/src/lib/plugins/markdown/index.tsx +50 -13
  509. package/src/lib/plugins/markdown/resolver.ts +92 -0
  510. package/src/lib/plugins/openapi/CollapsibleCode.tsx +80 -0
  511. package/src/lib/plugins/openapi/ColorizedParam.tsx +23 -14
  512. package/src/lib/plugins/openapi/Endpoint.tsx +7 -12
  513. package/src/lib/plugins/openapi/OperationList.tsx +20 -40
  514. package/src/lib/plugins/openapi/ParameterListItem.tsx +37 -31
  515. package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +18 -13
  516. package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +17 -12
  517. package/src/lib/plugins/openapi/Route.tsx +11 -12
  518. package/src/lib/plugins/openapi/Sidecar.tsx +73 -59
  519. package/src/lib/plugins/openapi/client/GraphQLClient.tsx +140 -0
  520. package/src/lib/plugins/openapi/client/GraphQLContext.tsx +16 -0
  521. package/src/lib/plugins/openapi/client/createServer.ts +2 -0
  522. package/src/lib/plugins/openapi/client/useCreateQuery.ts +18 -0
  523. package/src/lib/plugins/openapi/client/worker.ts +38 -24
  524. package/src/lib/plugins/openapi/graphql/fragment-masking.ts +11 -18
  525. package/src/lib/plugins/openapi/graphql/gql.ts +10 -27
  526. package/src/lib/plugins/openapi/graphql/graphql.ts +233 -665
  527. package/src/lib/plugins/openapi/index.tsx +42 -67
  528. package/src/lib/plugins/openapi/playground/Playground.tsx +3 -3
  529. package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +1 -1
  530. package/src/lib/plugins/openapi/schema/SchemaView.tsx +5 -2
  531. package/src/lib/plugins/openapi/util/generateSchemaExample.ts +28 -42
  532. package/src/lib/plugins/openapi-worker.ts +11 -1
  533. package/src/lib/plugins/redirect/index.tsx +5 -9
  534. package/src/lib/plugins/search-inkeep/index.tsx +2 -2
  535. package/src/lib/ui/Accordion.tsx +56 -0
  536. package/src/lib/ui/ActionButton.tsx +28 -0
  537. package/src/lib/ui/{Note.tsx → Alert.tsx} +11 -10
  538. package/src/lib/ui/AlertDialog.tsx +139 -0
  539. package/src/lib/ui/AspectRatio.tsx +5 -0
  540. package/src/lib/ui/Badge.tsx +36 -0
  541. package/src/lib/ui/Breadcrumb.tsx +115 -0
  542. package/src/lib/ui/Button.tsx +1 -1
  543. package/src/lib/ui/Carousel.tsx +260 -0
  544. package/src/lib/ui/Checkbox.tsx +28 -0
  545. package/src/lib/ui/Collapsible.tsx +9 -0
  546. package/src/lib/ui/Command.tsx +151 -0
  547. package/src/lib/{components → ui}/Dialog.tsx +4 -3
  548. package/src/lib/ui/Form.tsx +177 -0
  549. package/src/lib/ui/HoverCard.tsx +27 -0
  550. package/src/lib/ui/Label.tsx +24 -0
  551. package/src/lib/ui/Pagination.tsx +117 -0
  552. package/src/lib/ui/Popover.tsx +29 -0
  553. package/src/lib/ui/Progress.tsx +26 -0
  554. package/src/lib/ui/RadioGroup.tsx +42 -0
  555. package/src/lib/ui/ScrollArea.tsx +46 -0
  556. package/src/lib/ui/Skeleton.tsx +15 -0
  557. package/src/lib/ui/Slider.tsx +26 -0
  558. package/src/lib/ui/Switch.tsx +27 -0
  559. package/src/lib/ui/Textarea.tsx +23 -0
  560. package/src/lib/ui/Toggle.tsx +43 -0
  561. package/src/lib/ui/ToggleGroup.tsx +59 -0
  562. package/src/lib/ui/Tooltip.tsx +28 -0
  563. package/src/lib/util/MdxComponents.tsx +0 -1
  564. package/src/lib/util/useExposedProps.tsx +8 -2
  565. package/src/lib/util/useIsomorphicLayoutEffect.ts +5 -0
  566. package/src/lib/util/useOnScreen.ts +32 -0
  567. package/src/lib/util/useScrollToAnchor.ts +1 -1
  568. package/dist/internal.d.ts +0 -1
  569. package/dist/internal.js +0 -2
  570. package/dist/internal.js.map +0 -1
  571. package/dist/lib/components/DevPortal.js.map +0 -1
  572. package/dist/lib/components/Dialog.js.map +0 -1
  573. package/dist/lib/components/Select.js.map +0 -1
  574. package/dist/lib/components/context/ThemeContext.d.ts +0 -2
  575. package/dist/lib/components/context/ThemeContext.js +0 -7
  576. package/dist/lib/components/context/ThemeContext.js.map +0 -1
  577. package/dist/lib/components/context/ThemeProvider.d.ts +0 -4
  578. package/dist/lib/components/context/ThemeProvider.js +0 -23
  579. package/dist/lib/components/context/ThemeProvider.js.map +0 -1
  580. package/dist/lib/core/DevPortalContext.js.map +0 -1
  581. package/dist/lib/plugins/markdown/generateRoutes.d.ts +0 -3
  582. package/dist/lib/plugins/markdown/generateRoutes.js +0 -21
  583. package/dist/lib/plugins/markdown/generateRoutes.js.map +0 -1
  584. package/dist/lib/plugins/openapi/client/createMemoryClient.d.ts +0 -12
  585. package/dist/lib/plugins/openapi/client/createMemoryClient.js +0 -46
  586. package/dist/lib/plugins/openapi/client/createMemoryClient.js.map +0 -1
  587. package/dist/lib/plugins/openapi/client/createWorkerClient.d.ts +0 -10
  588. package/dist/lib/plugins/openapi/client/createWorkerClient.js +0 -61
  589. package/dist/lib/plugins/openapi/client/createWorkerClient.js.map +0 -1
  590. package/dist/lib/plugins/openapi/client/interfaces.d.ts +0 -4
  591. package/dist/lib/plugins/openapi/client/interfaces.js +0 -2
  592. package/dist/lib/plugins/openapi/client/interfaces.js.map +0 -1
  593. package/dist/lib/themeToggle.d.ts +0 -1
  594. package/dist/lib/themeToggle.js +0 -7
  595. package/dist/lib/themeToggle.js.map +0 -1
  596. package/dist/lib/ui/Note.d.ts +0 -8
  597. package/dist/lib/ui/Note.js +0 -23
  598. package/dist/lib/ui/Note.js.map +0 -1
  599. package/dist/lib/util/createWaitForNotify.d.ts +0 -1
  600. package/dist/lib/util/createWaitForNotify.js +0 -15
  601. package/dist/lib/util/createWaitForNotify.js.map +0 -1
  602. package/dist/vite/plugin-html-transform.d.ts +0 -2
  603. package/dist/vite/plugin-html-transform.js +0 -15
  604. package/dist/vite/plugin-html-transform.js.map +0 -1
  605. package/lib/ClientOnly-CVN6leDu.js.map +0 -1
  606. package/lib/DeveloperHint-CRiZjqd2.js +0 -16
  607. package/lib/DeveloperHint-CRiZjqd2.js.map +0 -1
  608. package/lib/Input-CO-1DOZa.js +0 -2229
  609. package/lib/Input-CO-1DOZa.js.map +0 -1
  610. package/lib/Markdown-DM4zv3MA.js +0 -20442
  611. package/lib/Markdown-DM4zv3MA.js.map +0 -1
  612. package/lib/OperationList-Cd3lue0b.js +0 -600
  613. package/lib/OperationList-Cd3lue0b.js.map +0 -1
  614. package/lib/Route-DI0Y0pIV.js +0 -13
  615. package/lib/Route-DI0Y0pIV.js.map +0 -1
  616. package/lib/SlotletProvider-CBqY8mp6.js +0 -241
  617. package/lib/SlotletProvider-CBqY8mp6.js.map +0 -1
  618. package/lib/Spinner-DFQhPMBl.js +0 -505
  619. package/lib/Spinner-DFQhPMBl.js.map +0 -1
  620. package/lib/ZudokuContext-DEoP3GGJ.js.map +0 -1
  621. package/lib/index-Bs9roz8y.js +0 -5973
  622. package/lib/index-Bs9roz8y.js.map +0 -1
  623. package/lib/index-CBr6BM_4.js +0 -2867
  624. package/lib/index-CBr6BM_4.js.map +0 -1
  625. package/lib/index-CRo94sKK.js +0 -1783
  626. package/lib/index-CRo94sKK.js.map +0 -1
  627. package/lib/index-UUT9q9f9.js +0 -124
  628. package/lib/index-UUT9q9f9.js.map +0 -1
  629. package/lib/joinPath-B7kNnUX4.js +0 -8
  630. package/lib/joinPath-B7kNnUX4.js.map +0 -1
  631. package/lib/state-CsuHT8ZO.js +0 -183
  632. package/lib/urql-core-KJnLL26g.js +0 -1455
  633. package/lib/urql-core-KJnLL26g.js.map +0 -1
  634. package/lib/useExposedProps-B9K-9GTc.js +0 -9
  635. package/lib/useExposedProps-B9K-9GTc.js.map +0 -1
  636. package/lib/utils-G5XSiZc9.js.map +0 -1
  637. package/src/lib/components/DevPortal.tsx +0 -111
  638. package/src/lib/components/context/ThemeContext.tsx +0 -8
  639. package/src/lib/components/context/ThemeProvider.tsx +0 -27
  640. package/src/lib/plugins/markdown/generateRoutes.tsx +0 -38
  641. package/src/lib/plugins/openapi/client/createMemoryClient.ts +0 -51
  642. package/src/lib/plugins/openapi/client/createWorkerClient.ts +0 -75
  643. package/src/lib/plugins/openapi/client/interfaces.ts +0 -5
  644. package/src/lib/themeToggle.ts +0 -7
  645. package/src/lib/util/createWaitForNotify.ts +0 -18
  646. /package/dist/lib/{components → ui}/Dialog.d.ts +0 -0
  647. /package/dist/lib/{components → ui}/Select.d.ts +0 -0
  648. /package/dist/lib/{components → ui}/Select.js +0 -0
  649. /package/src/lib/{components → ui}/Select.tsx +0 -0
@@ -1,9 +1,9 @@
1
- import { MoonStarIcon, SunIcon } from "lucide-react";
2
1
  import { memo } from "react";
3
2
  import { Link } from "react-router-dom";
3
+ import { Button } from "zudoku/ui/Button.js";
4
+ import { Skeleton } from "zudoku/ui/Skeleton.js";
4
5
  import { useAuth } from "../authentication/hook.js";
5
6
  import { isProfileMenuPlugin, ProfileNavigationItem } from "../core/plugins.js";
6
- import { Button } from "../ui/Button.js";
7
7
  import {
8
8
  DropdownMenu,
9
9
  DropdownMenuContent,
@@ -16,13 +16,14 @@ import {
16
16
  DropdownMenuSubTrigger,
17
17
  DropdownMenuTrigger,
18
18
  } from "../ui/DropdownMenu.js";
19
- import { cn } from "../util/cn.js";
19
+ import { joinPath } from "../util/joinPath.js";
20
20
  import { Banner } from "./Banner.js";
21
- import { useTheme } from "./context/ThemeContext.js";
21
+ import { ClientOnly } from "./ClientOnly.js";
22
22
  import { useZudoku } from "./context/ZudokuContext.js";
23
23
  import { MobileTopNavigation } from "./MobileTopNavigation.js";
24
24
  import { Search } from "./Search.js";
25
25
  import { Slotlet } from "./SlotletProvider.js";
26
+ import { ThemeSwitch } from "./ThemeSwitch.js";
26
27
  import { TopNavigation } from "./TopNavigation.js";
27
28
 
28
29
  const RecursiveMenu = ({ item }: { item: ProfileNavigationItem }) => {
@@ -47,7 +48,6 @@ const RecursiveMenu = ({ item }: { item: ProfileNavigationItem }) => {
47
48
 
48
49
  export const Header = memo(function HeaderInner() {
49
50
  const auth = useAuth();
50
- const [isDark, toggleTheme] = useTheme();
51
51
  const { isAuthenticated, profile, isAuthEnabled } = useAuth();
52
52
  const context = useZudoku();
53
53
  const { page, plugins } = context;
@@ -57,8 +57,6 @@ export const Header = memo(function HeaderInner() {
57
57
  .flatMap((p) => p.getProfileMenuItems(context))
58
58
  .map((i) => <RecursiveMenu key={i.label} item={i} />);
59
59
 
60
- const ThemeIcon = isDark ? MoonStarIcon : SunIcon;
61
-
62
60
  return (
63
61
  <header className="sticky lg:top-0 z-10 bg-background/80 backdrop-blur w-full">
64
62
  <Banner />
@@ -70,17 +68,32 @@ export const Header = memo(function HeaderInner() {
70
68
  {page?.logo && (
71
69
  <>
72
70
  <img
73
- src={page.logo.src.light}
71
+ src={
72
+ /https?:\/\//.test(page.logo.src.light)
73
+ ? page.logo.src.light
74
+ : joinPath(
75
+ import.meta.env.BASE_URL,
76
+ page.logo.src.light,
77
+ )
78
+ }
74
79
  alt={page.logo.alt ?? page.pageTitle}
75
80
  style={{ width: page.logo.width }}
76
- className={cn("h-10", isDark && "hidden")}
81
+ className="h-10 dark:hidden"
77
82
  loading="lazy"
78
83
  />
79
84
  <img
80
- src={page.logo.src.dark}
85
+ data-hide-on-theme="light"
86
+ src={
87
+ /https?:\/\//.test(page.logo.src.dark)
88
+ ? page.logo.src.dark
89
+ : joinPath(
90
+ import.meta.env.BASE_URL,
91
+ page.logo.src.dark,
92
+ )
93
+ }
81
94
  alt={page.logo.alt ?? page.pageTitle}
82
95
  style={{ width: page.logo.width }}
83
- className={cn("h-10", !isDark && "hidden")}
96
+ className="h-10"
84
97
  loading="lazy"
85
98
  />
86
99
  </>
@@ -99,36 +112,33 @@ export const Header = memo(function HeaderInner() {
99
112
  <MobileTopNavigation />
100
113
  <div className="hidden lg:flex items-center justify-self-end text-sm gap-2">
101
114
  <Slotlet name="head-navigation-start" />
102
- {isAuthEnabled && !isAuthenticated ? (
103
- <Button variant="ghost" onClick={() => auth.login()}>
104
- Login
105
- </Button>
106
- ) : (
107
- accountItems.length > 0 && (
108
- <DropdownMenu modal={false}>
109
- <DropdownMenuTrigger asChild>
110
- <Button variant="ghost">
111
- {profile?.email ? `${profile.email}` : "My Account"}
112
- </Button>
113
- </DropdownMenuTrigger>
114
- <DropdownMenuContent className="w-56">
115
- <DropdownMenuLabel>My Account</DropdownMenuLabel>
116
- <DropdownMenuSeparator />
117
- {accountItems}
118
- </DropdownMenuContent>
119
- </DropdownMenu>
120
- )
115
+ {isAuthEnabled && (
116
+ <ClientOnly
117
+ fallback={<Skeleton className="rounded h-5 w-24 mr-4" />}
118
+ >
119
+ {!isAuthenticated ? (
120
+ <Button variant="ghost" onClick={() => auth.login()}>
121
+ Login
122
+ </Button>
123
+ ) : (
124
+ accountItems.length > 0 && (
125
+ <DropdownMenu modal={false}>
126
+ <DropdownMenuTrigger asChild>
127
+ <Button variant="ghost">
128
+ {profile?.email ? `${profile.email}` : "My Account"}
129
+ </Button>
130
+ </DropdownMenuTrigger>
131
+ <DropdownMenuContent className="w-56">
132
+ <DropdownMenuLabel>My Account</DropdownMenuLabel>
133
+ <DropdownMenuSeparator />
134
+ {accountItems}
135
+ </DropdownMenuContent>
136
+ </DropdownMenu>
137
+ )
138
+ )}
139
+ </ClientOnly>
121
140
  )}
122
- <button
123
- type="button"
124
- aria-label={
125
- isDark ? "Switch to light mode" : "Switch to dark mode"
126
- }
127
- className="cursor-pointer hover:bg-secondary p-2.5 -m-2.5 rounded-full"
128
- onClick={toggleTheme}
129
- >
130
- <ThemeIcon size={18} />
131
- </button>
141
+ <ThemeSwitch />
132
142
  <Slotlet name="head-navigation-end" />
133
143
  </div>
134
144
  </div>
@@ -1,7 +1,7 @@
1
1
  import { Helmet } from "@zudoku/react-helmet-async";
2
2
  import { PanelLeftIcon } from "lucide-react";
3
3
  import { Suspense, useEffect, useRef, type ReactNode } from "react";
4
- import { Outlet, useLocation } from "react-router-dom";
4
+ import { Outlet, useLocation, useNavigation } from "react-router-dom";
5
5
  import { Drawer, DrawerTrigger } from "../ui/Drawer.js";
6
6
  import { cn } from "../util/cn.js";
7
7
  import { useScrollToAnchor } from "../util/useScrollToAnchor.js";
@@ -13,6 +13,12 @@ import { Sidebar } from "./navigation/Sidebar.js";
13
13
  import { Slotlet } from "./SlotletProvider.js";
14
14
  import { Spinner } from "./Spinner.js";
15
15
 
16
+ const LoadingFallback = () => (
17
+ <main className="grid h-[calc(100vh-var(--header-height))] place-items-center">
18
+ <Spinner />
19
+ </main>
20
+ );
21
+
16
22
  export const Layout = ({ children }: { children?: ReactNode }) => {
17
23
  const location = useLocation();
18
24
  const { setActiveAnchor } = useViewportAnchor();
@@ -36,6 +42,9 @@ export const Layout = ({ children }: { children?: ReactNode }) => {
36
42
  previousLocationPath.current = location.pathname;
37
43
  }, [location.pathname, setActiveAnchor]);
38
44
 
45
+ // Page transition is happening: https://reactrouter.com/start/framework/pending-ui#global-pending-navigation
46
+ const isNavigating = Boolean(useNavigation().location);
47
+
39
48
  return (
40
49
  <>
41
50
  {import.meta.env.MODE === "standalone" && (
@@ -52,41 +61,39 @@ export const Layout = ({ children }: { children?: ReactNode }) => {
52
61
  <Slotlet name="layout-after-head" />
53
62
 
54
63
  <div className="w-full max-w-screen-2xl mx-auto px-10 lg:px-12">
55
- <Suspense
56
- fallback={
57
- <main className="grid h-[calc(100vh-var(--header-height))] place-items-center">
58
- <Spinner />
59
- </main>
60
- }
61
- >
62
- <Drawer direction="left">
63
- <Sidebar />
64
- <div
65
- className={cn(
66
- "lg:hidden -mx-10 px-10 py-2 sticky bg-background/80 backdrop-blur z-10 top-0 left-0 right-0 border-b",
67
- "peer-data-[navigation=false]:hidden",
68
- )}
69
- >
70
- <DrawerTrigger className="flex items-center gap-2">
71
- <PanelLeftIcon size={16} strokeWidth={1.5} />
72
- <span className="text-sm">Menu</span>
73
- </DrawerTrigger>
74
- </div>
75
- <main
76
- className={cn(
77
- "h-full dark:border-white/10 translate-x-0",
78
- "lg:overflow-visible",
79
- // This works in tandem with the `SidebarWrapper` component
80
- "lg:peer-data-[navigation=true]:w-[calc(100%-var(--side-nav-width))]",
81
- "lg:peer-data-[navigation=true]:translate-x-[--side-nav-width] lg:peer-data-[navigation=true]:pl-12",
82
- )}
83
- >
84
- <Slotlet name="zudoku-before-content" />
85
- {children ?? <Outlet />}
86
- <Slotlet name="zudoku-after-content" />
87
- </main>
88
- </Drawer>
89
- </Suspense>
64
+ {isNavigating ? (
65
+ <LoadingFallback />
66
+ ) : (
67
+ <Suspense fallback={<LoadingFallback />}>
68
+ <Drawer direction="left">
69
+ <Sidebar />
70
+ <div
71
+ className={cn(
72
+ "lg:hidden -mx-10 px-10 py-2 sticky bg-background/80 backdrop-blur z-10 top-0 left-0 right-0 border-b",
73
+ "peer-data-[navigation=false]:hidden",
74
+ )}
75
+ >
76
+ <DrawerTrigger className="flex items-center gap-2">
77
+ <PanelLeftIcon size={16} strokeWidth={1.5} />
78
+ <span className="text-sm">Menu</span>
79
+ </DrawerTrigger>
80
+ </div>
81
+ <main
82
+ className={cn(
83
+ "h-full dark:border-white/10 translate-x-0",
84
+ "lg:overflow-visible",
85
+ // This works in tandem with the `SidebarWrapper` component
86
+ "lg:peer-data-[navigation=true]:w-[calc(100%-var(--side-nav-width))]",
87
+ "lg:peer-data-[navigation=true]:translate-x-[--side-nav-width] lg:peer-data-[navigation=true]:pl-12",
88
+ )}
89
+ >
90
+ <Slotlet name="zudoku-before-content" />
91
+ {children ?? <Outlet />}
92
+ <Slotlet name="zudoku-after-content" />
93
+ </main>
94
+ </Drawer>
95
+ </Suspense>
96
+ )}
90
97
  </div>
91
98
  </>
92
99
  );
@@ -1,25 +1,29 @@
1
1
  import { VisuallyHidden } from "@radix-ui/react-visually-hidden";
2
- import { cx } from "class-variance-authority";
3
2
  import { MenuIcon } from "lucide-react";
4
- import { NavLink } from "react-router-dom";
3
+ import { useState } from "react";
5
4
  import { useAuth } from "../authentication/hook.js";
6
5
  import {
7
6
  Drawer,
8
- DrawerClose,
9
7
  DrawerContent,
10
8
  DrawerTitle,
11
9
  DrawerTrigger,
12
10
  } from "../ui/Drawer.js";
13
11
  import { useZudoku } from "./context/ZudokuContext.js";
14
12
  import { Search } from "./Search.js";
15
- import { isHiddenItem } from "./TopNavigation.js";
13
+ import { ThemeSwitch } from "./ThemeSwitch.js";
14
+ import { isHiddenItem, TopNavItem } from "./TopNavigation.js";
16
15
 
17
16
  export const MobileTopNavigation = () => {
18
17
  const { topNavigation } = useZudoku();
19
18
  const { isAuthenticated } = useAuth();
19
+ const [drawerOpen, setDrawerOpen] = useState(false);
20
20
 
21
21
  return (
22
- <Drawer direction="right">
22
+ <Drawer
23
+ direction="right"
24
+ open={drawerOpen}
25
+ onOpenChange={(open) => setDrawerOpen(open)}
26
+ >
23
27
  <div className="flex lg:hidden justify-self-end">
24
28
  <DrawerTrigger className="lg:hidden">
25
29
  <MenuIcon size={22} />
@@ -36,21 +40,14 @@ export const MobileTopNavigation = () => {
36
40
  <Search />
37
41
  </div>
38
42
  <ul className="flex flex-col items-center gap-4 p-4">
43
+ <li>
44
+ <ThemeSwitch />
45
+ </li>
39
46
  {topNavigation.filter(isHiddenItem(isAuthenticated)).map((item) => (
40
47
  <li key={item.label}>
41
- <NavLink
42
- className={({ isActive }) =>
43
- cx(
44
- "block font-medium border-b-2",
45
- isActive
46
- ? "border-primary text-foreground"
47
- : "border-transparent text-foreground/75 hover:text-foreground hover:border-accent-foreground/25",
48
- )
49
- }
50
- to={item.id}
51
- >
52
- <DrawerClose>{item.label}</DrawerClose>
53
- </NavLink>
48
+ <button onClick={() => setDrawerOpen(false)}>
49
+ <TopNavItem {...item} />
50
+ </button>
54
51
  </li>
55
52
  ))}
56
53
  </ul>
@@ -8,6 +8,7 @@ import { isValidElementType } from "react-is";
8
8
  import {
9
9
  type Location,
10
10
  type NavigateFunction,
11
+ type Params,
11
12
  type SetURLSearchParams,
12
13
  } from "react-router-dom";
13
14
  import { useExposedProps } from "../util/useExposedProps.js";
@@ -38,6 +39,7 @@ export type ExposedComponentProps = {
38
39
  navigate: NavigateFunction;
39
40
  searchParams: URLSearchParams;
40
41
  setSearchParams: SetURLSearchParams;
42
+ params: Params;
41
43
  };
42
44
 
43
45
  export const Slotlet = ({ name }: { name: string }) => {
@@ -33,9 +33,10 @@ void import("prismjs/components/prism-javascript.min.js");
33
33
  // @ts-expect-error This is untyped
34
34
  void import("prismjs/components/prism-typescript.min.js");
35
35
 
36
+ import { useTheme } from "next-themes";
36
37
  import { useState } from "react";
37
38
  import { cn } from "../util/cn.js";
38
- import { useTheme } from "./context/ThemeContext.js";
39
+ import { ClientOnly } from "./ClientOnly.js";
39
40
 
40
41
  type SyntaxHighlightProps = {
41
42
  className?: string;
@@ -46,77 +47,115 @@ type SyntaxHighlightProps = {
46
47
  language?: string;
47
48
  } & Omit<HighlightProps, "children" | "language">;
48
49
 
50
+ const remapLang = {
51
+ mdx: "md",
52
+ } as Record<string, string>;
53
+
49
54
  export const SyntaxHighlight = ({
50
55
  copyable = true,
51
56
  language = "plain",
52
57
  ...props
53
58
  }: SyntaxHighlightProps) => {
54
- const [isDark] = useTheme();
59
+ const { resolvedTheme } = useTheme();
55
60
  const [isCopied, setIsCopied] = useState(false);
56
61
 
57
62
  if (!props.code) {
58
63
  return null;
59
64
  }
60
65
 
66
+ const highlightTheme =
67
+ resolvedTheme === "dark" ? themes.vsDark : themes.github;
68
+
69
+ // hardcoded values from the themes to avoid color flash in SSR
70
+ const themeColorClasses =
71
+ "bg-[#f6f8fa] text-[#393a34] dark:bg-[#1e1e1e] dark:text-[#9cdcfe]";
72
+
61
73
  return (
62
- <Highlight
63
- theme={isDark ? themes.vsDark : themes.github}
64
- language={language}
65
- {...props}
66
- >
67
- {({ className, style, tokens, getLineProps, getTokenProps }) => (
74
+ <ClientOnly
75
+ fallback={
68
76
  <div className="relative group">
69
77
  <pre
70
78
  className={cn(
71
79
  "relative scrollbar overflow-x-auto",
72
- className,
73
80
  props.className,
74
- props.noBackground && "!bg-transparent",
81
+ props.noBackground ? "!bg-transparent" : themeColorClasses,
75
82
  props.wrapLines && "whitespace-pre-wrap break-words",
76
83
  )}
77
- style={style}
78
84
  >
79
- {tokens.map((line, i) => (
80
- // eslint-disable-next-line react/no-array-index-key
81
- <div key={i} {...getLineProps({ line })}>
82
- {line.map((token, key) => (
83
- // eslint-disable-next-line react/no-array-index-key
84
- <span key={key} {...getTokenProps({ token })} />
85
- ))}
86
- </div>
87
- ))}
85
+ {props.code}
88
86
  </pre>
89
87
  {props.showLanguageIndicator && (
90
88
  <span className="absolute top-1.5 right-3 text-[11px] font-mono text-muted-foreground transition group-hover:opacity-0">
91
89
  {language}
92
90
  </span>
93
91
  )}
94
- {copyable && (
95
- <button
96
- type="button"
97
- aria-label="Copy code"
98
- title="Copy code"
99
- className="absolute top-2 right-2 p-2 opacity-0 group-hover:opacity-100 group-hover:bg-zinc-100 group-hover:dark:bg-zinc-700 hover:outline hover:outline-border/75 dark:hover:outline-border rounded-md text-sm text-gray-400 hover:text-gray-600 dark:text-gray-500 dark:hover:text-gray-400 transition"
100
- disabled={isCopied}
101
- onClick={() => {
102
- setIsCopied(true);
103
- void navigator.clipboard.writeText(
104
- tokens
105
- .map((line) => line.map(({ content }) => content).join(""))
106
- .join("\n"),
107
- );
108
- setTimeout(() => setIsCopied(false), 2000);
109
- }}
110
- >
111
- {isCopied ? (
112
- <CheckIcon className="text-emerald-600" size={16} />
113
- ) : (
114
- <CopyIcon size={16} />
115
- )}
116
- </button>
117
- )}
118
92
  </div>
119
- )}
120
- </Highlight>
93
+ }
94
+ >
95
+ <Highlight
96
+ theme={highlightTheme}
97
+ language={remapLang[language] ?? language}
98
+ {...props}
99
+ >
100
+ {({ className, style, tokens, getLineProps, getTokenProps }) => (
101
+ <div className="relative group">
102
+ <pre
103
+ className={cn(
104
+ "relative scrollbar overflow-x-auto",
105
+ className,
106
+ props.className,
107
+ props.noBackground && "!bg-transparent",
108
+ props.wrapLines && "whitespace-pre-wrap break-words",
109
+ )}
110
+ style={style}
111
+ >
112
+ {tokens.map((line, i) => (
113
+ // eslint-disable-next-line react/no-array-index-key
114
+ <div key={i} {...getLineProps({ line })}>
115
+ {line.map((token, key) => (
116
+ // eslint-disable-next-line react/no-array-index-key
117
+ <span key={key} {...getTokenProps({ token })} />
118
+ ))}
119
+ </div>
120
+ ))}
121
+ </pre>
122
+ {props.showLanguageIndicator && (
123
+ <span className="absolute top-1.5 right-3 text-[11px] font-mono text-muted-foreground transition group-hover:opacity-0">
124
+ {language}
125
+ </span>
126
+ )}
127
+ {copyable && (
128
+ <button
129
+ type="button"
130
+ aria-label="Copy code"
131
+ title="Copy code"
132
+ className="absolute top-2 right-2 p-2 opacity-0 group-hover:opacity-100 group-hover:bg-zinc-100 group-hover:dark:bg-zinc-700 hover:outline hover:outline-border/75 dark:hover:outline-border rounded-md text-sm text-gray-400 hover:text-gray-600 dark:text-gray-500 dark:hover:text-gray-400 transition"
133
+ disabled={isCopied}
134
+ onClick={() => {
135
+ setIsCopied(true);
136
+ void navigator.clipboard.writeText(
137
+ tokens
138
+ .map((l) => l.map(({ content }) => content).join(""))
139
+ .join("\n"),
140
+ );
141
+ setTimeout(() => setIsCopied(false), 2000);
142
+ }}
143
+ >
144
+ {isCopied ? (
145
+ <CheckIcon
146
+ className="text-emerald-600"
147
+ size={16}
148
+ strokeWidth={2.5}
149
+ absoluteStrokeWidth
150
+ />
151
+ ) : (
152
+ <CopyIcon size={16} />
153
+ )}
154
+ </button>
155
+ )}
156
+ </div>
157
+ )}
158
+ </Highlight>
159
+ </ClientOnly>
121
160
  );
122
161
  };
@@ -0,0 +1,26 @@
1
+ import { MoonStarIcon, SunIcon } from "lucide-react";
2
+ import { useTheme } from "next-themes";
3
+ import { Button } from "zudoku/ui/Button.js";
4
+ import { ClientOnly } from "./ClientOnly.js";
5
+
6
+ export const ThemeSwitch = () => {
7
+ const { resolvedTheme, setTheme } = useTheme();
8
+ const ThemeIcon = resolvedTheme === "dark" ? MoonStarIcon : SunIcon;
9
+
10
+ return (
11
+ <ClientOnly>
12
+ <Button
13
+ variant="ghost"
14
+ aria-label={
15
+ resolvedTheme === "dark"
16
+ ? "Switch to light mode"
17
+ : "Switch to dark mode"
18
+ }
19
+ className="p-2.5 -m-2.5 rounded-full"
20
+ onClick={() => setTheme(resolvedTheme === "dark" ? "light" : "dark")}
21
+ >
22
+ <ThemeIcon size={18} />
23
+ </Button>
24
+ </ClientOnly>
25
+ );
26
+ };
@@ -1,8 +1,12 @@
1
1
  import { cx } from "class-variance-authority";
2
- import { NavLink } from "react-router-dom";
3
-
2
+ import { Suspense } from "react";
3
+ import { NavLink, useNavigation } from "react-router-dom";
4
+ import { TopNavigationItem } from "../../config/validators/validate.js";
4
5
  import { useAuth } from "../authentication/hook.js";
5
- import { useZudoku } from "./context/ZudokuContext.js";
6
+ import { ZudokuError } from "../util/invariant.js";
7
+ import { joinPath } from "../util/joinPath.js";
8
+ import { useCurrentNavigation, useZudoku } from "./context/ZudokuContext.js";
9
+ import { traverseSidebar } from "./navigation/utils.js";
6
10
 
7
11
  export const isHiddenItem =
8
12
  (isAuthenticated?: boolean) =>
@@ -25,26 +29,64 @@ export const TopNavigation = () => {
25
29
  }
26
30
 
27
31
  return (
28
- <nav className="hidden lg:block border-b text-sm px-12 h-[--top-nav-height]">
29
- <ul className="flex flex-row items-center gap-8">
30
- {topNavigation.filter(isHiddenItem(isAuthenticated)).map((item) => (
31
- <li key={item.label}>
32
- <NavLink
33
- className={({ isActive }) =>
34
- cx(
35
- "block py-3.5 font-medium -mb-px border-b-2",
36
- isActive
37
- ? "border-primary text-foreground"
38
- : "border-transparent text-foreground/75 hover:text-foreground hover:border-accent-foreground/25",
39
- )
40
- }
41
- to={item.id}
42
- >
43
- {item.label}
44
- </NavLink>
45
- </li>
46
- ))}
47
- </ul>
48
- </nav>
32
+ <Suspense>
33
+ <nav className="hidden lg:block border-b text-sm px-12 h-[--top-nav-height]">
34
+ <ul className="flex flex-row items-center gap-8">
35
+ {topNavigation.filter(isHiddenItem(isAuthenticated)).map((item) => (
36
+ <li key={item.id}>
37
+ <TopNavItem {...item} />
38
+ </li>
39
+ ))}
40
+ </ul>
41
+ </nav>
42
+ </Suspense>
43
+ );
44
+ };
45
+
46
+ export const TopNavItem = ({
47
+ id,
48
+ label,
49
+ default: defaultLink,
50
+ }: TopNavigationItem) => {
51
+ const { sidebars } = useZudoku();
52
+ const currentSidebar = sidebars[id];
53
+ const currentNav = useCurrentNavigation();
54
+ const isNavigating = Boolean(useNavigation().location);
55
+ const isActive = currentNav.topNavItem?.id === id && !isNavigating;
56
+
57
+ // TODO: This is a bit of a hack to get the first link in the sidebar
58
+ // We should really process this when we load the config so we can validate
59
+ // that the sidebar is actually set. In this case we just fall back to linking
60
+ // to the id if we can't resolve a sidebar.
61
+ const first =
62
+ defaultLink ??
63
+ (currentSidebar
64
+ ? traverseSidebar(currentSidebar, (item) => {
65
+ if (item.type === "doc") return joinPath(item.id);
66
+ })
67
+ : joinPath(id));
68
+
69
+ if (!first) {
70
+ throw new ZudokuError("Page not found.", {
71
+ developerHint: `No links found in top navigation for '${id}'. Check that the sidebar isn't empty or that a default link is set.`,
72
+ });
73
+ }
74
+
75
+ return (
76
+ // We don't use isActive here because it has to be inside the sidebar,
77
+ // the top nav id doesn't necessarily start with the sidebar id
78
+ <NavLink
79
+ className={({ isPending }) =>
80
+ cx(
81
+ "block lg:py-3.5 font-medium -mb-px border-b-2",
82
+ isActive || isPending
83
+ ? "border-primary text-foreground"
84
+ : "border-transparent text-foreground/75 hover:text-foreground hover:border-accent-foreground/25",
85
+ )
86
+ }
87
+ to={first}
88
+ >
89
+ {label}
90
+ </NavLink>
49
91
  );
50
92
  };