zudoku 0.47.2 → 0.48.1

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 (265) hide show
  1. package/dist/app/ZuploBuildConfig.d.ts +4 -114
  2. package/dist/app/ZuploBuildConfig.js +1 -1
  3. package/dist/app/ZuploBuildConfig.js.map +1 -1
  4. package/dist/app/demo.js +4 -3
  5. package/dist/app/demo.js.map +1 -1
  6. package/dist/app/main.js +5 -5
  7. package/dist/app/main.js.map +1 -1
  8. package/dist/app/standalone.js +4 -3
  9. package/dist/app/standalone.js.map +1 -1
  10. package/dist/config/loader.js +1 -2
  11. package/dist/config/loader.js.map +1 -1
  12. package/dist/config/validators/BuildSchema.d.ts +20 -44
  13. package/dist/config/validators/BuildSchema.js +3 -14
  14. package/dist/config/validators/BuildSchema.js.map +1 -1
  15. package/dist/config/validators/InputNavigationSchema.d.ts +7217 -0
  16. package/dist/config/validators/InputNavigationSchema.js +74 -0
  17. package/dist/config/validators/InputNavigationSchema.js.map +1 -0
  18. package/dist/config/validators/InputNavigationSchema.test-d.d.ts +1 -0
  19. package/dist/config/validators/InputNavigationSchema.test-d.js +146 -0
  20. package/dist/config/validators/InputNavigationSchema.test-d.js.map +1 -0
  21. package/dist/config/validators/NavigationSchema.d.ts +44 -0
  22. package/dist/config/validators/NavigationSchema.js +95 -0
  23. package/dist/config/validators/NavigationSchema.js.map +1 -0
  24. package/dist/config/validators/icon-types.d.ts +2 -1
  25. package/dist/config/validators/icon-types.js +1775 -1
  26. package/dist/config/validators/icon-types.js.map +1 -1
  27. package/dist/config/validators/validate.d.ts +442 -5780
  28. package/dist/config/validators/validate.js +37 -55
  29. package/dist/config/validators/validate.js.map +1 -1
  30. package/dist/config/validators/validate.test.js +0 -2
  31. package/dist/config/validators/validate.test.js.map +1 -1
  32. package/dist/flat-config.d.ts +320 -0
  33. package/dist/index.d.ts +1 -1
  34. package/dist/index.js.map +1 -1
  35. package/dist/lib/components/BuildCheck.js +1 -1
  36. package/dist/lib/components/BuildCheck.js.map +1 -1
  37. package/dist/lib/components/Header.js +10 -9
  38. package/dist/lib/components/Header.js.map +1 -1
  39. package/dist/lib/components/Heading.d.ts +6 -2
  40. package/dist/lib/components/Heading.js +2 -2
  41. package/dist/lib/components/Heading.js.map +1 -1
  42. package/dist/lib/components/Main.js +4 -4
  43. package/dist/lib/components/Main.js.map +1 -1
  44. package/dist/lib/components/MobileTopNavigation.js +5 -5
  45. package/dist/lib/components/MobileTopNavigation.js.map +1 -1
  46. package/dist/lib/components/PageProgress.d.ts +1 -0
  47. package/dist/lib/components/PageProgress.js +20 -0
  48. package/dist/lib/components/PageProgress.js.map +1 -0
  49. package/dist/lib/components/TopNavigation.d.ts +2 -3
  50. package/dist/lib/components/TopNavigation.js +45 -44
  51. package/dist/lib/components/TopNavigation.js.map +1 -1
  52. package/dist/lib/components/context/ZudokuContext.d.ts +3 -7
  53. package/dist/lib/components/context/ZudokuContext.js +44 -26
  54. package/dist/lib/components/context/ZudokuContext.js.map +1 -1
  55. package/dist/lib/components/navigation/Navigation.d.ts +5 -0
  56. package/dist/lib/components/navigation/Navigation.js +12 -0
  57. package/dist/lib/components/navigation/Navigation.js.map +1 -0
  58. package/dist/lib/components/navigation/{SidebarBadge.d.ts → NavigationBadge.d.ts} +1 -1
  59. package/dist/lib/components/navigation/{SidebarBadge.js → NavigationBadge.js} +2 -2
  60. package/dist/lib/components/navigation/NavigationBadge.js.map +1 -0
  61. package/dist/lib/components/navigation/NavigationCategory.d.ts +5 -0
  62. package/dist/lib/components/navigation/{SidebarCategory.js → NavigationCategory.js} +14 -12
  63. package/dist/lib/components/navigation/NavigationCategory.js.map +1 -0
  64. package/dist/lib/components/navigation/NavigationItem.d.ts +6 -0
  65. package/dist/lib/components/navigation/NavigationItem.js +47 -0
  66. package/dist/lib/components/navigation/NavigationItem.js.map +1 -0
  67. package/dist/lib/components/navigation/{SidebarWrapper.d.ts → NavigationWrapper.d.ts} +1 -1
  68. package/dist/lib/components/navigation/{SidebarWrapper.js → NavigationWrapper.js} +3 -3
  69. package/dist/lib/components/navigation/NavigationWrapper.js.map +1 -0
  70. package/dist/lib/components/navigation/utils.d.ts +7 -9
  71. package/dist/lib/components/navigation/utils.js +17 -17
  72. package/dist/lib/components/navigation/utils.js.map +1 -1
  73. package/dist/lib/core/ZudokuContext.d.ts +6 -8
  74. package/dist/lib/core/ZudokuContext.js +5 -7
  75. package/dist/lib/core/ZudokuContext.js.map +1 -1
  76. package/dist/lib/core/plugins.d.ts +2 -2
  77. package/dist/lib/hooks/useEvent.test.js +5 -3
  78. package/dist/lib/hooks/useEvent.test.js.map +1 -1
  79. package/dist/lib/plugins/api-catalog/Catalog.d.ts +1 -1
  80. package/dist/lib/plugins/api-catalog/index.d.ts +6 -6
  81. package/dist/lib/plugins/api-catalog/index.js +10 -10
  82. package/dist/lib/plugins/api-catalog/index.js.map +1 -1
  83. package/dist/lib/plugins/api-keys/SettingsApiKeys.js +4 -4
  84. package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
  85. package/dist/lib/plugins/custom-pages/index.d.ts +3 -2
  86. package/dist/lib/plugins/custom-pages/index.js +15 -8
  87. package/dist/lib/plugins/custom-pages/index.js.map +1 -1
  88. package/dist/lib/plugins/markdown/MdxPage.js +6 -3
  89. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  90. package/dist/lib/plugins/markdown/index.d.ts +2 -1
  91. package/dist/lib/plugins/markdown/index.js +9 -26
  92. package/dist/lib/plugins/markdown/index.js.map +1 -1
  93. package/dist/lib/plugins/openapi/OperationList.js +1 -1
  94. package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
  95. package/dist/lib/plugins/openapi/OperationListItem.js +1 -1
  96. package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
  97. package/dist/lib/plugins/openapi/SchemaList.js +1 -1
  98. package/dist/lib/plugins/openapi/SchemaList.js.map +1 -1
  99. package/dist/lib/plugins/openapi/graphql/gql.d.ts +1 -1
  100. package/dist/lib/plugins/openapi/graphql/gql.js +1 -1
  101. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  102. package/dist/lib/plugins/openapi/graphql/graphql.d.ts +3 -3
  103. package/dist/lib/plugins/openapi/graphql/graphql.js +2 -2
  104. package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
  105. package/dist/lib/plugins/openapi/index.d.ts +3 -3
  106. package/dist/lib/plugins/openapi/index.js +9 -9
  107. package/dist/lib/plugins/openapi/index.js.map +1 -1
  108. package/dist/lib/plugins/openapi/interfaces.d.ts +3 -3
  109. package/dist/lib/plugins/openapi/util/createNavigationCategory.d.ts +9 -0
  110. package/dist/lib/plugins/openapi/util/{createSidebarCategory.js → createNavigationCategory.js} +5 -4
  111. package/dist/lib/plugins/openapi/util/createNavigationCategory.js.map +1 -0
  112. package/dist/lib/plugins/openapi/util/getRoutes.js +2 -2
  113. package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -1
  114. package/dist/lib/plugins/openapi/util/methodColorMap.d.ts +1 -1
  115. package/dist/lib/util/useScrollToAnchor.js +3 -3
  116. package/dist/lib/util/useScrollToAnchor.js.map +1 -1
  117. package/dist/vite/api/SchemaManager.d.ts +4 -4
  118. package/dist/vite/api/SchemaManager.js +19 -19
  119. package/dist/vite/api/SchemaManager.js.map +1 -1
  120. package/dist/vite/api/SchemaManager.test.js +4 -4
  121. package/dist/vite/api/SchemaManager.test.js.map +1 -1
  122. package/dist/vite/config.js +1 -0
  123. package/dist/vite/config.js.map +1 -1
  124. package/dist/vite/plugin-api.js +8 -8
  125. package/dist/vite/plugin-api.js.map +1 -1
  126. package/dist/vite/plugin-config-reload.js +2 -0
  127. package/dist/vite/plugin-config-reload.js.map +1 -1
  128. package/dist/vite/plugin-custom-pages.js +2 -2
  129. package/dist/vite/plugin-custom-pages.js.map +1 -1
  130. package/dist/vite/plugin-docs.js +61 -59
  131. package/dist/vite/plugin-docs.js.map +1 -1
  132. package/dist/vite/{plugin-sidebar.d.ts → plugin-navigation.d.ts} +1 -1
  133. package/dist/vite/{plugin-sidebar.js → plugin-navigation.js} +20 -19
  134. package/dist/vite/plugin-navigation.js.map +1 -0
  135. package/dist/vite/plugin.js +2 -2
  136. package/dist/vite/plugin.js.map +1 -1
  137. package/dist/vite/shadcn-registry.d.ts +4 -4
  138. package/lib/{Markdown-C5j8kKSX.js → Markdown-DCAIYXF5.js} +480 -475
  139. package/lib/Markdown-DCAIYXF5.js.map +1 -0
  140. package/lib/{MdxPage-CKTMf1cR.js → MdxPage-Cf9YXWoC.js} +30 -30
  141. package/lib/MdxPage-Cf9YXWoC.js.map +1 -0
  142. package/lib/OasProvider-JMVTfG6_.js +35 -0
  143. package/lib/OasProvider-JMVTfG6_.js.map +1 -0
  144. package/lib/{OperationList-BJAKaG5p.js → OperationList-m4tFCI4S.js} +8 -8
  145. package/lib/{OperationList-BJAKaG5p.js.map → OperationList-m4tFCI4S.js.map} +1 -1
  146. package/lib/{RouteGuard-B7GVW4oL.js → RouteGuard-gV7nvzi7.js} +2 -2
  147. package/lib/{RouteGuard-B7GVW4oL.js.map → RouteGuard-gV7nvzi7.js.map} +1 -1
  148. package/lib/{SchemaList-Dgc0A8x5.js → SchemaList-_wRy4aQ0.js} +20 -20
  149. package/lib/SchemaList-_wRy4aQ0.js.map +1 -0
  150. package/lib/{SchemaView-DVx-jFN4.js → SchemaView-CRl_cQYH.js} +3 -3
  151. package/lib/{SchemaView-DVx-jFN4.js.map → SchemaView-CRl_cQYH.js.map} +1 -1
  152. package/lib/{SignUp-CRIKdWt9.js → SignUp-B6w5AwHM.js} +2 -2
  153. package/lib/{SignUp-CRIKdWt9.js.map → SignUp-B6w5AwHM.js.map} +1 -1
  154. package/lib/{Slot-ITby_hMb.js → Slot-BkYrj_uC.js} +4 -4
  155. package/lib/{Slot-ITby_hMb.js.map → Slot-BkYrj_uC.js.map} +1 -1
  156. package/lib/{SyntaxHighlight-CqKHkyEy.js → SyntaxHighlight-CH9OUJre.js} +2 -2
  157. package/lib/{SyntaxHighlight-CqKHkyEy.js.map → SyntaxHighlight-CH9OUJre.js.map} +1 -1
  158. package/lib/{Toc-Csq3UNtW.js → Toc-DRxqEsFc.js} +2 -2
  159. package/lib/{Toc-Csq3UNtW.js.map → Toc-DRxqEsFc.js.map} +1 -1
  160. package/lib/{circular-BP4OrHFK.js → circular-wJaV4vh_.js} +2 -2
  161. package/lib/{circular-BP4OrHFK.js.map → circular-wJaV4vh_.js.map} +1 -1
  162. package/lib/{createServer-zu4cDiPe.js → createServer-DN5AJLcN.js} +3 -3
  163. package/lib/{createServer-zu4cDiPe.js.map → createServer-DN5AJLcN.js.map} +1 -1
  164. package/lib/{errors-CPPSp5F4.js → errors-D_5vKvUq.js} +3 -3
  165. package/lib/{errors-CPPSp5F4.js.map → errors-D_5vKvUq.js.map} +1 -1
  166. package/lib/hook-CHXroBFt.js +1503 -0
  167. package/lib/hook-CHXroBFt.js.map +1 -0
  168. package/lib/{index-jWXxqkni.js → index-DJVaRmzI.js} +63 -62
  169. package/lib/index-DJVaRmzI.js.map +1 -0
  170. package/lib/{mutation-C1XCQTQL.js → mutation-BpcyTgWI.js} +2 -2
  171. package/lib/{mutation-C1XCQTQL.js.map → mutation-BpcyTgWI.js.map} +1 -1
  172. package/lib/ui/SyntaxHighlight.js +2 -2
  173. package/lib/{useMutation-BKvPttRn.js → useMutation-N4ockVKi.js} +3 -3
  174. package/lib/{useMutation-BKvPttRn.js.map → useMutation-N4ockVKi.js.map} +1 -1
  175. package/lib/zudoku.auth-auth0.js +1 -1
  176. package/lib/zudoku.auth-azureb2c.js +2 -2
  177. package/lib/zudoku.auth-clerk.js +2 -2
  178. package/lib/zudoku.auth-openid.js +2 -2
  179. package/lib/zudoku.components.js +2756 -3424
  180. package/lib/zudoku.components.js.map +1 -1
  181. package/lib/zudoku.hooks.js +2 -2
  182. package/lib/zudoku.plugin-api-catalog.js +44 -44
  183. package/lib/zudoku.plugin-api-catalog.js.map +1 -1
  184. package/lib/zudoku.plugin-api-keys.js +42 -39
  185. package/lib/zudoku.plugin-api-keys.js.map +1 -1
  186. package/lib/zudoku.plugin-custom-pages.js +22 -16
  187. package/lib/zudoku.plugin-custom-pages.js.map +1 -1
  188. package/lib/zudoku.plugin-markdown.js +20 -69
  189. package/lib/zudoku.plugin-markdown.js.map +1 -1
  190. package/lib/zudoku.plugin-openapi.js +5 -5
  191. package/lib/zudoku.plugin-search-pagefind.js +2 -2
  192. package/lib/zudoku.plugins.js.map +1 -1
  193. package/package.json +12 -9
  194. package/src/app/ZuploBuildConfig.ts +1 -1
  195. package/src/app/demo.tsx +4 -3
  196. package/src/app/main.css +5 -0
  197. package/src/app/main.tsx +6 -5
  198. package/src/app/standalone.tsx +4 -3
  199. package/src/lib/components/BuildCheck.tsx +1 -1
  200. package/src/lib/components/Header.tsx +5 -3
  201. package/src/lib/components/Heading.tsx +7 -3
  202. package/src/lib/components/Main.tsx +8 -8
  203. package/src/lib/components/MobileTopNavigation.tsx +12 -11
  204. package/src/lib/components/PageProgress.tsx +28 -0
  205. package/src/lib/components/TopNavigation.tsx +57 -66
  206. package/src/lib/components/context/ZudokuContext.ts +50 -32
  207. package/src/lib/components/navigation/{Sidebar.tsx → Navigation.tsx} +18 -16
  208. package/src/lib/components/navigation/{SidebarBadge.tsx → NavigationBadge.tsx} +1 -1
  209. package/src/lib/components/navigation/{SidebarCategory.tsx → NavigationCategory.tsx} +16 -14
  210. package/src/lib/components/navigation/{SidebarItem.tsx → NavigationItem.tsx} +23 -17
  211. package/src/lib/components/navigation/{SidebarWrapper.tsx → NavigationWrapper.tsx} +2 -2
  212. package/src/lib/components/navigation/utils.ts +27 -28
  213. package/src/lib/core/ZudokuContext.ts +9 -15
  214. package/src/lib/core/plugins.ts +2 -2
  215. package/src/lib/hooks/useEvent.test.tsx +7 -5
  216. package/src/lib/plugins/api-catalog/Catalog.tsx +1 -1
  217. package/src/lib/plugins/api-catalog/index.tsx +19 -19
  218. package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +6 -5
  219. package/src/lib/plugins/custom-pages/index.tsx +20 -11
  220. package/src/lib/plugins/markdown/MdxPage.tsx +6 -3
  221. package/src/lib/plugins/markdown/index.tsx +19 -40
  222. package/src/lib/plugins/openapi/OperationList.tsx +1 -1
  223. package/src/lib/plugins/openapi/OperationListItem.tsx +1 -1
  224. package/src/lib/plugins/openapi/SchemaList.tsx +2 -2
  225. package/src/lib/plugins/openapi/graphql/gql.ts +5 -5
  226. package/src/lib/plugins/openapi/graphql/graphql.ts +6 -6
  227. package/src/lib/plugins/openapi/index.tsx +11 -11
  228. package/src/lib/plugins/openapi/interfaces.ts +3 -3
  229. package/src/lib/plugins/openapi/util/{createSidebarCategory.tsx → createNavigationCategory.tsx} +6 -5
  230. package/src/lib/plugins/openapi/util/getRoutes.tsx +2 -2
  231. package/src/lib/plugins/openapi/util/methodColorMap.tsx +1 -1
  232. package/src/lib/util/useScrollToAnchor.ts +3 -3
  233. package/dist/config/validators/InputSidebarSchema.d.ts +0 -220
  234. package/dist/config/validators/InputSidebarSchema.js +0 -63
  235. package/dist/config/validators/InputSidebarSchema.js.map +0 -1
  236. package/dist/config/validators/SidebarSchema.d.ts +0 -46
  237. package/dist/config/validators/SidebarSchema.js +0 -118
  238. package/dist/config/validators/SidebarSchema.js.map +0 -1
  239. package/dist/lib/components/navigation/Sidebar.d.ts +0 -5
  240. package/dist/lib/components/navigation/Sidebar.js +0 -10
  241. package/dist/lib/components/navigation/Sidebar.js.map +0 -1
  242. package/dist/lib/components/navigation/SidebarBadge.js.map +0 -1
  243. package/dist/lib/components/navigation/SidebarCategory.d.ts +0 -5
  244. package/dist/lib/components/navigation/SidebarCategory.js.map +0 -1
  245. package/dist/lib/components/navigation/SidebarItem.d.ts +0 -6
  246. package/dist/lib/components/navigation/SidebarItem.js +0 -44
  247. package/dist/lib/components/navigation/SidebarItem.js.map +0 -1
  248. package/dist/lib/components/navigation/SidebarWrapper.js.map +0 -1
  249. package/dist/lib/plugins/markdown/resolver.d.ts +0 -32
  250. package/dist/lib/plugins/markdown/resolver.js +0 -46
  251. package/dist/lib/plugins/markdown/resolver.js.map +0 -1
  252. package/dist/lib/plugins/openapi/util/createSidebarCategory.d.ts +0 -9
  253. package/dist/lib/plugins/openapi/util/createSidebarCategory.js.map +0 -1
  254. package/dist/vite/plugin-sidebar.js.map +0 -1
  255. package/lib/Markdown-C5j8kKSX.js.map +0 -1
  256. package/lib/MdxPage-CKTMf1cR.js.map +0 -1
  257. package/lib/OasProvider-_GzmsbMg.js +0 -33
  258. package/lib/OasProvider-_GzmsbMg.js.map +0 -1
  259. package/lib/SchemaList-Dgc0A8x5.js.map +0 -1
  260. package/lib/hook-7wZANGJP.js +0 -1483
  261. package/lib/hook-7wZANGJP.js.map +0 -1
  262. package/lib/index-jWXxqkni.js.map +0 -1
  263. package/lib/joinPath-B7kNnUX4.js +0 -8
  264. package/lib/joinPath-B7kNnUX4.js.map +0 -1
  265. package/src/lib/plugins/markdown/resolver.ts +0 -59
