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.
Files changed (48) hide show
  1. package/dist/{FileTree-K0YVFXhg.d.ts → Features-D_Pt7zpA.d.ts} +9 -47
  2. package/dist/Search-DOJMNI2T.css +193 -0
  3. package/dist/Search-DOJMNI2T.css.map +1 -0
  4. package/dist/Search-VYYG3D43.js +10 -0
  5. package/dist/chunk-4YQE3TNM.js +1 -0
  6. package/dist/chunk-4YQE3TNM.js.map +1 -0
  7. package/dist/chunk-AXLJDGQL.js +1 -0
  8. package/dist/chunk-AXLJDGQL.js.map +1 -0
  9. package/dist/{chunk-TDBU2FXP.js → chunk-CZM5NX27.js} +301 -236
  10. package/dist/chunk-CZM5NX27.js.map +1 -0
  11. package/dist/{chunk-UWFMFHRD.js → chunk-IEPSORG5.js} +177 -63
  12. package/dist/chunk-IEPSORG5.js.map +1 -0
  13. package/dist/chunk-KUWEUO37.js +1 -0
  14. package/dist/chunk-KUWEUO37.js.map +1 -0
  15. package/dist/chunk-PMS3P4MA.js +43 -0
  16. package/dist/chunk-PMS3P4MA.js.map +1 -0
  17. package/dist/{chunk-BHHI2BO4.js → chunk-ZPYQQZ7J.js} +36 -20
  18. package/dist/chunk-ZPYQQZ7J.js.map +1 -0
  19. package/dist/index.css +1290 -0
  20. package/dist/index.css.map +1 -0
  21. package/dist/index.d.ts +1 -1
  22. package/dist/index.js +7 -8
  23. package/dist/mdx/provider.css +403 -0
  24. package/dist/mdx/provider.css.map +1 -0
  25. package/dist/mdx/provider.js +3 -2
  26. package/dist/mdx/provider.js.map +1 -1
  27. package/dist/theme/index.d.ts +196 -0
  28. package/dist/theme/index.js +135 -0
  29. package/dist/theme/index.js.map +1 -0
  30. package/dist/ui/index.css +1290 -0
  31. package/dist/ui/index.css.map +1 -0
  32. package/dist/ui/index.d.ts +3 -23
  33. package/dist/ui/index.js +7 -10
  34. package/dist/ui/styles.css +1039 -1976
  35. package/dist/ui/styles.css.map +1 -0
  36. package/dist/ui/styles.d.ts +2 -0
  37. package/dist/ui/styles.js +4 -0
  38. package/dist/ui/styles.js.map +1 -0
  39. package/dist/vite/index.js +4 -0
  40. package/dist/vite/index.js.map +1 -1
  41. package/package.json +12 -2
  42. package/dist/Search-MXGJE6PQ.js +0 -9
  43. package/dist/chunk-BHHI2BO4.js.map +0 -1
  44. package/dist/chunk-MJQGGJQZ.js +0 -88
  45. package/dist/chunk-MJQGGJQZ.js.map +0 -1
  46. package/dist/chunk-TDBU2FXP.js.map +0 -1
  47. package/dist/chunk-UWFMFHRD.js.map +0 -1
  48. /package/dist/{Search-MXGJE6PQ.js.map → Search-VYYG3D43.js.map} +0 -0
