zudoku 0.32.0 → 0.32.2
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.
- package/dist/app/tailwind.js +6 -0
- package/dist/app/tailwind.js.map +1 -1
- package/dist/config/validators/InputSidebarSchema.d.ts +15 -15
- package/dist/config/validators/InputSidebarSchema.js +10 -1
- package/dist/config/validators/InputSidebarSchema.js.map +1 -1
- package/dist/config/validators/common.d.ts +40 -40
- package/dist/config/validators/icon-types.d.ts +1 -1
- package/dist/config/validators/validate.d.ts +19 -19
- package/dist/lib/components/Header.js +1 -1
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Layout.js +1 -1
- package/dist/lib/components/Layout.js.map +1 -1
- package/dist/lib/components/TopNavigation.js +3 -2
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/context/ZudokuContext.d.ts +1 -1
- package/dist/lib/components/index.d.ts +1 -0
- package/dist/lib/components/index.js +2 -0
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/SidebarBadge.d.ts +2 -0
- package/dist/lib/components/navigation/SidebarBadge.js +3 -1
- package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
- package/dist/lib/components/navigation/SidebarItem.js +1 -1
- package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
- package/dist/lib/oas/graphql/index.js +3 -1
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -2
- package/dist/lib/plugins/api-catalog/Catalog.js +11 -24
- package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
- package/dist/lib/plugins/api-catalog/index.d.ts +1 -0
- package/dist/lib/plugins/api-catalog/index.js +37 -8
- package/dist/lib/plugins/api-catalog/index.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.js +1 -1
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/openapi/Sidecar.js +1 -1
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.js +2 -2
- package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.js +0 -11
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/ui/Badge.d.ts +1 -1
- package/dist/lib/ui/Button.d.ts +1 -1
- package/dist/lib/ui/Command.d.ts +1 -1
- package/dist/lib/ui/SyntaxHighlight.d.ts +14 -0
- package/dist/lib/{components → ui}/SyntaxHighlight.js +9 -6
- package/dist/lib/ui/SyntaxHighlight.js.map +1 -0
- package/dist/lib/ui/util.d.ts +2 -0
- package/dist/lib/ui/util.js +3 -0
- package/dist/lib/ui/util.js.map +1 -0
- package/dist/lib/util/MdxComponents.js +1 -1
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/vite/config.js +4 -1
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/plugin-api.js +2 -2
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-sidebar.js +3 -9
- package/dist/vite/plugin-sidebar.js.map +1 -1
- package/lib/{AuthenticationPlugin-_YVa673u.js → AuthenticationPlugin-BlxA4Mbn.js} +4 -4
- package/lib/{AuthenticationPlugin-_YVa673u.js.map → AuthenticationPlugin-BlxA4Mbn.js.map} +1 -1
- package/lib/{CategoryHeading-MYL1u_6K.js → CategoryHeading-DpB47wvk.js} +3 -3
- package/lib/{CategoryHeading-MYL1u_6K.js.map → CategoryHeading-DpB47wvk.js.map} +1 -1
- package/lib/{Markdown-8mv9nhGd.js → Markdown-Cr9sYpR_.js} +4800 -4729
- package/lib/Markdown-Cr9sYpR_.js.map +1 -0
- package/lib/{MdxPage-GM1T5jmO.js → MdxPage-Dt-UEQl8.js} +10 -10
- package/lib/MdxPage-Dt-UEQl8.js.map +1 -0
- package/lib/{OasProvider-IS9wBrb7.js → OasProvider-WVtvHP5H.js} +6 -6
- package/lib/{OasProvider-IS9wBrb7.js.map → OasProvider-WVtvHP5H.js.map} +1 -1
- package/lib/{OperationList-BTmRbbXk.js → OperationList-DhOwupvv.js} +18 -19
- package/lib/{OperationList-BTmRbbXk.js.map → OperationList-DhOwupvv.js.map} +1 -1
- package/lib/Select-D9hI1G-y.js +223 -0
- package/lib/{Select-D9CKL33X.js.map → Select-D9hI1G-y.js.map} +1 -1
- package/lib/{SlotletProvider-D0mFmGJu.js → SlotletProvider-CEfNOA8i.js} +53 -53
- package/lib/{SlotletProvider-D0mFmGJu.js.map → SlotletProvider-CEfNOA8i.js.map} +1 -1
- package/lib/{Spinner-BlzrEEk1.js → Spinner-1KrEmx1V.js} +3 -3
- package/lib/{Spinner-BlzrEEk1.js.map → Spinner-1KrEmx1V.js.map} +1 -1
- package/lib/{SyntaxHighlight-B0L4SC_N.js → SyntaxHighlight-CcnUjERD.js} +445 -445
- package/lib/SyntaxHighlight-CcnUjERD.js.map +1 -0
- package/lib/{chunk-SYFQ2XB5-QijJrSf0.js → chunk-IR6S3I6Y-D_3UmFIn.js} +597 -597
- package/lib/chunk-IR6S3I6Y-D_3UmFIn.js.map +1 -0
- package/lib/{circular-DxaIIlWD.js → circular-v7K6lDDh.js} +1413 -1413
- package/lib/{circular-DxaIIlWD.js.map → circular-v7K6lDDh.js.map} +1 -1
- package/lib/context-DLCwaMXN.js +22 -0
- package/lib/{context-rwLGh-6_.js.map → context-DLCwaMXN.js.map} +1 -1
- package/lib/{createServer-DSQiPwjN.js → createServer-DMf6O2Rz.js} +3669 -3562
- package/lib/createServer-DMf6O2Rz.js.map +1 -0
- package/lib/{hook-C_t2ISLC.js → hook-CWwSAAlH.js} +384 -379
- package/lib/hook-CWwSAAlH.js.map +1 -0
- package/lib/index-Bn6Lc9tq.js +9 -0
- package/lib/index-Bn6Lc9tq.js.map +1 -0
- package/lib/index-CPNSgwSb.js +36 -0
- package/lib/{index-Djenk2Hj.js.map → index-CPNSgwSb.js.map} +1 -1
- package/lib/{index-BANyVRgL.js → index-Do_30Hpk.js} +78 -78
- package/lib/index-Do_30Hpk.js.map +1 -0
- package/lib/{index-B7mqiOei.js → index-Du5aNddU.js} +101 -101
- package/lib/index-Du5aNddU.js.map +1 -0
- package/lib/{index-CjJS0l4l.js → index-LNp6rxyU.js} +2 -2
- package/lib/{index-CjJS0l4l.js.map → index-LNp6rxyU.js.map} +1 -1
- package/lib/{index.esm-CrSoEshU.js → index.esm--gIChbWs.js} +3 -3
- package/lib/{index.esm-CrSoEshU.js.map → index.esm--gIChbWs.js.map} +1 -1
- package/lib/{index.esm-9-TF9KQB.js → index.esm-CQHE3GEU.js} +52 -53
- package/lib/{index.esm-9-TF9KQB.js.map → index.esm-CQHE3GEU.js.map} +1 -1
- package/lib/joinUrl-10po2Jdj.js +20 -0
- package/lib/{joinUrl-nLx9pD-Z.js.map → joinUrl-10po2Jdj.js.map} +1 -1
- package/lib/{jsx-runtime-Bdg6XQ1m.js → jsx-runtime-CYK1ROHF.js} +99 -99
- package/lib/{jsx-runtime-Bdg6XQ1m.js.map → jsx-runtime-CYK1ROHF.js.map} +1 -1
- package/lib/{mutation-Cm3O9f3X.js → mutation-B0wxqzSN.js} +26 -26
- package/lib/{mutation-Cm3O9f3X.js.map → mutation-B0wxqzSN.js.map} +1 -1
- package/lib/post-processors/removeExtensions.js +4 -4
- package/lib/ui/Accordion.js +1 -1
- package/lib/ui/ActionButton.js +2 -2
- package/lib/ui/Alert.js +2 -2
- package/lib/ui/AlertDialog.js +1 -1
- package/lib/ui/Badge.js +2 -2
- package/lib/ui/Breadcrumb.js +4 -4
- package/lib/ui/Button.js +2 -2
- package/lib/ui/Callout.js +4 -4
- package/lib/ui/Card.js +1 -1
- package/lib/ui/Carousel.js +1 -1
- package/lib/ui/Checkbox.js +2 -2
- package/lib/ui/Command.js +2 -2
- package/lib/ui/Dialog.js +1 -1
- package/lib/ui/Drawer.js +521 -543
- package/lib/ui/Drawer.js.map +1 -1
- package/lib/ui/DropdownMenu.js +1 -1
- package/lib/ui/Form.js +5 -5
- package/lib/ui/HoverCard.js +1 -1
- package/lib/ui/Input.js +1 -1
- package/lib/ui/Label.js +2 -2
- package/lib/ui/Pagination.js +10 -10
- package/lib/ui/Popover.js +1 -1
- package/lib/ui/Progress.js +1 -1
- package/lib/ui/RadioGroup.js +1 -1
- package/lib/ui/ScrollArea.js +1 -1
- package/lib/ui/Select.js +1 -1
- package/lib/ui/Skeleton.js +1 -1
- package/lib/ui/Slider.js +1 -1
- package/lib/ui/Switch.js +1 -1
- package/lib/ui/SyntaxHighlight.js +10 -0
- package/lib/ui/SyntaxHighlight.js.map +1 -0
- package/lib/ui/Tabs.js +1 -1
- package/lib/ui/Textarea.js +1 -1
- package/lib/ui/Toggle.js +2 -2
- package/lib/ui/ToggleGroup.js +1 -1
- package/lib/ui/Tooltip.js +1 -1
- package/lib/ui/util.js +6 -0
- package/lib/ui/util.js.map +1 -0
- package/lib/{useExposedProps-Bbf99zic.js → useExposedProps-RIvey2Oy.js} +2 -2
- package/lib/{useExposedProps-Bbf99zic.js.map → useExposedProps-RIvey2Oy.js.map} +1 -1
- package/lib/{useScrollToAnchor-BGEcH3HM.js → useScrollToAnchor-C-sRxs9o.js} +13 -9
- package/lib/useScrollToAnchor-C-sRxs9o.js.map +1 -0
- package/lib/zudoku.auth-auth0.js +1 -1
- package/lib/zudoku.auth-clerk.js +18 -18
- package/lib/zudoku.auth-openid.js +255 -295
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +305 -298
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.icons.js +1 -1
- package/lib/zudoku.plugin-api-catalog.js +91 -108
- package/lib/zudoku.plugin-api-catalog.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +6 -6
- package/lib/zudoku.plugin-custom-pages.js +3 -3
- package/lib/zudoku.plugin-markdown.js +2 -2
- package/lib/zudoku.plugin-openapi.js +6 -6
- package/lib/zudoku.plugin-redirect.js +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +9 -9
- package/package.json +49 -50
- package/src/app/tailwind.ts +6 -0
- package/src/lib/components/Header.tsx +1 -1
- package/src/lib/components/Layout.tsx +1 -1
- package/src/lib/components/TopNavigation.tsx +13 -9
- package/src/lib/components/index.ts +2 -0
- package/src/lib/components/navigation/SidebarBadge.tsx +4 -1
- package/src/lib/components/navigation/SidebarItem.tsx +1 -0
- package/src/lib/components/navigation/SidebarWrapper.tsx +1 -1
- package/src/lib/oas/graphql/index.ts +4 -1
- package/src/lib/plugins/api-catalog/Catalog.tsx +31 -94
- package/src/lib/plugins/api-catalog/index.tsx +54 -9
- package/src/lib/plugins/markdown/MdxPage.tsx +1 -1
- package/src/lib/plugins/openapi/Sidecar.tsx +1 -1
- package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -2
- package/src/lib/plugins/openapi/graphql/gql.ts +9 -1
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +1 -1
- package/src/lib/{components → ui}/SyntaxHighlight.tsx +23 -8
- package/src/lib/ui/util.tsx +3 -0
- package/src/lib/util/MdxComponents.tsx +1 -1
- package/dist/lib/components/SyntaxHighlight.d.ts +0 -12
- package/dist/lib/components/SyntaxHighlight.js.map +0 -1
- package/lib/Markdown-8mv9nhGd.js.map +0 -1
- package/lib/MdxPage-GM1T5jmO.js.map +0 -1
- package/lib/Select-D9CKL33X.js +0 -223
- package/lib/SyntaxHighlight-B0L4SC_N.js.map +0 -1
- package/lib/chunk-SYFQ2XB5-QijJrSf0.js.map +0 -1
- package/lib/context-rwLGh-6_.js +0 -22
- package/lib/createServer-DSQiPwjN.js.map +0 -1
- package/lib/hook-C_t2ISLC.js.map +0 -1
- package/lib/index-B7mqiOei.js.map +0 -1
- package/lib/index-BANyVRgL.js.map +0 -1
- package/lib/index-Djenk2Hj.js +0 -36
- package/lib/joinUrl-nLx9pD-Z.js +0 -20
- package/lib/useScrollToAnchor-BGEcH3HM.js.map +0 -1
package/lib/zudoku.icons.js
CHANGED
|
@@ -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-
|
|
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-
|
|
2
|
-
import { s as
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
const
|
|
9
|
-
items:
|
|
10
|
-
filterCatalogItems:
|
|
11
|
-
|
|
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
|
|
15
|
-
queryFn: () =>
|
|
16
|
-
queryKey: ["catalogItems",
|
|
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(
|
|
20
|
-
/* @__PURE__ */ e.jsxs("div", { className: "grid
|
|
21
|
-
/* @__PURE__ */ e.jsx(
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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:
|
|
99
|
-
items:
|
|
100
|
-
label:
|
|
101
|
-
categories:
|
|
102
|
-
filterCatalogItems:
|
|
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
|
-
|
|
105
|
-
{
|
|
106
|
-
|
|
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
|
-
|
|
90
|
+
M,
|
|
109
91
|
{
|
|
110
|
-
label:
|
|
111
|
-
items:
|
|
112
|
-
filterCatalogItems:
|
|
113
|
-
categories:
|
|
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-
|
|
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-
|
|
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-
|
|
6
|
-
import { a as P } from "./index.esm
|
|
7
|
-
import { a as D, L as u, O as R } from "./chunk-
|
|
8
|
-
import { i as y, k as q, e as O, a as z } from "./hook-
|
|
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-
|
|
1
|
+
import { j as o } from "./jsx-runtime-CYK1ROHF.js";
|
|
2
2
|
import a from "react";
|
|
3
|
-
import { P as n } from "./Markdown-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
2
|
-
import "./index-
|
|
1
|
+
import "./jsx-runtime-CYK1ROHF.js";
|
|
2
|
+
import "./index-LNp6rxyU.js";
|
|
3
3
|
import "lucide-react";
|
|
4
|
-
import "./chunk-
|
|
5
|
-
import "./hook-
|
|
4
|
+
import "./chunk-IR6S3I6Y-D_3UmFIn.js";
|
|
5
|
+
import "./hook-CWwSAAlH.js";
|
|
6
6
|
import "./ui/Button.js";
|
|
7
|
-
import "./joinUrl-
|
|
8
|
-
import { U as n, o as s } from "./index-
|
|
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,5 +1,5 @@
|
|
|
1
|
-
import { j as i } from "./jsx-runtime-
|
|
2
|
-
import { useRef as
|
|
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 =
|
|
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
|
|
47
|
+
return u(() => {
|
|
48
48
|
if (s) return;
|
|
49
49
|
const t = setInterval(() => {
|
|
50
|
-
typeof Inkeep < "u" && (
|
|
50
|
+
typeof Inkeep < "u" && (d(!0), clearInterval(t));
|
|
51
51
|
}, 100);
|
|
52
52
|
return () => clearInterval(t);
|
|
53
|
-
}, [s]),
|
|
54
|
-
!s ||
|
|
55
|
-
}, [a, s]),
|
|
53
|
+
}, [s]), u(() => {
|
|
54
|
+
!s || c.current || (c.current = Inkeep().embed(a));
|
|
55
|
+
}, [a, s]), u(() => {
|
|
56
56
|
var t;
|
|
57
|
-
(t =
|
|
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.
|
|
3
|
+
"version": "0.32.2",
|
|
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.
|
|
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": "
|
|
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.
|
|
126
|
-
"@radix-ui/react-accordion": "1.2.
|
|
127
|
-
"@radix-ui/react-alert-dialog": "1.1.
|
|
128
|
-
"@radix-ui/react-aspect-ratio": "1.1.
|
|
129
|
-
"@radix-ui/react-checkbox": "1.1.
|
|
130
|
-
"@radix-ui/react-collapsible": "1.1.
|
|
131
|
-
"@radix-ui/react-dialog": "1.1.
|
|
132
|
-
"@radix-ui/react-dropdown-menu": "2.1.
|
|
133
|
-
"@radix-ui/react-hover-card": "1.1.
|
|
134
|
-
"@radix-ui/react-label": "2.1.
|
|
135
|
-
"@radix-ui/react-popover": "1.1.
|
|
136
|
-
"@radix-ui/react-progress": "1.1.
|
|
137
|
-
"@radix-ui/react-radio-group": "1.2.
|
|
138
|
-
"@radix-ui/react-scroll-area": "1.2.
|
|
139
|
-
"@radix-ui/react-select": "2.1.
|
|
140
|
-
"@radix-ui/react-slider": "1.2.
|
|
141
|
-
"@radix-ui/react-slot": "1.1.
|
|
142
|
-
"@radix-ui/react-switch": "1.1.
|
|
143
|
-
"@radix-ui/react-tabs": "1.1.
|
|
144
|
-
"@radix-ui/react-toggle": "1.1.
|
|
145
|
-
"@radix-ui/react-toggle-group": "1.1.
|
|
146
|
-
"@radix-ui/react-tooltip": "1.1.
|
|
147
|
-
"@radix-ui/react-visually-hidden": "1.1.
|
|
148
|
-
"@scalar/openapi-parser": "0.10.
|
|
149
|
-
"@sentry/node": "
|
|
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.
|
|
154
|
-
"@types/react": "19.0.
|
|
155
|
-
"@types/react-dom": "19.0.
|
|
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
|
|
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.
|
|
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.
|
|
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.
|
|
188
|
-
"posthog-node": "4.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
207
|
-
"semver": "7.
|
|
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
|
|
219
|
+
"vite": "6.1.0",
|
|
221
220
|
"yaml": "2.7.0",
|
|
222
221
|
"yargs": "17.7.2",
|
|
223
|
-
"zod": "3.24.
|
|
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.
|
|
229
|
-
"@graphql-codegen/client-preset": "4.
|
|
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.
|
|
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.
|
|
257
|
-
"@sentry/react": "^
|
|
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"
|
package/src/app/tailwind.ts
CHANGED
|
@@ -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-
|
|
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-8 h-[--top-header-height]">
|
|
70
70
|
<div className="flex">
|
|
71
71
|
<Link to="/">
|
|
72
72
|
<div className="flex items-center gap-3.5">
|
|
@@ -66,7 +66,7 @@ export const Layout = ({ children }: { children?: ReactNode }) => {
|
|
|
66
66
|
<Header />
|
|
67
67
|
<Slotlet name="layout-after-head" />
|
|
68
68
|
|
|
69
|
-
<div className="w-full max-w-screen-2xl mx-auto px-4 lg:px-
|
|
69
|
+
<div className="w-full max-w-screen-2xl mx-auto px-4 lg:px-8 border-l border-r">
|
|
70
70
|
{showSpinner ? (
|
|
71
71
|
<LoadingFallback />
|
|
72
72
|
) : (
|