@@ -7,16 +7,16 @@ import { Drawer, DrawerContent, DrawerTitle, DrawerTrigger, } from "../ui/Drawer
7
7
  import { useZudoku } from "./context/ZudokuContext.js";
8
8
  import { PoweredByZudoku } from "./navigation/PoweredByZudoku.js";
9
9
  import { isHiddenItem } from "./navigation/utils.js";
10
+ import { PageProgress } from "./PageProgress.js";
10
11
  import { Search } from "./Search.js";
11
12
  import { Slot } from "./Slot.js";
12
13
  import { ThemeSwitch } from "./ThemeSwitch.js";
13
- import { PageProgress, TopNavItem } from "./TopNavigation.js";
14
+ import { TopNavItem } from "./TopNavigation.js";
14
15
  export const MobileTopNavigation = () => {
15
- const { topNavigation, options } = useZudoku();
16
+ const { navigation, options } = useZudoku();
16
17
  const { isAuthenticated } = useAuth();
17
18
  const [drawerOpen, setDrawerOpen] = useState(false);
18
- return (_jsxs(Drawer, { direction: options.page?.dir === "rtl" ? "left" : "right", open: drawerOpen, onOpenChange: (open) => setDrawerOpen(open), children: [_jsxs("div", { className: "flex lg:hidden justify-self-end", children: [_jsx(DrawerTrigger, { className: "lg:hidden", children: _jsx(MenuIcon, { size: 22 }) }), _jsx(PageProgress, {})] }), _jsx(DrawerContent, { className: "lg:hidden h-[100dvh] end-0 start-auto w-[320px] rounded-none", "aria-describedby": undefined, children: _jsxs("div", { className: "p-4 overflow-y-auto overscroll-none h-full flex flex-col justify-between", children: [_jsxs("div", { children: [_jsx(VisuallyHidden, { children: _jsx(DrawerTitle, { children: "Navigation" }) }), _jsx(Search, { className: "flex p-4" }), _jsxs("ul", { className: "flex flex-col items-center gap-4 p-4", children: [_jsx("li", { className: "empty:hidden", children: _jsx(Slot.Target, { name: "top-navigation-side" }) }), _jsx("li", { children: _jsx(ThemeSwitch, {}) }), topNavigation
19
- .filter(isHiddenItem(isAuthenticated))
20
- .map((item) => (_jsx("li", { children: _jsx("button", { type: "button", onClick: () => setDrawerOpen(false), children: _jsx(TopNavItem, { ...item }) }) }, item.label)))] })] }), options.page?.showPoweredBy !== false && (_jsx(PoweredByZudoku, { className: "grow-0 justify-center gap-1" }))] }) })] }));
19
+ const filteredItems = navigation.filter(isHiddenItem(isAuthenticated));
20
+ return (_jsxs(Drawer, { direction: options.page?.dir === "rtl" ? "left" : "right", open: drawerOpen, onOpenChange: (open) => setDrawerOpen(open), children: [_jsxs("div", { className: "flex lg:hidden justify-self-end", children: [_jsx(DrawerTrigger, { className: "lg:hidden", children: _jsx(MenuIcon, { size: 22 }) }), _jsx(PageProgress, {})] }), _jsx(DrawerContent, { className: "lg:hidden h-[100dvh] end-0 start-auto w-[320px] rounded-none", "aria-describedby": undefined, children: _jsxs("div", { className: "p-4 overflow-y-auto overscroll-none h-full flex flex-col justify-between", children: [_jsxs("div", { children: [_jsx(VisuallyHidden, { children: _jsx(DrawerTitle, { children: "Navigation" }) }), _jsx(Search, { className: "flex p-4" }), _jsxs("ul", { className: "flex flex-col items-center gap-4 p-4", children: [_jsx("li", { className: "empty:hidden", children: _jsx(Slot.Target, { name: "top-navigation-side" }) }), _jsx("li", { children: _jsx(ThemeSwitch, {}) }), filteredItems.map((item) => (_jsx("li", { children: _jsx("button", { type: "button", onClick: () => setDrawerOpen(false), children: _jsx(TopNavItem, { ...item }) }) }, item.label)))] })] }), options.page?.showPoweredBy !== false && (_jsx(PoweredByZudoku, { className: "grow-0 justify-center gap-1" }))] }) })] }));
21
21
  };