@@ -1,12 +1,12 @@
1
1
  import {
2
- AlertTriangleIcon,
3
- CheckIcon,
4
- CopyIcon,
5
- FileTextIcon,
6
- InfoIcon,
7
- LightbulbIcon,
8
- XCircleIcon
9
- } from "./chunk-MJQGGJQZ.js";
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: "ardo-content-body ardo-content", children });
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 editLink = showEditLink ? themeConfig.editLink.pattern.replace(":path", pageData?.relativePath || "") : null;
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: "ardo-content-container", children: [
55
- pageData?.frontmatter.title && /* @__PURE__ */ jsxs("header", { className: "ardo-content-header", children: [
56
- /* @__PURE__ */ jsx2("h1", { className: "ardo-content-title", children: pageData.frontmatter.title }),
57
- pageData.frontmatter.description && /* @__PURE__ */ jsx2("p", { className: "ardo-content-description", children: pageData.frontmatter.description })
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: "ardo-content-body ardo-content", children }),
60
- /* @__PURE__ */ jsxs("footer", { className: "ardo-content-footer", children: [
61
- (showEditLink || showLastUpdated) && /* @__PURE__ */ jsxs("div", { className: "ardo-content-meta", children: [
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: editLink,
92
+ href: editLink2,
66
93
  target: "_blank",
67
94
  rel: "noopener noreferrer",
68
- className: "ardo-edit-link",
95
+ className: editLink,
69
96
  children: themeConfig.editLink?.text ?? "Edit this page"
70
97
  }
71
98
  ),
72
- showLastUpdated && /* @__PURE__ */ jsxs("span", { className: "ardo-last-updated", children: [
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: "ardo-prev-next", "aria-label": "Page navigation", children: [
79
- prev ? /* @__PURE__ */ jsxs(Link, { to: prev.link, className: "ardo-prev-link", children: [
80
- /* @__PURE__ */ jsx2("span", { className: "ardo-prev-next-label", children: "Previous" }),
81
- /* @__PURE__ */ jsx2("span", { className: "ardo-prev-next-title", children: prev.text })
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: "ardo-next-link", children: [
84
- /* @__PURE__ */ jsx2("span", { className: "ardo-prev-next-label", children: "Next" }),
85
- /* @__PURE__ */ jsx2("span", { className: "ardo-prev-next-title", children: next.text })
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: "ardo-copy-button",
161
+ className: copyButton,
130
162
  onClick: handleCopy,
131
163
  "aria-label": copied ? "Copied!" : "Copy code",
132
164
  children: [
133
- copied ? /* @__PURE__ */ jsx4(CheckIcon, { size: 16 }) : /* @__PURE__ */ jsx4(CopyIcon, { size: 16 }),
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 = ["ardo-code-line"];
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: "ardo-line-number", children: lineNum }),
179
- /* @__PURE__ */ jsx5("span", { className: "ardo-line-content", children: line }),
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: "ardo-code-block", "data-lang": language, children: [
185
- title && /* @__PURE__ */ jsx5("div", { className: "ardo-code-title", children: title }),
186
- /* @__PURE__ */ jsxs3("div", { className: "ardo-code-wrapper", children: [
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 tabs = childArray.map((child, index) => {
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: "ardo-code-group", children: [
202
- /* @__PURE__ */ jsx5("div", { className: "ardo-code-group-tabs", children: tabs.map((tab, index) => /* @__PURE__ */ jsx5(
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: ["ardo-code-group-tab", index === activeTab && "active"].filter(Boolean).join(" "),
249
+ className: [codeGroupTab, index === activeTab && "active"].filter(Boolean).join(" "),
206
250
  onClick: () => setActiveTab(index),
207
- children: tab
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(LightbulbIcon, { size: 18 }),
234
- warning: /* @__PURE__ */ jsx6(AlertTriangleIcon, { size: 18 }),
235
- danger: /* @__PURE__ */ jsx6(XCircleIcon, { size: 18 }),
236
- info: /* @__PURE__ */ jsx6(InfoIcon, { size: 18 }),
237
- note: /* @__PURE__ */ jsx6(FileTextIcon, { size: 18 })
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: `ardo-container ardo-container-${type}`, children: [
242
- /* @__PURE__ */ jsxs4("p", { className: "ardo-container-title", children: [
243
- /* @__PURE__ */ jsx6("span", { className: "ardo-container-icon", children: icons[type] }),
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: "ardo-container-content", children })
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 Info({ title, children }) {
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 { useState as useState3, createContext as createContext2, useContext as useContext2 } from "react";
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
- return /* @__PURE__ */ jsx7(TabsContext.Provider, { value: { activeTab, setActiveTab }, children: /* @__PURE__ */ jsx7("div", { className: "ardo-tabs", children }) });
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: "ardo-tab-list", role: "tablist", children });
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 isActive = activeTab === value;
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: ["ardo-tab", isActive && "active"].filter(Boolean).join(" "),
292
- onClick: () => setActiveTab(value),
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 isActive = activeTab === value;
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: "ardo-tab-panel", children });
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-UWFMFHRD.js.map
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":[]}