@1money/component-ui 0.0.23 → 0.0.24
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/es/stories/docs/ComponentDocsPage.js +234 -0
- package/es/stories/docs/componentDocMeta.js +97 -0
- package/es/stories/docs/storybook-docs.css +79 -0
- package/lib/stories/docs/ComponentDocsPage.js +244 -0
- package/lib/stories/docs/componentDocMeta.js +104 -0
- package/lib/stories/docs/storybook-docs.css +79 -0
- package/package.json +23 -8
- package/scripts/mcp-server/README.md +267 -0
- package/scripts/mcp-server/bin.mjs +2 -0
- package/scripts/mcp-server/drift.json +5 -0
- package/scripts/mcp-server/examples.generated.json +2651 -0
- package/scripts/mcp-server/index.generated.json +18098 -0
- package/scripts/mcp-server/index.mjs +308 -26
- package/scripts/mcp-server/tools/get-examples.mjs +125 -0
- package/scripts/mcp-server/tools/get-library-info.mjs +25 -0
- package/scripts/mcp-server/tools/get-symbol.mjs +232 -0
- package/scripts/mcp-server/tools/get-token.mjs +60 -0
- package/scripts/mcp-server/tools/list-icons.mjs +38 -0
- package/scripts/mcp-server/tools/list-symbols.mjs +46 -0
- package/scripts/mcp-server/tools/resolve-import.mjs +125 -0
- package/scripts/mcp-server/tools/search-symbols.mjs +79 -0
- package/.agents/skills/1money-component-dev/SKILL.md +0 -224
- package/.agents/skills/1money-component-dev/checklist.md +0 -159
- package/.agents/skills/1money-component-dev/references/ComponentPatterns.md +0 -478
- package/.agents/skills/1money-component-dev/references/FigmaExtractionChecklist.md +0 -144
- package/.agents/skills/1money-component-dev/references/HooksGuide.md +0 -360
- package/.agents/skills/1money-component-dev/references/SemanticColors.md +0 -215
- package/.agents/skills/1money-component-dev/references/StyleSystemAPI.md +0 -389
- package/.claude/settings.local.json +0 -120
- package/.claude/skills/1money-component-dev/SKILL.md +0 -229
- package/.claude/skills/1money-component-dev/checklist.md +0 -159
- package/.claude/skills/1money-component-dev/references/ComponentPatterns.md +0 -478
- package/.claude/skills/1money-component-dev/references/FigmaExtractionChecklist.md +0 -144
- package/.claude/skills/1money-component-dev/references/HooksGuide.md +0 -360
- package/.claude/skills/1money-component-dev/references/SemanticColors.md +0 -215
- package/.claude/skills/1money-component-dev/references/StyleSystemAPI.md +0 -389
- package/.claude/skills/1money-component-review/SKILL.md +0 -316
- package/.claude/skills/component-pipeline/SKILL.md +0 -116
- package/.claude/skills/component-pipeline/checklist.md +0 -125
- package/.hintrc +0 -13
- package/@types/global.d.ts +0 -28
- package/AGENTS.md +0 -546
- package/CLAUDE.md +0 -1
- package/jest.setup.d.ts +0 -1
- package/jest.setup.ts +0 -1
- package/patches/primereact.patch +0 -323
- package/patches/react-pro-sidebar.patch +0 -6421
- package/public/favicon.ico +0 -0
- package/public/fonts/Aeonik/Aeonik-Air.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-AirItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Black.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-BlackItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Bold.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-BoldItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Light.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-LightItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Medium.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-MediumItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Regular.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-RegularItalic.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-Thin.ttf +0 -0
- package/public/fonts/Aeonik/Aeonik-ThinItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Black.ttf +0 -0
- package/public/fonts/Inter/Inter-BlackItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Bold.ttf +0 -0
- package/public/fonts/Inter/Inter-BoldItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-ExtraBold.ttf +0 -0
- package/public/fonts/Inter/Inter-ExtraBoldItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-ExtraLight.ttf +0 -0
- package/public/fonts/Inter/Inter-ExtraLightItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Italic.ttf +0 -0
- package/public/fonts/Inter/Inter-Light.ttf +0 -0
- package/public/fonts/Inter/Inter-LightItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Medium.ttf +0 -0
- package/public/fonts/Inter/Inter-MediumItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Regular.ttf +0 -0
- package/public/fonts/Inter/Inter-SemiBold.ttf +0 -0
- package/public/fonts/Inter/Inter-SemiBoldItalic.ttf +0 -0
- package/public/fonts/Inter/Inter-Thin.ttf +0 -0
- package/public/fonts/Inter/Inter-ThinItalic.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Black.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Bold.ttf +0 -0
- package/public/fonts/Outfit/Outfit-ExtraBold.ttf +0 -0
- package/public/fonts/Outfit/Outfit-ExtraLight.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Light.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Medium.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Regular.ttf +0 -0
- package/public/fonts/Outfit/Outfit-SemiBold.ttf +0 -0
- package/public/fonts/Outfit/Outfit-Thin.ttf +0 -0
- package/public/github-mark.svg +0 -3
- package/public/tokens/GYEN.svg +0 -9
- package/public/tokens/PYUSD.svg +0 -9
- package/public/tokens/USDT.svg +0 -6
- package/scripts/mcp-server/resources.d.mts +0 -1
- package/scripts/mcp-server/resources.mjs +0 -102
- package/test/jsdom-global-register.d.ts +0 -1
- package/test/jsdom-global-register.js +0 -1
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.ComponentDocsPage = ComponentDocsPage;
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _blocks = require("@storybook/blocks");
|
|
12
|
+
var _componentDocMeta = require("./componentDocMeta");
|
|
13
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
14
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
15
|
+
var README_FILES = import.meta.glob('../../components/*/README.md', {
|
|
16
|
+
eager: true,
|
|
17
|
+
"import": 'default',
|
|
18
|
+
query: '?raw'
|
|
19
|
+
});
|
|
20
|
+
var README_ALIASES = {
|
|
21
|
+
CheckboxGroup: 'Checkbox'
|
|
22
|
+
};
|
|
23
|
+
function slugify(value) {
|
|
24
|
+
return value.trim().toLowerCase().replace(/[^a-z0-9]+/g, '-').replace(/^-+|-+$/g, '');
|
|
25
|
+
}
|
|
26
|
+
function parseReadme(markdown) {
|
|
27
|
+
var _a;
|
|
28
|
+
var lines = markdown.replace(/\r\n/g, '\n').trim().split('\n');
|
|
29
|
+
if (!lines.length) {
|
|
30
|
+
return {
|
|
31
|
+
sections: [],
|
|
32
|
+
summary: ''
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
if (/^#\s+/.test(lines[0])) {
|
|
36
|
+
lines.shift();
|
|
37
|
+
}
|
|
38
|
+
while (lines[0] === '') {
|
|
39
|
+
lines.shift();
|
|
40
|
+
}
|
|
41
|
+
var summaryLines = [];
|
|
42
|
+
while (lines.length && !/^##\s+/.test(lines[0])) {
|
|
43
|
+
summaryLines.push((_a = lines.shift()) !== null && _a !== void 0 ? _a : '');
|
|
44
|
+
}
|
|
45
|
+
var counts = new Map();
|
|
46
|
+
var sections = [];
|
|
47
|
+
var heading = '';
|
|
48
|
+
var content = [];
|
|
49
|
+
var pushSection = function pushSection() {
|
|
50
|
+
var _a;
|
|
51
|
+
var trimmedContent = content.join('\n').trim();
|
|
52
|
+
if (!heading || !trimmedContent) {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
var baseId = slugify(heading);
|
|
56
|
+
var count = (_a = counts.get(baseId)) !== null && _a !== void 0 ? _a : 0;
|
|
57
|
+
counts.set(baseId, count + 1);
|
|
58
|
+
sections.push({
|
|
59
|
+
content: trimmedContent,
|
|
60
|
+
heading: heading,
|
|
61
|
+
id: count === 0 ? baseId : "".concat(baseId, "-").concat(count + 1)
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
lines.forEach(function (line) {
|
|
65
|
+
var match = line.match(/^##\s+(.*)$/);
|
|
66
|
+
if (match) {
|
|
67
|
+
pushSection();
|
|
68
|
+
heading = match[1].trim();
|
|
69
|
+
content = [];
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
content.push(line);
|
|
73
|
+
});
|
|
74
|
+
pushSection();
|
|
75
|
+
return {
|
|
76
|
+
sections: sections,
|
|
77
|
+
summary: summaryLines.join('\n').trim()
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
function ComponentDocsPage() {
|
|
81
|
+
var _a, _b, _c, _d;
|
|
82
|
+
var docsContext = (0, _react.useContext)(_blocks.DocsContext);
|
|
83
|
+
var resolvedMeta = (0, _blocks.useOf)('meta', ['meta']);
|
|
84
|
+
var titlePath = (_a = resolvedMeta.preparedMeta.title) !== null && _a !== void 0 ? _a : 'Components';
|
|
85
|
+
var componentName = (_b = titlePath.split('/').pop()) !== null && _b !== void 0 ? _b : titlePath;
|
|
86
|
+
var readmeName = (_c = README_ALIASES[componentName]) !== null && _c !== void 0 ? _c : componentName;
|
|
87
|
+
var readmeContent = (_d = README_FILES["../../components/".concat(readmeName, "/README.md")]) !== null && _d !== void 0 ? _d : '';
|
|
88
|
+
var componentDocMeta = (0, _componentDocMeta.getComponentDocMeta)(componentName);
|
|
89
|
+
var parsedReadme = (0, _react.useMemo)(function () {
|
|
90
|
+
return parseReadme(readmeContent);
|
|
91
|
+
}, [readmeContent]);
|
|
92
|
+
var stories = docsContext.componentStories();
|
|
93
|
+
var hasComponent = Boolean(resolvedMeta.preparedMeta.component);
|
|
94
|
+
return (0, _jsxRuntime.jsx)("div", {
|
|
95
|
+
className: "sb-docs-shell",
|
|
96
|
+
children: (0, _jsxRuntime.jsx)("div", {
|
|
97
|
+
className: "sb-docs-layout",
|
|
98
|
+
children: (0, _jsxRuntime.jsxs)("div", {
|
|
99
|
+
className: "sb-docs-main",
|
|
100
|
+
children: [(0, _jsxRuntime.jsxs)("section", {
|
|
101
|
+
className: "sb-docs-hero",
|
|
102
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
103
|
+
className: "sb-docs-hero-copy",
|
|
104
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
105
|
+
className: "sb-docs-kicker",
|
|
106
|
+
children: titlePath
|
|
107
|
+
}), (0, _jsxRuntime.jsx)("h1", {
|
|
108
|
+
className: "sb-docs-title",
|
|
109
|
+
children: componentName
|
|
110
|
+
}), parsedReadme.summary ? (0, _jsxRuntime.jsx)("p", {
|
|
111
|
+
className: "sb-docs-lead",
|
|
112
|
+
children: parsedReadme.summary
|
|
113
|
+
}) : (0, _jsxRuntime.jsx)("div", {
|
|
114
|
+
className: "sb-docs-description",
|
|
115
|
+
children: (0, _jsxRuntime.jsx)(_blocks.Description, {})
|
|
116
|
+
})]
|
|
117
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
118
|
+
className: "sb-docs-hero-panel",
|
|
119
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
120
|
+
className: "sb-docs-stat",
|
|
121
|
+
children: [(0, _jsxRuntime.jsx)("span", {
|
|
122
|
+
className: "sb-docs-stat-label",
|
|
123
|
+
children: "Package"
|
|
124
|
+
}), (0, _jsxRuntime.jsx)("strong", {
|
|
125
|
+
children: "@1money/components-ui"
|
|
126
|
+
})]
|
|
127
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
128
|
+
className: "sb-docs-stat",
|
|
129
|
+
children: [(0, _jsxRuntime.jsx)("span", {
|
|
130
|
+
className: "sb-docs-stat-label",
|
|
131
|
+
children: "Stories"
|
|
132
|
+
}), (0, _jsxRuntime.jsx)("strong", {
|
|
133
|
+
children: stories.length
|
|
134
|
+
})]
|
|
135
|
+
}), (0, _jsxRuntime.jsxs)("div", {
|
|
136
|
+
className: "sb-docs-stat",
|
|
137
|
+
children: [(0, _jsxRuntime.jsx)("span", {
|
|
138
|
+
className: "sb-docs-stat-label",
|
|
139
|
+
children: "README"
|
|
140
|
+
}), (0, _jsxRuntime.jsx)("strong", {
|
|
141
|
+
children: readmeContent ? 'Available' : 'Story-driven'
|
|
142
|
+
})]
|
|
143
|
+
})]
|
|
144
|
+
})]
|
|
145
|
+
}), (componentDocMeta === null || componentDocMeta === void 0 ? void 0 : componentDocMeta.whenToUse.length) ? (0, _jsxRuntime.jsxs)("section", {
|
|
146
|
+
className: "sb-docs-section",
|
|
147
|
+
id: "when-to-use",
|
|
148
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
149
|
+
className: "sb-docs-section-header",
|
|
150
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
151
|
+
className: "sb-docs-section-kicker",
|
|
152
|
+
children: "Guidance"
|
|
153
|
+
}), (0, _jsxRuntime.jsx)("h2", {
|
|
154
|
+
children: "When To Use"
|
|
155
|
+
}), (0, _jsxRuntime.jsx)("p", {
|
|
156
|
+
children: "Keep the component choice opinionated so the library reads consistently across products."
|
|
157
|
+
})]
|
|
158
|
+
}), (0, _jsxRuntime.jsx)("ul", {
|
|
159
|
+
className: "sb-docs-use-list",
|
|
160
|
+
children: componentDocMeta.whenToUse.map(function (item) {
|
|
161
|
+
return (0, _jsxRuntime.jsx)("li", {
|
|
162
|
+
children: item
|
|
163
|
+
}, item);
|
|
164
|
+
})
|
|
165
|
+
})]
|
|
166
|
+
}) : null, (0, _jsxRuntime.jsxs)("section", {
|
|
167
|
+
className: "sb-docs-section",
|
|
168
|
+
id: "examples",
|
|
169
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
170
|
+
className: "sb-docs-section-header",
|
|
171
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
172
|
+
className: "sb-docs-section-kicker",
|
|
173
|
+
children: "Preview"
|
|
174
|
+
}), (0, _jsxRuntime.jsx)("h2", {
|
|
175
|
+
children: "Primary example"
|
|
176
|
+
}), (0, _jsxRuntime.jsx)("p", {
|
|
177
|
+
children: "Start with the default state, then use the stories below to inspect edge cases, variants, and richer composition patterns."
|
|
178
|
+
})]
|
|
179
|
+
}), (0, _jsxRuntime.jsx)(_blocks.Primary, {})]
|
|
180
|
+
}), stories.length > 1 ? (0, _jsxRuntime.jsxs)("section", {
|
|
181
|
+
className: "sb-docs-section",
|
|
182
|
+
id: "stories",
|
|
183
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
184
|
+
className: "sb-docs-section-header",
|
|
185
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
186
|
+
className: "sb-docs-section-kicker",
|
|
187
|
+
children: "Examples"
|
|
188
|
+
}), (0, _jsxRuntime.jsx)("h2", {
|
|
189
|
+
children: "Usage patterns"
|
|
190
|
+
}), (0, _jsxRuntime.jsx)("p", {
|
|
191
|
+
children: "Each story focuses on one behavior so you can review the API surface quickly."
|
|
192
|
+
})]
|
|
193
|
+
}), (0, _jsxRuntime.jsx)(_blocks.Stories, {
|
|
194
|
+
includePrimary: false,
|
|
195
|
+
title: "Usage patterns"
|
|
196
|
+
})]
|
|
197
|
+
}) : null, hasComponent ? (0, _jsxRuntime.jsxs)("section", {
|
|
198
|
+
className: "sb-docs-section",
|
|
199
|
+
id: "api",
|
|
200
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
201
|
+
className: "sb-docs-section-header",
|
|
202
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
203
|
+
className: "sb-docs-section-kicker",
|
|
204
|
+
children: "Reference"
|
|
205
|
+
}), (0, _jsxRuntime.jsx)("h2", {
|
|
206
|
+
children: "API"
|
|
207
|
+
}), (0, _jsxRuntime.jsx)("p", {
|
|
208
|
+
children: "Controls and prop tables are generated from the component metadata in this repo."
|
|
209
|
+
})]
|
|
210
|
+
}), (0, _jsxRuntime.jsx)(_blocks.Controls, {})]
|
|
211
|
+
}) : null, parsedReadme.sections.length ? (0, _jsxRuntime.jsxs)("section", {
|
|
212
|
+
className: "sb-docs-section",
|
|
213
|
+
id: "guidance",
|
|
214
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
215
|
+
className: "sb-docs-section-header",
|
|
216
|
+
children: [(0, _jsxRuntime.jsx)("p", {
|
|
217
|
+
className: "sb-docs-section-kicker",
|
|
218
|
+
children: "Guidance"
|
|
219
|
+
}), (0, _jsxRuntime.jsx)("h2", {
|
|
220
|
+
children: "Documentation notes"
|
|
221
|
+
}), (0, _jsxRuntime.jsx)("p", {
|
|
222
|
+
children: "These sections come from the component README so package docs and Storybook stay in sync."
|
|
223
|
+
})]
|
|
224
|
+
}), (0, _jsxRuntime.jsx)("div", {
|
|
225
|
+
className: "sb-docs-markdown-grid",
|
|
226
|
+
children: parsedReadme.sections.map(function (section) {
|
|
227
|
+
return (0, _jsxRuntime.jsxs)("article", {
|
|
228
|
+
className: "sb-docs-markdown-card",
|
|
229
|
+
id: section.id,
|
|
230
|
+
children: [(0, _jsxRuntime.jsx)("h3", {
|
|
231
|
+
children: section.heading
|
|
232
|
+
}), (0, _jsxRuntime.jsx)(_blocks.Markdown, {
|
|
233
|
+
children: section.content
|
|
234
|
+
})]
|
|
235
|
+
}, section.id);
|
|
236
|
+
})
|
|
237
|
+
})]
|
|
238
|
+
}) : null]
|
|
239
|
+
})
|
|
240
|
+
})
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
var _default = exports["default"] = ComponentDocsPage;
|
|
244
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["stories/docs/ComponentDocsPage.js","stories/src/stories/docs/ComponentDocsPage.tsx"],"names":["_jsxRuntime","require","_react","_interopRequireWildcard","_blocks","_componentDocMeta","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","README_FILES","import","meta","glob","eager","query","README_ALIASES","CheckboxGroup","slugify","value","trim","toLowerCase","replace","parseReadme","markdown","_a","lines","split","length","sections","summary","test","shift","summaryLines","push","counts","Map","heading","content","pushSection","trimmedContent","join","baseId","count","id","concat","forEach","line","match","ComponentDocsPage","_b","_c","_d","docsContext","useContext","DocsContext","resolvedMeta","useOf","titlePath","preparedMeta","title","componentName","pop","readmeName","readmeContent","componentDocMeta","getComponentDocMeta","parsedReadme","useMemo","stories","componentStories","hasComponent","Boolean","component","_jsx","className","children","_jsxs","Description","whenToUse","map","item","Primary","Stories","includePrimary","Controls","section","Markdown","_default","exports"],"mappings":";;;;;;;;AAAA,IAAAA,WAAA,GAAAC,OAAA;ACAA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,OAAA,GAAAH,OAAA;AASA,IAAAI,iBAAA,GAAAJ,OAAA;AAAyD,SAAAK,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAJ,wBAAAI,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAazD,IAAMW,YAAY,GAAGC,MAAM,CAACC,IAAI,CAACC,IAAI,CAAC,8BAA8B,EAAE;EACpEC,KAAK,EAAE,IAAI;EACX,UAAQ,SAAS;EACjBC,KAAK,EAAE;ADlBT,CCmBC,CAA2B;AAE5B,IAAMC,cAAc,GAA2B;EAC7CC,aAAa,EAAE;ADnBjB,CCoBC;AAED,SAASC,OAAOA,CAACC,KAAa,EAAA;EAC5B,OAAOA,KAAK,CACTC,IAAI,CAAA,CAAE,CACNC,WAAW,CAAA,CAAE,CACbC,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAC3BA,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;AAC5B;AAEA,SAASC,WAAWA,CAACC,QAAgB,EAAA;EDrBjC,IAAIC,EAAE;ECsBR,IAAMC,KAAK,GAAGF,QAAQ,CAACF,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAACF,IAAI,CAAA,CAAE,CAACO,KAAK,CAAC,IAAI,CAAC;EAEhE,IAAI,CAACD,KAAK,CAACE,MAAM,EAAE;IACjB,OAAO;MAAEC,QAAQ,EAAE,EAAE;MAAEC,OAAO,EAAE;IAAE,CAAE;EACtC;EAEA,IAAI,OAAO,CAACC,IAAI,CAACL,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;IAC1BA,KAAK,CAACM,KAAK,CAAA,CAAE;EACf;EAEA,OAAON,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE;IACtBA,KAAK,CAACM,KAAK,CAAA,CAAE;EACf;EAEA,IAAMC,YAAY,GAAa,EAAE;EAEjC,OAAOP,KAAK,CAACE,MAAM,IAAI,CAAC,QAAQ,CAACG,IAAI,CAACL,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;IAC/CO,YAAY,CAACC,IAAI,CAAC,CAAAT,EAAA,GAAAC,KAAK,CAACM,KAAK,CAAA,CAAE,MAAA,IAAA,IAAAP,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAI,EAAE,CAAC;EACxC;EAEA,IAAMU,MAAM,GAAG,IAAIC,GAAG,CAAA,CAAkB;EACxC,IAAMP,QAAQ,GAA0B,EAAE;EAC1C,IAAIQ,OAAO,GAAG,EAAE;EAChB,IAAIC,OAAO,GAAa,EAAE;EAE1B,IAAMC,WAAW,GAAG,SAAdA,WAAWA,CAAA,EAAQ;ID3BnB,IAAId,EAAE;IC4BV,IAAMe,cAAc,GAAGF,OAAO,CAACG,IAAI,CAAC,IAAI,CAAC,CAACrB,IAAI,CAAA,CAAE;IAEhD,IAAI,CAACiB,OAAO,IAAI,CAACG,cAAc,EAAE;MAC/B;IACF;IAEA,IAAME,MAAM,GAAGxB,OAAO,CAACmB,OAAO,CAAC;IAC/B,IAAMM,KAAK,GAAG,CAAAlB,EAAA,GAAAU,MAAM,CAACrC,GAAG,CAAC4C,MAAM,CAAC,MAAA,IAAA,IAAAjB,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAI,CAAC;IACrCU,MAAM,CAAC1B,GAAG,CAACiC,MAAM,EAAEC,KAAK,GAAG,CAAC,CAAC;IAE7Bd,QAAQ,CAACK,IAAI,CAAC;MACZI,OAAO,EAAEE,cAAc;MACvBH,OAAO,EAAPA,OAAO;MACPO,EAAE,EAAED,KAAK,KAAK,CAAC,GAAGD,MAAM,MAAAG,MAAA,CAAMH,MAAM,OAAAG,MAAA,CAAIF,KAAK,GAAG,CAAC;ID7B/C,CC8BH,CAAC;EACJ,CAAC;EAEDjB,KAAK,CAACoB,OAAO,CAAC,UAACC,IAAI,EAAI;IACrB,IAAMC,KAAK,GAAGD,IAAI,CAACC,KAAK,CAAC,aAAa,CAAC;IAEvC,IAAIA,KAAK,EAAE;MACTT,WAAW,CAAA,CAAE;MACbF,OAAO,GAAGW,KAAK,CAAC,CAAC,CAAC,CAAC5B,IAAI,CAAA,CAAE;MACzBkB,OAAO,GAAG,EAAE;MACZ;IACF;IAEAA,OAAO,CAACJ,IAAI,CAACa,IAAI,CAAC;EACpB,CAAC,CAAC;EAEFR,WAAW,CAAA,CAAE;EAEb,OAAO;IACLV,QAAQ,EAARA,QAAQ;IACRC,OAAO,EAAEG,YAAY,CAACQ,IAAI,CAAC,IAAI,CAAC,CAACrB,IAAI,CAAA;EDlCrC,CCmCD;AACH;AAEM,SAAU6B,iBAAiBA,CAAA,EAAA;EDnC7B,IAAIxB,EAAE,EAAEyB,EAAE,EAAEC,EAAE,EAAEC,EAAE;ECoCpB,IAAMC,WAAW,GAAG,IAAAC,iBAAU,EAACC,mBAAW,CAAC;EAC3C,IAAMC,YAAY,GAAG,IAAAC,aAAK,EAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;EAC5C,IAAMC,SAAS,GAAG,CAAAjC,EAAA,GAAA+B,YAAY,CAACG,YAAY,CAACC,KAAK,MAAA,IAAA,IAAAnC,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAI,YAAY;EACjE,IAAMoC,aAAa,GAAG,CAAAX,EAAA,GAAAQ,SAAS,CAAC/B,KAAK,CAAC,GAAG,CAAC,CAACmC,GAAG,CAAA,CAAE,MAAA,IAAA,IAAAZ,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAIQ,SAAS;EAC7D,IAAMK,UAAU,GAAG,CAAAZ,EAAA,GAAAnC,cAAc,CAAC6C,aAAa,CAAC,MAAA,IAAA,IAAAV,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAIU,aAAa;EACjE,IAAMG,aAAa,GAAG,CAAAZ,EAAA,GAAA1C,YAAY,qBAAAmC,MAAA,CAAqBkB,UAAU,gBAAa,MAAA,IAAA,IAAAX,EAAA,KAAA,KAAA,CAAA,GAAAA,EAAA,GAAI,EAAE;EACpF,IAAMa,gBAAgB,GAAG,IAAAC,qCAAmB,EAACL,aAAa,CAAC;EAC3D,IAAMM,YAAY,GAAG,IAAAC,cAAO,EAAC;IAAA,OAAM7C,WAAW,CAACyC,aAAa,CAAC;EAAA,GAAE,CAACA,aAAa,CAAC,CAAC;EAC/E,IAAMK,OAAO,GAAGhB,WAAW,CAACiB,gBAAgB,CAAA,CAAE;EAC9C,IAAMC,YAAY,GAAGC,OAAO,CAAChB,YAAY,CAACG,YAAY,CAACc,SAAS,CAAC;EAEjE,OACE,IAAAC,eAAA,EAAA,KAAA,EAAA;IAAKC,SAAS,EAAC,eAAe;IAAAC,QAAA,EAC5B,IAAAF,eAAA,EAAA,KAAA,EAAA;MAAKC,SAAS,EAAC,gBAAgB;MAAAC,QAAA,EAC7B,IAAAC,gBAAA,EAAA,KAAA,EAAA;QAAKF,SAAS,EAAC,cAAc;QAAAC,QAAA,EAAA,CAC3B,IAAAC,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,cAAc;UAAAC,QAAA,EAAA,CAC/B,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,mBAAmB;YAAAC,QAAA,EAAA,CAChC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,gBAAgB;cAAAC,QAAA,EAAElB;YAAS,CAAA,CAAK,EAC7C,IAAAgB,eAAA,EAAA,IAAA,EAAA;cAAIC,SAAS,EAAC,eAAe;cAAAC,QAAA,EAAEf;YAAa,CAAA,CAAM,EACjDM,YAAY,CAACrC,OAAO,GACnB,IAAA4C,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,cAAc;cAAAC,QAAA,EAAET,YAAY,CAACrC;YAAO,CAAA,CAAK,GAEtD,IAAA4C,eAAA,EAAA,KAAA,EAAA;cAAKC,SAAS,EAAC,qBAAqB;cAAAC,QAAA,EAClC,IAAAF,eAAA,EAACI,mBAAW,EAAA,CAAA,CAAA;YAAG,CAAA,CAElB;UAAA,CAAA,CACG,EAEN,IAAAD,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,oBAAoB;YAAAC,QAAA,EAAA,CACjC,IAAAC,gBAAA,EAAA,KAAA,EAAA;cAAKF,SAAS,EAAC,cAAc;cAAAC,QAAA,EAAA,CAC3B,IAAAF,eAAA,EAAA,MAAA,EAAA;gBAAMC,SAAS,EAAC,oBAAoB;gBAAAC,QAAA,EAAA;cAAA,CAAA,CAAe,EACnD,IAAAF,eAAA,EAAA,QAAA,EAAA;gBAAAE,QAAA,EAAA;cAAA,CAAA,CAAsC;YAAA,CAAA,CAClC,EACN,IAAAC,gBAAA,EAAA,KAAA,EAAA;cAAKF,SAAS,EAAC,cAAc;cAAAC,QAAA,EAAA,CAC3B,IAAAF,eAAA,EAAA,MAAA,EAAA;gBAAMC,SAAS,EAAC,oBAAoB;gBAAAC,QAAA,EAAA;cAAA,CAAA,CAAe,EACnD,IAAAF,eAAA,EAAA,QAAA,EAAA;gBAAAE,QAAA,EAASP,OAAO,CAACzC;cAAM,CAAA,CAAU;YAAA,CAAA,CAC7B,EACN,IAAAiD,gBAAA,EAAA,KAAA,EAAA;cAAKF,SAAS,EAAC,cAAc;cAAAC,QAAA,EAAA,CAC3B,IAAAF,eAAA,EAAA,MAAA,EAAA;gBAAMC,SAAS,EAAC,oBAAoB;gBAAAC,QAAA,EAAA;cAAA,CAAA,CAAc,EAClD,IAAAF,eAAA,EAAA,QAAA,EAAA;gBAAAE,QAAA,EAASZ,aAAa,GAAG,WAAW,GAAG;cAAc,CAAA,CAAU;YAAA,CAAA,CAC3D;UAAA,CAAA,CACF;QAAA,CAAA,CACE,EAET,CAAAC,gBAAgB,KAAA,IAAA,IAAhBA,gBAAgB,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAhBA,gBAAgB,CAAEc,SAAS,CAACnD,MAAM,IACjC,IAAAiD,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,iBAAiB;UAAC/B,EAAE,EAAC,aAAa;UAAAgC,QAAA,EAAA,CACnD,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,wBAAwB;YAAAC,QAAA,EAAA,CACrC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,wBAAwB;cAAAC,QAAA,EAAA;YAAA,CAAA,CAAa,EAClD,IAAAF,eAAA,EAAA,IAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAoB,EACpB,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAGI;UAAA,CAAA,CACA,EAEN,IAAAF,eAAA,EAAA,IAAA,EAAA;YAAIC,SAAS,EAAC,kBAAkB;YAAAC,QAAA,EAC7BX,gBAAgB,CAACc,SAAS,CAACC,GAAG,CAAC,UAACC,IAAI;cAAA,OACnC,IAAAP,eAAA,EAAA,IAAA,EAAA;gBAAAE,QAAA,EAAgBK;cAAI,CAAA,EAAXA,IAAI,CAAa;YAAA,CAC3B;UAAC,CAAA,CACC;QAAA,CAAA,CACG,GACR,IAAI,EAER,IAAAJ,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,iBAAiB;UAAC/B,EAAE,EAAC,UAAU;UAAAgC,QAAA,EAAA,CAChD,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,wBAAwB;YAAAC,QAAA,EAAA,CACrC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,wBAAwB;cAAAC,QAAA,EAAA;YAAA,CAAA,CAAY,EACjD,IAAAF,eAAA,EAAA,IAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAwB,EACxB,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAGI;UAAA,CAAA,CACA,EACN,IAAAF,eAAA,EAACQ,eAAO,EAAA,CAAA,CAAA,CAAG;QAAA,CAAA,CACH,EAETb,OAAO,CAACzC,MAAM,GAAG,CAAC,GACjB,IAAAiD,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,iBAAiB;UAAC/B,EAAE,EAAC,SAAS;UAAAgC,QAAA,EAAA,CAC/C,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,wBAAwB;YAAAC,QAAA,EAAA,CACrC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,wBAAwB;cAAAC,QAAA,EAAA;YAAA,CAAA,CAAa,EAClD,IAAAF,eAAA,EAAA,IAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAuB,EACvB,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAoF;UAAA,CAAA,CAChF,EACN,IAAAF,eAAA,EAACS,eAAO,EAAA;YAACC,cAAc,EAAE,KAAK;YAAExB,KAAK,EAAC;UAAgB,CAAA,CAAG;QAAA,CAAA,CACjD,GACR,IAAI,EAEPW,YAAY,GACX,IAAAM,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,iBAAiB;UAAC/B,EAAE,EAAC,KAAK;UAAAgC,QAAA,EAAA,CAC3C,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,wBAAwB;YAAAC,QAAA,EAAA,CACrC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,wBAAwB;cAAAC,QAAA,EAAA;YAAA,CAAA,CAAc,EACnD,IAAAF,eAAA,EAAA,IAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAY,EACZ,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAAuF;UAAA,CAAA,CACnF,EACN,IAAAF,eAAA,EAACW,gBAAQ,EAAA,CAAA,CAAA,CAAG;QAAA,CAAA,CACJ,GACR,IAAI,EAEPlB,YAAY,CAACtC,QAAQ,CAACD,MAAM,GAC3B,IAAAiD,gBAAA,EAAA,SAAA,EAAA;UAASF,SAAS,EAAC,iBAAiB;UAAC/B,EAAE,EAAC,UAAU;UAAAgC,QAAA,EAAA,CAChD,IAAAC,gBAAA,EAAA,KAAA,EAAA;YAAKF,SAAS,EAAC,wBAAwB;YAAAC,QAAA,EAAA,CACrC,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAGC,SAAS,EAAC,wBAAwB;cAAAC,QAAA,EAAA;YAAA,CAAA,CAAa,EAClD,IAAAF,eAAA,EAAA,IAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAA4B,EAC5B,IAAAF,eAAA,EAAA,GAAA,EAAA;cAAAE,QAAA,EAAA;YAAA,CAAA,CAGI;UAAA,CAAA,CACA,EAEN,IAAAF,eAAA,EAAA,KAAA,EAAA;YAAKC,SAAS,EAAC,uBAAuB;YAAAC,QAAA,EACnCT,YAAY,CAACtC,QAAQ,CAACmD,GAAG,CAAC,UAACM,OAAO;cAAA,OACjC,IAAAT,gBAAA,EAAA,SAAA,EAAA;gBAASF,SAAS,EAAC,uBAAuB;gBAAC/B,EAAE,EAAE0C,OAAO,CAAC1C,EAAE;gBAAAgC,QAAA,EAAA,CACvD,IAAAF,eAAA,EAAA,IAAA,EAAA;kBAAAE,QAAA,EAAKU,OAAO,CAACjD;gBAAO,CAAA,CAAM,EAC1B,IAAAqC,eAAA,EAACa,gBAAQ,EAAA;kBAAAX,QAAA,EAAEU,OAAO,CAAChD;gBAAO,CAAA,CAAY;cAAA,CAAA,EAFwBgD,OAAO,CAAC1C,EAAE,CAGhE;YAAA,CACX;UAAC,CAAA,CACE;QAAA,CAAA,CACE,GACR,IAAI;MAAA,CAAA;IACJ,CAAA;EACF,CAAA,CACF;AAEV;AAAC,IAAA4C,QAAA,GAAAC,OAAA,cAEcxC,iBAAiB","file":"stories/docs/ComponentDocsPage.js","sourcesContent":["import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nimport React, { useContext, useMemo } from 'react';\nimport { Controls, Description, DocsContext, Markdown, Primary, Stories, useOf, } from '@storybook/blocks';\nimport { getComponentDocMeta } from './componentDocMeta';\nconst README_FILES = import.meta.glob('../../components/*/README.md', {\n    eager: true,\n    import: 'default',\n    query: '?raw',\n});\nconst README_ALIASES = {\n    CheckboxGroup: 'Checkbox',\n};\nfunction slugify(value) {\n    return value\n        .trim()\n        .toLowerCase()\n        .replace(/[^a-z0-9]+/g, '-')\n        .replace(/^-+|-+$/g, '');\n}\nfunction parseReadme(markdown) {\n    var _a;\n    const lines = markdown.replace(/\\r\\n/g, '\\n').trim().split('\\n');\n    if (!lines.length) {\n        return { sections: [], summary: '' };\n    }\n    if (/^#\\s+/.test(lines[0])) {\n        lines.shift();\n    }\n    while (lines[0] === '') {\n        lines.shift();\n    }\n    const summaryLines = [];\n    while (lines.length && !/^##\\s+/.test(lines[0])) {\n        summaryLines.push((_a = lines.shift()) !== null && _a !== void 0 ? _a : '');\n    }\n    const counts = new Map();\n    const sections = [];\n    let heading = '';\n    let content = [];\n    const pushSection = () => {\n        var _a;\n        const trimmedContent = content.join('\\n').trim();\n        if (!heading || !trimmedContent) {\n            return;\n        }\n        const baseId = slugify(heading);\n        const count = (_a = counts.get(baseId)) !== null && _a !== void 0 ? _a : 0;\n        counts.set(baseId, count + 1);\n        sections.push({\n            content: trimmedContent,\n            heading,\n            id: count === 0 ? baseId : `${baseId}-${count + 1}`,\n        });\n    };\n    lines.forEach((line) => {\n        const match = line.match(/^##\\s+(.*)$/);\n        if (match) {\n            pushSection();\n            heading = match[1].trim();\n            content = [];\n            return;\n        }\n        content.push(line);\n    });\n    pushSection();\n    return {\n        sections,\n        summary: summaryLines.join('\\n').trim(),\n    };\n}\nexport function ComponentDocsPage() {\n    var _a, _b, _c, _d;\n    const docsContext = useContext(DocsContext);\n    const resolvedMeta = useOf('meta', ['meta']);\n    const titlePath = (_a = resolvedMeta.preparedMeta.title) !== null && _a !== void 0 ? _a : 'Components';\n    const componentName = (_b = titlePath.split('/').pop()) !== null && _b !== void 0 ? _b : titlePath;\n    const readmeName = (_c = README_ALIASES[componentName]) !== null && _c !== void 0 ? _c : componentName;\n    const readmeContent = (_d = README_FILES[`../../components/${readmeName}/README.md`]) !== null && _d !== void 0 ? _d : '';\n    const componentDocMeta = getComponentDocMeta(componentName);\n    const parsedReadme = useMemo(() => parseReadme(readmeContent), [readmeContent]);\n    const stories = docsContext.componentStories();\n    const hasComponent = Boolean(resolvedMeta.preparedMeta.component);\n    return (_jsx(\"div\", { className: \"sb-docs-shell\", children: _jsx(\"div\", { className: \"sb-docs-layout\", children: _jsxs(\"div\", { className: \"sb-docs-main\", children: [_jsxs(\"section\", { className: \"sb-docs-hero\", children: [_jsxs(\"div\", { className: \"sb-docs-hero-copy\", children: [_jsx(\"p\", { className: \"sb-docs-kicker\", children: titlePath }), _jsx(\"h1\", { className: \"sb-docs-title\", children: componentName }), parsedReadme.summary ? (_jsx(\"p\", { className: \"sb-docs-lead\", children: parsedReadme.summary })) : (_jsx(\"div\", { className: \"sb-docs-description\", children: _jsx(Description, {}) }))] }), _jsxs(\"div\", { className: \"sb-docs-hero-panel\", children: [_jsxs(\"div\", { className: \"sb-docs-stat\", children: [_jsx(\"span\", { className: \"sb-docs-stat-label\", children: \"Package\" }), _jsx(\"strong\", { children: \"@1money/components-ui\" })] }), _jsxs(\"div\", { className: \"sb-docs-stat\", children: [_jsx(\"span\", { className: \"sb-docs-stat-label\", children: \"Stories\" }), _jsx(\"strong\", { children: stories.length })] }), _jsxs(\"div\", { className: \"sb-docs-stat\", children: [_jsx(\"span\", { className: \"sb-docs-stat-label\", children: \"README\" }), _jsx(\"strong\", { children: readmeContent ? 'Available' : 'Story-driven' })] })] })] }), (componentDocMeta === null || componentDocMeta === void 0 ? void 0 : componentDocMeta.whenToUse.length) ? (_jsxs(\"section\", { className: \"sb-docs-section\", id: \"when-to-use\", children: [_jsxs(\"div\", { className: \"sb-docs-section-header\", children: [_jsx(\"p\", { className: \"sb-docs-section-kicker\", children: \"Guidance\" }), _jsx(\"h2\", { children: \"When To Use\" }), _jsx(\"p\", { children: \"Keep the component choice opinionated so the library reads consistently across products.\" })] }), _jsx(\"ul\", { className: \"sb-docs-use-list\", children: componentDocMeta.whenToUse.map((item) => (_jsx(\"li\", { children: item }, item))) })] })) : null, _jsxs(\"section\", { className: \"sb-docs-section\", id: \"examples\", children: [_jsxs(\"div\", { className: \"sb-docs-section-header\", children: [_jsx(\"p\", { className: \"sb-docs-section-kicker\", children: \"Preview\" }), _jsx(\"h2\", { children: \"Primary example\" }), _jsx(\"p\", { children: \"Start with the default state, then use the stories below to inspect edge cases, variants, and richer composition patterns.\" })] }), _jsx(Primary, {})] }), stories.length > 1 ? (_jsxs(\"section\", { className: \"sb-docs-section\", id: \"stories\", children: [_jsxs(\"div\", { className: \"sb-docs-section-header\", children: [_jsx(\"p\", { className: \"sb-docs-section-kicker\", children: \"Examples\" }), _jsx(\"h2\", { children: \"Usage patterns\" }), _jsx(\"p\", { children: \"Each story focuses on one behavior so you can review the API surface quickly.\" })] }), _jsx(Stories, { includePrimary: false, title: \"Usage patterns\" })] })) : null, hasComponent ? (_jsxs(\"section\", { className: \"sb-docs-section\", id: \"api\", children: [_jsxs(\"div\", { className: \"sb-docs-section-header\", children: [_jsx(\"p\", { className: \"sb-docs-section-kicker\", children: \"Reference\" }), _jsx(\"h2\", { children: \"API\" }), _jsx(\"p\", { children: \"Controls and prop tables are generated from the component metadata in this repo.\" })] }), _jsx(Controls, {})] })) : null, parsedReadme.sections.length ? (_jsxs(\"section\", { className: \"sb-docs-section\", id: \"guidance\", children: [_jsxs(\"div\", { className: \"sb-docs-section-header\", children: [_jsx(\"p\", { className: \"sb-docs-section-kicker\", children: \"Guidance\" }), _jsx(\"h2\", { children: \"Documentation notes\" }), _jsx(\"p\", { children: \"These sections come from the component README so package docs and Storybook stay in sync.\" })] }), _jsx(\"div\", { className: \"sb-docs-markdown-grid\", children: parsedReadme.sections.map((section) => (_jsxs(\"article\", { className: \"sb-docs-markdown-card\", id: section.id, children: [_jsx(\"h3\", { children: section.heading }), _jsx(Markdown, { children: section.content })] }, section.id))) })] })) : null] }) }) }));\n}\nexport default ComponentDocsPage;",null],"sourceRoot":"../../../../../../../../../src"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.COMPONENT_DOC_META = void 0;
|
|
7
|
+
exports.getComponentDocMeta = getComponentDocMeta;
|
|
8
|
+
var COMPONENT_DOC_META = exports.COMPONENT_DOC_META = {
|
|
9
|
+
Accordion: {
|
|
10
|
+
whenToUse: ['Use it when long-form content needs to stay collapsed by default and expand on demand.', 'Use it when multiple related sections share the same page but should not compete for vertical space.', 'Use it for FAQs, advanced settings, breakdown panels, and progressively disclosed help content.']
|
|
11
|
+
},
|
|
12
|
+
Alert: {
|
|
13
|
+
whenToUse: ['Use it for inline page-level feedback that should remain visible until the user acknowledges it or the state changes.', 'Use it when a form, workflow, or dashboard section needs contextual status messaging without opening an overlay.', 'Use it for warnings, errors, maintenance states, and informative reminders that sit inside layout content.']
|
|
14
|
+
},
|
|
15
|
+
Button: {
|
|
16
|
+
whenToUse: ['Use it for primary and secondary actions that trigger an immediate user operation.', 'Use it when an action needs clear emphasis, loading state, or icon affordances.', 'Use text buttons for lightweight inline actions and contained buttons for stronger decision points.']
|
|
17
|
+
},
|
|
18
|
+
Checkbox: {
|
|
19
|
+
whenToUse: ['Use it when users can independently turn options on or off.', 'Use it for consent, feature toggles inside forms, and non-exclusive multi-select inputs.', 'Use it when the checked state should be explicit and persist alongside labels or descriptions.']
|
|
20
|
+
},
|
|
21
|
+
CheckboxGroup: {
|
|
22
|
+
whenToUse: ['Use it when users need to select multiple options from the same option set.', 'Use it for preference pickers, permission sets, and grouped filter controls.', 'Use it when shared name, disabled state, or orientation should be applied consistently across related checkboxes.']
|
|
23
|
+
},
|
|
24
|
+
Drawer: {
|
|
25
|
+
whenToUse: ['Use it for secondary workflows that should slide over the current page without full navigation.', 'Use it when editing, inspecting, or confirming information while preserving the user’s existing context.', 'Use it for side panels, detail inspectors, and task flows that benefit from extra space but should not block the entire screen like a modal.']
|
|
26
|
+
},
|
|
27
|
+
Dropdown: {
|
|
28
|
+
whenToUse: ['Use it for anchored action menus and lightweight floating panels.', 'Use it when the trigger should reveal a short set of contextual commands near the originating element.', 'Use it for action menus, overflow menus, and compact confirmation content attached to a button or icon trigger.']
|
|
29
|
+
},
|
|
30
|
+
Empty: {
|
|
31
|
+
whenToUse: ['Use it when a list, table, or surface has no data and needs a clear zero-state message.', 'Use it to explain why content is missing and what users should do next.', 'Use it for first-run experiences, filtered-empty states, and unavailable-result messaging.']
|
|
32
|
+
},
|
|
33
|
+
Flex: {
|
|
34
|
+
whenToUse: ['Use it for one-dimensional layout problems where content is arranged in a row or column.', 'Use it for toolbars, action bars, inline alignment, and vertically stacked content blocks.', 'Use it when spacing, wrapping, justification, and alignment should be controlled without dropping into raw CSS.']
|
|
35
|
+
},
|
|
36
|
+
Form: {
|
|
37
|
+
whenToUse: ['Use it when field registration, validation rules, and submit/reset handling should be managed as a single form state.', 'Use it for standard data entry flows that need labels, rules, and predictable layout behavior.', 'Use it when multiple controls should share validation lifecycle and submission events.']
|
|
38
|
+
},
|
|
39
|
+
Grid: {
|
|
40
|
+
whenToUse: ['Use it for responsive multi-column page structure and content layouts.', 'Use it when cards, forms, or sections must align to a 12-column system across breakpoints.', 'Use it for dashboards, split panes, multi-column forms, and content areas that reflow between desktop and mobile.']
|
|
41
|
+
},
|
|
42
|
+
Icons: {
|
|
43
|
+
whenToUse: ['Use it whenever an interaction, status, or branded surface needs a consistent icon asset from the shared set.', 'Use it for buttons, inputs, alerts, navigation, and illustration-backed empty or modal states.', 'Use it when icon naming, sizing, and styling should remain consistent across the library.']
|
|
44
|
+
},
|
|
45
|
+
Input: {
|
|
46
|
+
whenToUse: ['Use it for single-line and text-entry scenarios where the user must type a value directly.', 'Use the family variants for password, search, textarea, and OTP workflows under the same visual shell.', 'Use it when labels, descriptions, validation status, prefix/suffix slots, and helper feedback all need to stay visually consistent.']
|
|
47
|
+
},
|
|
48
|
+
Dialog: {
|
|
49
|
+
whenToUse: ['Use it for blocking tasks that require focused attention before the user can continue.', 'Use it when confirmation, acknowledgement, or critical workflow steps should interrupt the current page.', 'Use it for dialogs that need dedicated title, body, illustration/media, and footer actions in a contained overlay.']
|
|
50
|
+
},
|
|
51
|
+
Notification: {
|
|
52
|
+
whenToUse: ['Use it for transient global feedback that appears above the page without changing layout.', 'Use it when a background operation, success state, warning, or error must be surfaced immediately to the user.', 'Use the static API when feedback should be triggered imperatively from actions, async events, or service responses.']
|
|
53
|
+
},
|
|
54
|
+
Pagination: {
|
|
55
|
+
whenToUse: ['Use it when large result sets are split across pages and users need to navigate predictably between them.', 'Use it for tables, activity feeds, and management screens where item count exceeds a single view.', 'Use it when page index, page size, and navigation affordances should stay explicit and reusable.']
|
|
56
|
+
},
|
|
57
|
+
Popconfirm: {
|
|
58
|
+
whenToUse: ['Use it when a destructive or irreversible action needs a lightweight confirmation without opening a full modal.', 'Use it for inline delete, archive, revoke, and remove flows that should stay anchored to the initiating control.', 'Use it when the interaction should feel contextual, fast, and visually tied to the trigger element.']
|
|
59
|
+
},
|
|
60
|
+
ProForm: {
|
|
61
|
+
whenToUse: ['Use it when you need higher-level, product-ready form composition rather than assembling every field manually.', 'Use it for search forms, dialog forms, and structured data-entry flows that benefit from field wrappers and layout helpers.', 'Use it when a page should move quickly from schema-like field configuration to working business forms.']
|
|
62
|
+
},
|
|
63
|
+
Radio: {
|
|
64
|
+
whenToUse: ['Use it when the user must choose exactly one option from a small, visible set.', 'Use it when all available choices should stay on screen for comparison.', 'Use it for mutually exclusive selections such as status mode, transfer type, or display preference.']
|
|
65
|
+
},
|
|
66
|
+
Segment: {
|
|
67
|
+
whenToUse: ['Use it for compact single-choice switching between closely related views or modes.', 'Use it when the options behave like a grouped control rather than a navigation tab set.', 'Use it for density-sensitive places such as chart mode switches, filter modes, or embedded content toggles.']
|
|
68
|
+
},
|
|
69
|
+
Select: {
|
|
70
|
+
whenToUse: ['Use it when users should choose from predefined options instead of typing a free-form value.', 'Use it for single-select and multi-select workflows with optional search, grouping, and rich option rendering.', 'Use it when the option list may be longer than a radio group can comfortably display inline.']
|
|
71
|
+
},
|
|
72
|
+
Space: {
|
|
73
|
+
whenToUse: ['Use it for quick, uniform spacing between inline or stacked elements.', 'Use it when components should be distributed with consistent preset gaps instead of manual margins.', 'Use it for button groups, tag rows, compact metadata blocks, and simple horizontal or vertical clusters.']
|
|
74
|
+
},
|
|
75
|
+
Spinner: {
|
|
76
|
+
whenToUse: ['Use it to communicate that a task is loading and a result is on the way.', 'Use it for button loading states, panel-level data fetches, and transitional waiting states.', 'Use it when the UI should acknowledge progress without yet showing a determinate percentage.']
|
|
77
|
+
},
|
|
78
|
+
Step: {
|
|
79
|
+
whenToUse: ['Use it when a workflow is divided into explicit sequential stages.', 'Use it for onboarding, identity verification, checkout, and other multi-step task progressions.', 'Use it when users benefit from seeing current progress, completed steps, and what remains.']
|
|
80
|
+
},
|
|
81
|
+
Switch: {
|
|
82
|
+
whenToUse: ['Use it for immediate binary toggles where the change takes effect as soon as the user flips the control.', 'Use it for settings, permissions, and feature activation patterns that do not require a submit button.', 'Use it when the mental model is “on/off” rather than selecting among multiple options.']
|
|
83
|
+
},
|
|
84
|
+
Tabs: {
|
|
85
|
+
whenToUse: ['Use it to switch between peer sections of content without leaving the current page.', 'Use it when several related panels share the same layout shell but only one should be visible at a time.', 'Use it for information architecture inside settings, detail pages, and modular dashboards.']
|
|
86
|
+
},
|
|
87
|
+
Tag: {
|
|
88
|
+
whenToUse: ['Use it to label entities, statuses, and short categorical metadata.', 'Use it for concise semantic markers such as state badges, asset labels, and filter chips.', 'Use it when the content should stay compact, highly scannable, and visually distinct from body text.']
|
|
89
|
+
},
|
|
90
|
+
Tooltip: {
|
|
91
|
+
whenToUse: ['Use it to reveal supplemental context without permanently occupying page space.', 'Use it for definitions, helper hints, truncated content disclosure, and icon-only explanations.', 'Use it when information is useful but not important enough to surface inline by default.']
|
|
92
|
+
},
|
|
93
|
+
Trigger: {
|
|
94
|
+
whenToUse: ['Use it when another surface should be shown or hidden in response to hover, click, or focus behavior.', 'Use it as the low-level interaction shell for popups, overlays, and anchored floating experiences.', 'Use it when trigger orchestration matters more than the visual treatment of the revealed content.']
|
|
95
|
+
},
|
|
96
|
+
Typography: {
|
|
97
|
+
whenToUse: ['Use it whenever product text should align to the semantic typography scale instead of ad hoc font styling.', 'Use it for headings, labels, body copy, links, and truncated or copyable text content.', 'Use it when text hierarchy, readability, and token-driven consistency matter across dense product surfaces.']
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
function getComponentDocMeta(componentName) {
|
|
101
|
+
var _a;
|
|
102
|
+
return (_a = COMPONENT_DOC_META[componentName]) !== null && _a !== void 0 ? _a : null;
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["stories/src/stories/docs/componentDocMeta.ts","stories/docs/componentDocMeta.js"],"names":["COMPONENT_DOC_META","exports","Accordion","whenToUse","Alert","Button","Checkbox","CheckboxGroup","Drawer","Dropdown","Empty","Flex","Form","Grid","Icons","Input","Dialog","Notification","Pagination","Popconfirm","ProForm","Radio","Segment","Select","Space","Spinner","Step","Switch","Tabs","Tag","Tooltip","Trigger","Typography","getComponentDocMeta","componentName","_a"],"mappings":"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","file":"stories/docs/componentDocMeta.js","sourcesContent":[null,"export const COMPONENT_DOC_META = {\n    Accordion: {\n        whenToUse: [\n            'Use it when long-form content needs to stay collapsed by default and expand on demand.',\n            'Use it when multiple related sections share the same page but should not compete for vertical space.',\n            'Use it for FAQs, advanced settings, breakdown panels, and progressively disclosed help content.',\n        ],\n    },\n    Alert: {\n        whenToUse: [\n            'Use it for inline page-level feedback that should remain visible until the user acknowledges it or the state changes.',\n            'Use it when a form, workflow, or dashboard section needs contextual status messaging without opening an overlay.',\n            'Use it for warnings, errors, maintenance states, and informative reminders that sit inside layout content.',\n        ],\n    },\n    Button: {\n        whenToUse: [\n            'Use it for primary and secondary actions that trigger an immediate user operation.',\n            'Use it when an action needs clear emphasis, loading state, or icon affordances.',\n            'Use text buttons for lightweight inline actions and contained buttons for stronger decision points.',\n        ],\n    },\n    Checkbox: {\n        whenToUse: [\n            'Use it when users can independently turn options on or off.',\n            'Use it for consent, feature toggles inside forms, and non-exclusive multi-select inputs.',\n            'Use it when the checked state should be explicit and persist alongside labels or descriptions.',\n        ],\n    },\n    CheckboxGroup: {\n        whenToUse: [\n            'Use it when users need to select multiple options from the same option set.',\n            'Use it for preference pickers, permission sets, and grouped filter controls.',\n            'Use it when shared name, disabled state, or orientation should be applied consistently across related checkboxes.',\n        ],\n    },\n    Drawer: {\n        whenToUse: [\n            'Use it for secondary workflows that should slide over the current page without full navigation.',\n            'Use it when editing, inspecting, or confirming information while preserving the user’s existing context.',\n            'Use it for side panels, detail inspectors, and task flows that benefit from extra space but should not block the entire screen like a modal.',\n        ],\n    },\n    Dropdown: {\n        whenToUse: [\n            'Use it for anchored action menus and lightweight floating panels.',\n            'Use it when the trigger should reveal a short set of contextual commands near the originating element.',\n            'Use it for action menus, overflow menus, and compact confirmation content attached to a button or icon trigger.',\n        ],\n    },\n    Empty: {\n        whenToUse: [\n            'Use it when a list, table, or surface has no data and needs a clear zero-state message.',\n            'Use it to explain why content is missing and what users should do next.',\n            'Use it for first-run experiences, filtered-empty states, and unavailable-result messaging.',\n        ],\n    },\n    Flex: {\n        whenToUse: [\n            'Use it for one-dimensional layout problems where content is arranged in a row or column.',\n            'Use it for toolbars, action bars, inline alignment, and vertically stacked content blocks.',\n            'Use it when spacing, wrapping, justification, and alignment should be controlled without dropping into raw CSS.',\n        ],\n    },\n    Form: {\n        whenToUse: [\n            'Use it when field registration, validation rules, and submit/reset handling should be managed as a single form state.',\n            'Use it for standard data entry flows that need labels, rules, and predictable layout behavior.',\n            'Use it when multiple controls should share validation lifecycle and submission events.',\n        ],\n    },\n    Grid: {\n        whenToUse: [\n            'Use it for responsive multi-column page structure and content layouts.',\n            'Use it when cards, forms, or sections must align to a 12-column system across breakpoints.',\n            'Use it for dashboards, split panes, multi-column forms, and content areas that reflow between desktop and mobile.',\n        ],\n    },\n    Icons: {\n        whenToUse: [\n            'Use it whenever an interaction, status, or branded surface needs a consistent icon asset from the shared set.',\n            'Use it for buttons, inputs, alerts, navigation, and illustration-backed empty or modal states.',\n            'Use it when icon naming, sizing, and styling should remain consistent across the library.',\n        ],\n    },\n    Input: {\n        whenToUse: [\n            'Use it for single-line and text-entry scenarios where the user must type a value directly.',\n            'Use the family variants for password, search, textarea, and OTP workflows under the same visual shell.',\n            'Use it when labels, descriptions, validation status, prefix/suffix slots, and helper feedback all need to stay visually consistent.',\n        ],\n    },\n    Dialog: {\n        whenToUse: [\n            'Use it for blocking tasks that require focused attention before the user can continue.',\n            'Use it when confirmation, acknowledgement, or critical workflow steps should interrupt the current page.',\n            'Use it for dialogs that need dedicated title, body, illustration/media, and footer actions in a contained overlay.',\n        ],\n    },\n    Notification: {\n        whenToUse: [\n            'Use it for transient global feedback that appears above the page without changing layout.',\n            'Use it when a background operation, success state, warning, or error must be surfaced immediately to the user.',\n            'Use the static API when feedback should be triggered imperatively from actions, async events, or service responses.',\n        ],\n    },\n    Pagination: {\n        whenToUse: [\n            'Use it when large result sets are split across pages and users need to navigate predictably between them.',\n            'Use it for tables, activity feeds, and management screens where item count exceeds a single view.',\n            'Use it when page index, page size, and navigation affordances should stay explicit and reusable.',\n        ],\n    },\n    Popconfirm: {\n        whenToUse: [\n            'Use it when a destructive or irreversible action needs a lightweight confirmation without opening a full modal.',\n            'Use it for inline delete, archive, revoke, and remove flows that should stay anchored to the initiating control.',\n            'Use it when the interaction should feel contextual, fast, and visually tied to the trigger element.',\n        ],\n    },\n    ProForm: {\n        whenToUse: [\n            'Use it when you need higher-level, product-ready form composition rather than assembling every field manually.',\n            'Use it for search forms, dialog forms, and structured data-entry flows that benefit from field wrappers and layout helpers.',\n            'Use it when a page should move quickly from schema-like field configuration to working business forms.',\n        ],\n    },\n    Radio: {\n        whenToUse: [\n            'Use it when the user must choose exactly one option from a small, visible set.',\n            'Use it when all available choices should stay on screen for comparison.',\n            'Use it for mutually exclusive selections such as status mode, transfer type, or display preference.',\n        ],\n    },\n    Segment: {\n        whenToUse: [\n            'Use it for compact single-choice switching between closely related views or modes.',\n            'Use it when the options behave like a grouped control rather than a navigation tab set.',\n            'Use it for density-sensitive places such as chart mode switches, filter modes, or embedded content toggles.',\n        ],\n    },\n    Select: {\n        whenToUse: [\n            'Use it when users should choose from predefined options instead of typing a free-form value.',\n            'Use it for single-select and multi-select workflows with optional search, grouping, and rich option rendering.',\n            'Use it when the option list may be longer than a radio group can comfortably display inline.',\n        ],\n    },\n    Space: {\n        whenToUse: [\n            'Use it for quick, uniform spacing between inline or stacked elements.',\n            'Use it when components should be distributed with consistent preset gaps instead of manual margins.',\n            'Use it for button groups, tag rows, compact metadata blocks, and simple horizontal or vertical clusters.',\n        ],\n    },\n    Spinner: {\n        whenToUse: [\n            'Use it to communicate that a task is loading and a result is on the way.',\n            'Use it for button loading states, panel-level data fetches, and transitional waiting states.',\n            'Use it when the UI should acknowledge progress without yet showing a determinate percentage.',\n        ],\n    },\n    Step: {\n        whenToUse: [\n            'Use it when a workflow is divided into explicit sequential stages.',\n            'Use it for onboarding, identity verification, checkout, and other multi-step task progressions.',\n            'Use it when users benefit from seeing current progress, completed steps, and what remains.',\n        ],\n    },\n    Switch: {\n        whenToUse: [\n            'Use it for immediate binary toggles where the change takes effect as soon as the user flips the control.',\n            'Use it for settings, permissions, and feature activation patterns that do not require a submit button.',\n            'Use it when the mental model is “on/off” rather than selecting among multiple options.',\n        ],\n    },\n    Tabs: {\n        whenToUse: [\n            'Use it to switch between peer sections of content without leaving the current page.',\n            'Use it when several related panels share the same layout shell but only one should be visible at a time.',\n            'Use it for information architecture inside settings, detail pages, and modular dashboards.',\n        ],\n    },\n    Tag: {\n        whenToUse: [\n            'Use it to label entities, statuses, and short categorical metadata.',\n            'Use it for concise semantic markers such as state badges, asset labels, and filter chips.',\n            'Use it when the content should stay compact, highly scannable, and visually distinct from body text.',\n        ],\n    },\n    Tooltip: {\n        whenToUse: [\n            'Use it to reveal supplemental context without permanently occupying page space.',\n            'Use it for definitions, helper hints, truncated content disclosure, and icon-only explanations.',\n            'Use it when information is useful but not important enough to surface inline by default.',\n        ],\n    },\n    Trigger: {\n        whenToUse: [\n            'Use it when another surface should be shown or hidden in response to hover, click, or focus behavior.',\n            'Use it as the low-level interaction shell for popups, overlays, and anchored floating experiences.',\n            'Use it when trigger orchestration matters more than the visual treatment of the revealed content.',\n        ],\n    },\n    Typography: {\n        whenToUse: [\n            'Use it whenever product text should align to the semantic typography scale instead of ad hoc font styling.',\n            'Use it for headings, labels, body copy, links, and truncated or copyable text content.',\n            'Use it when text hierarchy, readability, and token-driven consistency matter across dense product surfaces.',\n        ],\n    },\n};\nexport function getComponentDocMeta(componentName) {\n    var _a;\n    return (_a = COMPONENT_DOC_META[componentName]) !== null && _a !== void 0 ? _a : null;\n}"],"sourceRoot":"../../../../../../../../../src"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
.doc-article,.doc-home,.sb-docs-shell{--sb-doc-accent:#1677ff;--sb-doc-accent-soft:rgba(22,119,255,12%);--sb-doc-border:#e6ebf2;--sb-doc-border-strong:#d7deea;--sb-doc-text:#1f2329;--sb-doc-text-secondary:#5b667a;--sb-doc-surface:#fff;--sb-doc-surface-muted:#f7f9fc;--sb-doc-shadow:0 18px 48px rgba(15,23,42,8%);color:var(--sb-doc-text);font-family:Aeonik,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.sb-docs-shell{padding:28px 24px 96px}.sb-docs-layout{max-width:1360px;margin:0 auto}.doc-article,.doc-home,.sb-docs-main{min-width:0}.doc-home-card,.doc-home-chip,.doc-home-hero,.doc-home-info-card,.doc-home-section,.sb-docs-hero,.sb-docs-section{background:var(--sb-doc-surface);border:1px solid var(--sb-doc-border);border-radius:24px;box-shadow:var(--sb-doc-shadow)}.doc-home-hero,.sb-docs-hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.85fr);gap:24px;margin-bottom:24px;padding:36px;background:radial-gradient(circle at top right,rgba(22,119,255,14%),transparent 38%),linear-gradient(180deg,#fff,#fbfcff)}.doc-home-card-kicker,.doc-home-kicker,.sb-docs-kicker,.sb-docs-section-kicker{margin:0 0 12px;color:var(--sb-doc-accent);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase}.doc-article h1,.doc-home h1,.sb-docs-title{margin:0 0 16px;color:#111827;font-weight:700;font-size:clamp(34px,4vw,52px);font-family:Aeonik,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.04;letter-spacing:-.04em}.doc-article-lead,.doc-home-lead,.sb-docs-description :where(p),.sb-docs-lead{max-width:760px;margin:0;color:var(--sb-doc-text-secondary);font-size:18px;line-height:1.72}.sb-docs-hero-panel{display:grid;gap:12px;align-content:start}.doc-home-chip,.doc-home-info-card,.doc-home-panel,.sb-docs-stat{padding:18px 20px;background:rgba(255,255,255,82%);border:1px solid var(--sb-doc-border);border-radius:18px}.sb-docs-stat-label{display:block;margin-bottom:6px;color:var(--sb-doc-text-secondary);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.doc-home-chip strong,.doc-home-info-card strong,.sb-docs-stat strong{color:var(--sb-doc-text);font-weight:600;font-size:16px}.doc-home-section,.sb-docs-section{margin-bottom:24px;padding:28px}.doc-home-section-header,.sb-docs-section-header{margin-bottom:20px}.doc-article h2,.doc-home-section h2,.sb-docs-section-header h2{margin:0 0 10px;color:#111827;font-weight:700;font-size:30px;line-height:1.15;letter-spacing:-.03em}.doc-article>p,.doc-home-section-header p,.doc-home-section>p,.sb-docs-section-header p{margin:0;color:var(--sb-doc-text-secondary);font-size:15px;line-height:1.7}.doc-home-card-grid,.doc-home-grid,.sb-docs-markdown-grid{display:grid;gap:16px}.sb-docs-use-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}.sb-docs-use-list li{position:relative;padding:16px 18px 16px 48px;color:var(--sb-doc-text-secondary);font-size:15px;line-height:1.72;background:var(--sb-doc-surface-muted);border:1px solid var(--sb-doc-border);border-radius:18px}.sb-docs-use-list li:before{position:absolute;top:23px;left:20px;width:12px;height:12px;background:linear-gradient(180deg,#1677ff,#69a8ff);border-radius:999px;box-shadow:0 0 0 6px rgba(22,119,255,10%);content:""}.doc-home-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:24px}.doc-home-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:20px}.doc-home-card,.sb-docs-markdown-card{min-width:0;padding:24px;background:var(--sb-doc-surface-muted);border:1px solid var(--sb-doc-border);border-radius:20px}.doc-article h3,.doc-home-card h3,.doc-home-section h3,.sb-docs-markdown-card h3{margin:0 0 12px;color:#111827;font-weight:700;font-size:21px;line-height:1.28}.doc-article li,.doc-home-card li,.doc-home-card p,.doc-home-section li,.sb-docs-markdown-card li,.sb-docs-markdown-card p{color:var(--sb-doc-text-secondary);font-size:14px;line-height:1.72}.doc-article :where(ul,ol),.doc-home-section :where(ul,ol),.sb-docs-markdown-card :where(ul,ol){padding-left:20px}.doc-article :where(pre,code),.doc-home-section :where(pre,code),.sb-docs-markdown-card :where(pre,code),.sb-docs-section :where(pre,code){font-family:SFMono-Regular,ui-monospace,Menlo,Monaco,Consolas,Liberation Mono,monospace}.doc-article :where(pre),.doc-home-section :where(pre),.sb-docs-markdown-card :where(pre),.sb-docs-section :where(pre){padding:16px 18px;overflow-x:auto;color:#dbe7ff;background:#0f172a;border-radius:16px}.doc-article :where(code:not(pre code)),.doc-home-section :where(code:not(pre code)),.sb-docs-markdown-card :where(code:not(pre code)),.sb-docs-section :where(code:not(pre code)){padding:.18em .45em;color:#1456b8;background:rgba(22,119,255,8%);border-radius:8px}.doc-article :where(table),.doc-home-section :where(table),.sb-docs-markdown-card :where(table),.sb-docs-section :where(table){width:100%;border-collapse:collapse}.doc-article :where(th,td),.doc-home-section :where(th,td),.sb-docs-markdown-card :where(th,td),.sb-docs-section :where(th,td){padding:12px 14px;text-align:left;vertical-align:top;border-bottom:1px solid var(--sb-doc-border)}.doc-article :where(th),.doc-home-section :where(th),.sb-docs-markdown-card :where(th),.sb-docs-section :where(th){color:#111827;font-weight:700;font-size:13px;background:rgba(15,23,42,3%)}.doc-article :where(td),.doc-home-section :where(td),.sb-docs-markdown-card :where(td),.sb-docs-section :where(td){color:var(--sb-doc-text-secondary);font-size:14px;line-height:1.6}.doc-home-panel{display:grid;gap:14px;align-content:start}.doc-home-chip-list{display:flex;flex-wrap:wrap;gap:10px}.doc-home-chip{padding:10px 14px;background:var(--sb-doc-surface);border-radius:999px}.doc-home-card-grid .doc-home-card,.doc-home-grid .doc-home-card{margin:0}.doc-home-card p:last-child,.sb-docs-markdown-card p:last-child{margin-bottom:0}@media (width <= 960px){.doc-home-card-grid,.doc-home-grid,.doc-home-hero,.sb-docs-hero{grid-template-columns:minmax(0,1fr)}}@media (width <= 720px){.doc-article,.doc-home,.sb-docs-shell{padding-right:16px;padding-left:16px}.doc-home-card,.doc-home-hero,.doc-home-section,.sb-docs-hero,.sb-docs-markdown-card,.sb-docs-section{padding:20px;border-radius:20px}.doc-article h1,.doc-home h1,.sb-docs-title{font-size:34px}.doc-article h2,.doc-home-section h2,.sb-docs-section-header h2{font-size:26px}}round: rgba(15, 23, 42, 3%);
|
|
2
|
+
}
|
|
3
|
+
|
|
4
|
+
.doc-home-section :where(td),
|
|
5
|
+
.doc-article :where(td),
|
|
6
|
+
.sb-docs-markdown-card :where(td),
|
|
7
|
+
.sb-docs-section :where(td) {
|
|
8
|
+
color: var(--sb-doc-text-secondary);
|
|
9
|
+
font-size: 14px;
|
|
10
|
+
line-height: 1.6;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.doc-home-panel {
|
|
14
|
+
display: grid;
|
|
15
|
+
gap: 14px;
|
|
16
|
+
align-content: start;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.doc-home-chip-list {
|
|
20
|
+
display: flex;
|
|
21
|
+
flex-wrap: wrap;
|
|
22
|
+
gap: 10px;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.doc-home-chip {
|
|
26
|
+
padding: 10px 14px;
|
|
27
|
+
background: var(--sb-doc-surface);
|
|
28
|
+
border-radius: 999px;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.doc-home-card-grid .doc-home-card,
|
|
32
|
+
.doc-home-grid .doc-home-card {
|
|
33
|
+
margin: 0;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.doc-home-card p:last-child,
|
|
37
|
+
.sb-docs-markdown-card p:last-child {
|
|
38
|
+
margin-bottom: 0;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
@media (width <= 960px) {
|
|
42
|
+
.sb-docs-hero,
|
|
43
|
+
.doc-home-hero,
|
|
44
|
+
.doc-home-grid,
|
|
45
|
+
.doc-home-card-grid {
|
|
46
|
+
grid-template-columns: minmax(0, 1fr);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
@media (width <= 720px) {
|
|
51
|
+
.sb-docs-shell,
|
|
52
|
+
.doc-home,
|
|
53
|
+
.doc-article {
|
|
54
|
+
padding-right: 16px;
|
|
55
|
+
padding-left: 16px;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.sb-docs-hero,
|
|
59
|
+
.doc-home-hero,
|
|
60
|
+
.sb-docs-section,
|
|
61
|
+
.doc-home-section,
|
|
62
|
+
.doc-home-card,
|
|
63
|
+
.sb-docs-markdown-card {
|
|
64
|
+
padding: 20px;
|
|
65
|
+
border-radius: 20px;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.sb-docs-title,
|
|
69
|
+
.doc-home h1,
|
|
70
|
+
.doc-article h1 {
|
|
71
|
+
font-size: 34px;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.sb-docs-section-header h2,
|
|
75
|
+
.doc-home-section h2,
|
|
76
|
+
.doc-article h2 {
|
|
77
|
+
font-size: 26px;
|
|
78
|
+
}
|
|
79
|
+
}
|
package/package.json
CHANGED
|
@@ -1,9 +1,25 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@1money/component-ui",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.24",
|
|
4
4
|
"description": "React Components based on primereact for 1money front-end projects",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"module": "es/index.js",
|
|
7
|
+
"bin": {
|
|
8
|
+
"1money-ui-mcp": "scripts/mcp-server/bin.mjs"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"es/",
|
|
12
|
+
"lib/",
|
|
13
|
+
"scripts/mcp-server/bin.mjs",
|
|
14
|
+
"scripts/mcp-server/index.mjs",
|
|
15
|
+
"scripts/mcp-server/index.d.mts",
|
|
16
|
+
"scripts/mcp-server/index.generated.json",
|
|
17
|
+
"scripts/mcp-server/examples.generated.json",
|
|
18
|
+
"scripts/mcp-server/drift.json",
|
|
19
|
+
"scripts/mcp-server/tools/*.mjs",
|
|
20
|
+
"README.md",
|
|
21
|
+
"LICENSE"
|
|
22
|
+
],
|
|
7
23
|
"exports": {
|
|
8
24
|
".": {
|
|
9
25
|
"types": "./es/index.d.ts",
|
|
@@ -94,11 +110,6 @@
|
|
|
94
110
|
"import": "./es/components/Flex/index.js",
|
|
95
111
|
"require": "./lib/components/Flex/index.js"
|
|
96
112
|
},
|
|
97
|
-
"./Form": {
|
|
98
|
-
"types": "./es/components/Form/index.d.ts",
|
|
99
|
-
"import": "./es/components/Form/index.js",
|
|
100
|
-
"require": "./lib/components/Form/index.js"
|
|
101
|
-
},
|
|
102
113
|
"./Grid": {
|
|
103
114
|
"types": "./es/components/Grid/index.d.ts",
|
|
104
115
|
"import": "./es/components/Grid/index.js",
|
|
@@ -258,7 +269,10 @@
|
|
|
258
269
|
"scripts": {
|
|
259
270
|
"start": "omni dev",
|
|
260
271
|
"dev": "omni dev",
|
|
261
|
-
"dev:mcp": "node scripts/mcp-server/
|
|
272
|
+
"dev:mcp": "node scripts/mcp-server/bin.mjs",
|
|
273
|
+
"mcp:check": "node scripts/mcp-server/bin.mjs --selftest",
|
|
274
|
+
"build:mcp-index": "node scripts/mcp-server/indexer/build-index.mjs",
|
|
275
|
+
"test:mcp-index": "node --test scripts/mcp-server/indexer/__tests__/*.test.mjs scripts/mcp-server/tools/__tests__/*.test.mjs",
|
|
262
276
|
"test": "jest --passWithNoTests",
|
|
263
277
|
"test:snapshot": "jest --updateSnapshot",
|
|
264
278
|
"lint": "npm run lint:prettier && npm run lint:es && npm run lint:style",
|
|
@@ -271,6 +285,7 @@
|
|
|
271
285
|
"lint:style_fix": "stylelint \"src/**/*.{css,less,scss,sass}\" --fix --allow-empty-input",
|
|
272
286
|
"lint:commit": "commitlint -e $HUSKY_GIT_PARAMS",
|
|
273
287
|
"new": "omni new",
|
|
288
|
+
"prebuild": "pnpm build:mcp-index",
|
|
274
289
|
"build": "omni build",
|
|
275
290
|
"build:demo": "storybook build -c .storybook -o dist-story",
|
|
276
291
|
"release": "omni release",
|
|
@@ -305,6 +320,7 @@
|
|
|
305
320
|
"@dnd-kit/sortable": "^10.0.0",
|
|
306
321
|
"@dnd-kit/utilities": "^3.2.2",
|
|
307
322
|
"@floating-ui/react": "^0.27.19",
|
|
323
|
+
"@modelcontextprotocol/sdk": "^1.25.0",
|
|
308
324
|
"bignumber.js": "^9.3.0",
|
|
309
325
|
"classnames": "~2.2.6",
|
|
310
326
|
"clsx": "^2.1.1",
|
|
@@ -332,7 +348,6 @@
|
|
|
332
348
|
"@chromatic-com/storybook": "^1.9.0",
|
|
333
349
|
"@commitlint/cli": "8.3.5",
|
|
334
350
|
"@eslint/js": "^9.24.0",
|
|
335
|
-
"@modelcontextprotocol/sdk": "^1.25.0",
|
|
336
351
|
"@omni-door/cli": "^3.2.2",
|
|
337
352
|
"@storybook/addon-actions": "^8.6.12",
|
|
338
353
|
"@storybook/addon-console": "^3.0.0",
|