22
22
  //# sourceMappingURL=MobileTopNavigation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"MobileTopNavigation.js","sourceRoot":"","sources":["../../../src/lib/components/MobileTopNavigation.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EACL,MAAM,EACN,aAAa,EACb,WAAW,EACX,aAAa,GACd,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAE9D,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAG,EAAE;IACtC,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC;IAC/C,MAAM,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IACtC,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEpD,OAAO,CACL,MAAC,MAAM,IACL,SAAS,EAAE,OAAO,CAAC,IAAI,EAAE,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EACzD,IAAI,EAAE,UAAU,EAChB,YAAY,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,aAE3C,eAAK,SAAS,EAAC,iCAAiC,aAC9C,KAAC,aAAa,IAAC,SAAS,EAAC,WAAW,YAClC,KAAC,QAAQ,IAAC,IAAI,EAAE,EAAE,GAAI,GACR,EAChB,KAAC,YAAY,KAAG,IACZ,EACN,KAAC,aAAa,IACZ,SAAS,EAAC,8DAA8D,sBACtD,SAAS,YAE3B,eAAK,SAAS,EAAC,0EAA0E,aACvF,0BACE,KAAC,cAAc,cACb,KAAC,WAAW,6BAAyB,GACtB,EACjB,KAAC,MAAM,IAAC,SAAS,EAAC,UAAU,GAAG,EAC/B,cAAI,SAAS,EAAC,sCAAsC,aAClD,aAAI,SAAS,EAAC,cAAc,YAC1B,KAAC,IAAI,CAAC,MAAM,IAAC,IAAI,EAAC,qBAAqB,GAAG,GACvC,EACL,uBACE,KAAC,WAAW,KAAG,GACZ,EACJ,aAAa;6CACX,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;6CACrC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACb,uBACE,iBAAQ,IAAI,EAAC,QAAQ,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,YACvD,KAAC,UAAU,OAAK,IAAI,GAAI,GACjB,IAHF,IAAI,CAAC,KAAK,CAId,CACN,CAAC,IACD,IACD,EACL,OAAO,CAAC,IAAI,EAAE,aAAa,KAAK,KAAK,IAAI,CACxC,KAAC,eAAe,IAAC,SAAS,EAAC,6BAA6B,GAAG,CAC5D,IACG,GACQ,IACT,CACV,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"MobileTopNavigation.js","sourceRoot":"","sources":["../../../src/lib/components/MobileTopNavigation.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EACL,MAAM,EACN,aAAa,EACb,WAAW,EACX,aAAa,GACd,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAG,EAAE;IACtC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC;IAC5C,MAAM,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IACtC,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEpD,MAAM,aAAa,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC,CAAC;IAEvE,OAAO,CACL,MAAC,MAAM,IACL,SAAS,EAAE,OAAO,CAAC,IAAI,EAAE,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EACzD,IAAI,EAAE,UAAU,EAChB,YAAY,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,aAE3C,eAAK,SAAS,EAAC,iCAAiC,aAC9C,KAAC,aAAa,IAAC,SAAS,EAAC,WAAW,YAClC,KAAC,QAAQ,IAAC,IAAI,EAAE,EAAE,GAAI,GACR,EAChB,KAAC,YAAY,KAAG,IACZ,EACN,KAAC,aAAa,IACZ,SAAS,EAAC,8DAA8D,sBACtD,SAAS,YAE3B,eAAK,SAAS,EAAC,0EAA0E,aACvF,0BACE,KAAC,cAAc,cACb,KAAC,WAAW,6BAAyB,GACtB,EACjB,KAAC,MAAM,IAAC,SAAS,EAAC,UAAU,GAAG,EAC/B,cAAI,SAAS,EAAC,sCAAsC,aAClD,aAAI,SAAS,EAAC,cAAc,YAC1B,KAAC,IAAI,CAAC,MAAM,IAAC,IAAI,EAAC,qBAAqB,GAAG,GACvC,EACL,uBACE,KAAC,WAAW,KAAG,GACZ,EACJ,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAC3B,uBACE,iBAAQ,IAAI,EAAC,QAAQ,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,YACvD,KAAC,UAAU,OAAK,IAAI,GAAI,GACjB,IAHF,IAAI,CAAC,KAAK,CAId,CACN,CAAC,IACC,IACD,EACL,OAAO,CAAC,IAAI,EAAE,aAAa,KAAK,KAAK,IAAI,CACxC,KAAC,eAAe,IAAC,SAAS,EAAC,6BAA6B,GAAG,CAC5D,IACG,GACQ,IACT,CACV,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const PageProgress: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useNProgress } from "@tanem/react-nprogress";
