ardo 3.0.4 → 3.1.0
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/{FileTree-K0YVFXhg.d.ts → Features-D_Pt7zpA.d.ts} +9 -47
- package/dist/Search-DOJMNI2T.css +193 -0
- package/dist/Search-DOJMNI2T.css.map +1 -0
- package/dist/Search-VYYG3D43.js +10 -0
- package/dist/chunk-4YQE3TNM.js +1 -0
- package/dist/chunk-4YQE3TNM.js.map +1 -0
- package/dist/chunk-AXLJDGQL.js +1 -0
- package/dist/chunk-AXLJDGQL.js.map +1 -0
- package/dist/{chunk-TDBU2FXP.js → chunk-CZM5NX27.js} +301 -236
- package/dist/chunk-CZM5NX27.js.map +1 -0
- package/dist/{chunk-UWFMFHRD.js → chunk-IEPSORG5.js} +177 -63
- package/dist/chunk-IEPSORG5.js.map +1 -0
- package/dist/chunk-KUWEUO37.js +1 -0
- package/dist/chunk-KUWEUO37.js.map +1 -0
- package/dist/chunk-PMS3P4MA.js +43 -0
- package/dist/chunk-PMS3P4MA.js.map +1 -0
- package/dist/{chunk-BHHI2BO4.js → chunk-ZPYQQZ7J.js} +36 -20
- package/dist/chunk-ZPYQQZ7J.js.map +1 -0
- package/dist/index.css +1290 -0
- package/dist/index.css.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +7 -8
- package/dist/mdx/provider.css +403 -0
- package/dist/mdx/provider.css.map +1 -0
- package/dist/mdx/provider.js +3 -2
- package/dist/mdx/provider.js.map +1 -1
- package/dist/theme/index.d.ts +196 -0
- package/dist/theme/index.js +135 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/ui/index.css +1290 -0
- package/dist/ui/index.css.map +1 -0
- package/dist/ui/index.d.ts +3 -23
- package/dist/ui/index.js +7 -10
- package/dist/ui/styles.css +1039 -1976
- package/dist/ui/styles.css.map +1 -0
- package/dist/ui/styles.d.ts +2 -0
- package/dist/ui/styles.js +4 -0
- package/dist/ui/styles.js.map +1 -0
- package/dist/vite/index.js +4 -0
- package/dist/vite/index.js.map +1 -1
- package/package.json +12 -2
- package/dist/Search-MXGJE6PQ.js +0 -9
- package/dist/chunk-BHHI2BO4.js.map +0 -1
- package/dist/chunk-MJQGGJQZ.js +0 -88
- package/dist/chunk-MJQGGJQZ.js.map +0 -1
- package/dist/chunk-TDBU2FXP.js.map +0 -1
- package/dist/chunk-UWFMFHRD.js.map +0 -1
- /package/dist/{Search-MXGJE6PQ.js.map → Search-VYYG3D43.js.map} +0 -0
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
} from "./chunk-
|
|
2
|
+
Check,
|
|
3
|
+
CircleX,
|
|
4
|
+
Copy,
|
|
5
|
+
FileText,
|
|
6
|
+
Info,
|
|
7
|
+
Lightbulb,
|
|
8
|
+
TriangleAlert
|
|
9
|
+
} from "./chunk-PMS3P4MA.js";
|
|
10
10
|
import {
|
|
11
11
|
getPrevNextLinks
|
|
12
12
|
} from "./chunk-FZP2AVJL.js";
|
|
@@ -29,6 +29,33 @@ function useBareContent() {
|
|
|
29
29
|
|
|
30
30
|
// src/ui/Content.tsx
|
|
31
31
|
import { Link, useLocation } from "react-router";
|
|
32
|
+
|
|
33
|
+
// src/ui/DocPage.css.ts
|
|
34
|
+
var contentBody = "DocPage_contentBody__1f1m4jr5";
|
|
35
|
+
var contentContainer = "DocPage_contentContainer__1f1m4jr1";
|
|
36
|
+
var contentDescription = "DocPage_contentDescription__1f1m4jr4";
|
|
37
|
+
var contentHeader = "DocPage_contentHeader__1f1m4jr2";
|
|
38
|
+
var contentTitle = "DocPage_contentTitle__1f1m4jr3";
|
|
39
|
+
var docPage = "DocPage_docPage__1f1m4jr0";
|
|
40
|
+
|
|
41
|
+
// src/ui/Footer.css.ts
|
|
42
|
+
var contentFooter = "Footer_contentFooter__169q00b7";
|
|
43
|
+
var contentMeta = "Footer_contentMeta__169q00b8";
|
|
44
|
+
var editLink = "Footer_editLink__169q00b9";
|
|
45
|
+
var footer = "Footer_footer__169q00b0";
|
|
46
|
+
var footerBuildTime = "Footer_footerBuildTime__169q00b6";
|
|
47
|
+
var footerCopyright = "Footer_footerCopyright__169q00b5";
|
|
48
|
+
var footerLink = "Footer_footerLink__169q00b3";
|
|
49
|
+
var footerMessage = "Footer_footerMessage__169q00b4";
|
|
50
|
+
var footerPrimary = "Footer_footerPrimary__169q00b1";
|
|
51
|
+
var footerSeparator = "Footer_footerSeparator__169q00b2";
|
|
52
|
+
var nextLink = "Footer_nextLink__169q00bd Footer_prevNextLinkBase__169q00bb";
|
|
53
|
+
var prevLink = "Footer_prevNextLinkBase__169q00bb";
|
|
54
|
+
var prevNext = "Footer_prevNext__169q00ba";
|
|
55
|
+
var prevNextLabel = "Footer_prevNextLabel__169q00be";
|
|
56
|
+
var prevNextTitle = "Footer_prevNextTitle__169q00bf";
|
|
57
|
+
|
|
58
|
+
// src/ui/Content.tsx
|
|
32
59
|
import { jsx as jsx2, jsxs } from "react/jsx-runtime";
|
|
33
60
|
function Content({ children }) {
|
|
34
61
|
const isBare = useBareContent();
|
|
@@ -37,12 +64,12 @@ function Content({ children }) {
|
|
|
37
64
|
const sidebar = useSidebar();
|
|
38
65
|
const location = useLocation();
|
|
39
66
|
if (isBare) {
|
|
40
|
-
return /* @__PURE__ */ jsx2("div", { className:
|
|
67
|
+
return /* @__PURE__ */ jsx2("div", { className: `${contentBody} ardo-content`, children });
|
|
41
68
|
}
|
|
42
69
|
const { prev, next } = getPrevNextLinks(sidebar, location.pathname);
|
|
43
70
|
const showEditLink = pageData?.frontmatter.editLink !== false && themeConfig.editLink?.pattern;
|
|
44
71
|
const showLastUpdated = pageData?.frontmatter.lastUpdated !== false && themeConfig.lastUpdated?.enabled && pageData?.lastUpdated;
|
|
45
|
-
const
|
|
72
|
+
const editLink2 = showEditLink ? themeConfig.editLink.pattern.replace(":path", pageData?.relativePath || "") : null;
|
|
46
73
|
const lastUpdatedText = showLastUpdated ? new Date(pageData.lastUpdated).toLocaleDateString(
|
|
47
74
|
void 0,
|
|
48
75
|
themeConfig.lastUpdated?.formatOptions ?? {
|
|
@@ -51,38 +78,38 @@ function Content({ children }) {
|
|
|
51
78
|
day: "numeric"
|
|
52
79
|
}
|
|
53
80
|
) : null;
|
|
54
|
-
return /* @__PURE__ */ jsxs("article", { className:
|
|
55
|
-
pageData?.frontmatter.title && /* @__PURE__ */ jsxs("header", { className:
|
|
56
|
-
/* @__PURE__ */ jsx2("h1", { className:
|
|
57
|
-
pageData.frontmatter.description && /* @__PURE__ */ jsx2("p", { className:
|
|
81
|
+
return /* @__PURE__ */ jsxs("article", { className: contentContainer, children: [
|
|
82
|
+
pageData?.frontmatter.title && /* @__PURE__ */ jsxs("header", { className: contentHeader, children: [
|
|
83
|
+
/* @__PURE__ */ jsx2("h1", { className: contentTitle, children: pageData.frontmatter.title }),
|
|
84
|
+
pageData.frontmatter.description && /* @__PURE__ */ jsx2("p", { className: contentDescription, children: pageData.frontmatter.description })
|
|
58
85
|
] }),
|
|
59
|
-
/* @__PURE__ */ jsx2("div", { className:
|
|
60
|
-
/* @__PURE__ */ jsxs("footer", { className:
|
|
61
|
-
(showEditLink || showLastUpdated) && /* @__PURE__ */ jsxs("div", { className:
|
|
86
|
+
/* @__PURE__ */ jsx2("div", { className: `${contentBody} ardo-content`, children }),
|
|
87
|
+
/* @__PURE__ */ jsxs("footer", { className: contentFooter, children: [
|
|
88
|
+
(showEditLink || showLastUpdated) && /* @__PURE__ */ jsxs("div", { className: contentMeta, children: [
|
|
62
89
|
showEditLink && /* @__PURE__ */ jsx2(
|
|
63
90
|
"a",
|
|
64
91
|
{
|
|
65
|
-
href:
|
|
92
|
+
href: editLink2,
|
|
66
93
|
target: "_blank",
|
|
67
94
|
rel: "noopener noreferrer",
|
|
68
|
-
className:
|
|
95
|
+
className: editLink,
|
|
69
96
|
children: themeConfig.editLink?.text ?? "Edit this page"
|
|
70
97
|
}
|
|
71
98
|
),
|
|
72
|
-
showLastUpdated && /* @__PURE__ */ jsxs("span", {
|
|
99
|
+
showLastUpdated && /* @__PURE__ */ jsxs("span", { children: [
|
|
73
100
|
themeConfig.lastUpdated?.text ?? "Last updated",
|
|
74
101
|
": ",
|
|
75
102
|
lastUpdatedText
|
|
76
103
|
] })
|
|
77
104
|
] }),
|
|
78
|
-
(prev || next) && /* @__PURE__ */ jsxs("nav", { className:
|
|
79
|
-
prev ? /* @__PURE__ */ jsxs(Link, { to: prev.link, className:
|
|
80
|
-
/* @__PURE__ */ jsx2("span", { className:
|
|
81
|
-
/* @__PURE__ */ jsx2("span", { className:
|
|
105
|
+
(prev || next) && /* @__PURE__ */ jsxs("nav", { className: prevNext, "aria-label": "Page navigation", children: [
|
|
106
|
+
prev ? /* @__PURE__ */ jsxs(Link, { to: prev.link, className: prevLink, children: [
|
|
107
|
+
/* @__PURE__ */ jsx2("span", { className: prevNextLabel, children: "Previous" }),
|
|
108
|
+
/* @__PURE__ */ jsx2("span", { className: prevNextTitle, children: prev.text })
|
|
82
109
|
] }) : /* @__PURE__ */ jsx2("div", {}),
|
|
83
|
-
next ? /* @__PURE__ */ jsxs(Link, { to: next.link, className:
|
|
84
|
-
/* @__PURE__ */ jsx2("span", { className:
|
|
85
|
-
/* @__PURE__ */ jsx2("span", { className:
|
|
110
|
+
next ? /* @__PURE__ */ jsxs(Link, { to: next.link, className: nextLink, children: [
|
|
111
|
+
/* @__PURE__ */ jsx2("span", { className: prevNextLabel, children: "Next" }),
|
|
112
|
+
/* @__PURE__ */ jsx2("span", { className: prevNextTitle, children: next.text })
|
|
86
113
|
] }) : /* @__PURE__ */ jsx2("div", {})
|
|
87
114
|
] })
|
|
88
115
|
] })
|
|
@@ -111,6 +138,11 @@ function Icon({ name, ...props }) {
|
|
|
111
138
|
|
|
112
139
|
// src/ui/components/CopyButton.tsx
|
|
113
140
|
import { useState } from "react";
|
|
141
|
+
|
|
142
|
+
// src/ui/components/CopyButton.css.ts
|
|
143
|
+
var copyButton = "CopyButton_copyButton__1flm2ul0";
|
|
144
|
+
|
|
145
|
+
// src/ui/components/CopyButton.tsx
|
|
114
146
|
import { jsx as jsx4, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
115
147
|
function CopyButton({ code }) {
|
|
116
148
|
const [copied, setCopied] = useState(false);
|
|
@@ -126,11 +158,11 @@ function CopyButton({ code }) {
|
|
|
126
158
|
return /* @__PURE__ */ jsxs2(
|
|
127
159
|
"button",
|
|
128
160
|
{
|
|
129
|
-
className:
|
|
161
|
+
className: copyButton,
|
|
130
162
|
onClick: handleCopy,
|
|
131
163
|
"aria-label": copied ? "Copied!" : "Copy code",
|
|
132
164
|
children: [
|
|
133
|
-
copied ? /* @__PURE__ */ jsx4(
|
|
165
|
+
copied ? /* @__PURE__ */ jsx4(Check, { size: 16 }) : /* @__PURE__ */ jsx4(Copy, { size: 16 }),
|
|
134
166
|
/* @__PURE__ */ jsx4("span", { className: "ardo-copy-text", children: copied ? "Copied!" : "Copy" })
|
|
135
167
|
]
|
|
136
168
|
}
|
|
@@ -139,6 +171,18 @@ function CopyButton({ code }) {
|
|
|
139
171
|
|
|
140
172
|
// src/ui/components/CodeBlock.tsx
|
|
141
173
|
import { useState as useState2, Children, isValidElement } from "react";
|
|
174
|
+
|
|
175
|
+
// src/ui/components/CodeBlock.css.ts
|
|
176
|
+
var codeBlock = "CodeBlock_codeBlock__1l68ra30";
|
|
177
|
+
var codeGroup = "CodeBlock_codeGroup__1l68ra35";
|
|
178
|
+
var codeGroupTab = "CodeBlock_codeGroupTab__1l68ra37";
|
|
179
|
+
var codeGroupTabs = "CodeBlock_codeGroupTabs__1l68ra36";
|
|
180
|
+
var codeLine = "CodeBlock_codeLine__1l68ra33";
|
|
181
|
+
var codeTitle = "CodeBlock_codeTitle__1l68ra31";
|
|
182
|
+
var codeWrapper = "CodeBlock_codeWrapper__1l68ra32";
|
|
183
|
+
var lineNumber = "CodeBlock_lineNumber__1l68ra34";
|
|
184
|
+
|
|
185
|
+
// src/ui/components/CodeBlock.tsx
|
|
142
186
|
import { Fragment, jsx as jsx5, jsxs as jsxs3 } from "react/jsx-runtime";
|
|
143
187
|
function outdent(text) {
|
|
144
188
|
const trimmed = text.replace(/^\n+/, "").replace(/\n\s*$/, "");
|
|
@@ -172,18 +216,18 @@ function CodeBlock({
|
|
|
172
216
|
content = /* @__PURE__ */ jsx5("pre", { className: `language-${language}`, children: /* @__PURE__ */ jsx5("code", { children: lines.map((line, index) => {
|
|
173
217
|
const lineNum = index + 1;
|
|
174
218
|
const isHighlighted = highlightLines.includes(lineNum);
|
|
175
|
-
const classes = [
|
|
219
|
+
const classes = [codeLine];
|
|
176
220
|
if (isHighlighted) classes.push("highlighted");
|
|
177
221
|
return /* @__PURE__ */ jsxs3("span", { className: classes.join(" "), children: [
|
|
178
|
-
lineNumbers && /* @__PURE__ */ jsx5("span", { className:
|
|
179
|
-
/* @__PURE__ */ jsx5("span", {
|
|
222
|
+
lineNumbers && /* @__PURE__ */ jsx5("span", { className: lineNumber, children: lineNum }),
|
|
223
|
+
/* @__PURE__ */ jsx5("span", { children: line }),
|
|
180
224
|
index < lines.length - 1 && "\n"
|
|
181
225
|
] }, index);
|
|
182
226
|
}) }) });
|
|
183
227
|
}
|
|
184
|
-
return /* @__PURE__ */ jsxs3("div", { className:
|
|
185
|
-
title && /* @__PURE__ */ jsx5("div", { className:
|
|
186
|
-
/* @__PURE__ */ jsxs3("div", { className:
|
|
228
|
+
return /* @__PURE__ */ jsxs3("div", { className: codeBlock, "data-lang": language, children: [
|
|
229
|
+
title && /* @__PURE__ */ jsx5("div", { className: codeTitle, children: title }),
|
|
230
|
+
/* @__PURE__ */ jsxs3("div", { className: codeWrapper, children: [
|
|
187
231
|
content,
|
|
188
232
|
/* @__PURE__ */ jsx5(CopyButton, { code })
|
|
189
233
|
] })
|
|
@@ -193,18 +237,18 @@ function CodeGroup({ children, labels: labelsStr }) {
|
|
|
193
237
|
const [activeTab, setActiveTab] = useState2(0);
|
|
194
238
|
const childArray = Children.toArray(children).filter(isValidElement);
|
|
195
239
|
const labelArray = labelsStr ? labelsStr.split(",") : [];
|
|
196
|
-
const
|
|
240
|
+
const tabs2 = childArray.map((child, index) => {
|
|
197
241
|
if (labelArray[index]) return labelArray[index];
|
|
198
242
|
const props = child.props;
|
|
199
243
|
return props["data-label"] || props.title || props.language || `Tab ${index + 1}`;
|
|
200
244
|
});
|
|
201
|
-
return /* @__PURE__ */ jsxs3("div", { className:
|
|
202
|
-
/* @__PURE__ */ jsx5("div", { className:
|
|
245
|
+
return /* @__PURE__ */ jsxs3("div", { className: codeGroup, children: [
|
|
246
|
+
/* @__PURE__ */ jsx5("div", { className: codeGroupTabs, children: tabs2.map((tab2, index) => /* @__PURE__ */ jsx5(
|
|
203
247
|
"button",
|
|
204
248
|
{
|
|
205
|
-
className: [
|
|
249
|
+
className: [codeGroupTab, index === activeTab && "active"].filter(Boolean).join(" "),
|
|
206
250
|
onClick: () => setActiveTab(index),
|
|
207
|
-
children:
|
|
251
|
+
children: tab2
|
|
208
252
|
},
|
|
209
253
|
index
|
|
210
254
|
)) }),
|
|
@@ -220,6 +264,12 @@ function CodeGroup({ children, labels: labelsStr }) {
|
|
|
220
264
|
] });
|
|
221
265
|
}
|
|
222
266
|
|
|
267
|
+
// src/ui/components/Container.css.ts
|
|
268
|
+
import { createRuntimeFn as _7a468 } from "@vanilla-extract/recipes/createRuntimeFn";
|
|
269
|
+
var container = _7a468({ defaultClassName: "Container_container__1l7ew7r0", variantClassNames: { type: { tip: "Container_container_type_tip__1l7ew7r1", warning: "Container_container_type_warning__1l7ew7r2", danger: "Container_container_type_danger__1l7ew7r3", info: "Container_container_type_info__1l7ew7r4", note: "Container_container_type_note__1l7ew7r5" } }, defaultVariants: {}, compoundVariants: [] });
|
|
270
|
+
var containerContent = "Container_containerContent__1l7ew7rc";
|
|
271
|
+
var containerTitle = _7a468({ defaultClassName: "Container_containerTitle__1l7ew7r6", variantClassNames: { type: { tip: "Container_containerTitle_type_tip__1l7ew7r7", warning: "Container_containerTitle_type_warning__1l7ew7r8", danger: "Container_containerTitle_type_danger__1l7ew7r9", info: "Container_containerTitle_type_info__1l7ew7ra", note: "Container_containerTitle_type_note__1l7ew7rb" } }, defaultVariants: {}, compoundVariants: [] });
|
|
272
|
+
|
|
223
273
|
// src/ui/components/Container.tsx
|
|
224
274
|
import { jsx as jsx6, jsxs as jsxs4 } from "react/jsx-runtime";
|
|
225
275
|
var defaultTitles = {
|
|
@@ -230,20 +280,20 @@ var defaultTitles = {
|
|
|
230
280
|
note: "NOTE"
|
|
231
281
|
};
|
|
232
282
|
var icons = {
|
|
233
|
-
tip: /* @__PURE__ */ jsx6(
|
|
234
|
-
warning: /* @__PURE__ */ jsx6(
|
|
235
|
-
danger: /* @__PURE__ */ jsx6(
|
|
236
|
-
info: /* @__PURE__ */ jsx6(
|
|
237
|
-
note: /* @__PURE__ */ jsx6(
|
|
283
|
+
tip: /* @__PURE__ */ jsx6(Lightbulb, { size: 18 }),
|
|
284
|
+
warning: /* @__PURE__ */ jsx6(TriangleAlert, { size: 18 }),
|
|
285
|
+
danger: /* @__PURE__ */ jsx6(CircleX, { size: 18 }),
|
|
286
|
+
info: /* @__PURE__ */ jsx6(Info, { size: 18 }),
|
|
287
|
+
note: /* @__PURE__ */ jsx6(FileText, { size: 18 })
|
|
238
288
|
};
|
|
239
289
|
function Container({ type, title, children }) {
|
|
240
290
|
const displayTitle = title || defaultTitles[type];
|
|
241
|
-
return /* @__PURE__ */ jsxs4("div", { className:
|
|
242
|
-
/* @__PURE__ */ jsxs4("p", { className:
|
|
243
|
-
/* @__PURE__ */ jsx6("span", {
|
|
291
|
+
return /* @__PURE__ */ jsxs4("div", { className: container({ type }), children: [
|
|
292
|
+
/* @__PURE__ */ jsxs4("p", { className: containerTitle({ type }), children: [
|
|
293
|
+
/* @__PURE__ */ jsx6("span", { children: icons[type] }),
|
|
244
294
|
displayTitle
|
|
245
295
|
] }),
|
|
246
|
-
/* @__PURE__ */ jsx6("div", { className:
|
|
296
|
+
/* @__PURE__ */ jsx6("div", { className: containerContent, children })
|
|
247
297
|
] });
|
|
248
298
|
}
|
|
249
299
|
function Tip({ title, children }) {
|
|
@@ -255,7 +305,7 @@ function Warning({ title, children }) {
|
|
|
255
305
|
function Danger({ title, children }) {
|
|
256
306
|
return /* @__PURE__ */ jsx6(Container, { type: "danger", title, children });
|
|
257
307
|
}
|
|
258
|
-
function
|
|
308
|
+
function Info2({ title, children }) {
|
|
259
309
|
return /* @__PURE__ */ jsx6(Container, { type: "info", title, children });
|
|
260
310
|
}
|
|
261
311
|
function Note({ title, children }) {
|
|
@@ -263,9 +313,26 @@ function Note({ title, children }) {
|
|
|
263
313
|
}
|
|
264
314
|
|
|
265
315
|
// src/ui/components/Tabs.tsx
|
|
266
|
-
import {
|
|
316
|
+
import {
|
|
317
|
+
Children as Children2,
|
|
318
|
+
isValidElement as isValidElement2,
|
|
319
|
+
useEffect,
|
|
320
|
+
useRef,
|
|
321
|
+
useState as useState3,
|
|
322
|
+
createContext as createContext2,
|
|
323
|
+
useContext as useContext2
|
|
324
|
+
} from "react";
|
|
325
|
+
|
|
326
|
+
// src/ui/components/Tabs.css.ts
|
|
327
|
+
var tab = "Tabs_tab__1jypr342";
|
|
328
|
+
var tabList = "Tabs_tabList__1jypr341";
|
|
329
|
+
var tabPanel = "Tabs_tabPanel__1jypr343";
|
|
330
|
+
var tabs = "Tabs_tabs__1jypr340";
|
|
331
|
+
|
|
332
|
+
// src/ui/components/Tabs.tsx
|
|
267
333
|
import { jsx as jsx7 } from "react/jsx-runtime";
|
|
268
334
|
var TabsContext = createContext2(null);
|
|
335
|
+
var AUTO_TAB_PREFIX = "__ardo-tab-";
|
|
269
336
|
function useTabsContext() {
|
|
270
337
|
const context = useContext2(TabsContext);
|
|
271
338
|
if (!context) {
|
|
@@ -274,40 +341,87 @@ function useTabsContext() {
|
|
|
274
341
|
return context;
|
|
275
342
|
}
|
|
276
343
|
function Tabs({ defaultValue, children }) {
|
|
277
|
-
const [activeTab, setActiveTab] = useState3(defaultValue
|
|
278
|
-
|
|
344
|
+
const [activeTab, setActiveTab] = useState3(() => defaultValue ?? findFirstTabValue(children));
|
|
345
|
+
const tabIndexRef = useRef(0);
|
|
346
|
+
const panelIndexRef = useRef(0);
|
|
347
|
+
tabIndexRef.current = 0;
|
|
348
|
+
panelIndexRef.current = 0;
|
|
349
|
+
const getTabValue = (value) => {
|
|
350
|
+
const index = tabIndexRef.current++;
|
|
351
|
+
return value ?? `${AUTO_TAB_PREFIX}${index}`;
|
|
352
|
+
};
|
|
353
|
+
const getPanelValue = (value) => {
|
|
354
|
+
const index = panelIndexRef.current++;
|
|
355
|
+
return value ?? `${AUTO_TAB_PREFIX}${index}`;
|
|
356
|
+
};
|
|
357
|
+
useEffect(() => {
|
|
358
|
+
if (defaultValue !== void 0) {
|
|
359
|
+
setActiveTab(defaultValue);
|
|
360
|
+
}
|
|
361
|
+
}, [defaultValue]);
|
|
362
|
+
return /* @__PURE__ */ jsx7(TabsContext.Provider, { value: { activeTab, setActiveTab, getTabValue, getPanelValue }, children: /* @__PURE__ */ jsx7("div", { className: tabs, children }) });
|
|
279
363
|
}
|
|
280
364
|
function TabList({ children }) {
|
|
281
|
-
return /* @__PURE__ */ jsx7("div", { className:
|
|
365
|
+
return /* @__PURE__ */ jsx7("div", { className: tabList, role: "tablist", children });
|
|
282
366
|
}
|
|
283
367
|
function Tab({ value, children }) {
|
|
284
|
-
const { activeTab, setActiveTab } = useTabsContext();
|
|
285
|
-
const
|
|
368
|
+
const { activeTab, setActiveTab, getTabValue } = useTabsContext();
|
|
369
|
+
const resolvedValue = getTabValue(value);
|
|
370
|
+
const isActive = activeTab === resolvedValue;
|
|
286
371
|
return /* @__PURE__ */ jsx7(
|
|
287
372
|
"button",
|
|
288
373
|
{
|
|
374
|
+
type: "button",
|
|
289
375
|
role: "tab",
|
|
290
376
|
"aria-selected": isActive,
|
|
291
|
-
className: [
|
|
292
|
-
onClick: () => setActiveTab(
|
|
377
|
+
className: [tab, isActive && "active"].filter(Boolean).join(" "),
|
|
378
|
+
onClick: () => setActiveTab(resolvedValue),
|
|
293
379
|
children
|
|
294
380
|
}
|
|
295
381
|
);
|
|
296
382
|
}
|
|
297
383
|
function TabPanel({ value, children }) {
|
|
298
|
-
const { activeTab } = useTabsContext();
|
|
299
|
-
const
|
|
384
|
+
const { activeTab, getPanelValue } = useTabsContext();
|
|
385
|
+
const resolvedValue = getPanelValue(value);
|
|
386
|
+
const isActive = activeTab === resolvedValue;
|
|
300
387
|
if (!isActive) {
|
|
301
388
|
return null;
|
|
302
389
|
}
|
|
303
|
-
return /* @__PURE__ */ jsx7("div", { role: "tabpanel", className:
|
|
390
|
+
return /* @__PURE__ */ jsx7("div", { role: "tabpanel", className: tabPanel, children });
|
|
304
391
|
}
|
|
305
392
|
function TabPanels({ children }) {
|
|
306
393
|
return /* @__PURE__ */ jsx7("div", { className: "ardo-tab-panels", children });
|
|
307
394
|
}
|
|
395
|
+
function findFirstTabValue(children) {
|
|
396
|
+
for (const child of Children2.toArray(children)) {
|
|
397
|
+
if (!isValidElement2(child)) {
|
|
398
|
+
continue;
|
|
399
|
+
}
|
|
400
|
+
if (child.type === Tab) {
|
|
401
|
+
const tabValue = child.props.value;
|
|
402
|
+
return tabValue ?? `${AUTO_TAB_PREFIX}0`;
|
|
403
|
+
}
|
|
404
|
+
const nestedChildren = child.props.children;
|
|
405
|
+
if (nestedChildren) {
|
|
406
|
+
const nestedValue = findFirstTabValue(nestedChildren);
|
|
407
|
+
if (nestedValue) {
|
|
408
|
+
return nestedValue;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
return "";
|
|
413
|
+
}
|
|
308
414
|
|
|
309
415
|
export {
|
|
416
|
+
footer,
|
|
417
|
+
footerBuildTime,
|
|
418
|
+
footerCopyright,
|
|
419
|
+
footerLink,
|
|
420
|
+
footerMessage,
|
|
421
|
+
footerPrimary,
|
|
422
|
+
footerSeparator,
|
|
310
423
|
BareContent,
|
|
424
|
+
docPage,
|
|
311
425
|
Content,
|
|
312
426
|
registerIcons,
|
|
313
427
|
getRegisteredIconNames,
|
|
@@ -319,7 +433,7 @@ export {
|
|
|
319
433
|
Tip,
|
|
320
434
|
Warning,
|
|
321
435
|
Danger,
|
|
322
|
-
Info,
|
|
436
|
+
Info2 as Info,
|
|
323
437
|
Note,
|
|
324
438
|
Tabs,
|
|
325
439
|
TabList,
|
|
@@ -327,4 +441,4 @@ export {
|
|
|
327
441
|
TabPanel,
|
|
328
442
|
TabPanels
|
|
329
443
|
};
|
|
330
|
-
//# sourceMappingURL=chunk-
|
|
444
|
+
//# sourceMappingURL=chunk-IEPSORG5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/ui/BareContent.tsx","../src/ui/Content.tsx","../src/ui/DocPage.css.ts","../src/ui/Footer.css.ts","../src/ui/components/Icon.tsx","../src/ui/components/CopyButton.tsx","../src/ui/components/CopyButton.css.ts","../src/ui/components/CodeBlock.tsx","../src/ui/components/CodeBlock.css.ts","../src/ui/components/Container.css.ts","../src/ui/components/Container.tsx","../src/ui/components/Tabs.tsx","../src/ui/components/Tabs.css.ts"],"sourcesContent":["import { createContext, useContext, type ReactNode } from \"react\"\n\nconst BareContentContext = createContext(false)\n\n/**\n * Wraps imported MDX content to render without the full Content wrapper\n * (article, header, footer, navigation). Only the content body is rendered.\n *\n * ```tsx\n * import MySnippet from \"./snippet.mdx\"\n *\n * <BareContent>\n * <MySnippet />\n * </BareContent>\n * ```\n */\nexport function BareContent({ children }: { children: ReactNode }) {\n return <BareContentContext value={true}>{children}</BareContentContext>\n}\n\nexport function useBareContent(): boolean {\n return useContext(BareContentContext)\n}\n","import { type ReactNode } from \"react\"\nimport { usePageData, useThemeConfig, useSidebar } from \"../runtime/hooks\"\nimport { getPrevNextLinks } from \"../runtime/sidebar-utils\"\nimport { Link, useLocation } from \"react-router\"\nimport { useBareContent } from \"./BareContent\"\nimport * as docStyles from \"./DocPage.css\"\nimport * as footerStyles from \"./Footer.css\"\n\ninterface ContentProps {\n children: ReactNode\n}\n\nexport function Content({ children }: ContentProps) {\n const isBare = useBareContent()\n const pageData = usePageData()\n const themeConfig = useThemeConfig()\n const sidebar = useSidebar()\n const location = useLocation()\n\n if (isBare) {\n return <div className={`${docStyles.contentBody} ardo-content`}>{children}</div>\n }\n\n const { prev, next } = getPrevNextLinks(sidebar, location.pathname)\n\n const showEditLink = pageData?.frontmatter.editLink !== false && themeConfig.editLink?.pattern\n\n const showLastUpdated =\n pageData?.frontmatter.lastUpdated !== false &&\n themeConfig.lastUpdated?.enabled &&\n pageData?.lastUpdated\n\n const editLink = showEditLink\n ? themeConfig.editLink!.pattern.replace(\":path\", pageData?.relativePath || \"\")\n : null\n\n const lastUpdatedText = showLastUpdated\n ? new Date(pageData!.lastUpdated!).toLocaleDateString(\n undefined,\n themeConfig.lastUpdated?.formatOptions ?? {\n year: \"numeric\",\n month: \"long\",\n day: \"numeric\",\n }\n )\n : null\n\n return (\n <article className={docStyles.contentContainer}>\n {pageData?.frontmatter.title && (\n <header className={docStyles.contentHeader}>\n <h1 className={docStyles.contentTitle}>{pageData.frontmatter.title}</h1>\n {pageData.frontmatter.description && (\n <p className={docStyles.contentDescription}>{pageData.frontmatter.description}</p>\n )}\n </header>\n )}\n\n <div className={`${docStyles.contentBody} ardo-content`}>{children}</div>\n\n <footer className={footerStyles.contentFooter}>\n {(showEditLink || showLastUpdated) && (\n <div className={footerStyles.contentMeta}>\n {showEditLink && (\n <a\n href={editLink!}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className={footerStyles.editLink}\n >\n {themeConfig.editLink?.text ?? \"Edit this page\"}\n </a>\n )}\n {showLastUpdated && (\n <span>\n {themeConfig.lastUpdated?.text ?? \"Last updated\"}: {lastUpdatedText}\n </span>\n )}\n </div>\n )}\n\n {(prev || next) && (\n <nav className={footerStyles.prevNext} aria-label=\"Page navigation\">\n {prev ? (\n <Link to={prev.link!} className={footerStyles.prevLink}>\n <span className={footerStyles.prevNextLabel}>Previous</span>\n <span className={footerStyles.prevNextTitle}>{prev.text}</span>\n </Link>\n ) : (\n <div />\n )}\n {next ? (\n <Link to={next.link!} className={footerStyles.nextLink}>\n <span className={footerStyles.prevNextLabel}>Next</span>\n <span className={footerStyles.prevNextTitle}>{next.text}</span>\n </Link>\n ) : (\n <div />\n )}\n </nav>\n )}\n </footer>\n </article>\n )\n}\n","import 'src/ui/DocPage.css.ts.vanilla.css?source=#H4sIAAAAAAAAA4WTP0_DMBDF93yKG1shR3YoUKULAgYGkBiQGJEbX1sjx46cA1JQvzuy04bQBJgivdyf37u8pDeueJBrfFb757NYiXL24jl8JgBK15WR2xxWBptFAlDKhr1rRZscCmmKyZv0E8akV44ZuXWvxApnCS3dy-Yp1E3hBIZF5Ir27bQd6tfa5sBBvpILSiWV0nbNDK4oH-mvtcKl9O2MRbJL0oOP_fprZ0lqi74zJKKh4CMHcWTlfxc9qMCZzaqmz-n1ekO_nqRzCyexc5T4FqXq4WYRt70MWzoiV-Yw4z_XHvQDztJ5hb6TRdVA7YxWfYOFMy6UhMpRkEdN5jsHp-3ZnA1H_8AcTs_bXVF6x9b4BedBM9oi2-w1kWZRQyL0rK5kEY_HeMozLBdDdyILk4dAN1gXXlekne2wZsdYYt5iRXv50DBhQ3cBbDoCej629sqpbbfvLO47ars4C32XJSotYdLLk-DxM8ee9O8_7Djr8Y67X8Zmcz4Y-0_gBxk9ZGWX7L4A44Kfbv0DAAA';\nexport var contentBody = 'DocPage_contentBody__1f1m4jr5';\nexport var contentContainer = 'DocPage_contentContainer__1f1m4jr1';\nexport var contentDescription = 'DocPage_contentDescription__1f1m4jr4';\nexport var contentHeader = 'DocPage_contentHeader__1f1m4jr2';\nexport var contentTitle = 'DocPage_contentTitle__1f1m4jr3';\nexport var docPage = 'DocPage_docPage__1f1m4jr0';","import 'src/ui/Footer.css.ts.vanilla.css?source=#H4sIAAAAAAAAA61WTW_bOBC9-1fMJYAFlF7KsfPBXBZdoKdmUSC99FRQ4ljmmiK5FB3bXeS_L0jJsmQpgdsGRvxBijNv5r15zOyTMR7d91X98T29uf-X0ozCfxMAy4WQumBwPbd7mC_s_mEC4HHvCVey0Axy1B5dWM3MnlRrLsyOAQWS2j1c2z2YjcrXUwrh9QfQGb1O4tM83xTObLVgoKRG7kjhuJCo_TS9owKLD_DM3ZQQ7oQhuVHGkaxIgF59OMac3d-GgCmktzSBlNKr5GHyMpkJ7jYwe6uuC7Gm7wc1vYtQl-dYeyi_OFlyd2jBphGskJVV_MBgpTD2P7aeSI9l1SXgn23l5epAcqM9at_dKrhlQMO3EIPsXPgd3uOS0Z5U8gcySBuGYw1sWFVg_rMs1j42puSukJpkxntTMrgJZ89LekLLHffmxMC8X5TUoackUybfhKA7KfyaQQNkjSFb-zMzTqAjofvbisGSXp0T9DpkdB3QgfZ0Xgd9RudlztVR0qUUQuGwlM9Sb9oqrmMVr_Upc1yLpJ0Vgblx3EujGWijMW44ritZrxnLc-kP3TinbbLilR8RSx8OW5tndBFUE40Bnd0Njz1iVfEC25OLeOZXNBAbeh7-L2MPLuy2CZbvm-DjVirxVZanCm4GCeY_k6DVsTd2IOJmlj71TeQ2Zuwdo3XKxjDrxXlftXEtWE1llBQjoomPJSPpH9HzNvnduCkMpr-yPEeSod8h6jds42yKj6DfgTAU0vdUev-7QxNB7RpPWFL6m4M0BHjBGFmHz3_j_iRw3iekcFJEz3VSEI-lVdxjKHFb6opBunLhr3Xl9Exxx_AB10denWSejfMeDV1Ih3ndgjrRQ_fyDilgTrtivEyIA8PtPFovkYxX-DZn3bt2kKreeCqTcya5Uq-w2GS8pGMdNptCGu0db-VFuJXrSzle-IvBhT-u0qdt5hUmF5b3KHp4dYO1xSkiwu5_VdFBR2vkGar2IL7mfGNzcqkbRhyx3yvjSgZba9HlvIpkKvQeHQneEqVFZ3SJ5YiNLMZV_VV6dSJodcJ_BHvzNtijR7xM_ixRSA7TSDGD-JHEeD-li0Z1danxaxjXb1Myt_vYjpfJy_8ztN0aIwsAAA';\nexport var contentFooter = 'Footer_contentFooter__169q00b7';\nexport var contentMeta = 'Footer_contentMeta__169q00b8';\nexport var editLink = 'Footer_editLink__169q00b9';\nexport var footer = 'Footer_footer__169q00b0';\nexport var footerBuildTime = 'Footer_footerBuildTime__169q00b6';\nexport var footerCopyright = 'Footer_footerCopyright__169q00b5';\nexport var footerLink = 'Footer_footerLink__169q00b3';\nexport var footerMessage = 'Footer_footerMessage__169q00b4';\nexport var footerPrimary = 'Footer_footerPrimary__169q00b1';\nexport var footerSeparator = 'Footer_footerSeparator__169q00b2';\nexport var nextLink = 'Footer_nextLink__169q00bd Footer_prevNextLinkBase__169q00bb';\nexport var prevLink = 'Footer_prevNextLinkBase__169q00bb';\nexport var prevNext = 'Footer_prevNext__169q00ba';\nexport var prevNextLabel = 'Footer_prevNextLabel__169q00be';\nexport var prevNextTitle = 'Footer_prevNextTitle__169q00bf';","import type { ComponentType, SVGAttributes, ReactNode } from \"react\"\n\ntype IconComponent = ComponentType<SVGAttributes<SVGSVGElement> & { size?: number }>\n\nexport interface IconProps extends SVGAttributes<SVGSVGElement> {\n /** Name of the registered icon */\n name: string\n /** Icon size */\n size?: number\n}\n\n// Icon registry - users register only the icons they need\nconst iconRegistry = new Map<string, IconComponent>()\n\n/**\n * Register icons for use with the Icon component.\n * Only registered icons are included in your bundle.\n *\n * @example\n * ```tsx\n * // In your app's entry point or layout:\n * import { registerIcons } from \"ardo/ui\"\n * import { Zap, Rocket, Code } from \"lucide-react\"\n *\n * registerIcons({ Zap, Rocket, Code })\n * ```\n */\nexport function registerIcons(icons: Record<string, IconComponent>): void {\n for (const [name, icon] of Object.entries(icons)) {\n iconRegistry.set(name, icon)\n }\n}\n\n/**\n * Get all registered icon names (useful for documentation).\n */\nexport function getRegisteredIconNames(): string[] {\n return Array.from(iconRegistry.keys())\n}\n\n/**\n * Renders a registered icon by name.\n * Icons must be registered first using `registerIcons()`.\n *\n * @example\n * ```tsx\n * // First register icons in your app:\n * import { registerIcons } from \"ardo/ui\"\n * import { Zap, Rocket } from \"lucide-react\"\n * registerIcons({ Zap, Rocket })\n *\n * // Then use in MDX:\n * <Icon name=\"Zap\" size={24} />\n * <Icon name=\"Rocket\" className=\"text-brand\" />\n * ```\n *\n * @see https://lucide.dev/icons for available icon names\n */\nexport function Icon({ name, ...props }: IconProps): ReactNode {\n const IconComp = iconRegistry.get(name)\n\n if (!IconComp) {\n console.warn(`[Ardo] Icon \"${name}\" not found. Did you register it with registerIcons()?`)\n return null\n }\n\n return <IconComp {...props} />\n}\n","import { useState } from \"react\"\nimport { CopyIcon, CheckIcon } from \"../icons\"\nimport * as styles from \"./CopyButton.css\"\n\ninterface CopyButtonProps {\n code: string\n}\n\nexport function CopyButton({ code }: CopyButtonProps) {\n const [copied, setCopied] = useState(false)\n\n const handleCopy = async () => {\n try {\n await navigator.clipboard.writeText(code)\n setCopied(true)\n setTimeout(() => setCopied(false), 2000)\n } catch (err) {\n console.error(\"Failed to copy:\", err)\n }\n }\n\n return (\n <button\n className={styles.copyButton}\n onClick={handleCopy}\n aria-label={copied ? \"Copied!\" : \"Copy code\"}\n >\n {copied ? <CheckIcon size={16} /> : <CopyIcon size={16} />}\n <span className=\"ardo-copy-text\">{copied ? \"Copied!\" : \"Copy\"}</span>\n </button>\n )\n}\n","import 'src/ui/components/CopyButton.css.ts.vanilla.css?source=LkNvcHlCdXR0b25fY29weUJ1dHRvbl9fMWZsbTJ1bDAgewogIHBvc2l0aW9uOiBhYnNvbHV0ZTsKICB0b3A6IDEwcHg7CiAgcmlnaHQ6IDEwcHg7CiAgZGlzcGxheTogZmxleDsKICBhbGlnbi1pdGVtczogY2VudGVyOwogIGdhcDogNnB4OwogIHBhZGRpbmc6IDZweCAxMHB4OwogIGJhY2tncm91bmQ6IHZhcigtLWFyZG8tY29sb3ItYmcpOwogIGJvcmRlcjogMXB4IHNvbGlkIHZhcigtLWFyZG8tY29sb3ItYm9yZGVyKTsKICBib3JkZXItcmFkaXVzOiB2YXIoLS1hcmRvLXJhZGl1cy1zbSk7CiAgY3Vyc29yOiBwb2ludGVyOwogIGZvbnQtc2l6ZTogMTJweDsKICBmb250LWZhbWlseTogdmFyKC0tYXJkby1mb250LWZhbWlseSk7CiAgY29sb3I6IHZhcigtLWFyZG8tY29sb3ItdGV4dExpZ2h0KTsKICBvcGFjaXR5OiAwLjY7CiAgdHJhbnNpdGlvbjogYWxsIHZhcigtLWFyZG8tdHJhbnNpdGlvbi1iYXNlKTsKfQouQ29weUJ1dHRvbl9jb3B5QnV0dG9uX18xZmxtMnVsMDpob3ZlciB7CiAgb3BhY2l0eTogMTsKICBiYWNrZ3JvdW5kOiB2YXIoLS1hcmRvLWNvbG9yLWJnU29mdCk7CiAgYm9yZGVyLWNvbG9yOiB2YXIoLS1hcmRvLWNvbG9yLWJyYW5kKTsKICBjb2xvcjogdmFyKC0tYXJkby1jb2xvci1icmFuZCk7Cn0';\nexport var copyButton = 'CopyButton_copyButton__1flm2ul0';","import { useState, Children, isValidElement } from \"react\"\nimport { CopyButton } from \"./CopyButton\"\nimport * as styles from \"./CodeBlock.css\"\n\n/**\n * Strips leading/trailing blank lines and removes common leading whitespace\n * so that template literals in indented JSX render cleanly.\n */\nfunction outdent(text: string): string {\n // Remove leading/trailing blank lines\n const trimmed = text.replace(/^\\n+/, \"\").replace(/\\n\\s*$/, \"\")\n const lines = trimmed.split(\"\\n\")\n\n // Find minimum indentation (ignoring empty lines)\n const indent = lines.reduce((min, line) => {\n if (line.trim().length === 0) return min\n const match = line.match(/^(\\s*)/)\n return match ? Math.min(min, match[1].length) : min\n }, Infinity)\n\n if (indent === 0 || indent === Infinity) return trimmed\n return lines.map((line) => line.slice(indent)).join(\"\\n\")\n}\n\nexport interface CodeBlockProps {\n /** The code to display (as prop or as children string) */\n code?: string\n /** Programming language for syntax highlighting */\n language?: string\n /** Optional title shown above the code */\n title?: string\n /** Show line numbers */\n lineNumbers?: boolean\n /** Line numbers to highlight */\n highlightLines?: number[]\n /** Code as children — supports template literals with auto-outdent */\n children?: React.ReactNode\n /** Pre-rendered Shiki HTML (injected by ardo:codeblock-highlight plugin) */\n __html?: string\n}\n\n/**\n * Syntax-highlighted code block with copy button.\n *\n * Code can be provided via the `code` prop or as children:\n * ```tsx\n * <CodeBlock language=\"typescript\">{`\n * const x = 42\n * `}</CodeBlock>\n * ```tsx\n * When children is a string, leading/trailing blank lines and common\n * indentation are stripped automatically.\n */\nexport function CodeBlock({\n code: codeProp,\n language = \"text\",\n title,\n lineNumbers = false,\n highlightLines = [],\n children,\n __html,\n}: CodeBlockProps) {\n const code = codeProp ?? (typeof children === \"string\" ? outdent(children) : \"\")\n const hasCustomChildren = children != null && typeof children !== \"string\"\n const lines = code.split(\"\\n\")\n\n let content: React.ReactNode\n if (__html) {\n content = <div dangerouslySetInnerHTML={{ __html }} />\n } else if (hasCustomChildren) {\n content = <>{children}</>\n } else {\n content = (\n <pre className={`language-${language}`}>\n <code>\n {lines.map((line, index) => {\n const lineNum = index + 1\n const isHighlighted = highlightLines.includes(lineNum)\n const classes = [styles.codeLine]\n if (isHighlighted) classes.push(\"highlighted\")\n\n return (\n <span key={index} className={classes.join(\" \")}>\n {lineNumbers && <span className={styles.lineNumber}>{lineNum}</span>}\n <span>{line}</span>\n {index < lines.length - 1 && \"\\n\"}\n </span>\n )\n })}\n </code>\n </pre>\n )\n }\n\n return (\n <div className={styles.codeBlock} data-lang={language}>\n {title && <div className={styles.codeTitle}>{title}</div>}\n <div className={styles.codeWrapper}>\n {content}\n <CopyButton code={code} />\n </div>\n </div>\n )\n}\n\nexport interface CodeGroupProps {\n /** CodeBlock components to display as tabs */\n children: React.ReactNode\n /** Comma-separated tab labels */\n labels?: string\n}\n\n/**\n * Tabbed group of code blocks.\n * Labels come from the `labels` prop (set at remark level) or fall back to\n * data-label / title / language props on children.\n */\nexport function CodeGroup({ children, labels: labelsStr }: CodeGroupProps) {\n const [activeTab, setActiveTab] = useState(0)\n\n // Filter to only valid React elements (skip whitespace text nodes)\n const childArray = Children.toArray(children).filter(isValidElement)\n const labelArray = labelsStr ? labelsStr.split(\",\") : []\n const tabs = childArray.map((child, index) => {\n if (labelArray[index]) return labelArray[index]\n const props = child.props as Record<string, unknown>\n return (\n (props[\"data-label\"] as string) ||\n (props.title as string) ||\n (props.language as string) ||\n `Tab ${index + 1}`\n )\n })\n\n return (\n <div className={styles.codeGroup}>\n <div className={styles.codeGroupTabs}>\n {tabs.map((tab, index) => (\n <button\n key={index}\n className={[styles.codeGroupTab, index === activeTab && \"active\"]\n .filter(Boolean)\n .join(\" \")}\n onClick={() => setActiveTab(index)}\n >\n {tab}\n </button>\n ))}\n </div>\n <div className=\"ardo-code-group-panels\">\n {childArray.map((child, index) => (\n <div\n key={index}\n className={[\"ardo-code-group-panel\", index === activeTab && \"active\"]\n .filter(Boolean)\n .join(\" \")}\n style={{ display: index === activeTab ? \"block\" : \"none\" }}\n >\n {child}\n </div>\n ))}\n </div>\n </div>\n )\n}\n","import 'src/ui/components/CodeBlock.css.ts.vanilla.css?source=#H4sIAAAAAAAAA-VWO2_bMBDe_StYFAFiIFQpv5IoWzt0Cbo0QMeAFs8SYZokSCpxWuS_F6RkWpZlWwXaqZt1vOd33905-aIYfBYqXz_n8ddzKhZ3hk4J-jVCaENNwWWGJkRvEXmIEixg5TKE04XeeulSGQYGG8p4ZTP0Qs01xtQw1YjwkloYe031AmYl1GuGSs4YyGBN83VhVCXZgWmuhDI4pFaM91EylOotskpwdkI7qDUWW2xLyny8Xt3v4XH8MHofJYdwPHEnIMKRBjg0ZYzLIkOpxyMW30pfcAnU4MKXDdJd3xMGxQ1Sa5GX1ySZ3SGSpHOU3hL0CZGEzMaIXN2crQOlhFyFalZKOmz5T8hQOq1jB9Er8KJ0GZoTEmUruuHi7aDqIN8oqYKzEKcHFQdb9-j9tSDHS-Wc2gxH_gjNH4ZqDSbiOanxVJY7rmSGDAjq-AsMMtUGDtgZqt73pmnLjml4myFaOTUcmjbOs9qZ7ysuG5zTZDG_BOG4ywxnqLSaGpAOfeAbrYyj0oV6GTVrNLjqJupHmMDdigwGzL8Ee8atFvQtQysBNYcEbDHjBvK6F7kS1Ub-mePEA1Q3hcs9UKLscfPI5X6wpoc5Lb3WQ7u3-yUTO0xQZ-_U22gaydnC-mL8pORFKXy-wEIu7aadmtt03ImOT3Fhaahk3YnwYH2rNssWlrNDHLgMjItwvHLmygxNJ3XdF4e32X_-G1PBCz9iXt5a4abpUQNlZcFgCwJylyGpJPRS82TmO1bObufzxX2wtSVf8yNIz8xBbWA1lW2XdZHhDYtmMcXMLpt4vb6N9NWoSsci5v_7uQtwPNGljZAs-rfF5ezb-fyd67FLLuZ2O_Ac1zzeQ7n7zitjPVG04tKBOXdc_80hnfTvqki4nR5O61SCVnMrqRDtaPsnvKLWDcMvKz0zj2fm-IoNcJbQ3N_us952e7CDxMW9OXRc3kdJI2aAvbrGmkoQ3bt67l8u6aNKZ9ZJd86iXv-Oexi9_wbZM8AFaAsAAA';\nexport var codeBlock = 'CodeBlock_codeBlock__1l68ra30';\nexport var codeGroup = 'CodeBlock_codeGroup__1l68ra35';\nexport var codeGroupTab = 'CodeBlock_codeGroupTab__1l68ra37';\nexport var codeGroupTabs = 'CodeBlock_codeGroupTabs__1l68ra36';\nexport var codeLine = 'CodeBlock_codeLine__1l68ra33';\nexport var codeTitle = 'CodeBlock_codeTitle__1l68ra31';\nexport var codeWrapper = 'CodeBlock_codeWrapper__1l68ra32';\nexport var lineNumber = 'CodeBlock_lineNumber__1l68ra34';","import 'src/ui/components/Container.css.ts.vanilla.css?source=#H4sIAAAAAAAAA52UwW7CMBBE7_mKPZaDEaE0UHNrf6F35MSOsWpsyzEFWvHvVZw0BErtpLdoMjN6knd3-qqVI0Ixuym6r00ql-ywtDP4SgB2xHKhMKSZOcJsnQAYQqlQHEM6N0ev12quLWUWWULFvsLwQewDQsRS3UooJxWbXJwYUnOESktBe3HJSodhcflzTqb3GN3JsI0TpoNNPWxOindu9V7RK4JCS22RE-aF9wga-Q-jd0xuyEKJSZj1QKwSine88zhvGxnG_GMex92mIuyUKN6bi8c4epMYRt56x4E3oQi3UKXuqBdx6to_jNk7xxHXkQiv0o51vE9x3to_jNc7x_HWkT9534STF9TMo1JRGUlOGErJ_EUgUnCFhGO7CkPBlGO2ljkxGFbN0Si1cujABN86DNls1mmV-GQY0kVja24QyrVzeteGQ2C_rsPSE_5ne3uFtyu8CpbGVqtXfLNfz8HeyOT3aq_GnwRLg8PZq7ya0DxYGZyfWmLKdVWFr7rz8lIohrbtgKTTbJ2cvwGhHDgltAYAAA';\nimport { createRuntimeFn as _7a468 } from '@vanilla-extract/recipes/createRuntimeFn';\nexport var container = _7a468({defaultClassName:'Container_container__1l7ew7r0',variantClassNames:{type:{tip:'Container_container_type_tip__1l7ew7r1',warning:'Container_container_type_warning__1l7ew7r2',danger:'Container_container_type_danger__1l7ew7r3',info:'Container_container_type_info__1l7ew7r4',note:'Container_container_type_note__1l7ew7r5'}},defaultVariants:{},compoundVariants:[]});\nexport var containerContent = 'Container_containerContent__1l7ew7rc';\nexport var containerTitle = _7a468({defaultClassName:'Container_containerTitle__1l7ew7r6',variantClassNames:{type:{tip:'Container_containerTitle_type_tip__1l7ew7r7',warning:'Container_containerTitle_type_warning__1l7ew7r8',danger:'Container_containerTitle_type_danger__1l7ew7r9',info:'Container_containerTitle_type_info__1l7ew7ra',note:'Container_containerTitle_type_note__1l7ew7rb'}},defaultVariants:{},compoundVariants:[]});","import { type ReactNode } from \"react\"\nimport { LightbulbIcon, AlertTriangleIcon, XCircleIcon, InfoIcon, FileTextIcon } from \"../icons\"\nimport * as styles from \"./Container.css\"\n\nexport type ContainerType = \"tip\" | \"warning\" | \"danger\" | \"info\" | \"note\"\n\nexport interface ContainerProps {\n /** Container type determining the style */\n type: ContainerType\n /** Optional custom title */\n title?: string\n /** Content to display inside the container */\n children: ReactNode\n}\n\nconst defaultTitles: Record<ContainerType, string> = {\n tip: \"TIP\",\n warning: \"WARNING\",\n danger: \"DANGER\",\n info: \"INFO\",\n note: \"NOTE\",\n}\n\nconst icons: Record<ContainerType, ReactNode> = {\n tip: <LightbulbIcon size={18} />,\n warning: <AlertTriangleIcon size={18} />,\n danger: <XCircleIcon size={18} />,\n info: <InfoIcon size={18} />,\n note: <FileTextIcon size={18} />,\n}\n\n/**\n * A styled container for callouts, tips, warnings, etc.\n */\nexport function Container({ type, title, children }: ContainerProps) {\n const displayTitle = title || defaultTitles[type]\n\n return (\n <div className={styles.container({ type })}>\n <p className={styles.containerTitle({ type })}>\n <span>{icons[type]}</span>\n {displayTitle}\n </p>\n <div className={styles.containerContent}>{children}</div>\n </div>\n )\n}\n\nexport interface TipProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A tip container for helpful information.\n */\nexport function Tip({ title, children }: TipProps) {\n return (\n <Container type=\"tip\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface WarningProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A warning container for cautionary information.\n */\nexport function Warning({ title, children }: WarningProps) {\n return (\n <Container type=\"warning\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface DangerProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A danger container for critical warnings.\n */\nexport function Danger({ title, children }: DangerProps) {\n return (\n <Container type=\"danger\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface InfoProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * An info container for informational content.\n */\nexport function Info({ title, children }: InfoProps) {\n return (\n <Container type=\"info\" title={title}>\n {children}\n </Container>\n )\n}\n\nexport interface NoteProps {\n /** Optional custom title */\n title?: string\n /** Content to display */\n children: ReactNode\n}\n\n/**\n * A note container for additional information.\n */\nexport function Note({ title, children }: NoteProps) {\n return (\n <Container type=\"note\" title={title}>\n {children}\n </Container>\n )\n}\n","import {\n Children,\n isValidElement,\n useEffect,\n useRef,\n useState,\n createContext,\n useContext,\n type ReactNode,\n} from \"react\"\nimport * as styles from \"./Tabs.css\"\n\ninterface TabsContextValue {\n activeTab: string\n setActiveTab: (tab: string) => void\n getTabValue: (value?: string) => string\n getPanelValue: (value?: string) => string\n}\n\nconst TabsContext = createContext<TabsContextValue | null>(null)\nconst AUTO_TAB_PREFIX = \"__ardo-tab-\"\n\nfunction useTabsContext() {\n const context = useContext(TabsContext)\n if (!context) {\n throw new Error(\"Tab components must be used within a Tabs component\")\n }\n return context\n}\n\nexport interface TabsProps {\n /** Default active tab value */\n defaultValue?: string\n /** Tab components (TabList and TabPanels) */\n children: ReactNode\n}\n\n/**\n * Tabs container component for organizing content into tabbed panels.\n */\nexport function Tabs({ defaultValue, children }: TabsProps) {\n const [activeTab, setActiveTab] = useState(() => defaultValue ?? findFirstTabValue(children))\n const tabIndexRef = useRef(0)\n const panelIndexRef = useRef(0)\n\n tabIndexRef.current = 0\n panelIndexRef.current = 0\n\n const getTabValue = (value?: string) => {\n const index = tabIndexRef.current++\n return value ?? `${AUTO_TAB_PREFIX}${index}`\n }\n\n const getPanelValue = (value?: string) => {\n const index = panelIndexRef.current++\n return value ?? `${AUTO_TAB_PREFIX}${index}`\n }\n\n useEffect(() => {\n if (defaultValue !== undefined) {\n setActiveTab(defaultValue)\n }\n }, [defaultValue])\n\n return (\n <TabsContext.Provider value={{ activeTab, setActiveTab, getTabValue, getPanelValue }}>\n <div className={styles.tabs}>{children}</div>\n </TabsContext.Provider>\n )\n}\n\nexport interface TabListProps {\n /** Tab buttons */\n children: ReactNode\n}\n\n/**\n * Container for Tab buttons.\n */\nexport function TabList({ children }: TabListProps) {\n return (\n <div className={styles.tabList} role=\"tablist\">\n {children}\n </div>\n )\n}\n\nexport interface TabProps {\n /** Unique value identifying this tab (optional if tab order matches panels) */\n value?: string\n /** Tab button label */\n children: ReactNode\n}\n\n/**\n * Individual tab button.\n */\nexport function Tab({ value, children }: TabProps) {\n const { activeTab, setActiveTab, getTabValue } = useTabsContext()\n const resolvedValue = getTabValue(value)\n const isActive = activeTab === resolvedValue\n\n return (\n <button\n type=\"button\"\n role=\"tab\"\n aria-selected={isActive}\n className={[styles.tab, isActive && \"active\"].filter(Boolean).join(\" \")}\n onClick={() => setActiveTab(resolvedValue)}\n >\n {children}\n </button>\n )\n}\n\nexport interface TabPanelProps {\n /** Value matching the corresponding Tab (optional if panel order matches tabs) */\n value?: string\n /** Panel content */\n children: ReactNode\n}\n\n/**\n * Content panel for a tab.\n */\nexport function TabPanel({ value, children }: TabPanelProps) {\n const { activeTab, getPanelValue } = useTabsContext()\n const resolvedValue = getPanelValue(value)\n const isActive = activeTab === resolvedValue\n\n if (!isActive) {\n return null\n }\n\n return (\n <div role=\"tabpanel\" className={styles.tabPanel}>\n {children}\n </div>\n )\n}\n\nexport interface TabPanelsProps {\n /** TabPanel components */\n children: ReactNode\n}\n\n/**\n * Container for TabPanel components.\n */\nexport function TabPanels({ children }: TabPanelsProps) {\n return <div className=\"ardo-tab-panels\">{children}</div>\n}\n\nfunction findFirstTabValue(children: ReactNode): string {\n for (const child of Children.toArray(children)) {\n if (!isValidElement(child)) {\n continue\n }\n\n if (child.type === Tab) {\n const tabValue = (child.props as { value?: string }).value\n return tabValue ?? `${AUTO_TAB_PREFIX}0`\n }\n\n const nestedChildren = (child.props as { children?: ReactNode }).children\n if (nestedChildren) {\n const nestedValue = findFirstTabValue(nestedChildren)\n if (nestedValue) {\n return nestedValue\n }\n }\n }\n\n return \"\"\n}\n","import 'src/ui/components/Tabs.css.ts.vanilla.css?source=LlRhYnNfdGFic19fMWp5cHIzNDAgewogIG1hcmdpbjogMjBweCAwOwp9Ci5UYWJzX3RhYkxpc3RfXzFqeXByMzQxIHsKICBkaXNwbGF5OiBmbGV4OwogIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCB2YXIoLS1hcmRvLWNvbG9yLWJvcmRlcik7CiAgZ2FwOiA0cHg7Cn0KLlRhYnNfdGFiX18xanlwcjM0MiB7CiAgcGFkZGluZzogMTBweCAxOHB4OwogIGJhY2tncm91bmQ6IG5vbmU7CiAgYm9yZGVyOiBub25lOwogIGN1cnNvcjogcG9pbnRlcjsKICBmb250LXNpemU6IDE0cHg7CiAgZm9udC13ZWlnaHQ6IDUwMDsKICBjb2xvcjogdmFyKC0tYXJkby1jb2xvci10ZXh0TGlnaHQpOwogIGJvcmRlci1ib3R0b206IDJweCBzb2xpZCB0cmFuc3BhcmVudDsKICBtYXJnaW4tYm90dG9tOiAtMXB4OwogIHRyYW5zaXRpb246IGFsbCB2YXIoLS1hcmRvLXRyYW5zaXRpb24tZmFzdCk7Cn0KLlRhYnNfdGFiX18xanlwcjM0Mjpob3ZlciB7CiAgY29sb3I6IHZhcigtLWFyZG8tY29sb3ItdGV4dCk7Cn0KLlRhYnNfdGFiX18xanlwcjM0Mi5hY3RpdmUgewogIGNvbG9yOiB2YXIoLS1hcmRvLWNvbG9yLWJyYW5kKTsKICBib3JkZXItYm90dG9tLWNvbG9yOiB2YXIoLS1hcmRvLWNvbG9yLWJyYW5kKTsKfQouVGFic190YWJQYW5lbF9fMWp5cHIzNDMgewogIHBhZGRpbmc6IDIwcHggMDsKfQ';\nexport var tab = 'Tabs_tab__1jypr342';\nexport var tabList = 'Tabs_tabList__1jypr341';\nexport var tabPanel = 'Tabs_tabPanel__1jypr343';\nexport var tabs = 'Tabs_tabs__1jypr340';"],"mappings":"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","names":["jsx","editLink","jsx","icons","jsx","jsxs","useState","jsx","jsxs","useState","tabs","tab","jsx","jsxs","Info","Children","isValidElement","useState","createContext","useContext","jsx","createContext","useContext","useState","Children","isValidElement"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=chunk-KUWEUO37.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
// src/ui/icons.tsx
|
|
2
|
+
import {
|
|
3
|
+
Github,
|
|
4
|
+
Twitter,
|
|
5
|
+
MessageCircle,
|
|
6
|
+
Linkedin,
|
|
7
|
+
Youtube,
|
|
8
|
+
Package,
|
|
9
|
+
Sun,
|
|
10
|
+
Moon,
|
|
11
|
+
Monitor,
|
|
12
|
+
Lightbulb,
|
|
13
|
+
TriangleAlert,
|
|
14
|
+
CircleX,
|
|
15
|
+
Info,
|
|
16
|
+
FileText,
|
|
17
|
+
Copy,
|
|
18
|
+
Check,
|
|
19
|
+
ChevronDown,
|
|
20
|
+
Search
|
|
21
|
+
} from "lucide-react";
|
|
22
|
+
|
|
23
|
+
export {
|
|
24
|
+
Github,
|
|
25
|
+
Twitter,
|
|
26
|
+
MessageCircle,
|
|
27
|
+
Linkedin,
|
|
28
|
+
Youtube,
|
|
29
|
+
Package,
|
|
30
|
+
Sun,
|
|
31
|
+
Moon,
|
|
32
|
+
Monitor,
|
|
33
|
+
Lightbulb,
|
|
34
|
+
TriangleAlert,
|
|
35
|
+
CircleX,
|
|
36
|
+
Info,
|
|
37
|
+
FileText,
|
|
38
|
+
Copy,
|
|
39
|
+
Check,
|
|
40
|
+
ChevronDown,
|
|
41
|
+
Search
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=chunk-PMS3P4MA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/ui/icons.tsx"],"sourcesContent":["export {\n Github as GithubIcon,\n Twitter as TwitterIcon,\n MessageCircle as MessageCircleIcon,\n Linkedin as LinkedinIcon,\n Youtube as YoutubeIcon,\n Package as PackageIcon,\n Sun as SunIcon,\n Moon as MoonIcon,\n Monitor as MonitorIcon,\n Lightbulb as LightbulbIcon,\n TriangleAlert as AlertTriangleIcon,\n CircleX as XCircleIcon,\n Info as InfoIcon,\n FileText as FileTextIcon,\n Copy as CopyIcon,\n Check as CheckIcon,\n ChevronDown as ChevronDownIcon,\n Search as SearchIcon,\n} from \"lucide-react\"\n"],"mappings":";AAAA;AAAA,EACY;AAAA,EACC;AAAA,EACM;AAAA,EACL;AAAA,EACD;AAAA,EACA;AAAA,EACJ;AAAA,EACC;AAAA,EACG;AAAA,EACE;AAAA,EACI;AAAA,EACN;AAAA,EACH;AAAA,EACI;AAAA,EACJ;AAAA,EACC;AAAA,EACM;AAAA,EACL;AAAA,OACL;","names":[]}
|