zudoku 0.32.1 → 0.32.3

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 (205) hide show
  1. package/dist/app/tailwind.js +6 -0
  2. package/dist/app/tailwind.js.map +1 -1
  3. package/dist/config/validators/InputSidebarSchema.d.ts +15 -15
  4. package/dist/config/validators/InputSidebarSchema.js +10 -1
  5. package/dist/config/validators/InputSidebarSchema.js.map +1 -1
  6. package/dist/config/validators/common.d.ts +40 -40
  7. package/dist/config/validators/icon-types.d.ts +1 -1
  8. package/dist/config/validators/validate.d.ts +19 -19
  9. package/dist/lib/components/Header.js +2 -2
  10. package/dist/lib/components/Header.js.map +1 -1
  11. package/dist/lib/components/Layout.js +1 -1
  12. package/dist/lib/components/Layout.js.map +1 -1
  13. package/dist/lib/components/TopNavigation.js +3 -2
  14. package/dist/lib/components/TopNavigation.js.map +1 -1
  15. package/dist/lib/components/context/ZudokuContext.d.ts +1 -1
  16. package/dist/lib/components/index.d.ts +1 -0
  17. package/dist/lib/components/index.js +2 -0
  18. package/dist/lib/components/index.js.map +1 -1
  19. package/dist/lib/components/navigation/SidebarBadge.d.ts +2 -0
  20. package/dist/lib/components/navigation/SidebarBadge.js +3 -1
  21. package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
  22. package/dist/lib/components/navigation/SidebarItem.js +1 -1
  23. package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
  24. package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
  25. package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
  26. package/dist/lib/oas/graphql/index.js +3 -1
  27. package/dist/lib/oas/graphql/index.js.map +1 -1
  28. package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -2
  29. package/dist/lib/plugins/api-catalog/Catalog.js +11 -24
  30. package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
  31. package/dist/lib/plugins/api-catalog/index.d.ts +1 -0
  32. package/dist/lib/plugins/api-catalog/index.js +37 -8
  33. package/dist/lib/plugins/api-catalog/index.js.map +1 -1
  34. package/dist/lib/plugins/markdown/MdxPage.js +1 -1
  35. package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
  36. package/dist/lib/plugins/openapi/Sidecar.js +1 -1
  37. package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
  38. package/dist/lib/plugins/openapi/SidecarExamples.js +2 -2
  39. package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
  40. package/dist/lib/plugins/openapi/graphql/gql.js +0 -11
  41. package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
  42. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +1 -1
  43. package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
  44. package/dist/lib/ui/Badge.d.ts +1 -1
  45. package/dist/lib/ui/Button.d.ts +1 -1
  46. package/dist/lib/ui/Command.d.ts +1 -1
  47. package/dist/lib/ui/SyntaxHighlight.d.ts +14 -0
  48. package/dist/lib/{components → ui}/SyntaxHighlight.js +9 -6
  49. package/dist/lib/ui/SyntaxHighlight.js.map +1 -0
  50. package/dist/lib/ui/util.d.ts +2 -0
  51. package/dist/lib/ui/util.js +3 -0
  52. package/dist/lib/ui/util.js.map +1 -0
  53. package/dist/lib/util/MdxComponents.js +1 -1
  54. package/dist/lib/util/MdxComponents.js.map +1 -1
  55. package/dist/vite/config.js +4 -14
  56. package/dist/vite/config.js.map +1 -1
  57. package/dist/vite/plugin-api.js +2 -2
  58. package/dist/vite/plugin-api.js.map +1 -1
  59. package/dist/vite/plugin-config-reload.js +2 -1
  60. package/dist/vite/plugin-config-reload.js.map +1 -1
  61. package/dist/vite/plugin-config.js +5 -2
  62. package/dist/vite/plugin-config.js.map +1 -1
  63. package/lib/{AuthenticationPlugin-_YVa673u.js → AuthenticationPlugin-BlxA4Mbn.js} +4 -4
  64. package/lib/{AuthenticationPlugin-_YVa673u.js.map → AuthenticationPlugin-BlxA4Mbn.js.map} +1 -1
  65. package/lib/{CategoryHeading-MYL1u_6K.js → CategoryHeading-DpB47wvk.js} +3 -3
  66. package/lib/{CategoryHeading-MYL1u_6K.js.map → CategoryHeading-DpB47wvk.js.map} +1 -1
  67. package/lib/{Markdown-8mv9nhGd.js → Markdown-Cr9sYpR_.js} +4800 -4729
  68. package/lib/Markdown-Cr9sYpR_.js.map +1 -0
  69. package/lib/{MdxPage-GM1T5jmO.js → MdxPage-Dt-UEQl8.js} +10 -10
  70. package/lib/MdxPage-Dt-UEQl8.js.map +1 -0
  71. package/lib/{OasProvider-IS9wBrb7.js → OasProvider-WVtvHP5H.js} +6 -6
  72. package/lib/{OasProvider-IS9wBrb7.js.map → OasProvider-WVtvHP5H.js.map} +1 -1
  73. package/lib/{OperationList-BTmRbbXk.js → OperationList-DhOwupvv.js} +18 -19
  74. package/lib/{OperationList-BTmRbbXk.js.map → OperationList-DhOwupvv.js.map} +1 -1
  75. package/lib/Select-D9hI1G-y.js +223 -0
  76. package/lib/{Select-D9CKL33X.js.map → Select-D9hI1G-y.js.map} +1 -1
  77. package/lib/{SlotletProvider-D0mFmGJu.js → SlotletProvider-CEfNOA8i.js} +53 -53
  78. package/lib/{SlotletProvider-D0mFmGJu.js.map → SlotletProvider-CEfNOA8i.js.map} +1 -1
  79. package/lib/{Spinner-BlzrEEk1.js → Spinner-1KrEmx1V.js} +3 -3
  80. package/lib/{Spinner-BlzrEEk1.js.map → Spinner-1KrEmx1V.js.map} +1 -1
  81. package/lib/{SyntaxHighlight-B0L4SC_N.js → SyntaxHighlight-CcnUjERD.js} +445 -445
  82. package/lib/SyntaxHighlight-CcnUjERD.js.map +1 -0
  83. package/lib/{chunk-SYFQ2XB5-QijJrSf0.js → chunk-IR6S3I6Y-D_3UmFIn.js} +597 -597
  84. package/lib/chunk-IR6S3I6Y-D_3UmFIn.js.map +1 -0
  85. package/lib/{circular-DxaIIlWD.js → circular-v7K6lDDh.js} +1413 -1413
  86. package/lib/{circular-DxaIIlWD.js.map → circular-v7K6lDDh.js.map} +1 -1
  87. package/lib/context-DLCwaMXN.js +22 -0
  88. package/lib/{context-rwLGh-6_.js.map → context-DLCwaMXN.js.map} +1 -1
  89. package/lib/{createServer-DSQiPwjN.js → createServer-DMf6O2Rz.js} +3669 -3562
  90. package/lib/createServer-DMf6O2Rz.js.map +1 -0
  91. package/lib/{hook-C_t2ISLC.js → hook-CWwSAAlH.js} +384 -379
  92. package/lib/hook-CWwSAAlH.js.map +1 -0
  93. package/lib/index-Bn6Lc9tq.js +9 -0
  94. package/lib/index-Bn6Lc9tq.js.map +1 -0
  95. package/lib/index-CPNSgwSb.js +36 -0
  96. package/lib/{index-Djenk2Hj.js.map → index-CPNSgwSb.js.map} +1 -1
  97. package/lib/{index-BANyVRgL.js → index-Do_30Hpk.js} +78 -78
  98. package/lib/index-Do_30Hpk.js.map +1 -0
  99. package/lib/{index-B7mqiOei.js → index-Du5aNddU.js} +101 -101
  100. package/lib/index-Du5aNddU.js.map +1 -0
  101. package/lib/{index-CjJS0l4l.js → index-LNp6rxyU.js} +2 -2
  102. package/lib/{index-CjJS0l4l.js.map → index-LNp6rxyU.js.map} +1 -1
  103. package/lib/{index.esm-CrSoEshU.js → index.esm--gIChbWs.js} +3 -3
  104. package/lib/{index.esm-CrSoEshU.js.map → index.esm--gIChbWs.js.map} +1 -1
  105. package/lib/{index.esm-9-TF9KQB.js → index.esm-CQHE3GEU.js} +52 -53
  106. package/lib/{index.esm-9-TF9KQB.js.map → index.esm-CQHE3GEU.js.map} +1 -1
  107. package/lib/joinUrl-10po2Jdj.js +20 -0
  108. package/lib/{joinUrl-nLx9pD-Z.js.map → joinUrl-10po2Jdj.js.map} +1 -1
  109. package/lib/{jsx-runtime-Bdg6XQ1m.js → jsx-runtime-CYK1ROHF.js} +99 -99
  110. package/lib/{jsx-runtime-Bdg6XQ1m.js.map → jsx-runtime-CYK1ROHF.js.map} +1 -1
  111. package/lib/{mutation-Cm3O9f3X.js → mutation-B0wxqzSN.js} +26 -26
  112. package/lib/{mutation-Cm3O9f3X.js.map → mutation-B0wxqzSN.js.map} +1 -1
  113. package/lib/post-processors/removeExtensions.js +4 -4
  114. package/lib/ui/Accordion.js +1 -1
  115. package/lib/ui/ActionButton.js +2 -2
  116. package/lib/ui/Alert.js +2 -2
  117. package/lib/ui/AlertDialog.js +1 -1
  118. package/lib/ui/Badge.js +2 -2
  119. package/lib/ui/Breadcrumb.js +4 -4
  120. package/lib/ui/Button.js +2 -2
  121. package/lib/ui/Callout.js +4 -4
  122. package/lib/ui/Card.js +1 -1
  123. package/lib/ui/Carousel.js +1 -1
  124. package/lib/ui/Checkbox.js +2 -2
  125. package/lib/ui/Command.js +2 -2
  126. package/lib/ui/Dialog.js +1 -1
  127. package/lib/ui/Drawer.js +521 -543
  128. package/lib/ui/Drawer.js.map +1 -1
  129. package/lib/ui/DropdownMenu.js +1 -1
  130. package/lib/ui/Form.js +5 -5
  131. package/lib/ui/HoverCard.js +1 -1
  132. package/lib/ui/Input.js +1 -1
  133. package/lib/ui/Label.js +2 -2
  134. package/lib/ui/Pagination.js +10 -10
  135. package/lib/ui/Popover.js +1 -1
  136. package/lib/ui/Progress.js +1 -1
  137. package/lib/ui/RadioGroup.js +1 -1
  138. package/lib/ui/ScrollArea.js +1 -1
  139. package/lib/ui/Select.js +1 -1
  140. package/lib/ui/Skeleton.js +1 -1
  141. package/lib/ui/Slider.js +1 -1
  142. package/lib/ui/Switch.js +1 -1
  143. package/lib/ui/SyntaxHighlight.js +10 -0
  144. package/lib/ui/SyntaxHighlight.js.map +1 -0
  145. package/lib/ui/Tabs.js +1 -1
  146. package/lib/ui/Textarea.js +1 -1
  147. package/lib/ui/Toggle.js +2 -2
  148. package/lib/ui/ToggleGroup.js +1 -1
  149. package/lib/ui/Tooltip.js +1 -1
  150. package/lib/ui/util.js +6 -0
  151. package/lib/ui/util.js.map +1 -0
  152. package/lib/{useExposedProps-Bbf99zic.js → useExposedProps-RIvey2Oy.js} +2 -2
  153. package/lib/{useExposedProps-Bbf99zic.js.map → useExposedProps-RIvey2Oy.js.map} +1 -1
  154. package/lib/{useScrollToAnchor-BGEcH3HM.js → useScrollToAnchor-C-sRxs9o.js} +13 -9
  155. package/lib/useScrollToAnchor-C-sRxs9o.js.map +1 -0
  156. package/lib/zudoku.auth-auth0.js +1 -1
  157. package/lib/zudoku.auth-clerk.js +18 -18
  158. package/lib/zudoku.auth-openid.js +255 -295
  159. package/lib/zudoku.auth-openid.js.map +1 -1
  160. package/lib/zudoku.components.js +290 -283
  161. package/lib/zudoku.components.js.map +1 -1
  162. package/lib/zudoku.icons.js +1 -1
  163. package/lib/zudoku.plugin-api-catalog.js +91 -108
  164. package/lib/zudoku.plugin-api-catalog.js.map +1 -1
  165. package/lib/zudoku.plugin-api-keys.js +6 -6
  166. package/lib/zudoku.plugin-custom-pages.js +3 -3
  167. package/lib/zudoku.plugin-markdown.js +2 -2
  168. package/lib/zudoku.plugin-openapi.js +6 -6
  169. package/lib/zudoku.plugin-redirect.js +1 -1
  170. package/lib/zudoku.plugin-search-inkeep.js +9 -9
  171. package/package.json +49 -50
  172. package/src/app/tailwind.ts +6 -0
  173. package/src/lib/components/Header.tsx +3 -3
  174. package/src/lib/components/Layout.tsx +2 -2
  175. package/src/lib/components/TopNavigation.tsx +13 -9
  176. package/src/lib/components/index.ts +2 -0
  177. package/src/lib/components/navigation/SidebarBadge.tsx +4 -1
  178. package/src/lib/components/navigation/SidebarItem.tsx +1 -0
  179. package/src/lib/components/navigation/SidebarWrapper.tsx +1 -1
  180. package/src/lib/oas/graphql/index.ts +4 -1
  181. package/src/lib/plugins/api-catalog/Catalog.tsx +31 -94
  182. package/src/lib/plugins/api-catalog/index.tsx +54 -9
  183. package/src/lib/plugins/markdown/MdxPage.tsx +1 -1
  184. package/src/lib/plugins/openapi/Sidecar.tsx +1 -1
  185. package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -2
  186. package/src/lib/plugins/openapi/graphql/gql.ts +9 -1
  187. package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +1 -1
  188. package/src/lib/{components → ui}/SyntaxHighlight.tsx +23 -8
  189. package/src/lib/ui/util.tsx +3 -0
  190. package/src/lib/util/MdxComponents.tsx +1 -1
  191. package/dist/lib/components/SyntaxHighlight.d.ts +0 -12
  192. package/dist/lib/components/SyntaxHighlight.js.map +0 -1
  193. package/lib/Markdown-8mv9nhGd.js.map +0 -1
  194. package/lib/MdxPage-GM1T5jmO.js.map +0 -1
  195. package/lib/Select-D9CKL33X.js +0 -223
  196. package/lib/SyntaxHighlight-B0L4SC_N.js.map +0 -1
  197. package/lib/chunk-SYFQ2XB5-QijJrSf0.js.map +0 -1
  198. package/lib/context-rwLGh-6_.js +0 -22
  199. package/lib/createServer-DSQiPwjN.js.map +0 -1
  200. package/lib/hook-C_t2ISLC.js.map +0 -1
  201. package/lib/index-B7mqiOei.js.map +0 -1
  202. package/lib/index-BANyVRgL.js.map +0 -1
  203. package/lib/index-Djenk2Hj.js +0 -36
  204. package/lib/joinUrl-nLx9pD-Z.js +0 -20
  205. package/lib/useScrollToAnchor-BGEcH3HM.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  import { CircleDashed as e } from "lucide-react";