3
+ import { useEffect, useState } from "react";
4
+ import { useNavigation } from "react-router";
5
+ export const PageProgress = () => {
6
+ const navigation = useNavigation();
7
+ const isNavigating = navigation.state === "loading";
8
+ // delay the animation to avoid flickering
9
+ const [isAnimating, setIsAnimating] = useState(false);
10
+ useEffect(() => {
11
+ const timer = setTimeout(() => setIsAnimating(isNavigating), 200);
12
+ return () => clearTimeout(timer);
13
+ }, [isNavigating]);
14
+ const { isFinished, progress } = useNProgress({ isAnimating });
15
+ return (_jsx("div", { className: "absolute w-0 left-0 right-0 bottom-[-1px] h-[2px] bg-primary transition-all duration-300 ease-in-out", style: {
16
+ opacity: isFinished ? 0 : 1,
17
+ width: isFinished ? 0 : `${progress * 100}%`,
18
+ } }));
19
+ };
20
+ //# sourceMappingURL=PageProgress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PageProgress.js","sourceRoot":"","sources":["../../../src/lib/components/PageProgress.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,EAAE;IAC/B,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,KAAK,SAAS,CAAC;IACpD,0CAA0C;IAC1C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEtD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE,GAAG,CAAC,CAAC;QAElE,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnB,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAE/D,OAAO,CACL,cACE,SAAS,EAAC,sGAAsG,EAChH,KAAK,EAAE;YACL,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3B,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,GAAG,GAAG;SAC7C,GACD,CACH,CAAC;AACJ,CAAC,CAAC"}
@@ -1,4 +1,3 @@
1
- import type { TopNavigationItem } from "../../config/validators/validate.js";
2
- export declare const PageProgress: () => import("react/jsx-runtime").JSX.Element;
1
+ import { type NavigationItem } from "../../config/validators/NavigationSchema.js";
3
2
  export declare const TopNavigation: () => import("react/jsx-runtime").JSX.Element;
4
- export declare const TopNavItem: ({ id, label, default: defaultLink, }: TopNavigationItem) => import("react/jsx-runtime").JSX.Element;
3
+ export declare const TopNavItem: (item: NavigationItem) => import("react/jsx-runtime").JSX.Element;
@@ -1,60 +1,61 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useNProgress } from "@tanem/react-nprogress";
3
2
  import { cx } from "class-variance-authority";
4
- import { Suspense, useEffect, useState } from "react";
5
- import { NavLink, useNavigation } from "react-router";
3
+ import { deepEqual } from "fast-equals";
4
+ import { Suspense } from "react";
5
+ import { NavLink } from "react-router";
6
6
  import { useAuth } from "../authentication/hook.js";
7
7
  import { joinUrl } from "../util/joinUrl.js";
8
8
  import { useCurrentNavigation, useZudoku } from "./context/ZudokuContext.js";
9
- import { isHiddenItem, traverseSidebar } from "./navigation/utils.js";
9
+ import { isHiddenItem, traverseNavigationItem } from "./navigation/utils.js";
10
10
  import { Slot } from "./Slot.js";
11
- export const PageProgress = () => {
12
- const navigation = useNavigation();
13
- const isNavigating = navigation.state === "loading";
14
- // delay the animation to avoid flickering
15
- const [isAnimating, setIsAnimating] = useState(false);
16
- useEffect(() => {
17
- const timer = setTimeout(() => setIsAnimating(isNavigating), 100);
18
- return () => clearTimeout(timer);
19
- }, [isNavigating]);
20
- const { isFinished, progress } = useNProgress({ isAnimating });
21
- return (_jsx("div", { className: "absolute w-0 left-0 right-0 bottom-[-1px] h-[2px] bg-primary transition-all duration-300 ease-in-out", style: {
22
- opacity: isFinished ? 0 : 1,
23
- width: isFinished ? 0 : `${progress * 100}%`,
24
- } }));
25
- };
26
11
  export const TopNavigation = () => {
27
- const { topNavigation } = useZudoku();
12
+ const { navigation } = useZudoku();
28
13
  const { isAuthenticated } = useAuth();
29
- const filteredItems = topNavigation.filter(isHiddenItem(isAuthenticated));
14
+ const filteredItems = navigation.filter(isHiddenItem(isAuthenticated));
30
15
  if (filteredItems.length === 0 || import.meta.env.MODE === "standalone") {
31
16
  return _jsx("style", { children: `:root { --top-nav-height: 0px; }` });
32
17
  }
33
- return (_jsxs(Suspense, { children: [_jsxs("div", { className: "items-center justify-between px-8 h-(--top-nav-height) hidden lg:flex text-sm relative", children: [_jsx("nav", { className: "text-sm", children: _jsx("ul", { className: "flex flex-row items-center gap-8", children: filteredItems.map((item) => (_jsx("li", { children: _jsx(TopNavItem, { ...item }) }, item.id))) }) }), _jsx(Slot.Target, { name: "top-navigation-side" })] }), _jsx(PageProgress, {})] }));
18
+ return (_jsx(Suspense, { children: _jsxs("div", { className: "items-center justify-between px-8 h-(--top-nav-height) hidden lg:flex text-sm relative", children: [_jsx("nav", { className: "text-sm", children: _jsx("ul", { className: "flex flex-row items-center gap-8", children: filteredItems.map((item) => (_jsx("li", { children: _jsx(TopNavItem, { ...item }) }, item.label + item.type))) }) }), _jsx(Slot.Target, { name: "top-navigation-side" })] }) }));
19
+ };
20
+ const getPathForItem = (item) => {
21
+ switch (item.type) {
22
+ case "doc":
23
+ return joinUrl(item.path);
24
+ case "link":
25
+ return item.to;
26
+ case "category": {
27
+ if (item.link?.path) {
28
+ return joinUrl(item.link.path);
29
+ }
30
+ return (traverseNavigationItem(item, (child) => {
31
+ if (child.type !== "category") {
32
+ return getPathForItem(child);
33
+ }
34
+ }) ?? "");
35
+ }
36
+ case "custom-page":
37
+ return item.path;
38
+ }
34
39
  };
