mcp-react-toolkit 1.3.0 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +28 -28
- package/node_modules/@mcp-showcase/shared/build/McpServerBase.d.ts +13 -0
- package/node_modules/@mcp-showcase/shared/build/McpServerBase.d.ts.map +1 -1
- package/node_modules/@mcp-showcase/shared/build/McpServerBase.js +40 -0
- package/node_modules/@mcp-showcase/shared/build/McpServerBase.js.map +1 -1
- package/node_modules/@mcp-showcase/shared/build/types.d.ts +11 -0
- package/node_modules/@mcp-showcase/shared/build/types.d.ts.map +1 -1
- package/node_modules/@mcp-showcase/shared/src/McpServerBase.ts +45 -0
- package/node_modules/@mcp-showcase/shared/src/types.ts +12 -0
- package/node_modules/@mcp-showcase/ui-kit/README.md +30 -0
- package/node_modules/@mcp-showcase/ui-kit/build/components.d.ts +10 -0
- package/node_modules/@mcp-showcase/ui-kit/build/components.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/components.js +177 -0
- package/node_modules/@mcp-showcase/ui-kit/build/components.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/escape.d.ts +3 -0
- package/node_modules/@mcp-showcase/ui-kit/build/escape.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/escape.js +10 -0
- package/node_modules/@mcp-showcase/ui-kit/build/escape.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/fixture.d.ts +4 -0
- package/node_modules/@mcp-showcase/ui-kit/build/fixture.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/fixture.js +52 -0
- package/node_modules/@mcp-showcase/ui-kit/build/fixture.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/generate-template.d.ts +2 -0
- package/node_modules/@mcp-showcase/ui-kit/build/generate-template.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/generate-template.js +19 -0
- package/node_modules/@mcp-showcase/ui-kit/build/generate-template.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/index.d.ts +6 -0
- package/node_modules/@mcp-showcase/ui-kit/build/index.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/index.js +7 -0
- package/node_modules/@mcp-showcase/ui-kit/build/index.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/render.d.ts +3 -0
- package/node_modules/@mcp-showcase/ui-kit/build/render.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/render.js +38 -0
- package/node_modules/@mcp-showcase/ui-kit/build/render.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-components.d.ts +9 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-components.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-components.js +105 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-components.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-fixture.d.ts +4 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-fixture.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-fixture.js +39 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-fixture.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-render.d.ts +3 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-render.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-render.js +37 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-render.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-runtime.d.ts +2 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-runtime.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-runtime.js +72 -0
- package/node_modules/@mcp-showcase/ui-kit/build/result-runtime.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/runtime.d.ts +2 -0
- package/node_modules/@mcp-showcase/ui-kit/build/runtime.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/runtime.js +221 -0
- package/node_modules/@mcp-showcase/ui-kit/build/runtime.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/theme.d.ts +2 -0
- package/node_modules/@mcp-showcase/ui-kit/build/theme.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/theme.js +278 -0
- package/node_modules/@mcp-showcase/ui-kit/build/theme.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/types.d.ts +113 -0
- package/node_modules/@mcp-showcase/ui-kit/build/types.d.ts.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/build/types.js +35 -0
- package/node_modules/@mcp-showcase/ui-kit/build/types.js.map +1 -0
- package/node_modules/@mcp-showcase/ui-kit/demo/index.html +653 -0
- package/node_modules/@mcp-showcase/ui-kit/demo/result.html +445 -0
- package/node_modules/@mcp-showcase/ui-kit/package.json +19 -0
- package/node_modules/@mcp-showcase/ui-kit/src/components.ts +191 -0
- package/node_modules/@mcp-showcase/ui-kit/src/escape.ts +9 -0
- package/node_modules/@mcp-showcase/ui-kit/src/fixture.ts +53 -0
- package/node_modules/@mcp-showcase/ui-kit/src/generate-template.ts +21 -0
- package/node_modules/@mcp-showcase/ui-kit/src/index.test.ts +72 -0
- package/node_modules/@mcp-showcase/ui-kit/src/index.ts +6 -0
- package/node_modules/@mcp-showcase/ui-kit/src/render.ts +48 -0
- package/node_modules/@mcp-showcase/ui-kit/src/result-components.ts +112 -0
- package/node_modules/@mcp-showcase/ui-kit/src/result-fixture.ts +40 -0
- package/node_modules/@mcp-showcase/ui-kit/src/result-render.test.ts +47 -0
- package/node_modules/@mcp-showcase/ui-kit/src/result-render.ts +47 -0
- package/node_modules/@mcp-showcase/ui-kit/src/result-runtime.ts +72 -0
- package/node_modules/@mcp-showcase/ui-kit/src/runtime.smoke.test.ts +103 -0
- package/node_modules/@mcp-showcase/ui-kit/src/runtime.ts +221 -0
- package/node_modules/@mcp-showcase/ui-kit/src/theme.ts +278 -0
- package/node_modules/@mcp-showcase/ui-kit/src/types.ts +140 -0
- package/node_modules/@mcp-showcase/ui-kit/tsconfig.json +9 -0
- package/package.json +16 -5
- package/tools/accessibility-checker/build/health-report.d.ts +27 -0
- package/tools/accessibility-checker/build/health-report.d.ts.map +1 -0
- package/tools/accessibility-checker/build/health-report.js +140 -0
- package/tools/accessibility-checker/build/health-report.js.map +1 -0
- package/tools/accessibility-checker/build/index.js +7 -1
- package/tools/accessibility-checker/build/index.js.map +1 -1
- package/tools/accessibility-checker/package.json +1 -0
- package/tools/code-modernizer/build/index.js +60 -44
- package/tools/code-modernizer/build/index.js.map +1 -1
- package/tools/code-modernizer/build/result-report.d.ts +24 -0
- package/tools/code-modernizer/build/result-report.d.ts.map +1 -0
- package/tools/code-modernizer/build/result-report.js +101 -0
- package/tools/code-modernizer/build/result-report.js.map +1 -0
- package/tools/code-modernizer/package.json +2 -0
- package/tools/component-factory/build/index.js +7 -1
- package/tools/component-factory/build/index.js.map +1 -1
- package/tools/component-factory/build/result-report.d.ts +11 -0
- package/tools/component-factory/build/result-report.d.ts.map +1 -0
- package/tools/component-factory/build/result-report.js +104 -0
- package/tools/component-factory/build/result-report.js.map +1 -0
- package/tools/component-factory/package.json +1 -0
- package/tools/component-fixer/build/index.js +6 -6
- package/tools/component-fixer/build/index.js.map +1 -1
- package/tools/component-fixer/build/result-report.d.ts +37 -0
- package/tools/component-fixer/build/result-report.d.ts.map +1 -0
- package/tools/component-fixer/build/result-report.js +106 -0
- package/tools/component-fixer/build/result-report.js.map +1 -0
- package/tools/component-fixer/package.json +1 -0
- package/tools/component-reviewer/build/health-report.d.ts +37 -0
- package/tools/component-reviewer/build/health-report.d.ts.map +1 -0
- package/tools/component-reviewer/build/health-report.js +116 -0
- package/tools/component-reviewer/build/health-report.js.map +1 -0
- package/tools/component-reviewer/build/index.d.ts.map +1 -1
- package/tools/component-reviewer/build/index.js +7 -6
- package/tools/component-reviewer/build/index.js.map +1 -1
- package/tools/component-reviewer/package.json +1 -0
- package/tools/dep-auditor/build/health-report.d.ts +16 -0
- package/tools/dep-auditor/build/health-report.d.ts.map +1 -0
- package/tools/dep-auditor/build/health-report.js +187 -0
- package/tools/dep-auditor/build/health-report.js.map +1 -0
- package/tools/dep-auditor/build/index.d.ts.map +1 -1
- package/tools/dep-auditor/build/index.js +7 -1
- package/tools/dep-auditor/build/index.js.map +1 -1
- package/tools/dep-auditor/package.json +1 -0
- package/tools/generate-tests/build/index.js +8 -1
- package/tools/generate-tests/build/index.js.map +1 -1
- package/tools/generate-tests/build/result-report.d.ts +14 -0
- package/tools/generate-tests/build/result-report.d.ts.map +1 -0
- package/tools/generate-tests/build/result-report.js +124 -0
- package/tools/generate-tests/build/result-report.js.map +1 -0
- package/tools/generate-tests/package.json +1 -0
- package/tools/legacy-analyzer/build/health-report.d.ts +4 -0
- package/tools/legacy-analyzer/build/health-report.d.ts.map +1 -0
- package/tools/legacy-analyzer/build/health-report.js +164 -0
- package/tools/legacy-analyzer/build/health-report.js.map +1 -0
- package/tools/legacy-analyzer/build/index.js +15 -1
- package/tools/legacy-analyzer/build/index.js.map +1 -1
- package/tools/legacy-analyzer/build/tools/01-detect-project-tech.d.ts.map +1 -1
- package/tools/legacy-analyzer/build/tools/01-detect-project-tech.js +3 -8
- package/tools/legacy-analyzer/build/tools/01-detect-project-tech.js.map +1 -1
- package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.d.ts.map +1 -1
- package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.js +25 -3
- package/tools/legacy-analyzer/build/tools/05-analyze-api-layer.js.map +1 -1
- package/tools/legacy-analyzer/package.json +1 -0
- package/tools/lighthouse-runner/build/health-report.d.ts +14 -0
- package/tools/lighthouse-runner/build/health-report.d.ts.map +1 -0
- package/tools/lighthouse-runner/build/health-report.js +138 -0
- package/tools/lighthouse-runner/build/health-report.js.map +1 -0
- package/tools/lighthouse-runner/build/index.d.ts.map +1 -1
- package/tools/lighthouse-runner/build/index.js +7 -1
- package/tools/lighthouse-runner/build/index.js.map +1 -1
- package/tools/lighthouse-runner/package.json +1 -0
- package/tools/monorepo-manager/build/index.js +9 -1
- package/tools/monorepo-manager/build/index.js.map +1 -1
- package/tools/monorepo-manager/build/result-report.d.ts +20 -0
- package/tools/monorepo-manager/build/result-report.d.ts.map +1 -0
- package/tools/monorepo-manager/build/result-report.js +84 -0
- package/tools/monorepo-manager/build/result-report.js.map +1 -0
- package/tools/monorepo-manager/package.json +1 -0
- package/tools/performance-audit/build/health-report.d.ts +30 -0
- package/tools/performance-audit/build/health-report.d.ts.map +1 -0
- package/tools/performance-audit/build/health-report.js +152 -0
- package/tools/performance-audit/build/health-report.js.map +1 -0
- package/tools/performance-audit/build/index.d.ts.map +1 -1
- package/tools/performance-audit/build/index.js +7 -1
- package/tools/performance-audit/build/index.js.map +1 -1
- package/tools/performance-audit/package.json +1 -0
- package/tools/quality-pipeline/build/health-report.d.ts +11 -0
- package/tools/quality-pipeline/build/health-report.d.ts.map +1 -0
- package/tools/quality-pipeline/build/health-report.js +137 -0
- package/tools/quality-pipeline/build/health-report.js.map +1 -0
- package/tools/quality-pipeline/build/index.js +7 -1
- package/tools/quality-pipeline/build/index.js.map +1 -1
- package/tools/quality-pipeline/package.json +1 -0
- package/tools/render-analyzer/build/health-report.d.ts +33 -0
- package/tools/render-analyzer/build/health-report.d.ts.map +1 -0
- package/tools/render-analyzer/build/health-report.js +142 -0
- package/tools/render-analyzer/build/health-report.js.map +1 -0
- package/tools/render-analyzer/build/index.d.ts.map +1 -1
- package/tools/render-analyzer/build/index.js +7 -1
- package/tools/render-analyzer/build/index.js.map +1 -1
- package/tools/render-analyzer/package.json +1 -0
- package/tools/shared/build/McpServerBase.d.ts +13 -0
- package/tools/shared/build/McpServerBase.d.ts.map +1 -1
- package/tools/shared/build/McpServerBase.js +40 -0
- package/tools/shared/build/McpServerBase.js.map +1 -1
- package/tools/shared/build/types.d.ts +11 -0
- package/tools/shared/build/types.d.ts.map +1 -1
- package/tools/storybook-generator/build/index.d.ts.map +1 -1
- package/tools/storybook-generator/build/index.js +9 -1
- package/tools/storybook-generator/build/index.js.map +1 -1
- package/tools/storybook-generator/build/result-report.d.ts +22 -0
- package/tools/storybook-generator/build/result-report.d.ts.map +1 -0
- package/tools/storybook-generator/build/result-report.js +77 -0
- package/tools/storybook-generator/build/result-report.js.map +1 -0
- package/tools/storybook-generator/package.json +1 -0
- package/tools/test-gap-analyzer/build/health-report.d.ts +34 -0
- package/tools/test-gap-analyzer/build/health-report.d.ts.map +1 -0
- package/tools/test-gap-analyzer/build/health-report.js +190 -0
- package/tools/test-gap-analyzer/build/health-report.js.map +1 -0
- package/tools/test-gap-analyzer/build/index.d.ts.map +1 -1
- package/tools/test-gap-analyzer/build/index.js +7 -1
- package/tools/test-gap-analyzer/build/index.js.map +1 -1
- package/tools/test-gap-analyzer/package.json +1 -0
- package/tools/typescript-enforcer/build/health-report.d.ts +33 -0
- package/tools/typescript-enforcer/build/health-report.d.ts.map +1 -0
- package/tools/typescript-enforcer/build/health-report.js +143 -0
- package/tools/typescript-enforcer/build/health-report.js.map +1 -0
- package/tools/typescript-enforcer/build/index.js +6 -1
- package/tools/typescript-enforcer/build/index.js.map +1 -1
- package/tools/typescript-enforcer/package.json +1 -0
- package/tools/ui-kit/README.md +30 -0
- package/tools/ui-kit/build/components.d.ts +10 -0
- package/tools/ui-kit/build/components.d.ts.map +1 -0
- package/tools/ui-kit/build/components.js +177 -0
- package/tools/ui-kit/build/components.js.map +1 -0
- package/tools/ui-kit/build/escape.d.ts +3 -0
- package/tools/ui-kit/build/escape.d.ts.map +1 -0
- package/tools/ui-kit/build/escape.js +10 -0
- package/tools/ui-kit/build/escape.js.map +1 -0
- package/tools/ui-kit/build/fixture.d.ts +4 -0
- package/tools/ui-kit/build/fixture.d.ts.map +1 -0
- package/tools/ui-kit/build/fixture.js +52 -0
- package/tools/ui-kit/build/fixture.js.map +1 -0
- package/tools/ui-kit/build/generate-template.d.ts +2 -0
- package/tools/ui-kit/build/generate-template.d.ts.map +1 -0
- package/tools/ui-kit/build/generate-template.js +19 -0
- package/tools/ui-kit/build/generate-template.js.map +1 -0
- package/tools/ui-kit/build/index.d.ts +6 -0
- package/tools/ui-kit/build/index.d.ts.map +1 -0
- package/tools/ui-kit/build/index.js +7 -0
- package/tools/ui-kit/build/index.js.map +1 -0
- package/tools/ui-kit/build/render.d.ts +3 -0
- package/tools/ui-kit/build/render.d.ts.map +1 -0
- package/tools/ui-kit/build/render.js +38 -0
- package/tools/ui-kit/build/render.js.map +1 -0
- package/tools/ui-kit/build/result-components.d.ts +9 -0
- package/tools/ui-kit/build/result-components.d.ts.map +1 -0
- package/tools/ui-kit/build/result-components.js +105 -0
- package/tools/ui-kit/build/result-components.js.map +1 -0
- package/tools/ui-kit/build/result-fixture.d.ts +4 -0
- package/tools/ui-kit/build/result-fixture.d.ts.map +1 -0
- package/tools/ui-kit/build/result-fixture.js +39 -0
- package/tools/ui-kit/build/result-fixture.js.map +1 -0
- package/tools/ui-kit/build/result-render.d.ts +3 -0
- package/tools/ui-kit/build/result-render.d.ts.map +1 -0
- package/tools/ui-kit/build/result-render.js +37 -0
- package/tools/ui-kit/build/result-render.js.map +1 -0
- package/tools/ui-kit/build/result-runtime.d.ts +2 -0
- package/tools/ui-kit/build/result-runtime.d.ts.map +1 -0
- package/tools/ui-kit/build/result-runtime.js +72 -0
- package/tools/ui-kit/build/result-runtime.js.map +1 -0
- package/tools/ui-kit/build/runtime.d.ts +2 -0
- package/tools/ui-kit/build/runtime.d.ts.map +1 -0
- package/tools/ui-kit/build/runtime.js +221 -0
- package/tools/ui-kit/build/runtime.js.map +1 -0
- package/tools/ui-kit/build/theme.d.ts +2 -0
- package/tools/ui-kit/build/theme.d.ts.map +1 -0
- package/tools/ui-kit/build/theme.js +278 -0
- package/tools/ui-kit/build/theme.js.map +1 -0
- package/tools/ui-kit/build/types.d.ts +113 -0
- package/tools/ui-kit/build/types.d.ts.map +1 -0
- package/tools/ui-kit/build/types.js +35 -0
- package/tools/ui-kit/build/types.js.map +1 -0
- package/tools/ui-kit/package.json +19 -0
|
@@ -0,0 +1,445 @@
|
|
|
1
|
+
<!doctype html>
|
|
2
|
+
<html lang="en" data-theme="light">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="utf-8"/>
|
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1"/>
|
|
6
|
+
<title>Component Factory — @repo/ui</title>
|
|
7
|
+
<style>
|
|
8
|
+
*,*::before,*::after{box-sizing:border-box}
|
|
9
|
+
html{-webkit-text-size-adjust:100%}
|
|
10
|
+
body{margin:0}
|
|
11
|
+
|
|
12
|
+
:root{
|
|
13
|
+
--font:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
|
|
14
|
+
--mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace;
|
|
15
|
+
|
|
16
|
+
/* light (default) */
|
|
17
|
+
--bg:#f7f7f6;
|
|
18
|
+
--surface:#ffffff;
|
|
19
|
+
--surface-2:#fbfbfa;
|
|
20
|
+
--text:#16161a;
|
|
21
|
+
--muted:#6b7280;
|
|
22
|
+
--faint:#9aa0aa;
|
|
23
|
+
--border:#ebe9e4;
|
|
24
|
+
--border-strong:#dedcd5;
|
|
25
|
+
--shadow:0 1px 2px rgba(16,16,20,.04),0 8px 24px -12px rgba(16,16,20,.10);
|
|
26
|
+
--ring:rgba(99,102,241,.45);
|
|
27
|
+
|
|
28
|
+
--good:#059669; --good-soft:#ecfdf5;
|
|
29
|
+
--warn:#d97706; --warn-soft:#fffbeb;
|
|
30
|
+
--bad:#e11d48; --bad-soft:#fff1f2;
|
|
31
|
+
|
|
32
|
+
--sev-critical:#e11d48; --sev-high:#ea580c; --sev-medium:#d97706; --sev-low:#64748b;
|
|
33
|
+
--sev-critical-soft:#fff1f2; --sev-high-soft:#fff7ed; --sev-medium-soft:#fffbeb; --sev-low-soft:#f1f5f9;
|
|
34
|
+
|
|
35
|
+
--accent:var(--good);
|
|
36
|
+
--accent-soft:var(--good-soft);
|
|
37
|
+
--radius:14px;
|
|
38
|
+
--radius-sm:10px;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
[data-theme="dark"]{
|
|
42
|
+
--bg:#0a0b0d;
|
|
43
|
+
--surface:#141519;
|
|
44
|
+
--surface-2:#0f1013;
|
|
45
|
+
--text:#f3f4f6;
|
|
46
|
+
--muted:#9aa1ad;
|
|
47
|
+
--faint:#6b7280;
|
|
48
|
+
--border:rgba(255,255,255,.07);
|
|
49
|
+
--border-strong:rgba(255,255,255,.12);
|
|
50
|
+
--shadow:0 1px 2px rgba(0,0,0,.4),0 16px 40px -20px rgba(0,0,0,.7);
|
|
51
|
+
--ring:rgba(129,140,248,.55);
|
|
52
|
+
|
|
53
|
+
--good:#34d399; --good-soft:rgba(52,211,153,.12);
|
|
54
|
+
--warn:#fbbf24; --warn-soft:rgba(251,191,36,.12);
|
|
55
|
+
--bad:#fb7185; --bad-soft:rgba(251,113,133,.12);
|
|
56
|
+
|
|
57
|
+
--sev-critical:#fb7185; --sev-high:#fb923c; --sev-medium:#fbbf24; --sev-low:#94a3b8;
|
|
58
|
+
--sev-critical-soft:rgba(251,113,133,.12); --sev-high-soft:rgba(251,146,60,.12);
|
|
59
|
+
--sev-medium-soft:rgba(251,191,36,.12); --sev-low-soft:rgba(148,163,184,.12);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
[data-band="good"]{--accent:var(--good);--accent-soft:var(--good-soft)}
|
|
63
|
+
[data-band="warn"]{--accent:var(--warn);--accent-soft:var(--warn-soft)}
|
|
64
|
+
[data-band="bad"]{--accent:var(--bad);--accent-soft:var(--bad-soft)}
|
|
65
|
+
|
|
66
|
+
body{
|
|
67
|
+
font-family:var(--font);
|
|
68
|
+
background:var(--bg);
|
|
69
|
+
color:var(--text);
|
|
70
|
+
font-size:14px;
|
|
71
|
+
line-height:1.5;
|
|
72
|
+
-webkit-font-smoothing:antialiased;
|
|
73
|
+
font-variant-numeric:tabular-nums;
|
|
74
|
+
}
|
|
75
|
+
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
|
|
76
|
+
|
|
77
|
+
.wrap{max-width:1040px;margin:0 auto;padding:28px 24px 64px}
|
|
78
|
+
|
|
79
|
+
/* header */
|
|
80
|
+
.hdr{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}
|
|
81
|
+
.brand{display:flex;align-items:center;gap:11px;min-width:0}
|
|
82
|
+
.brand .dot{width:30px;height:30px;border-radius:9px;background:var(--accent-soft);color:var(--accent);
|
|
83
|
+
display:grid;place-items:center;flex:none;border:1px solid var(--border)}
|
|
84
|
+
.brand h1{font-size:15px;font-weight:650;margin:0;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
|
|
85
|
+
.brand .sub{font-size:12px;color:var(--muted);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
|
|
86
|
+
.hdr-actions{display:flex;align-items:center;gap:8px;flex:none}
|
|
87
|
+
|
|
88
|
+
.btn{appearance:none;font-family:inherit;font-size:12.5px;font-weight:550;color:var(--text);
|
|
89
|
+
background:var(--surface);border:1px solid var(--border-strong);border-radius:9px;padding:7px 11px;
|
|
90
|
+
cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.16s ease;line-height:1}
|
|
91
|
+
.btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
|
|
92
|
+
.btn:active{transform:translateY(0)}
|
|
93
|
+
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}
|
|
94
|
+
.btn.icon{padding:7px;width:32px;height:32px;justify-content:center}
|
|
95
|
+
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
|
|
96
|
+
[data-theme="dark"] .btn.primary{color:#0a0b0d}
|
|
97
|
+
.btn.primary:hover{filter:brightness(1.05);color:#fff}
|
|
98
|
+
[data-theme="dark"] .btn.primary:hover{color:#0a0b0d}
|
|
99
|
+
|
|
100
|
+
/* hero */
|
|
101
|
+
.hero{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;
|
|
102
|
+
background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
|
|
103
|
+
padding:26px 28px;box-shadow:var(--shadow);margin-bottom:18px}
|
|
104
|
+
.gauge{position:relative;width:148px;height:148px;flex:none}
|
|
105
|
+
.gauge svg{transform:rotate(-90deg)}
|
|
106
|
+
.gauge .track{stroke:var(--border-strong);fill:none}
|
|
107
|
+
.gauge .arc{stroke:var(--accent);fill:none;stroke-linecap:round;transition:stroke-dashoffset 1.1s cubic-bezier(.22,1,.36,1)}
|
|
108
|
+
.gauge .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;line-height:1}
|
|
109
|
+
.gauge .score{font-size:42px;font-weight:680;letter-spacing:-.03em;line-height:1}
|
|
110
|
+
.gauge .of{font-size:11px;color:var(--faint);margin-top:3px}
|
|
111
|
+
.hero-meta{min-width:0}
|
|
112
|
+
.grade-row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}
|
|
113
|
+
.grade{font-size:13px;font-weight:650;color:var(--accent);background:var(--accent-soft);
|
|
114
|
+
border:1px solid var(--border);border-radius:7px;padding:3px 9px}
|
|
115
|
+
.verdict{font-size:18px;font-weight:620;letter-spacing:-.01em}
|
|
116
|
+
.hero p{color:var(--muted);margin:2px 0 14px;font-size:13px}
|
|
117
|
+
.chips{display:flex;flex-wrap:wrap;gap:7px}
|
|
118
|
+
.chip{font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);
|
|
119
|
+
border-radius:999px;padding:4px 10px;display:inline-flex;gap:5px}
|
|
120
|
+
.chip b{color:var(--text);font-weight:600}
|
|
121
|
+
|
|
122
|
+
/* section heading */
|
|
123
|
+
.sec{margin:26px 0 12px;display:flex;align-items:center;justify-content:space-between;gap:12px}
|
|
124
|
+
.sec h2{font-size:13px;font-weight:620;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);margin:0}
|
|
125
|
+
.sec .count{font-size:12px;color:var(--faint)}
|
|
126
|
+
|
|
127
|
+
/* category cards */
|
|
128
|
+
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:12px}
|
|
129
|
+
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px;
|
|
130
|
+
box-shadow:var(--shadow);transition:.16s ease;display:flex;flex-direction:column}
|
|
131
|
+
.card:hover{border-color:var(--border-strong);transform:translateY(-2px)}
|
|
132
|
+
.card .top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:9px}
|
|
133
|
+
.card .name{font-weight:600;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
134
|
+
.card .badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;flex:none}
|
|
135
|
+
.badge.good{color:var(--good);background:var(--good-soft)}
|
|
136
|
+
.badge.warn{color:var(--warn);background:var(--warn-soft)}
|
|
137
|
+
.badge.bad{color:var(--bad);background:var(--bad-soft)}
|
|
138
|
+
.card .sum{color:var(--muted);font-size:12.5px;line-height:1.45;min-height:3.9em;
|
|
139
|
+
display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
|
|
140
|
+
.bar{height:5px;border-radius:999px;background:var(--border-strong);overflow:hidden;margin-top:11px}
|
|
141
|
+
.bar > i{display:block;height:100%;border-radius:999px;transition:width 1s cubic-bezier(.22,1,.36,1)}
|
|
142
|
+
.bar > i.good{background:var(--good)} .bar > i.warn{background:var(--warn)} .bar > i.bad{background:var(--bad)}
|
|
143
|
+
.card .foot{display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:11.5px;color:var(--faint)}
|
|
144
|
+
|
|
145
|
+
/* toolbar */
|
|
146
|
+
.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}
|
|
147
|
+
.search{flex:1;min-width:180px;position:relative}
|
|
148
|
+
.search input{width:100%;font-family:inherit;font-size:13px;color:var(--text);background:var(--surface);
|
|
149
|
+
border:1px solid var(--border-strong);border-radius:9px;padding:8px 11px 8px 32px}
|
|
150
|
+
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
|
|
151
|
+
.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--faint)}
|
|
152
|
+
.filter{display:flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:3px}
|
|
153
|
+
.filter button{appearance:none;font-family:inherit;font-size:12px;font-weight:550;color:var(--muted);
|
|
154
|
+
background:transparent;border:0;border-radius:6px;padding:5px 10px;cursor:pointer;transition:.14s}
|
|
155
|
+
.filter button[aria-pressed="true"]{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}
|
|
156
|
+
.filter button:hover{color:var(--text)}
|
|
157
|
+
|
|
158
|
+
/* table */
|
|
159
|
+
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
|
|
160
|
+
box-shadow:var(--shadow);overflow:hidden}
|
|
161
|
+
table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}
|
|
162
|
+
thead th:nth-child(1),tbody td:nth-child(1){width:96px}
|
|
163
|
+
thead th:nth-child(3),tbody td:nth-child(3){width:120px}
|
|
164
|
+
thead th:nth-child(4),tbody td:nth-child(4){width:160px}
|
|
165
|
+
thead th{text-align:left;font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
|
|
166
|
+
color:var(--faint);padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;white-space:nowrap}
|
|
167
|
+
thead th .arr{opacity:.4;font-size:9px;margin-left:3px}
|
|
168
|
+
thead th[aria-sort] .arr{opacity:1;color:var(--accent)}
|
|
169
|
+
tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
|
|
170
|
+
tbody tr:last-child{border-bottom:0}
|
|
171
|
+
tbody tr:hover{background:var(--surface-2)}
|
|
172
|
+
tbody td{padding:11px 16px;vertical-align:top}
|
|
173
|
+
.sev{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px;white-space:nowrap}
|
|
174
|
+
.sev .pip{width:7px;height:7px;border-radius:999px;flex:none}
|
|
175
|
+
.sev.critical{color:var(--sev-critical)} .sev.critical .pip{background:var(--sev-critical)}
|
|
176
|
+
.sev.high{color:var(--sev-high)} .sev.high .pip{background:var(--sev-high)}
|
|
177
|
+
.sev.medium{color:var(--sev-medium)} .sev.medium .pip{background:var(--sev-medium)}
|
|
178
|
+
.sev.low{color:var(--sev-low)} .sev.low .pip{background:var(--sev-low)}
|
|
179
|
+
.cell-title{font-weight:550;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}
|
|
180
|
+
.cell-file{font-family:var(--mono);font-size:11.5px;color:var(--muted);overflow-wrap:anywhere;word-break:normal;max-width:200px}
|
|
181
|
+
.tag{font-size:11px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);
|
|
182
|
+
border-radius:6px;padding:2px 7px;white-space:nowrap}
|
|
183
|
+
.empty{padding:40px 16px;text-align:center;color:var(--muted)}
|
|
184
|
+
.empty .big{font-size:15px;color:var(--text);font-weight:600;margin-bottom:4px}
|
|
185
|
+
|
|
186
|
+
/* drawer */
|
|
187
|
+
.scrim{position:fixed;inset:0;background:rgba(10,11,13,.42);opacity:0;pointer-events:none;transition:.2s;z-index:40}
|
|
188
|
+
.scrim.open{opacity:1;pointer-events:auto}
|
|
189
|
+
.drawer{position:fixed;top:0;right:0;height:100%;width:min(440px,92vw);background:var(--surface);
|
|
190
|
+
border-left:1px solid var(--border);box-shadow:-24px 0 60px -30px rgba(0,0,0,.5);
|
|
191
|
+
transform:translateX(100%);transition:transform .26s cubic-bezier(.22,1,.36,1);z-index:50;
|
|
192
|
+
display:flex;flex-direction:column}
|
|
193
|
+
.drawer.open{transform:translateX(0)}
|
|
194
|
+
.drawer header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
|
|
195
|
+
padding:20px 22px 16px;border-bottom:1px solid var(--border)}
|
|
196
|
+
.drawer header h3{margin:0;font-size:16px;font-weight:640;letter-spacing:-.01em;line-height:1.35}
|
|
197
|
+
.drawer .body{padding:18px 22px;overflow-y:auto;flex:1}
|
|
198
|
+
.drawer .field{margin-bottom:16px}
|
|
199
|
+
.drawer .field .k{font-size:11px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--faint);margin-bottom:5px}
|
|
200
|
+
.drawer .field .v{font-size:13.5px;color:var(--text)}
|
|
201
|
+
.drawer .field .v.mono{font-family:var(--mono);font-size:12px;color:var(--muted);word-break:break-all}
|
|
202
|
+
.drawer .acts{padding:16px 22px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px}
|
|
203
|
+
.kv{display:flex;gap:8px;flex-wrap:wrap}
|
|
204
|
+
.kv .pair{font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:4px 9px}
|
|
205
|
+
.kv .pair b{color:var(--text);font-weight:600}
|
|
206
|
+
|
|
207
|
+
/* fix-first */
|
|
208
|
+
.queue{display:flex;flex-direction:column;gap:8px}
|
|
209
|
+
.qitem{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);
|
|
210
|
+
border-radius:var(--radius-sm);padding:11px 14px;box-shadow:var(--shadow);cursor:pointer;transition:.14s}
|
|
211
|
+
.qitem:hover{border-color:var(--accent);transform:translateX(2px)}
|
|
212
|
+
.qitem .rank{width:22px;height:22px;border-radius:7px;background:var(--accent-soft);color:var(--accent);
|
|
213
|
+
font-size:12px;font-weight:680;display:grid;place-items:center;flex:none}
|
|
214
|
+
.qitem .qt{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
|
|
215
|
+
.qitem .qt .t{display:block;font-weight:550;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
216
|
+
.qitem .qt .s{display:block;font-size:11.5px;color:var(--faint)}
|
|
217
|
+
|
|
218
|
+
/* toast */
|
|
219
|
+
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
|
|
220
|
+
background:var(--text);color:var(--bg);font-size:13px;font-weight:550;padding:10px 16px;border-radius:10px;
|
|
221
|
+
box-shadow:var(--shadow);transition:.22s;z-index:60;pointer-events:none;max-width:90vw}
|
|
222
|
+
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
|
|
223
|
+
|
|
224
|
+
.foot-note{margin-top:34px;text-align:center;font-size:11.5px;color:var(--faint)}
|
|
225
|
+
.foot-note a{color:var(--muted)}
|
|
226
|
+
|
|
227
|
+
@media (max-width:560px){
|
|
228
|
+
.hero{grid-template-columns:1fr;justify-items:center;text-align:center}
|
|
229
|
+
.hero-meta{text-align:center}.chips{justify-content:center}.grade-row{justify-content:center}
|
|
230
|
+
}
|
|
231
|
+
/* result view */
|
|
232
|
+
.result-hero{display:flex;align-items:center;gap:18px;flex-wrap:wrap;
|
|
233
|
+
background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
|
|
234
|
+
padding:22px 26px;box-shadow:var(--shadow);margin-bottom:18px}
|
|
235
|
+
.result-hero .glyph{width:52px;height:52px;border-radius:14px;background:var(--accent-soft);color:var(--accent);
|
|
236
|
+
display:grid;place-items:center;flex:none;border:1px solid var(--border)}
|
|
237
|
+
.result-hero .rh-main{min-width:0;flex:1}
|
|
238
|
+
.result-hero .rh-title{font-size:20px;font-weight:660;letter-spacing:-.02em;line-height:1.2}
|
|
239
|
+
.result-hero .rh-sub{color:var(--muted);font-size:13px;margin-top:3px}
|
|
240
|
+
.status-pill{font-size:12px;font-weight:650;padding:4px 10px;border-radius:999px;white-space:nowrap}
|
|
241
|
+
.status-pill.good{color:var(--good);background:var(--good-soft)}
|
|
242
|
+
.status-pill.warn{color:var(--warn);background:var(--warn-soft)}
|
|
243
|
+
.status-pill.bad{color:var(--bad);background:var(--bad-soft)}
|
|
244
|
+
.result-hero .chips{margin-top:0}
|
|
245
|
+
|
|
246
|
+
.changes{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
|
|
247
|
+
.change-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background .12s}
|
|
248
|
+
.change-row:last-child{border-bottom:0}
|
|
249
|
+
.change-row.clickable{cursor:pointer}
|
|
250
|
+
.change-row.clickable:hover{background:var(--surface-2)}
|
|
251
|
+
.kind{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:6px;flex:none;width:74px;text-align:center}
|
|
252
|
+
.kind.created{color:var(--good);background:var(--good-soft)}
|
|
253
|
+
.kind.modified{color:var(--warn);background:var(--warn-soft)}
|
|
254
|
+
.kind.deleted{color:var(--bad);background:var(--bad-soft)}
|
|
255
|
+
.kind.renamed{color:var(--sev-low);background:var(--sev-low-soft)}
|
|
256
|
+
.change-main{flex:1;min-width:0}
|
|
257
|
+
.change-path{font-family:var(--mono);font-size:12.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
258
|
+
.change-sum{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
|
|
259
|
+
.change-delta{font-family:var(--mono);font-size:11.5px;flex:none;white-space:nowrap}
|
|
260
|
+
.change-delta .add{color:var(--good)} .change-delta .del{color:var(--bad)}
|
|
261
|
+
|
|
262
|
+
.section{margin-top:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
|
|
263
|
+
.section-item{display:flex;align-items:flex-start;gap:10px;padding:11px 16px;border-bottom:1px solid var(--border)}
|
|
264
|
+
.section-item:last-child{border-bottom:0}
|
|
265
|
+
.section-item .ip{width:7px;height:7px;border-radius:999px;margin-top:6px;flex:none;background:var(--faint)}
|
|
266
|
+
.section-item .ip.ok{background:var(--good)} .section-item .ip.warn{background:var(--warn)} .section-item .ip.error{background:var(--bad)}
|
|
267
|
+
.section-item .it{font-size:13px;font-weight:550}
|
|
268
|
+
.section-item .id{font-size:12px;color:var(--muted)}
|
|
269
|
+
.next-steps{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
|
|
270
|
+
.diff{font-family:var(--mono);font-size:12px;line-height:1.55;white-space:pre-wrap;word-break:break-word;
|
|
271
|
+
background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}
|
|
272
|
+
.diff .dl-add{color:var(--good)} .diff .dl-del{color:var(--bad)} .diff .dl-ctx{color:var(--muted)}
|
|
273
|
+
|
|
274
|
+
@media (prefers-reduced-motion:reduce){
|
|
275
|
+
*{transition:none!important;animation:none!important}
|
|
276
|
+
}
|
|
277
|
+
</style>
|
|
278
|
+
</head>
|
|
279
|
+
<body>
|
|
280
|
+
<div class="wrap">
|
|
281
|
+
|
|
282
|
+
<header class="hdr">
|
|
283
|
+
<div class="brand">
|
|
284
|
+
<span class="dot" aria-hidden="true">
|
|
285
|
+
<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M22 12h-4l-3 9L9 3l-3 9H2"/></svg>
|
|
286
|
+
</span>
|
|
287
|
+
<div style="min-width:0">
|
|
288
|
+
<h1>Component Factory</h1>
|
|
289
|
+
<p class="sub">@repo/ui</p>
|
|
290
|
+
</div>
|
|
291
|
+
</div>
|
|
292
|
+
<div class="hdr-actions">
|
|
293
|
+
<button class="btn icon" id="theme-toggle" type="button" aria-label="Toggle colour theme" title="Toggle theme">
|
|
294
|
+
<span class="theme-sun" hidden><svg width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"><circle cx="12" cy="12" r="4"/><path d="M12 2v2M12 20v2M4.9 4.9l1.4 1.4M17.7 17.7l1.4 1.4M2 12h2M20 12h2M4.9 19.1l1.4-1.4M17.7 6.3l1.4-1.4"/></svg></span><span class="theme-moon"><svg width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 12.8A9 9 0 1 1 11.2 3a7 7 0 0 0 9.8 9.8z"/></svg></span>
|
|
295
|
+
</button>
|
|
296
|
+
<button class="btn" id="export-btn" type="button" title="Copy summary as Markdown">
|
|
297
|
+
<svg width="13" height="13" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"/><path d="M7 10l5 5 5-5"/><path d="M12 15V3"/></svg>
|
|
298
|
+
Export
|
|
299
|
+
</button>
|
|
300
|
+
</div>
|
|
301
|
+
</header>
|
|
302
|
+
|
|
303
|
+
<section class="result-hero" data-band="good">
|
|
304
|
+
<span class="glyph" aria-hidden="true">
|
|
305
|
+
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M20 6 9 17l-5-5"/></svg>
|
|
306
|
+
</span>
|
|
307
|
+
<div class="rh-main">
|
|
308
|
+
<div class="rh-title">Created 3 files for Button</div>
|
|
309
|
+
<div class="rh-sub">shadcn/ui · Button</div>
|
|
310
|
+
<div class="chips" style="margin-top:10px"><span class="chip"><span>Created</span><b>3</b></span><span class="chip"><span>Template</span><b>shadcn/ui</b></span><span class="chip"><span>Variants</span><b>6</b></span></div>
|
|
311
|
+
</div>
|
|
312
|
+
<span class="status-pill good">Success</span>
|
|
313
|
+
</section>
|
|
314
|
+
|
|
315
|
+
<div class="sec"><h2>Next steps</h2></div>
|
|
316
|
+
<div class="next-steps"><button class="btn primary" type="button" data-action="review">Review the component</button><button class="btn" type="button" data-action="story">Generate more stories</button><button class="btn" type="button" data-action="barrel">Update barrel export</button></div>
|
|
317
|
+
|
|
318
|
+
<div class="sec"><h2>Changes</h2><span class="count">3 files</span></div>
|
|
319
|
+
<div class="changes">
|
|
320
|
+
<div class="change-row clickable" data-change="0" role="button" tabindex="0">
|
|
321
|
+
<span class="kind created">created</span>
|
|
322
|
+
<span class="change-main">
|
|
323
|
+
<span class="change-path">src/components/Button/Button.tsx</span>
|
|
324
|
+
<span class="change-sum">Component with 6 variants + 4 sizes</span>
|
|
325
|
+
</span>
|
|
326
|
+
<span class="change-delta"><span class="add">+84</span> </span>
|
|
327
|
+
</div>
|
|
328
|
+
<div class="change-row " >
|
|
329
|
+
<span class="kind created">created</span>
|
|
330
|
+
<span class="change-main">
|
|
331
|
+
<span class="change-path">src/components/Button/Button.test.tsx</span>
|
|
332
|
+
<span class="change-sum">Vitest + RTL suite, 8 cases</span>
|
|
333
|
+
</span>
|
|
334
|
+
<span class="change-delta"><span class="add">+52</span> </span>
|
|
335
|
+
</div>
|
|
336
|
+
<div class="change-row " >
|
|
337
|
+
<span class="kind created">created</span>
|
|
338
|
+
<span class="change-main">
|
|
339
|
+
<span class="change-path">src/components/Button/Button.stories.tsx</span>
|
|
340
|
+
<span class="change-sum">Storybook stories: Default, variants, sizes</span>
|
|
341
|
+
</span>
|
|
342
|
+
<span class="change-delta"><span class="add">+39</span> </span>
|
|
343
|
+
</div></div>
|
|
344
|
+
|
|
345
|
+
<div class="sec"><h2>Steps</h2><span class="count">4</span></div>
|
|
346
|
+
<div class="section">
|
|
347
|
+
<div class="section-item">
|
|
348
|
+
<span class="ip ok"></span>
|
|
349
|
+
<div style="min-width:0"><div class="it">Resolved shadcn/ui Button template</div></div>
|
|
350
|
+
</div>
|
|
351
|
+
<div class="section-item">
|
|
352
|
+
<span class="ip ok"></span>
|
|
353
|
+
<div style="min-width:0"><div class="it">Generated variants with CVA</div></div>
|
|
354
|
+
</div>
|
|
355
|
+
<div class="section-item">
|
|
356
|
+
<span class="ip ok"></span>
|
|
357
|
+
<div style="min-width:0"><div class="it">Wrote tests + stories</div></div>
|
|
358
|
+
</div>
|
|
359
|
+
<div class="section-item">
|
|
360
|
+
<span class="ip warn"></span>
|
|
361
|
+
<div style="min-width:0"><div class="it">Skipped: index barrel not updated</div><div class="id">Add `export * from './Button'` to src/components/index.ts</div></div>
|
|
362
|
+
</div></div>
|
|
363
|
+
<div class="foot-note">component-factory · generated 2026-06-27 · mcp-react-toolkit</div>
|
|
364
|
+
</div>
|
|
365
|
+
|
|
366
|
+
<div class="scrim" id="scrim"></div>
|
|
367
|
+
<aside class="drawer" id="drawer" role="dialog" aria-modal="true" aria-labelledby="d-title">
|
|
368
|
+
<header>
|
|
369
|
+
<h3 id="d-title"></h3>
|
|
370
|
+
<button class="btn icon" id="d-close" type="button" aria-label="Close detail">
|
|
371
|
+
<svg width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"><path d="M18 6 6 18M6 6l12 12"/></svg>
|
|
372
|
+
</button>
|
|
373
|
+
</header>
|
|
374
|
+
<div class="body" id="d-body"></div>
|
|
375
|
+
<div class="acts" id="d-acts"></div>
|
|
376
|
+
</aside>
|
|
377
|
+
<div class="toast" id="toast" role="status" aria-live="polite"></div>
|
|
378
|
+
<script id="report-data" type="application/json">{"meta":{"title":"Component Factory","subtitle":"shadcn/ui · Button","target":"@repo/ui","generatedAt":"2026-06-27","tool":"component-factory"},"headline":"Created 3 files for Button","status":"success","stats":[{"label":"Created","value":"3"},{"label":"Template","value":"shadcn/ui"},{"label":"Variants","value":"6"}],"changes":[{"path":"src/components/Button/Button.tsx","kind":"created","summary":"Component with 6 variants + 4 sizes","additions":84,"language":"tsx","diff":"+ import { cva } from 'class-variance-authority';\n+ export const Button = ({ variant, size, ...props }) => {\n+ return \u003cbutton className={cn(buttonVariants({ variant, size }))} {...props} />;\n+ };"},{"path":"src/components/Button/Button.test.tsx","kind":"created","summary":"Vitest + RTL suite, 8 cases","additions":52,"language":"tsx"},{"path":"src/components/Button/Button.stories.tsx","kind":"created","summary":"Storybook stories: Default, variants, sizes","additions":39,"language":"tsx"}],"sections":[{"title":"Steps","items":[{"title":"Resolved shadcn/ui Button template","status":"ok"},{"title":"Generated variants with CVA","status":"ok"},{"title":"Wrote tests + stories","status":"ok"},{"title":"Skipped: index barrel not updated","detail":"Add `export * from './Button'` to src/components/index.ts","status":"warn"}]}],"nextActions":[{"id":"review","label":"Review the component","kind":"tool","tool":"component-reviewer","params":{"path":"src/components/Button/Button.tsx"},"fallback":"Review src/components/Button/Button.tsx."},{"id":"story","label":"Generate more stories","kind":"tool","tool":"storybook-generator","params":{"path":"src/components/Button/Button.tsx"},"fallback":"Generate Storybook stories for Button."},{"id":"barrel","label":"Update barrel export","kind":"prompt","prompt":"Add `export * from './Button'` to src/components/index.ts"}]}</script>
|
|
379
|
+
<script>(function(){
|
|
380
|
+
"use strict";
|
|
381
|
+
function readEmbedded(){ var el=document.getElementById('report-data'); if(!el) return null;
|
|
382
|
+
try{ return JSON.parse(el.textContent||'null'); }catch(e){ return null; } }
|
|
383
|
+
function readUrl(){ try{ var p=new URLSearchParams(location.search).get('data'); if(!p) return null;
|
|
384
|
+
var bytes=Uint8Array.from(atob(p), function(c){ return c.charCodeAt(0); });
|
|
385
|
+
return JSON.parse(new TextDecoder().decode(bytes)); }catch(e){ return null; } }
|
|
386
|
+
var DATA = window.__REPORT__ || readEmbedded() || readUrl();
|
|
387
|
+
if(!DATA){ return; }
|
|
388
|
+
var EMBEDDED=false; try{ EMBEDDED = window.self !== window.top; }catch(e){ EMBEDDED=true; }
|
|
389
|
+
var HOST_ORIGIN = window.__MCP_HOST_ORIGIN__ || '*';
|
|
390
|
+
var root=document.documentElement, lastFocus=null;
|
|
391
|
+
function E(s){ return String(s==null?'':s).replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>').replace(/"/g,'"').replace(/'/g,'''); }
|
|
392
|
+
function $(id){ return document.getElementById(id); }
|
|
393
|
+
|
|
394
|
+
// theme
|
|
395
|
+
function store(k,v){ try{ if(v==null) return localStorage.getItem(k); localStorage.setItem(k,v); }catch(e){ return null; } }
|
|
396
|
+
function applyTheme(t){ root.setAttribute('data-theme',t);
|
|
397
|
+
var sun=document.querySelector('.theme-sun'), moon=document.querySelector('.theme-moon');
|
|
398
|
+
if(sun&&moon){ sun.hidden=t!=='dark'; moon.hidden=t==='dark'; } }
|
|
399
|
+
var prefersDark = window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
|
|
400
|
+
applyTheme(store('mcp-ui-theme') || (prefersDark?'dark':'light'));
|
|
401
|
+
var tt=$('theme-toggle'); if(tt) tt.addEventListener('click', function(){
|
|
402
|
+
var n=root.getAttribute('data-theme')==='dark'?'light':'dark'; applyTheme(n); store('mcp-ui-theme',n); });
|
|
403
|
+
|
|
404
|
+
root.setAttribute('data-band', DATA.status==='partial'?'warn':'good');
|
|
405
|
+
|
|
406
|
+
// actions
|
|
407
|
+
var actionsById={}; (DATA.nextActions||[]).forEach(function(a){ actionsById[a.id]=a; });
|
|
408
|
+
function copy(text){ try{ if(navigator.clipboard&&navigator.clipboard.writeText) return navigator.clipboard.writeText(text); }catch(e){}
|
|
409
|
+
try{ var t=document.createElement('textarea'); t.value=text; document.body.appendChild(t); t.select(); document.execCommand('copy'); document.body.removeChild(t); }catch(e){} }
|
|
410
|
+
var toastTimer; function toast(msg){ var el=$('toast'); if(!el) return; el.textContent=msg; el.classList.add('show');
|
|
411
|
+
clearTimeout(toastTimer); toastTimer=setTimeout(function(){ el.classList.remove('show'); },2600); }
|
|
412
|
+
function runAction(id){ var a=actionsById[id]; if(!a) return;
|
|
413
|
+
if(a.kind==='link'){ if(!/^https?:\/\//i.test(a.href||'')){ toast('Unsafe link blocked'); return; } window.open(a.href,'_blank','noopener'); return; }
|
|
414
|
+
if(EMBEDDED){ var msg = a.kind==='tool' ? { type:'tool', messageId:'mcp-ui-'+Date.now(), payload:{ toolName:a.tool, params:a.params||{} } } : { type:'prompt', messageId:'mcp-ui-'+Date.now(), payload:{ prompt:a.prompt } };
|
|
415
|
+
try{ window.parent.postMessage(msg,HOST_ORIGIN); toast(a.kind==='tool'?('Running '+a.tool+' …'):'Sent to agent ✓'); return; }catch(e){} }
|
|
416
|
+
var text = a.kind==='tool' ? (a.fallback||('Run '+a.tool)) : (a.prompt||a.fallback||a.label); copy(text); toast('Copied — paste into your agent'); }
|
|
417
|
+
document.addEventListener('click', function(e){ var el=e.target.closest && e.target.closest('[data-action]');
|
|
418
|
+
if(el){ e.preventDefault(); runAction(el.getAttribute('data-action')); } });
|
|
419
|
+
|
|
420
|
+
// change diff drawer
|
|
421
|
+
var drawer=$('drawer'), scrim=$('scrim');
|
|
422
|
+
function renderDiff(diff){ return diff.split('\n').map(function(l){
|
|
423
|
+
var c = l.charAt(0)==='+' ? 'dl-add' : l.charAt(0)==='-' ? 'dl-del' : 'dl-ctx'; return '<span class="'+c+'">'+E(l)+'</span>'; }).join('\n'); }
|
|
424
|
+
function openChange(i){ var c=(DATA.changes||[])[i]; if(!c||!c.diff) return; lastFocus=document.activeElement;
|
|
425
|
+
$('d-title').textContent=c.path;
|
|
426
|
+
$('d-body').innerHTML='<div class="kv" style="margin-bottom:14px"><span class="pair"><b>'+E(c.kind)+'</b></span>'+(c.language?'<span class="pair">'+E(c.language)+'</span>':'')+'</div><div class="diff">'+renderDiff(c.diff)+'</div>';
|
|
427
|
+
$('d-acts').innerHTML='';
|
|
428
|
+
drawer.classList.add('open'); scrim.classList.add('open'); var dc=$('d-close'); if(dc) dc.focus(); }
|
|
429
|
+
function closeDrawer(){ drawer.classList.remove('open'); scrim.classList.remove('open'); if(lastFocus&&lastFocus.focus){ lastFocus.focus(); lastFocus=null; } }
|
|
430
|
+
document.addEventListener('click', function(e){ var r=e.target.closest && e.target.closest('.change-row[data-change]'); if(r) openChange(parseInt(r.getAttribute('data-change'),10)); });
|
|
431
|
+
document.addEventListener('keydown', function(e){ if((e.key==='Enter'||e.key===' ')){ var r=e.target.closest && e.target.closest('.change-row[data-change]'); if(r){ e.preventDefault(); openChange(parseInt(r.getAttribute('data-change'),10)); } } });
|
|
432
|
+
if(scrim) scrim.addEventListener('click', closeDrawer);
|
|
433
|
+
var dcl=$('d-close'); if(dcl) dcl.addEventListener('click', closeDrawer);
|
|
434
|
+
document.addEventListener('keydown', function(e){ if(e.key==='Escape') closeDrawer(); });
|
|
435
|
+
|
|
436
|
+
// export
|
|
437
|
+
var ex=$('export-btn'); function md(s){ return String(s==null?'':s).replace(/[\r\n]+/g,' '); }
|
|
438
|
+
if(ex) ex.addEventListener('click', function(){ var L=[]; L.push('# '+md(DATA.meta.title)); L.push('');
|
|
439
|
+
L.push('**'+md(DATA.headline)+'** ('+DATA.status+') '); L.push('**Target:** '+md(DATA.meta.target)); L.push('');
|
|
440
|
+
if((DATA.changes||[]).length){ L.push('## Changes'); (DATA.changes||[]).forEach(function(c){ L.push('- ['+c.kind.toUpperCase()+'] '+md(c.path)+(c.summary?(' — '+md(c.summary)):'')); }); L.push(''); }
|
|
441
|
+
(DATA.sections||[]).forEach(function(s){ L.push('## '+md(s.title)); s.items.forEach(function(it){ L.push('- '+md(it.title)+(it.detail?(' — '+md(it.detail)):'')); }); L.push(''); });
|
|
442
|
+
copy(L.join('\n')); toast('Summary copied as Markdown ✓'); });
|
|
443
|
+
})();</script>
|
|
444
|
+
</body>
|
|
445
|
+
</html>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@mcp-showcase/ui-kit",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"description": "Reusable single-file HTML report UI for MCP tools — dependency-free, dual-theme, agentic. Flagship: Codebase Health Studio.",
|
|
6
|
+
"main": "./build/index.js",
|
|
7
|
+
"types": "./build/index.d.ts",
|
|
8
|
+
"scripts": {
|
|
9
|
+
"build": "tsc && node build/generate-template.js",
|
|
10
|
+
"dev": "tsc --watch",
|
|
11
|
+
"test": "vitest run"
|
|
12
|
+
},
|
|
13
|
+
"devDependencies": {
|
|
14
|
+
"@types/node": "^20.0.0",
|
|
15
|
+
"jsdom": "^29.1.1",
|
|
16
|
+
"typescript": "^5.0.0",
|
|
17
|
+
"vitest": "^2.0.0"
|
|
18
|
+
}
|
|
19
|
+
}
|