2
2
  export * from "lucide-react";
3
- import { j as o } from "./jsx-runtime-Bdg6XQ1m.js";
3
+ import { j as o } from "./jsx-runtime-CYK1ROHF.js";
4
4
  import { TooltipProvider as t, Tooltip as i, TooltipTrigger as s, TooltipContent as n } from "./ui/Tooltip.js";
5
5
  const d = (r) => /* @__PURE__ */ o.jsx(t, { children: /* @__PURE__ */ o.jsxs(i, { children: [
6
6
  /* @__PURE__ */ o.jsx(s, { className: "text-red-500", children: /* @__PURE__ */ o.jsx(e, { ...r }) }),
@@ -1,122 +1,105 @@
1
- import { j as e } from "./jsx-runtime-Bdg6XQ1m.js";
2
- import { s as j } from "./index-CjJS0l4l.js";
3
- import { u as b, a as y } from "./hook-C_t2ISLC.js";
4
- import { b as v } from "./chunk-SYFQ2XB5-QijJrSf0.js";
5
- import { Head as N, Link as w } from "./zudoku.components.js";
6
- import { M as C } from "./Markdown-8mv9nhGd.js";
7
- import { c as h } from "./cn-qaFjX9_3.js";
8
- const f = (r, n) => j(`${r}-${n}`), k = ({
9
- items: r,
10
- filterCatalogItems: n = (o) => o,
11
- categories: l,
12
- label: c = "API Library"
1
+ import { j as e } from "./jsx-runtime-CYK1ROHF.js";
2
+ import { s as f } from "./index-LNp6rxyU.js";
3
+ import { d as b, m as x } from "./chunk-IR6S3I6Y-D_3UmFIn.js";
4
+ import { j as d } from "./joinUrl-10po2Jdj.js";
5
+ import { u as j, a as y } from "./hook-CWwSAAlH.js";
6
+ import { Head as v, Link as N } from "./zudoku.components.js";
7
+ import { H as S, M as w } from "./Markdown-Cr9sYpR_.js";
8
+ const M = ({
9
+ items: a,
10
+ filterCatalogItems: r = (s) => s,
11
+ label: p = "API Library"
13
12
  }) => {
14
- const [o, p] = v(), a = o.get("category"), x = b(), g = y({
15
- queryFn: () => n(r, { auth: x }),
16
- queryKey: ["catalogItems", x]
13
+ const s = j(), i = b({ path: "/catalog/:category" }), l = i == null ? void 0 : i.params.category, o = y({
14
+ queryFn: () => r(a, { auth: s }),
15
+ queryKey: ["catalogItems", s]
17
16
  });
18
17
  return /* @__PURE__ */ e.jsxs("section", { className: "pt-[--padding-content-top] pb-[--padding-content-bottom]", children: [
19
- /* @__PURE__ */ e.jsx(N, { children: /* @__PURE__ */ e.jsx("title", { children: c }) }),
20
- /* @__PURE__ */ e.jsxs("div", { className: "grid grid-cols-12 gap-12", children: [
21
- /* @__PURE__ */ e.jsx("div", { className: "flex flex-col gap-4 col-span-3 not-prose sticky top-48", children: /* @__PURE__ */ e.jsx("div", { className: "max-w-[--side-nav-width] flex flex-col gap-4 justify-between", children: l == null ? void 0 : l.map((s, d) => /* @__PURE__ */ e.jsxs("div", { children: [
22
- /* @__PURE__ */ e.jsxs("div", { className: "flex justify-between mb-2.5", children: [
23
- /* @__PURE__ */ e.jsx("span", { className: "font-medium text-sm", children: s.label }),
24
- d === 0 && a && /* @__PURE__ */ e.jsx(
25
- "button",
26
- {
27
- type: "button",
28
- className: "text-end text-sm text-foreground/60 hover:text-foreground",
29
- onClick: () => p({}),
30
- children: "Clear"
31
- }
32
- )
33
- ] }),
34
- /* @__PURE__ */ e.jsx("ul", { className: "space-y-1 [&>li]:py-2", children: s.tags.map((t) => ({
35
- tag: t,
36
- count: r.filter(
37
- (m) => m.categories.find((i) => i.tags.includes(t))
38
- ).length
39
- })).map(({ tag: t, count: m }) => {
40
- const i = f(s.label, t), u = i === a;
41
- return /* @__PURE__ */ e.jsxs(
42
- "li",
43
- {
44
- className: h(
45
- "flex rounded-lg justify-between text-sm cursor-pointer hover:text-primary transition px-[--padding-nav-item] -mx-[--padding-nav-item]",
46
- u && "bg-border/30 rounded"
47
- ),
48
- onClick: () => p({ category: i }),
49
- children: [
50
- /* @__PURE__ */ e.jsx("span", { children: t }),
51
- /* @__PURE__ */ e.jsx(
52
- "span",
53
- {
54
- className: h(
55
- "flex items-center justify-center border rounded-md w-8 text-xs font-semibold",
56
- u && "bg-primary border-primary text-primary-foreground"
57
- ),
58
- children: m
59
- }
60
- )
61
- ]
62
- },
63
- i
64
- );
65
- }) })
66
- ] }, s.label)) }) }),
67
- /* @__PURE__ */ e.jsxs("div", { className: "col-span-9", children: [
68
- /* @__PURE__ */ e.jsx("h3", { className: "mt-0 text-2xl font-bold mb-4", children: c }),
69
- /* @__PURE__ */ e.jsx("div", { className: "grid grid-cols-2 gap-4", children: g.data.filter(
70
- (s) => !a || s.categories.find(
71
- (d) => d.tags.find((t) => f(d.label, t) === a)
72
- )
73
- ).map((s) => /* @__PURE__ */ e.jsx(
74
- w,
75
- {
76
- to: {
77
- pathname: `/${s.path}`,
78
- search: a ? `category=${a}` : ""
79
- },
80
- className: "no-underline hover:!text-foreground",
81
- children: /* @__PURE__ */ e.jsxs("div", { className: "border h-full rounded p-4 flex flex-col gap-2 cursor-pointer hover:bg-border/20 font-normal", children: [
82
- /* @__PURE__ */ e.jsx("span", { className: "font-semibold", children: s.label }),
83
- /* @__PURE__ */ e.jsx(
84
- C,
85
- {
86
- className: "text-sm whitespace-pre-wrap mb-6 line-clamp-2",
87
- content: s.description
88
- }
89
- )
90
- ] })
91
- },
92
- s.path
93
- )) })
94
- ] })
18
+ /* @__PURE__ */ e.jsx(v, { children: /* @__PURE__ */ e.jsx("title", { children: p }) }),
19
+ /* @__PURE__ */ e.jsxs("div", { className: "grid gap-4", children: [
20
+ /* @__PURE__ */ e.jsx(S, { level: 2, children: p }),
21
+ /* @__PURE__ */ e.jsx("div", { className: "grid grid-cols-2 gap-4", children: o.data.filter(
22
+ (t) => !l || t.categories.find(
23
+ (n) => n.tags.find((c) => m(n.label, c) === l)
24
+ )
25
+ ).map((t) => /* @__PURE__ */ e.jsx(
26
+ N,
27
+ {
28
+ to: d(t.path),
29
+ className: "no-underline hover:!text-foreground",
30
+ children: /* @__PURE__ */ e.jsxs("div", { className: "border h-full rounded-lg p-4 flex flex-col gap-2 cursor-pointer hover:bg-border/20 font-normal", children: [
31
+ /* @__PURE__ */ e.jsx("span", { className: "font-semibold", children: t.label }),
32
+ /* @__PURE__ */ e.jsx(
33
+ w,
34
+ {
35
+ className: "text-sm whitespace-pre-wrap mb-6 line-clamp-2",
36
+ content: t.description
37
+ }
38
+ )
39
+ ] })
40
+ },
41
+ t.path
42
+ )) })
95
43
  ] })
96
44
  ] });
97
- }, L = ({
98
- navigationId: r,
99
- items: n,
100
- label: l,
101
- categories: c,
102
- filterCatalogItems: o
45
+ }, m = (a, r) => f(`${a}-${r}`), L = ({
46
+ navigationId: a,
47
+ items: r,
48
+ label: p,
49
+ categories: s = [],
50
+ filterCatalogItems: i
103
51
  }) => ({
104
- getRoutes: () => [
105
- {
106
- path: r,
52
+ getSidebar: async function(o) {
53
+ if (!x({ path: d(a), end: !1 }, o))
54
+ return [];
55
+ const t = s.map((n) => ({
56
+ type: "category",
57
+ label: n.label,
58
+ collapsible: !1,
59
+ items: n.tags.map((c) => {
60
+ const u = m(n.label, c);
61
+ return {
62
+ type: "doc",
63
+ id: d(a, u),
64
+ label: c,
65
+ badge: {
66
+ label: String(
67
+ r.filter(
68
+ (g) => g.categories.find((h) => h.tags.includes(c))
69
+ ).length
70
+ ),
71
+ color: "outline"
72
+ }
73
+ };
74
+ })
75
+ }));
76
+ return t.unshift({
77
+ type: "doc",
78
+ id: d(a),
79
+ label: "Overview",
80
+ badge: { label: String(r.length), color: "outline" }
81
+ }), t;
82
+ },
83
+ getRoutes: () => s.flatMap(
84
+ (l) => [void 0, ...l.tags].map((o) => ({
85
+ path: d(
86
+ a,
87
+ o ? m(l.label, o) : void 0
88
+ ),
107
89
  element: /* @__PURE__ */ e.jsx(
108
- k,
90
+ M,
109
91
  {
110
- label: l,
111
- items: n,
112
- filterCatalogItems: o,
113
- categories: c ?? []
92
+ label: p,
93
+ items: r,
94
+ filterCatalogItems: i,
95
+ categories: s
114
96
  }
115
97
  )
116
- }
117
- ]
98
+ }))
99
+ )
118
100
  });
119
101
  export {
120
- L as apiCatalogPlugin
102
+ L as apiCatalogPlugin,
103
+ m as getKey
121
104
  };
122
105
  //# sourceMappingURL=zudoku.plugin-api-catalog.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"zudoku.plugin-api-catalog.js","sources":["../src/lib/plugins/api-catalog/Catalog.tsx","../src/lib/plugins/api-catalog/index.tsx"],"sourcesContent":["import slugify from \"@sindresorhus/slugify\";\nimport { useSuspenseQuery } from \"@tanstack/react-query\";\nimport { useSearchParams } from \"react-router\";\nimport { Head, Link } from \"zudoku/components\";\nimport { useAuthState } from \"../../authentication/state.js\";\nimport { Markdown } from \"../../components/Markdown.js\";\nimport { cn } from \"../../util/cn.js\";\nimport type { ApiCatalogPluginOptions } from \"./index.js\";\n\nconst getKey = (category: string, tag: string) => slugify(`${category}-${tag}`);\n\nexport const Catalog = ({\n items,\n filterCatalogItems = (items) => items,\n categories,\n label = \"API Library\",\n}: Omit<ApiCatalogPluginOptions, \"navigationId\">) => {\n const [searchParams, setSearchParams] = useSearchParams();\n const activeCategory = searchParams.get(\"category\");\n const auth = useAuthState();\n\n const catalogItems = useSuspenseQuery({\n queryFn: () => filterCatalogItems(items, { auth }),\n queryKey: [\"catalogItems\", auth],\n });\n\n return (\n <section className=\"pt-[--padding-content-top] pb-[--padding-content-bottom]\">\n <Head>\n <title>{label}</title>\n </Head>\n <div className=\"grid grid-cols-12 gap-12\">\n <div className=\"flex flex-col gap-4 col-span-3 not-prose sticky top-48\">\n <div className=\"max-w-[--side-nav-width] flex flex-col gap-4 justify-between\">\n {categories?.map((category, idx) => (\n <div key={category.label}>\n <div className=\"flex justify-between mb-2.5\">\n <span className=\"font-medium text-sm\">{category.label}</span>\n {idx === 0 && activeCategory && (\n <button\n type=\"button\"\n className=\"text-end text-sm text-foreground/60 hover:text-foreground\"\n onClick={() => setSearchParams({})}\n >\n Clear\n </button>\n )}\n </div>\n <ul className=\"space-y-1 [&>li]:py-2\">\n {category.tags\n .map((tag) => ({\n tag,\n count: items.filter((api) =>\n api.categories.find((c) => c.tags.includes(tag)),\n ).length,\n }))\n .map(({ tag, count }) => {\n const slug = getKey(category.label, tag);\n const isActive = slug === activeCategory;\n\n return (\n <li\n key={slug}\n className={cn(\n \"flex rounded-lg justify-between text-sm cursor-pointer hover:text-primary transition px-[--padding-nav-item] -mx-[--padding-nav-item]\",\n isActive && \"bg-border/30 rounded\",\n )}\n onClick={() => setSearchParams({ category: slug })}\n >\n <span>{tag}</span>\n <span\n className={cn(\n \"flex items-center justify-center border rounded-md w-8 text-xs font-semibold\",\n isActive &&\n \"bg-primary border-primary text-primary-foreground\",\n )}\n >\n {count}\n </span>\n </li>\n );\n })}\n </ul>\n </div>\n ))}\n </div>\n </div>\n <div className=\"col-span-9\">\n <h3 className=\"mt-0 text-2xl font-bold mb-4\">{label}</h3>\n\n <div className=\"grid grid-cols-2 gap-4\">\n {catalogItems.data\n .filter(\n (api) =>\n !activeCategory ||\n api.categories.find((c) =>\n c.tags.find((t) => getKey(c.label, t) === activeCategory),\n ),\n )\n .map((api) => (\n <Link\n to={{\n pathname: `/${api.path}`,\n search: activeCategory ? `category=${activeCategory}` : \"\",\n }}\n className=\"no-underline hover:!text-foreground\"\n key={api.path}\n >\n <div className=\"border h-full rounded p-4 flex flex-col gap-2 cursor-pointer hover:bg-border/20 font-normal\">\n <span className=\"font-semibold\">{api.label}</span>\n <Markdown\n className=\"text-sm whitespace-pre-wrap mb-6 line-clamp-2\"\n content={api.description}\n />\n </div>\n </Link>\n ))}\n </div>\n </div>\n </div>\n </section>\n );\n};\n","import type { AuthState } from \"../../authentication/state.js\";\nimport type { ZudokuPlugin } from \"../../core/plugins.js\";\nimport { Catalog } from \"./Catalog.js\";\n\nexport type ApiCatalogItem = {\n path: string;\n label: string;\n description: string;\n categories: CatalogCategory[];\n};\n\nexport type CatalogCategory = {\n label: string;\n tags: string[];\n};\n\nexport type ApiCatalogPluginOptions = {\n navigationId: string;\n label: string;\n categories?: CatalogCategory[];\n items: ApiCatalogItem[];\n filterCatalogItems?: filterCatalogItems;\n};\n\nexport type CatalogContext<ProviderData = unknown> = {\n auth: AuthState<ProviderData>;\n};\n\nexport type filterCatalogItems<ProviderData = unknown> = (\n items: ApiCatalogItem[],\n { auth }: CatalogContext<ProviderData>,\n) => ApiCatalogItem[];\n\nexport const apiCatalogPlugin = ({\n navigationId,\n items,\n label,\n categories,\n filterCatalogItems,\n}: {\n navigationId: string;\n label: string;\n categories?: CatalogCategory[];\n items: ApiCatalogItem[];\n filterCatalogItems?: filterCatalogItems;\n}): ZudokuPlugin => {\n return {\n getRoutes: () => {\n return [\n {\n path: navigationId,\n element: (\n <Catalog\n label={label}\n items={items}\n filterCatalogItems={filterCatalogItems}\n categories={categories ?? []}\n />\n ),\n },\n ];\n },\n };\n};\n"],"names":["getKey","category","tag","slugify","Catalog","items","filterCatalogItems","categories","label","searchParams","setSearchParams","useSearchParams","activeCategory","auth","useAuthState","catalogItems","useSuspenseQuery","jsxs","jsx","Head","idx","api","c","count","slug","isActive","cn","Link","Markdown","apiCatalogPlugin","navigationId"],"mappings":"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"}
1
+ {"version":3,"file":"zudoku.plugin-api-catalog.js","sources":["../src/lib/plugins/api-catalog/Catalog.tsx","../src/lib/plugins/api-catalog/index.tsx"],"sourcesContent":["import { useSuspenseQuery } from \"@tanstack/react-query\";\nimport { useMatch } from \"react-router\";\nimport { Head, Link } from \"zudoku/components\";\nimport { useAuthState } from \"../../authentication/state.js\";\nimport { Heading } from \"../../components/Heading.js\";\nimport { Markdown } from \"../../components/Markdown.js\";\nimport { joinUrl } from \"../../util/joinUrl.js\";\nimport { type ApiCatalogPluginOptions, getKey } from \"./index.js\";\n\nexport const Catalog = ({\n items,\n filterCatalogItems = (items) => items,\n label = \"API Library\",\n}: Omit<ApiCatalogPluginOptions, \"navigationId\">) => {\n const auth = useAuthState();\n const match = useMatch({ path: \"/catalog/:category\" });\n const activeCategory = match?.params.category;\n\n const catalogItems = useSuspenseQuery({\n queryFn: () => filterCatalogItems(items, { auth }),\n queryKey: [\"catalogItems\", auth],\n });\n\n return (\n <section className=\"pt-[--padding-content-top] pb-[--padding-content-bottom]\">\n <Head>\n <title>{label}</title>\n </Head>\n <div className=\"grid gap-4\">\n <Heading level={2}>{label}</Heading>\n\n <div className=\"grid grid-cols-2 gap-4\">\n {catalogItems.data\n .filter(\n (api) =>\n !activeCategory ||\n api.categories.find((c) =>\n c.tags.find((t) => getKey(c.label, t) === activeCategory),\n ),\n )\n .map((api) => (\n <Link\n to={joinUrl(api.path)}\n className=\"no-underline hover:!text-foreground\"\n key={api.path}\n >\n <div className=\"border h-full rounded-lg p-4 flex flex-col gap-2 cursor-pointer hover:bg-border/20 font-normal\">\n <span className=\"font-semibold\">{api.label}</span>\n <Markdown\n className=\"text-sm whitespace-pre-wrap mb-6 line-clamp-2\"\n content={api.description}\n />\n </div>\n </Link>\n ))}\n </div>\n </div>\n </section>\n );\n};\n","import slugify from \"@sindresorhus/slugify\";\nimport { matchPath } from \"react-router\";\nimport type { SidebarItem } from \"../../../config/validators/SidebarSchema.js\";\nimport type { AuthState } from \"../../authentication/state.js\";\nimport type { ZudokuPlugin } from \"../../core/plugins.js\";\nimport { joinUrl } from \"../../util/joinUrl.js\";\nimport { Catalog } from \"./Catalog.js\";\n\nexport const getKey = (category: string, tag: string) =>\n slugify(`${category}-${tag}`);\n\nexport type ApiCatalogItem = {\n path: string;\n label: string;\n description: string;\n categories: CatalogCategory[];\n};\n\nexport type CatalogCategory = {\n label: string;\n tags: string[];\n};\n\nexport type ApiCatalogPluginOptions = {\n navigationId: string;\n label: string;\n categories?: CatalogCategory[];\n items: ApiCatalogItem[];\n filterCatalogItems?: filterCatalogItems;\n};\n\nexport type CatalogContext<ProviderData = unknown> = {\n auth: AuthState<ProviderData>;\n};\n\nexport type filterCatalogItems<ProviderData = unknown> = (\n items: ApiCatalogItem[],\n { auth }: CatalogContext<ProviderData>,\n) => ApiCatalogItem[];\n\nexport const apiCatalogPlugin = ({\n navigationId,\n items,\n label,\n categories = [],\n filterCatalogItems,\n}: {\n navigationId: string;\n label: string;\n categories?: CatalogCategory[];\n items: ApiCatalogItem[];\n filterCatalogItems?: filterCatalogItems;\n}): ZudokuPlugin => {\n return {\n getSidebar: async function Sidebar(path) {\n if (!matchPath({ path: joinUrl(navigationId), end: false }, path)) {\n return [];\n }\n\n const sidebar: SidebarItem[] = categories.map((category) => ({\n type: \"category\" as const,\n label: category.label,\n collapsible: false,\n items: category.tags.map((tag) => {\n const tagPath = getKey(category.label, tag);\n return {\n type: \"doc\" as const,\n id: joinUrl(navigationId, tagPath),\n label: tag,\n badge: {\n label: String(\n items.filter((api) =>\n api.categories.find((c) => c.tags.includes(tag)),\n ).length,\n ),\n color: \"outline\" as const,\n },\n };\n }),\n }));\n\n sidebar.unshift({\n type: \"doc\" as const,\n id: joinUrl(navigationId),\n label: \"Overview\",\n badge: { label: String(items.length), color: \"outline\" as const },\n });\n\n return sidebar;\n },\n getRoutes: () =>\n categories.flatMap((category) =>\n [undefined, ...category.tags].map((tag) => ({\n path: joinUrl(\n navigationId,\n tag ? getKey(category.label, tag) : undefined,\n ),\n element: (\n <Catalog\n label={label}\n items={items}\n filterCatalogItems={filterCatalogItems}\n categories={categories}\n />\n ),\n })),\n ),\n };\n};\n"],"names":["Catalog","items","filterCatalogItems","label","auth","useAuthState","match","useMatch","activeCategory","catalogItems","useSuspenseQuery","jsxs","jsx","Head","Heading","api","c","t","getKey","Link","joinUrl","Markdown","category","tag","slugify","apiCatalogPlugin","navigationId","categories","path","matchPath","sidebar","tagPath"],"mappings":"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"}
@@ -1,11 +1,11 @@
1
- import { j as e } from "./jsx-runtime-Bdg6XQ1m.js";
1
+ import { j as e } from "./jsx-runtime-CYK1ROHF.js";
2
2
  import { RotateCwIcon as g, TrashIcon as f, EyeOffIcon as j, EyeIcon as v, CheckIcon as w, CopyIcon as K, FileKey2Icon as b } from "lucide-react";
3
- import { D as k, S as m, R as N } from "./SlotletProvider-D0mFmGJu.js";
3
+ import { D as k, S as m, R as N } from "./SlotletProvider-CEfNOA8i.js";
4
4
  import { i as c } from "./invariant-Caa8-XvF.js";
5
- import { u as d, S as I, a as S, b as A, c as C, d as E, e as x } from "./Select-D9CKL33X.js";
6
- import { a as P } from "./index.esm-CrSoEshU.js";
7
- import { a as D, L as u, O as R } from "./chunk-SYFQ2XB5-QijJrSf0.js";
8
- import { i as y, k as q, e as O, a as z } from "./hook-C_t2ISLC.js";
5
+ import { u as d, S as I, a as S, b as A, c as C, d as E, e as x } from "./Select-D9hI1G-y.js";
6
+ import { a as P } from "./index.esm--gIChbWs.js";
7
+ import { a as D, L as u, O as R } from "./chunk-IR6S3I6Y-D_3UmFIn.js";
8
+ import { i as y, k as q, e as O, a as z } from "./hook-CWwSAAlH.js";
9
9
  import { Button as l } from "./ui/Button.js";
10
10
  import { Input as F } from "./ui/Input.js";
11
11
  import { useState as p } from "react";
@@ -1,8 +1,8 @@
1
- import { j as o } from "./jsx-runtime-Bdg6XQ1m.js";
1
+ import { j as o } from "./jsx-runtime-CYK1ROHF.js";
2
2
  import a from "react";
3
- import { P as n } from "./Markdown-8mv9nhGd.js";
3
+ import { P as n } from "./Markdown-Cr9sYpR_.js";
4
4
  import { c } from "./cn-qaFjX9_3.js";
5
- import { u as p } from "./useExposedProps-Bbf99zic.js";
5
+ import { u as p } from "./useExposedProps-RIvey2Oy.js";
6
6
  const u = ({
7
7
  element: t,
8
8
  render: s,
@@ -1,7 +1,7 @@
1
1
  var h = Object.defineProperty;
2
2
  var g = (e, t, o) => t in e ? h(e, t, { enumerable: !0, configurable: !0, writable: !0, value: o }) : e[t] = o;
3
3
  var c = (e, t, o) => g(e, typeof t != "symbol" ? t + "" : t, o);
4
- import { j as d } from "./jsx-runtime-Bdg6XQ1m.js";
4
+ import { j as d } from "./jsx-runtime-CYK1ROHF.js";
5
5
  const m = "/pages/**/*.{md,mdx}";
6
6
  class w {
7
7
  constructor(t) {
@@ -53,7 +53,7 @@ const P = (e) => ({
53
53
  const u = {
54
54
  path: r,
55
55
  lazy: async () => {
56
- const { MdxPage: p } = await import("./MdxPage-GM1T5jmO.js"), { default: f, ...l } = await i();
56
+ const { MdxPage: p } = await import("./MdxPage-Dt-UEQl8.js"), { default: f, ...l } = await i();
57
57
  return {
58
58
  element: /* @__PURE__ */ d.jsx(
59
59
  p,
@@ -1,11 +1,11 @@
1
- import "./jsx-runtime-Bdg6XQ1m.js";
2
- import "./index-CjJS0l4l.js";
1
+ import "./jsx-runtime-CYK1ROHF.js";
2
+ import "./index-LNp6rxyU.js";
3
3
  import "lucide-react";
4
- import "./chunk-SYFQ2XB5-QijJrSf0.js";
5
- import "./hook-C_t2ISLC.js";
4
+ import "./chunk-IR6S3I6Y-D_3UmFIn.js";
5
+ import "./hook-CWwSAAlH.js";
6
6
  import "./ui/Button.js";
7
- import "./joinUrl-nLx9pD-Z.js";
8
- import { U as n, o as s } from "./index-BANyVRgL.js";
7
+ import "./joinUrl-10po2Jdj.js";
8
+ import { U as n, o as s } from "./index-Do_30Hpk.js";
9
9
  export {
10
10
  n as UNTAGGED_PATH,
11
11
  s as openApiPlugin
@@ -1,4 +1,4 @@
1
- import { r as o } from "./chunk-SYFQ2XB5-QijJrSf0.js";
1
+ import { r as o } from "./chunk-IR6S3I6Y-D_3UmFIn.js";
2
2
  const a = (r) => ({
3
3
  getRoutes: () => r.redirects.map(({ from: e, to: t }) => ({
4
4
  path: e,
@@ -1,5 +1,5 @@
1
- import { j as i } from "./jsx-runtime-Bdg6XQ1m.js";
2
- import { useRef as d, useState as f, useMemo as m, useEffect as c } from "react";
1
+ import { j as i } from "./jsx-runtime-CYK1ROHF.js";
2
+ import { useRef as l, useState as f, useMemo as m, useEffect as u } from "react";
3
3
  import { C as g } from "./ClientOnly-E7hGysn1.js";
4
4
  const h = {
5
5
  theme: {
@@ -25,7 +25,7 @@ const h = {
25
25
  onClose: n,
26
26
  settings: p
27
27
  }) => {
28
- const o = d(null), u = d(null), [s, l] = f(
28
+ const o = l(null), c = l(null), [s, d] = f(
29
29
  typeof Inkeep < "u"
30
30
  ), a = m(
31
31
  () => ({
@@ -44,17 +44,17 @@ const h = {
44
44
  }),
45
45
  [e, n, r, p, o]
46
46
  );
47
- return c(() => {
47
+ return u(() => {
48
48
  if (s) return;
49
49
  const t = setInterval(() => {
50
- typeof Inkeep < "u" && (l(!0), clearInterval(t));
50
+ typeof Inkeep < "u" && (d(!0), clearInterval(t));
51
51
  }, 100);
52
52
  return () => clearInterval(t);
53
- }, [s]), c(() => {
54
- !s || u.current || (u.current = Inkeep().embed(a));
55
- }, [a, s]), c(() => {
53
+ }, [s]), u(() => {
54
+ !s || c.current || (c.current = Inkeep().embed(a));
55
+ }, [a, s]), u(() => {
56
56
  var t;
57
- (t = u.current) == null || t.render({ ...a, isOpen: e });
57
+ (t = c.current) == null || t.render({ ...a, isOpen: e });
58
58
  }, [a, e]), /* @__PURE__ */ i.jsx("div", { ref: o });
59
59
  }, x = (r) => ({
60
60
  getHead: () => /* @__PURE__ */ i.jsx(
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zudoku",
3
- "version": "0.32.1",
3
+ "version": "0.32.3",
4
4
  "type": "module",
5
5
  "homepage": "https://zudoku.dev",
6
6
  "repository": {
@@ -115,61 +115,60 @@
115
115
  }
116
116
  },
117
117
  "dependencies": {
118
- "@apidevtools/json-schema-ref-parser": "11.9.0",
118
+ "@apidevtools/json-schema-ref-parser": "11.9.1",
119
119
  "@envelop/core": "5.0.3",
120
120
  "@graphql-typed-document-node/core": "3.2.0",
121
- "@hookform/resolvers": "3.10.0",
121
+ "@hookform/resolvers": "4.1.0",
122
122
  "@lekoarts/rehype-meta-as-attributes": "3.0.2",
123
123
  "@mdx-js/react": "3.1.0",
124
124
  "@mdx-js/rollup": "3.1.0",
125
- "@pothos/core": "3.41.0",
126
- "@radix-ui/react-accordion": "1.2.2",
127
- "@radix-ui/react-alert-dialog": "1.1.4",
128
- "@radix-ui/react-aspect-ratio": "1.1.1",
129
- "@radix-ui/react-checkbox": "1.1.3",
130
- "@radix-ui/react-collapsible": "1.1.2",
131
- "@radix-ui/react-dialog": "1.1.4",
132
- "@radix-ui/react-dropdown-menu": "2.1.4",
133
- "@radix-ui/react-hover-card": "1.1.4",
134
- "@radix-ui/react-label": "2.1.1",
135
- "@radix-ui/react-popover": "1.1.4",
136
- "@radix-ui/react-progress": "1.1.1",
137
- "@radix-ui/react-radio-group": "1.2.2",
138
- "@radix-ui/react-scroll-area": "1.2.2",
139
- "@radix-ui/react-select": "2.1.5",
140
- "@radix-ui/react-slider": "1.2.2",
141
- "@radix-ui/react-slot": "1.1.1",
142
- "@radix-ui/react-switch": "1.1.2",
143
- "@radix-ui/react-tabs": "1.1.2",
144
- "@radix-ui/react-toggle": "1.1.1",
145
- "@radix-ui/react-toggle-group": "1.1.1",
146
- "@radix-ui/react-tooltip": "1.1.6",
147
- "@radix-ui/react-visually-hidden": "1.1.1",
148
- "@scalar/openapi-parser": "0.10.5",
149
- "@sentry/node": "8.50.0",
125
+ "@pothos/core": "4.3.0",
126
+ "@radix-ui/react-accordion": "1.2.3",
127
+ "@radix-ui/react-alert-dialog": "1.1.6",
128
+ "@radix-ui/react-aspect-ratio": "1.1.2",
129
+ "@radix-ui/react-checkbox": "1.1.4",
130
+ "@radix-ui/react-collapsible": "1.1.3",
131
+ "@radix-ui/react-dialog": "1.1.6",
132
+ "@radix-ui/react-dropdown-menu": "2.1.6",
133
+ "@radix-ui/react-hover-card": "1.1.6",
134
+ "@radix-ui/react-label": "2.1.2",
135
+ "@radix-ui/react-popover": "1.1.6",
136
+ "@radix-ui/react-progress": "1.1.2",
137
+ "@radix-ui/react-radio-group": "1.2.3",
138
+ "@radix-ui/react-scroll-area": "1.2.3",
139
+ "@radix-ui/react-select": "2.1.6",
140
+ "@radix-ui/react-slider": "1.2.3",
141
+ "@radix-ui/react-slot": "1.1.2",
142
+ "@radix-ui/react-switch": "1.1.3",
143
+ "@radix-ui/react-tabs": "1.1.3",
144
+ "@radix-ui/react-toggle": "1.1.2",
145
+ "@radix-ui/react-toggle-group": "1.1.2",
146
+ "@radix-ui/react-tooltip": "1.1.8",
147
+ "@radix-ui/react-visually-hidden": "1.1.2",
148
+ "@scalar/openapi-parser": "0.10.6",
149
+ "@sentry/node": "9.1.0",
150
150
  "@sindresorhus/slugify": "2.2.1",
151
151
  "@stefanprobst/rehype-extract-toc": "2.2.1",
152
152
  "@tailwindcss/typography": "0.5.16",
153
- "@tanstack/react-query": "5.64.2",
154
- "@types/react": "19.0.7",
155
- "@types/react-dom": "19.0.3",
153
+ "@tanstack/react-query": "5.66.6",
154
+ "@types/react": "19.0.10",
155
+ "@types/react-dom": "19.0.4",
156
156
  "@vitejs/plugin-react": "4.3.4",
157
157
  "@zudoku/httpsnippet": "10.0.9",
158
158
  "@zudoku/react-helmet-async": "2.0.5",
159
159
  "autoprefixer": "10.4.20",
160
- "chokidar": "3.6.0",
161
160
  "class-variance-authority": "0.7.1",
162
161
  "clsx": "2.1.1",
163
162
  "cmdk": "1.0.4",
164
163
  "devlop": "^1.1.0",
165
164
  "dotenv": "16.4.7",
166
165
  "embla-carousel-react": "8.5.2",
167
- "estree-util-value-to-estree": "3.2.1",
166
+ "estree-util-value-to-estree": "3.3.2",
168
167
  "express": "4.21.2",
169
168
  "glob": "11.0.1",
170
169
  "graphql": "16.10.0",
171
170
  "graphql-type-json": "0.3.2",
172
- "graphql-yoga": "5.10.10",
171
+ "graphql-yoga": "5.11.0",
173
172
  "gray-matter": "4.0.3",
174
173
  "hast-util-to-jsx-runtime": "^2.3.2",
175
174
  "hast-util-to-string": "3.0.1",
@@ -177,34 +176,34 @@
177
176
  "http-terminator": "3.2.0",
178
177
  "loglevel": "1.9.2",
179
178
  "lru-cache": "11.0.2",
180
- "lucide-react": "0.473.0",
179
+ "lucide-react": "0.475.0",
181
180
  "next-themes": "0.4.4",
182
181
  "oauth4webapi": "2.17.0",
183
182
  "object-hash": "3.0.0",
184
183
  "openapi-types": "12.1.3",
185
184
  "picocolors": "1.1.1",
186
185
  "piscina": "5.0.0-alpha.1",
187
- "postcss": "8.5.1",
188
- "posthog-node": "4.4.1",
186
+ "postcss": "8.5.2",
187
+ "posthog-node": "4.6.0",
189
188
  "prism-react-renderer": "2.4.1",
190
189
  "prismjs": "1.29.0",
191
190
  "react-error-boundary": "5.0.0",
192
191
  "react-hook-form": "7.54.2",
193
192
  "react-is": "19.0.0",
194
- "react-router": "7.1.3",
193
+ "react-router": "7.1.5",
195
194
  "rehype-mdx-import-media": "1.2.0",
196
195
  "rehype-raw": "7.0.0",
197
196
  "rehype-slug": "6.0.0",
198
197
  "remark-comment": "1.0.0",
199
- "remark-directive": "3.0.0",
198
+ "remark-directive": "3.0.1",
200
199
  "remark-directive-rehype": "0.4.2",
201
200
  "remark-frontmatter": "5.0.0",
202
- "remark-gfm": "4.0.0",
201
+ "remark-gfm": "4.0.1",
203
202
  "remark-mdx-frontmatter": "5.0.0",
204
203
  "remark-parse": "^11.0.0",
205
204
  "remark-rehype": "^11.1.1",
206
- "rollup": "4.31.0",
207
- "semver": "7.6.3",
205
+ "rollup": "4.34.8",
206
+ "semver": "7.7.1",
208
207
  "sitemap": "8.0.0",
209
208
  "spin-delay": "2.0.1",
210
209
  "strip-ansi": "7.1.0",
@@ -217,16 +216,16 @@
217
216
  "urql": "4.2.1",
218
217
  "vaul": "1.1.2",
219
218
  "vfile": "6.0.3",
220
- "vite": "6.0.11",
219
+ "vite": "6.1.0",
221
220
  "yaml": "2.7.0",
222
221
  "yargs": "17.7.2",
223
- "zod": "3.24.1",
222
+ "zod": "3.24.2",
224
223
  "zod-validation-error": "3.4.0",
225
224
  "zustand": "5.0.3"
226
225
  },
227
226
  "devDependencies": {
228
- "@graphql-codegen/cli": "5.0.3",
229
- "@graphql-codegen/client-preset": "4.5.1",
227
+ "@graphql-codegen/cli": "5.0.5",
228
+ "@graphql-codegen/client-preset": "4.6.2",
230
229
  "@types/estree": "1.0.6",
231
230
  "@types/express": "5.0.0",
232
231
  "@types/har-format": "1.2.16",
@@ -240,7 +239,7 @@
240
239
  "@types/semver": "7.5.8",
241
240
  "@types/unist": "^3.0.3",
242
241
  "@types/yargs": "17.0.33",
243
- "@vitest/coverage-v8": "3.0.2",
242
+ "@vitest/coverage-v8": "3.0.5",
244
243
  "mdast-util-mdx": "3.0.0",
245
244
  "react": "19.0.0",
246
245
  "react-dom": "19.0.0",
@@ -253,15 +252,15 @@
253
252
  "react-dom": ">=19"
254
253
  },
255
254
  "optionalDependencies": {
256
- "@clerk/clerk-js": "^5.51.0",
257
- "@sentry/react": "^8.50.0"
255
+ "@clerk/clerk-js": "^5.52.3",
256
+ "@sentry/react": "^9.1.0"
258
257
  },
259
258
  "scripts": {
260
259
  "build": "tsc --project tsconfig.app.json",
261
260
  "build:vite": "vite build",
262
261
  "generate:icon-types": "tsx ./scripts/generate-icon-types.ts",
263
262
  "build:standalone:vite": "vite build --mode standalone --config vite.standalone.config.ts",
264
- "build:standalone:html": "cp ./src/app/standalone.html ./standalone/standalone.html && cp ./src/app/demo.html ./standalone/demo.html && cp ./src/app/demo-cdn.html ./standalone/index.html",
263
+ "build:standalone:html": "cp ./src/app/standalone.html ./standalone/standalone.html && cp ./src/app/demo.html ./standalone/demo.html && cp ./src/app/demo-cdn.html ./standalone/index.html && cp standalone/zudoku.css standalone/style.css",
265
264
  "clean": "tsc --build --clean",
266
265
  "codegen": "graphql-codegen --config ./src/codegen.ts",
267
266
  "test": "vitest run"
@@ -74,6 +74,12 @@ const config = (zudokuConfig?: LoadedConfig): Omit<Config, "content"> => {
74
74
  foreground: "hsl(var(--card-foreground))",
75
75
  },
76
76
  },
77
+ borderRadius: {
78
+ xl: "calc(var(--radius) + 4px)",
79
+ lg: `var(--radius)`,
80
+ md: `calc(var(--radius) - 2px)`,
81
+ sm: "calc(var(--radius) - 4px)",
82
+ },
77
83
  },
78
84
  },
79
85
  plugins: [typographyPlugin],
@@ -66,7 +66,7 @@ export const Header = memo(function HeaderInner() {
66
66
  <header className="sticky lg:top-0 z-10 bg-background/80 backdrop-blur w-full">
67
67
  <Banner />
68
68
  <div className="border-b">
69
- <div className="max-w-screen-2xl border-l border-r mx-auto grid grid-cols-[1fr_auto] lg:grid-cols-[calc(var(--side-nav-width))_1fr] lg:gap-12 items-center px-4 lg:px-12 h-[--top-header-height]">
69
+ <div className="max-w-screen-2xl 2xl:border-x mx-auto grid grid-cols-[1fr_auto] lg:grid-cols-[calc(var(--side-nav-width))_1fr] lg:gap-12 items-center px-4 lg:px-8 h-[--top-header-height]">
70
70
  <div className="flex">
71
71
  <Link to="/">
72
72
  <div className="flex items-center gap-3.5">
@@ -177,8 +177,8 @@ export const Header = memo(function HeaderInner() {
177
177
  </div>
178
178
  </div>
179
179
  </div>
180
- <div className="border-b">
181
- <div className="max-w-screen-2xl mx-auto border-l border-r">
180
+ <div className="border-b hidden lg:block">
181
+ <div className="max-w-screen-2xl mx-auto 2xl:border-x">
182
182
  <Slotlet name="top-navigation-before" />
183
183
  <TopNavigation />
184
184
  <Slotlet name="top-navigation-after" />