35
- export const TopNavItem = ({ id, label, default: defaultLink, }) => {
36
- const { sidebars } = useZudoku();
37
- const currentSidebar = sidebars[id];
40
+ export const TopNavItem = (item) => {
38
41
  const currentNav = useCurrentNavigation();
39
- const isNavigating = Boolean(useNavigation().location);
40
- const isActive = currentNav.topNavItem?.id === id && !isNavigating;
41
- // TODO: This is a bit of a hack to get the first link in the sidebar
42
- // We should really process this when we load the config so we can validate
43
- // that the sidebar is actually set. In this case we just fall back to linking
44
- // to the id if we can't resolve a sidebar.
45
- const first = defaultLink ??
46
- (currentSidebar
47
- ? traverseSidebar(currentSidebar, (item) => {
48
- if (item.type === "doc")
49
- return joinUrl(item.id);
50
- })
51
- : joinUrl(id)) ??
52
- joinUrl(id);
42
+ const isActiveTopNavItem = deepEqual(currentNav.topNavItem, item);
43
+ const path = getPathForItem(item);
53
44
  return (
54
- // We don't use isActive here because it has to be inside the sidebar,
55
- // the top nav id doesn't necessarily start with the sidebar id
56
- _jsx(NavLink, { className: ({ isPending }) => cx("block lg:py-3.5 font-medium -mb-px", isActive || isPending
57
- ? "border-primary text-foreground"
58
- : "border-transparent text-foreground/75 hover:text-foreground hover:border-accent-foreground/25"), to: first, children: label }));
45
+ // We don't use isActive here because it has to be inside the navigation,
46
+ // the top nav id doesn't necessarily start with the navigation id
47
+ _jsxs(NavLink, { viewTransition: true, to: path, className: ({ isActive: isActiveNavLink, isPending }) => {
48
+ const isActive = isActiveNavLink || isActiveTopNavItem;
49
+ return cx("flex items-center gap-2 lg:py-3.5 font-medium -mb-px transition duration-150 delay-75 relative", isActive || isPending
50
+ ? [
51
+ "text-foreground",
52
+ // underline with view transition animation
53
+ "after:content-[''] after:absolute after:bottom-0 after:left-0 after:right-0",
54
+ "after:h-0.5 after:bg-primary",
55
+ isActive && "after:[view-transition-name:top-nav-underline]",
56
+ isPending && "after:bg-primary/25",
57
+ ]
58
+ : "text-foreground/75 hover:text-foreground");
59
+ }, children: [item.icon && _jsx(item.icon, { size: 16, className: "align-[-0.125em]" }), item.label] }));
59
60
  };
60
61
  //# sourceMappingURL=TopNavigation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TopNavigation.js","sourceRoot":"","sources":["../../../src/lib/components/TopNavigation.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAEtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,EAAE;IAC/B,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,KAAK,SAAS,CAAC;IACpD,0CAA0C;IAC1C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAEtD,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE,GAAG,CAAC,CAAC;QAElE,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnB,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,YAAY,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAE/D,OAAO,CACL,cACE,SAAS,EAAC,sGAAsG,EAChH,KAAK,EAAE;YACL,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3B,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,GAAG,GAAG,GAAG;SAC7C,GACD,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE;IAChC,MAAM,EAAE,aAAa,EAAE,GAAG,SAAS,EAAE,CAAC;IACtC,MAAM,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IAEtC,MAAM,aAAa,GAAG,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC,CAAC;IAE1E,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;QACxE,OAAO,0BAAQ,kCAAkC,GAAS,CAAC;IAC7D,CAAC;IAED,OAAO,CACL,MAAC,QAAQ,eACP,eAAK,SAAS,EAAC,wFAAwF,aACrG,cAAK,SAAS,EAAC,SAAS,YACtB,aAAI,SAAS,EAAC,kCAAkC,YAC7C,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAC3B,uBACE,KAAC,UAAU,OAAK,IAAI,GAAI,IADjB,IAAI,CAAC,EAAE,CAEX,CACN,CAAC,GACC,GACD,EACN,KAAC,IAAI,CAAC,MAAM,IAAC,IAAI,EAAC,qBAAqB,GAAG,IACtC,EACN,KAAC,YAAY,KAAG,IACP,CACZ,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,EAAE,EACF,KAAK,EACL,OAAO,EAAE,WAAW,GACF,EAAE,EAAE;IACtB,MAAM,EAAE,QAAQ,EAAE,GAAG,SAAS,EAAE,CAAC;IACjC,MAAM,cAAc,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACpC,MAAM,UAAU,GAAG,oBAAoB,EAAE,CAAC;IAC1C,MAAM,YAAY,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,QAAQ,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,UAAU,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC;IAEnE,qEAAqE;IACrE,2EAA2E;IAC3E,8EAA8E;IAC9E,2CAA2C;IAC3C,MAAM,KAAK,GACT,WAAW;QACX,CAAC,cAAc;YACb,CAAC,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC,IAAI,EAAE,EAAE;gBACvC,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK;oBAAE,OAAO,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACnD,CAAC,CAAC;YACJ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,EAAE,CAAC,CAAC;IAEd,OAAO;IACL,sEAAsE;IACtE,+DAA+D;IAC/D,KAAC,OAAO,IACN,SAAS,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,CAC3B,EAAE,CACA,oCAAoC,EACpC,QAAQ,IAAI,SAAS;YACnB,CAAC,CAAC,gCAAgC;YAClC,CAAC,CAAC,+FAA+F,CACpG,EAEH,EAAE,EAAE,KAAK,YAER,KAAK,GACE,CACX,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"TopNavigation.js","sourceRoot":"","sources":["../../../src/lib/components/TopNavigation.tsx"],"names":[],"mappings":"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"}
@@ -1,13 +1,9 @@
1
+ import { type NavigationItem } from "../../../config/validators/NavigationSchema.js";
1
2
  import type { ZudokuContext } from "../../core/ZudokuContext.js";
2
3
  export declare const ZudokuReactContext: import("react").Context<ZudokuContext | undefined>;
3
4
  export declare const useZudoku: () => ZudokuContext;
4
5
  export declare const useApiIdentities: () => import("@tanstack/react-query").UseQueryResult<import("../../core/ZudokuContext.js").ApiIdentity[], Error>;
5
6
  export declare const useCurrentNavigation: () => {
6
- sidebar: import("../../../config/validators/SidebarSchema.js").SidebarItem[];
7
- topNavItem: {
8
- id: string;
9
- label: string;
10
- default?: string | undefined;
11
- display?: "auth" | "anon" | "always" | "hide" | undefined;
12
- } | undefined;
7
+ navigation: NavigationItem[];
8
+ topNavItem: import("../../../config/validators/NavigationSchema.js").NavigationDoc | import("../../../config/validators/NavigationSchema.js").NavigationLink | import("../../../config/validators/NavigationSchema.js").NavigationCategory | import("../../../config/validators/NavigationSchema.js").NavigationCustomPage | undefined;
13
9
  };
@@ -4,7 +4,7 @@ import { matchPath, useLocation } from "react-router";
4
4
  import { useAuth } from "../../authentication/hook.js";
5
5
  import { joinUrl } from "../../util/joinUrl.js";
6
6
  import { CACHE_KEYS } from "../cache.js";
7
- import { traverseSidebar } from "../navigation/utils.js";
7
+ import { traverseNavigation } from "../navigation/utils.js";
8
8
  export const ZudokuReactContext = createContext(undefined);
9
9
  export const useZudoku = () => {
10
10
  const context = useContext(ZudokuReactContext);
@@ -20,40 +20,58 @@ export const useApiIdentities = () => {
20
20
  queryKey: CACHE_KEYS.API_IDENTITIES,
21
21
  });
22
22
  };
23
+ const getItemPath = (item) => {
24
+ switch (item.type) {
25
+ case "doc":
26
+ return joinUrl(item.path);
27
+ case "category":
28
+ return item.link ? joinUrl(item.link.path) : undefined;
29
+ case "link":
30
+ return item.to;
31
+ case "custom-page":
32
+ return item.path;
33
+ default:
34
+ return undefined;
35
+ }
36
+ };
23
37
  export const useCurrentNavigation = () => {
24
- const { getPluginSidebar, sidebars, topNavigation, options } = useZudoku();
38
+ const { getPluginNavigation, navigation, options } = useZudoku();
25
39
  const location = useLocation();
26
40
  const auth = useAuth();
27
41
  const isProtectedRoute = options.protectedRoutes?.some((route) => matchPath(route, location.pathname));
28
- let currentSidebarItem = Object.entries(sidebars).find(([, sidebar]) => {
29
- return traverseSidebar(sidebar, (item) => {
30
- const itemId = item.type === "doc"
31
- ? joinUrl(item.id)
32
- : item.type === "category" && item.link
33
- ? joinUrl(item.link.id)
34
- : undefined;
35
- if (itemId === location.pathname) {
36
- return item;
37
- }
38
- });
42
+ const navItem = traverseNavigation(navigation, (item, parentCategories) => {
43
+ if (getItemPath(item) === location.pathname) {
44
+ return parentCategories.at(0) ?? item;
45
+ }
39
46
  });
40
- const currentTopNavItem = topNavigation.find((t) => t.id === currentSidebarItem?.[0]) ??
41
- topNavigation.find((item) => matchPath(item.id, location.pathname));
42
- if (currentTopNavItem &&
43
- !currentSidebarItem &&
44
- currentTopNavItem.id in sidebars) {
45
- currentSidebarItem = ["", sidebars[currentTopNavItem.id]];
46
- }
47
47
  const { data } = useSuspenseQuery({
48
- queryFn: () => getPluginSidebar(location.pathname),
49
- queryKey: ["plugin-sidebar", location.pathname],
48
+ queryFn: () => getPluginNavigation(location.pathname),
49
+ queryKey: ["plugin-navigation", location.pathname],
50
50
  });
51
- const hideSidebar = auth.isAuthEnabled && !auth.isAuthenticated && isProtectedRoute;
51
+ let topNavItem = navItem;
52
+ if (!navItem && data.length > 0) {
53
+ // Extract base paths from plugin navigation items
54
+ const pluginBasePaths = data.flatMap((item) => {
55
+ return getItemPath(item)?.split("?").at(0)?.split("#").at(0) ?? [];
56
+ });
57
+ // Find top-level nav item that matches any plugin base path
58
+ topNavItem = navigation
59
+ .flatMap((item) => {
60
+ const itemPath = getItemPath(item);
61
+ return itemPath ? [{ item, path: itemPath }] : [];
62
+ })
63
+ .sort((a, b) => b.path.length - a.path.length)
64
+ .find(({ path }) => {
65
+ return pluginBasePaths.some((basePath) => matchPath({ path, end: false }, basePath) ??
66
+ matchPath({ path: basePath, end: false }, path));
67
+ })?.item;
68
+ }
69
+ const hasNavigation = auth.isAuthEnabled && !auth.isAuthenticated && isProtectedRoute;
52
70
  return {
53
- sidebar: hideSidebar
71
+ navigation: hasNavigation
54
72
  ? []
55
- : [...(currentSidebarItem ? currentSidebarItem[1] : []), ...data],
56
- topNavItem: currentTopNavItem,
73
+ : [...(navItem?.type === "category" ? navItem.items : []), ...data],
74
+ topNavItem,
57
75
  };
58
76
  };
59
77
  //# sourceMappingURL=ZudokuContext.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ZudokuContext.js","sourceRoot":"","sources":["../../../../src/lib/components/context/ZudokuContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AAEvD,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,MAAM,CAAC,MAAM,kBAAkB,GAAG,aAAa,CAC7C,SAAS,CACV,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG,GAAG,EAAE;IAC5B,MAAM,OAAO,GAAG,UAAU,CAAC,kBAAkB,CAAC,CAAC;IAE/C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;IACrE,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,EAAE;IACnC,MAAM,EAAE,gBAAgB,EAAE,GAAG,SAAS,EAAE,CAAC;IAEzC,OAAO,QAAQ,CAAC;QACd,OAAO,EAAE,gBAAgB;QACzB,QAAQ,EAAE,UAAU,CAAC,cAAc;KACpC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,EAAE,gBAAgB,EAAE,QAAQ,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC;IAC3E,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,IAAI,GAAG,OAAO,EAAE,CAAC;IAEvB,MAAM,gBAAgB,GAAG,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAC/D,SAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,QAAQ,CAAC,CACpC,CAAC;IAEF,IAAI,kBAAkB,GAAG,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,EAAE;QACrE,OAAO,eAAe,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,EAAE;YACvC,MAAM,MAAM,GACV,IAAI,CAAC,IAAI,KAAK,KAAK;gBACjB,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBAClB,CAAC,CAAC,IAAI,CAAC,IAAI,KAAK,UAAU,IAAI,IAAI,CAAC,IAAI;oBACrC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;oBACvB,CAAC,CAAC,SAAS,CAAC;YAElB,IAAI,MAAM,KAAK,QAAQ,CAAC,QAAQ,EAAE,CAAC;gBACjC,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,MAAM,iBAAiB,GACrB,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,kBAAkB,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,aAAa,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;IAEtE,IACE,iBAAiB;QACjB,CAAC,kBAAkB;QACnB,iBAAiB,CAAC,EAAE,IAAI,QAAQ,EAChC,CAAC;QACD,kBAAkB,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,iBAAiB,CAAC,EAAE,CAAE,CAAC,CAAC;IAC7D,CAAC;IAED,MAAM,EAAE,IAAI,EAAE,GAAG,gBAAgB,CAAC;QAChC,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAClD,QAAQ,EAAE,CAAC,gBAAgB,EAAE,QAAQ,CAAC,QAAQ,CAAC;KAChD,CAAC,CAAC;IAEH,MAAM,WAAW,GACf,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,gBAAgB,CAAC;IAElE,OAAO;QACL,OAAO,EAAE,WAAW;YAClB,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC;QACnE,UAAU,EAAE,iBAAiB;KAC9B,CAAC;AACJ,CAAC,CAAC"}
1
+ {"version":3,"file":"ZudokuContext.js","sourceRoot":"","sources":["../../../../src/lib/components/context/ZudokuContext.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { NavigationItem as NavigationItemType } from "../../../config/validators/NavigationSchema.js";
2
+ export declare const Navigation: ({ onRequestClose, navigation, }: {
3
+ onRequestClose?: () => void;
4
+ navigation: NavigationItemType[];
5
+ }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { VisuallyHidden } from "@radix-ui/react-visually-hidden";
3
+ import { DrawerContent, DrawerTitle } from "../../ui/Drawer.js";
4
+ import { Slot } from "../Slot.js";
5
+ import { NavigationItem } from "./NavigationItem.js";
6
+ import { NavigationWrapper } from "./NavigationWrapper.js";
7
+ export const Navigation = ({ onRequestClose, navigation, }) => (_jsxs(_Fragment, { children: [_jsxs(NavigationWrapper, { children: [_jsx(Slot.Target, { name: "navigation-before" }), navigation.map((item) => (_jsx(NavigationItem, { item: item }, item.type +
8
+ (item.label ?? "") +
9
+ ("path" in item ? item.path : "") +
10
+ ("file" in item ? item.file : "") +
11
+ ("to" in item ? item.to : "")))), _jsx(Slot.Target, { name: "navigation-after" })] }), _jsx(DrawerContent, { className: "lg:hidden h-[100dvh] start-0 w-[320px] rounded-none", "aria-describedby": undefined, children: _jsxs("div", { className: "p-4 overflow-y-auto overscroll-none", children: [_jsx(VisuallyHidden, { children: _jsx(DrawerTitle, { children: "Navigation" }) }), navigation.map((item) => (_jsx(NavigationItem, { item: item, onRequestClose: onRequestClose }, item.label)))] }) })] }));
12
+ //# sourceMappingURL=Navigation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Navigation.js","sourceRoot":"","sources":["../../../../src/lib/components/navigation/Navigation.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,cAAc,EACd,UAAU,GAIX,EAAE,EAAE,CAAC,CACJ,8BACE,MAAC,iBAAiB,eAChB,KAAC,IAAI,CAAC,MAAM,IAAC,IAAI,EAAC,mBAAmB,GAAG,EACvC,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACxB,KAAC,cAAc,IAQb,IAAI,EAAE,IAAI,IANR,IAAI,CAAC,IAAI;oBACT,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;oBAClB,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;oBACjC,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;oBACjC,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAG/B,CACH,CAAC,EACF,KAAC,IAAI,CAAC,MAAM,IAAC,IAAI,EAAC,kBAAkB,GAAG,IACrB,EACpB,KAAC,aAAa,IACZ,SAAS,EAAC,qDAAqD,sBAC7C,SAAS,YAE3B,eAAK,SAAS,EAAC,qCAAqC,aAClD,KAAC,cAAc,cACb,KAAC,WAAW,6BAAyB,GACtB,EAChB,UAAU,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACxB,KAAC,cAAc,IAEb,IAAI,EAAE,IAAI,EACV,cAAc,EAAE,cAAc,IAFzB,IAAI,CAAC,KAAK,CAGf,CACH,CAAC,IACE,GACQ,IACf,CACJ,CAAC"}
@@ -18,7 +18,7 @@ export declare const ColorMapInvert: {
18
18
  gray: string;
19
19
  outline: string;
20
20
  };
21
- export declare const SidebarBadge: ({ color, label, className, invert, }: {
21
+ export declare const NavigationBadge: ({ color, label, className, invert, }: {
22
22
  color: keyof typeof ColorMap;
23
23
  label: string;
24
24
  className?: string;
@@ -20,7 +20,7 @@ export const ColorMapInvert = {
20
20
  gray: "text-gray-400 dark:text-gray-600",
21
21
  outline: "",
22
22
  };
23
- export const SidebarBadge = ({ color, label, className, invert, }) => {
23
+ export const NavigationBadge = ({ color, label, className, invert, }) => {
24
24
  return (_jsx("span", { className: cn("flex items-center duration-200 transition-opacity text-center uppercase text-[0.65rem] leading-5 font-bold rounded-sm text-background dark:text-zinc-50 h-full", color === "outline" ? "px-3" : "mt-0.5 px-1", invert ? ColorMapInvert[color] : ColorMap[color], className), children: label }));
25
25
  };
26
- //# sourceMappingURL=SidebarBadge.js.map
26
+ //# sourceMappingURL=NavigationBadge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavigationBadge.js","sourceRoot":"","sources":["../../../../src/lib/components/navigation/NavigationBadge.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAEtC,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,KAAK,EAAE,gCAAgC;IACvC,IAAI,EAAE,4BAA4B;IAClC,MAAM,EAAE,kCAAkC;IAC1C,GAAG,EAAE,4BAA4B;IACjC,MAAM,EAAE,kCAAkC;IAC1C,MAAM,EAAE,kCAAkC;IAC1C,IAAI,EAAE,8BAA8B;IACpC,OAAO,EAAE,iDAAiD;CAC3D,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,KAAK,EAAE,oCAAoC;IAC3C,IAAI,EAAE,gCAAgC;IACtC,MAAM,EAAE,sCAAsC;IAC9C,GAAG,EAAE,gCAAgC;IACrC,MAAM,EAAE,sCAAsC;IAC9C,MAAM,EAAE,sCAAsC;IAC9C,IAAI,EAAE,kCAAkC;IACxC,OAAO,EAAE,EAAE;CACZ,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAC9B,KAAK,EACL,KAAK,EACL,SAAS,EACT,MAAM,GAMP,EAAE,EAAE;IACH,OAAO,CACL,eACE,SAAS,EAAE,EAAE,CACX,gKAAgK,EAChK,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa,EAC5C,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAChD,SAAS,CACV,YAEA,KAAK,GACD,CACR,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { NavigationCategory as NavigationCategoryType } from "../../../config/validators/NavigationSchema.js";
2
+ export declare const NavigationCategory: import("react").MemoExoticComponent<({ category, onRequestClose, }: {
3
+ category: NavigationCategoryType;
4
+ onRequestClose?: () => void;
5
+ }) => import("react/jsx-runtime").JSX.Element>;
@@ -7,9 +7,9 @@ import { NavLink, useLocation, useMatch } from "react-router";
7
7
  import { Button } from "zudoku/ui/Button.js";
8
8
  import { cn } from "../../util/cn.js";
9
9
  import { joinUrl } from "../../util/joinUrl.js";
10
- import { SidebarItem } from "./SidebarItem.js";
10
+ import { NavigationItem } from "./NavigationItem.js";
11
11
  import { navigationListItem, useIsCategoryOpen } from "./utils.js";
12
- const SidebarCategoryInner = ({ category, onRequestClose, }) => {
12
+ const NavigationCategoryInner = ({ category, onRequestClose, }) => {
13
13
  const isCategoryOpen = useIsCategoryOpen(category);
14
14
  const [hasInteracted, setHasInteracted] = useState(false);
15
15
  const location = useLocation();
@@ -17,10 +17,10 @@ const SidebarCategoryInner = ({ category, onRequestClose, }) => {
17
17
  const isCollapsed = category.collapsed ?? true;
18
18
  const isDefaultOpen = Boolean(!isCollapsible || !isCollapsed || isCategoryOpen);
19
19
  const [open, setOpen] = useState(isDefaultOpen);
20
- const isActive = useMatch(category.link?.id ?? "");
20
+ const isActive = useMatch(category.link?.path ?? "");
21
21
  useEffect(() => {
22
- // this is triggered when an item from the sidebar is clicked
23
- // and the sidebar, enclosing this item, is not opened
22
+ // this is triggered when an item from the navigation is clicked
23
+ // and the navigation, enclosing this item, is not opened
24
24
  if (isCategoryOpen) {
25
25
  setOpen(true);
26
26
  }
@@ -40,7 +40,7 @@ const SidebarCategoryInner = ({ category, onRequestClose, }) => {
40
40
  ],
41
41
  });
42
42
  return (_jsxs(Collapsible.Root, { className: "flex flex-col", defaultOpen: isDefaultOpen, open: open, onOpenChange: () => setOpen(true), children: [_jsx(Collapsible.Trigger, { className: "group", asChild: true, disabled: !isCollapsible, children: category.link?.type === "doc" ? (_jsxs(NavLink, { to: {
43
- pathname: joinUrl(category.link.id),
43
+ pathname: joinUrl(category.link.path),
44
44
  search: location.search,
45
45
  }, className: styles, onClick: () => {
46
46
  setHasInteracted(true);
@@ -50,10 +50,12 @@ const SidebarCategoryInner = ({ category, onRequestClose, }) => {
50
50
  }
51
51
  }, children: [icon, _jsxs("div", { className: "flex items-center gap-2 justify-between w-full text-foreground/80 group-aria-[current='page']:text-primary", children: [_jsx("div", { className: "truncate", children: category.label }), ToggleButton] })] })) : (_jsxs("div", { onClick: () => setHasInteracted(true), className: styles, children: [icon, _jsxs("div", { className: "flex items-center justify-between w-full", children: [_jsx("div", { className: "flex gap-2 truncate w-full", children: category.label }), ToggleButton] })] })) }), _jsx(Collapsible.Content, { className: cn(
52
52
  // CollapsibleContent class is used to animate and it should only be applied when the user has triggered the toggle
53
- hasInteracted && "CollapsibleContent", category.items.length === 0 && "hidden", "ms-6 my-1"), children: _jsx("ul", { className: "relative after:absolute after:-start-(--padding-nav-item) after:translate-x-[1.5px] after:top-0 after:bottom-0 after:w-px after:bg-border", children: category.items.map((item) => (_jsx(SidebarItem, { onRequestClose: onRequestClose, item: item }, ("id" in item ? item.id : "") +
54
- ("href" in item ? item.href : "") +
55
- item.label))) }) })] }));
53
+ hasInteracted && "CollapsibleContent", category.items.length === 0 && "hidden", "ms-6 my-1"), children: _jsx("ul", { className: "relative after:absolute after:-start-(--padding-nav-item) after:translate-x-[1.5px] after:top-0 after:bottom-0 after:w-px after:bg-border", children: category.items.map((item) => (_jsx(NavigationItem, { onRequestClose: onRequestClose, item: item }, item.type +
54
+ (item.label ?? "") +
55
+ ("path" in item ? item.path : "") +
56
+ ("file" in item ? item.file : "") +
57
+ ("to" in item ? item.to : "")))) }) })] }));
56
58
  };
57
- export const SidebarCategory = memo(SidebarCategoryInner, deepEqual);
58
- SidebarCategory.displayName = "SidebarCategory";
59
- //# sourceMappingURL=SidebarCategory.js.map
59
+ export const NavigationCategory = memo(NavigationCategoryInner, deepEqual);
60
+ NavigationCategory.displayName = "NavigationCategory";
61
+ //# sourceMappingURL=NavigationCategory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavigationCategory.js","sourceRoot":"","sources":["../../../../src/lib/components/navigation/NavigationCategory.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { NavigationItem as NavigationItemType } from "../../../config/validators/NavigationSchema.js";
2
+ export declare const DATA_ANCHOR_ATTR = "data-anchor";
3
+ export declare const NavigationItem: ({ item, onRequestClose, }: {
4
+ item: NavigationItemType;
5
+ onRequestClose?: () => void;
6
+ }) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,47 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { ExternalLinkIcon } from "lucide-react";
3
+ import { useEffect, useRef, useState } from "react";
4
+ import { NavLink, useLocation } from "react-router";
5
+ import { Tooltip, TooltipArrow, TooltipContent, TooltipProvider, TooltipTrigger, } from "zudoku/ui/Tooltip.js";
6
+ import { cn } from "../../util/cn.js";
7
+ import { joinUrl } from "../../util/joinUrl.js";
8
+ import { AnchorLink } from "../AnchorLink.js";
9
+ import { useViewportAnchor } from "../context/ViewportAnchorContext.js";
10
+ import { NavigationBadge } from "./NavigationBadge.js";
11
+ import { NavigationCategory } from "./NavigationCategory.js";
12
+ import { navigationListItem } from "./utils.js";
13
+ const TruncatedLabel = ({ label, className, }) => {
14
+ const ref = useRef(null);
15
+ const [isTruncated, setIsTruncated] = useState(false);
16
+ useEffect(() => {
17
+ if (!ref.current)
18
+ return;
19
+ if (ref.current.offsetWidth < ref.current.scrollWidth) {
20
+ setIsTruncated(true);
21
+ }
22
+ }, []);
23
+ return (_jsxs(_Fragment, { children: [_jsx("span", { className: cn("truncate flex-1", className), title: label, ref: ref, children: label }), isTruncated && (_jsx(TooltipProvider, { delayDuration: 500, children: _jsxs(Tooltip, { disableHoverableContent: true, children: [_jsx(TooltipTrigger, { className: "absolute inset-0 z-10" }), _jsxs(TooltipContent, { className: "max-w-64 rounded-lg", side: "bottom", align: "center", children: [_jsx(TooltipArrow, {}), label] })] }) }))] }));
24
+ };
25
+ export const DATA_ANCHOR_ATTR = "data-anchor";
26
+ export const NavigationItem = ({ item, onRequestClose, }) => {
27
+ const location = useLocation();
28
+ const { activeAnchor } = useViewportAnchor();
29
+ switch (item.type) {
30
+ case "category":
31
+ return (_jsx(NavigationCategory, { category: item, onRequestClose: onRequestClose }));
32
+ case "doc":
33
+ return (_jsxs(NavLink, { viewTransition: true, className: ({ isActive, isPending }) => navigationListItem({ isActive, isPending }), to: joinUrl(item.path), onClick: onRequestClose, end: true, children: [item.icon && _jsx(item.icon, { size: 16, className: "align-[-0.125em]" }), item.badge ? (_jsxs(_Fragment, { children: [item.label && (_jsx(TruncatedLabel, { label: item.label, className: "flex-1" })), _jsx(NavigationBadge, { ...item.badge })] })) : (item.label)] }));
34
+ case "link":
35
+ case "custom-page": {
36
+ const href = item.type === "link" ? item.to : item.path;
37
+ return !href.startsWith("http") ? (_jsxs(AnchorLink, { to: {
38
+ pathname: href.split("#")[0],
39
+ hash: href.split("#")[1],
40
+ search: location.search,
41
+ }, [DATA_ANCHOR_ATTR]: href.split("#")[1], className: navigationListItem({
42
+ isActive: href === [location.pathname, activeAnchor].join("#"),
43
+ }), onClick: onRequestClose, children: [item.icon && _jsx(item.icon, { size: 16, className: "align-[-0.125em]" }), item.badge ? (_jsxs(_Fragment, { children: [item.label && _jsx(TruncatedLabel, { label: item.label }), _jsx(NavigationBadge, { ...item.badge })] })) : (_jsx("span", { className: "break-all", children: item.label }))] })) : (_jsxs("a", { className: navigationListItem(), href: href, target: "_blank", rel: "noopener noreferrer", onClick: onRequestClose, children: [item.icon && _jsx(item.icon, { size: 16, className: "align-[-0.125em]" }), _jsx("span", { className: "whitespace-normal", children: item.label }), _jsx("span", { className: "whitespace-nowrap", children: _jsx(ExternalLinkIcon, { className: "inline -translate-y-0.5", size: 12 }) })] }));
44
+ }
45
+ }
46
+ };
47
+ //# sourceMappingURL=NavigationItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavigationItem.js","sourceRoot":"","sources":["../../../../src/lib/components/navigation/NavigationItem.tsx"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { type PropsWithChildren } from "react";
2
- export declare const SidebarWrapper: {
2
+ export declare const NavigationWrapper: {
3
3
  ({ children, className, }: PropsWithChildren<{
4
4
  className?: string;
5
5
  }>): import("react/jsx-runtime").JSX.Element;
@@ -4,7 +4,7 @@ import { cn } from "../../util/cn.js";
4
4
  import { scrollIntoViewIfNeeded } from "../../util/scrollIntoViewIfNeeded.js";
5
5
  import { useZudoku } from "../context/ZudokuContext.js";
6
6
  import { PoweredByZudoku } from "./PoweredByZudoku.js";
7
- export const SidebarWrapper = ({ children, className, }) => {
7
+ export const NavigationWrapper = ({ children, className, }) => {
8
8
  const { options } = useZudoku();
9
9
  const navRef = useRef(null);
10
10
  useEffect(() => {
@@ -17,5 +17,5 @@ export const SidebarWrapper = ({ children, className, }) => {
17
17
  maskImage: `linear-gradient(180deg, transparent 1%, rgba(0, 0, 0, 1) 20px, rgba(0, 0, 0, 1) 90%, transparent 99%)`,
18
18
  }, children: children }), _jsx("div", { className: "bg-background border-t p-2 mx-5 gap-2 items-center mt-2 drop-shadow-[0_-3px_1px_rgba(0,0,0,0.015)] hidden lg:[&:has(>_:nth-child(1):last-child)]:flex", children: options.page?.showPoweredBy !== false && _jsx(PoweredByZudoku, {}) })] }));
19
19
  };
20
- SidebarWrapper.displayName = "SidebarWrapper";
21
- //# sourceMappingURL=SidebarWrapper.js.map
20
+ NavigationWrapper.displayName = "NavigationWrapper";
21
+ //# sourceMappingURL=NavigationWrapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavigationWrapper.js","sourceRoot":"","sources":["../../../../src/lib/components/navigation/NavigationWrapper.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAA0B,MAAM,OAAO,CAAC;AAClE,OAAO,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AACtC,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAChC,QAAQ,EACR,SAAS,GAGT,EAAE,EAAE;IACJ,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAC;IAChC,MAAM,MAAM,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAE5C,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,EAAE,aAAa,CAAC,uBAAuB,CAAC,CAAC;QACtE,sBAAsB,CAAC,MAAM,IAAI,IAAI,CAAC,CAAC;IACzC,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,eAAK,SAAS,EAAC,gHAAgH,aAC7H,cACE,GAAG,EAAE,MAAM,EACX,SAAS,EAAE,EAAE,CACX,kJAAkJ,EAClJ,gFAAgF;gBAChF,+CAA+C;gBAC/C,SAAS,EACT,SAAS,CACV,EACD,KAAK,EAAE;oBACL,SAAS,EAAE,uGAAuG;iBACnH,YAEA,QAAQ,GACL,EAEN,cAAK,SAAS,EAAC,wJAAwJ,YACpK,OAAO,CAAC,IAAI,EAAE,aAAa,KAAK,KAAK,IAAI,KAAC,eAAe,KAAG,GACzD,IACF,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,iBAAiB,CAAC,WAAW,GAAG,mBAAmB,CAAC"}
@@ -1,9 +1,9 @@
1
- import type { SidebarItem, SidebarItemCategory } from "../../../config/validators/SidebarSchema.js";
2
- export type TraverseCallback<T> = (item: SidebarItem, parentCategories: SidebarItem[]) => T | void;
3
- export declare const traverseSidebar: <T>(sidebar: SidebarItem[], callback: TraverseCallback<T>) => T | undefined;
4
- export declare const traverseSidebarItem: <T>(item: SidebarItem, callback: TraverseCallback<T>, parentCategories?: SidebarItem[]) => T | undefined;
5
- export declare const useCurrentItem: () => import("../../../config/validators/SidebarSchema.js").SidebarItemDoc | undefined;
6
- export declare const useIsCategoryOpen: (category: SidebarItemCategory) => true | undefined;
1
+ import type { NavigationCategory, NavigationItem } from "../../../config/validators/NavigationSchema.js";
2
+ export type TraverseCallback<T> = (item: NavigationItem, parentCategories: NavigationItem[]) => T | void;
3
+ export declare const traverseNavigation: <T>(navigation: NavigationItem[], callback: TraverseCallback<T>) => T | undefined;
4
+ export declare const traverseNavigationItem: <T>(item: NavigationItem, callback: TraverseCallback<T>, parentCategories?: NavigationItem[]) => T | undefined;
5
+ export declare const useCurrentItem: () => import("../../../config/validators/NavigationSchema.js").NavigationDoc | undefined;
6
+ export declare const useIsCategoryOpen: (category: NavigationCategory) => true | undefined;
7
7
  export declare const usePrevNext: () => {
8
8
  prev?: {
9
9
  label: string;
@@ -19,6 +19,4 @@ export declare const navigationListItem: (props?: ({
19
19
  isMuted?: boolean | null | undefined;
20
20
  isPending?: boolean | null | undefined;
21
21
  } & import("class-variance-authority/types").ClassProp) | undefined) => string;
22
- export declare const isHiddenItem: (isAuthenticated?: boolean) => (item: {
23
- display?: "auth" | "anon" | "always" | "hide";
24
- }) => boolean;
22
+ export declare const isHiddenItem: (isAuthenticated?: boolean) => (item: NavigationItem) => boolean;