@tuongaz/seeflow 0.1.75 → 0.1.76
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/web/assets/{architectureDiagram-3BPJPVTR-BE013nUd.js → architectureDiagram-3BPJPVTR-CVOsL8en.js} +1 -1
- package/dist/web/assets/{blockDiagram-GPEHLZMM-Dp6be3Ms.js → blockDiagram-GPEHLZMM-C4ln3pHP.js} +1 -1
- package/dist/web/assets/{c4Diagram-AAUBKEIU-DaXH8gyS.js → c4Diagram-AAUBKEIU-COBq_O0m.js} +1 -1
- package/dist/web/assets/channel-BpDUSI6-.js +1 -0
- package/dist/web/assets/{chart-CTfwAwIW.js → chart-DD5RfLtm.js} +1 -1
- package/dist/web/assets/{chunk-2J33WTMH-DBOxtwXe.js → chunk-2J33WTMH-Bdm-YMMv.js} +1 -1
- package/dist/web/assets/{chunk-4BX2VUAB-BkqIaZzX.js → chunk-4BX2VUAB-BV9NRSCp.js} +1 -1
- package/dist/web/assets/{chunk-55IACEB6-Bf2GGBjw.js → chunk-55IACEB6-D-Xe7eUY.js} +1 -1
- package/dist/web/assets/{chunk-727SXJPM-DT7H_Ach.js → chunk-727SXJPM-DB6EZ4tw.js} +1 -1
- package/dist/web/assets/{chunk-AQP2D5EJ-VrM-sHKP.js → chunk-AQP2D5EJ-DDlp8cdl.js} +1 -1
- package/dist/web/assets/{chunk-FMBD7UC4-Cl6A8JUa.js → chunk-FMBD7UC4-qmkSV1r1.js} +1 -1
- package/dist/web/assets/{chunk-ND2GUHAM-LRV96SE3.js → chunk-ND2GUHAM-BFkM9OZ5.js} +1 -1
- package/dist/web/assets/{chunk-QZHKN3VN-Dj5_UVo9.js → chunk-QZHKN3VN-Cye5hUth.js} +1 -1
- package/dist/web/assets/classDiagram-4FO5ZUOK-po1qHJgX.js +1 -0
- package/dist/web/assets/classDiagram-v2-Q7XG4LA2-po1qHJgX.js +1 -0
- package/dist/web/assets/{code-block-Be3Lawg0.js → code-block-B2Jj4pwe.js} +1 -1
- package/dist/web/assets/{cose-bilkent-S5V4N54A-4_XIQLKW.js → cose-bilkent-S5V4N54A-B8Q15-m-.js} +1 -1
- package/dist/web/assets/{dagre-BM42HDAG-Csr5BSLw.js → dagre-BM42HDAG-BEYccL0v.js} +1 -1
- package/dist/web/assets/{diagram-2AECGRRQ-D9cawnSD.js → diagram-2AECGRRQ-BHPvhIzV.js} +1 -1
- package/dist/web/assets/{diagram-5GNKFQAL-Ba9mTl4r.js → diagram-5GNKFQAL-Csqbxt3l.js} +1 -1
- package/dist/web/assets/{diagram-KO2AKTUF-D_gNaP7M.js → diagram-KO2AKTUF-BR6CIJyT.js} +1 -1
- package/dist/web/assets/{diagram-LMA3HP47-BwPi3QWV.js → diagram-LMA3HP47-CNtClLgB.js} +1 -1
- package/dist/web/assets/{diagram-OG6HWLK6-C2iDWN55.js → diagram-OG6HWLK6-6C-uLOFp.js} +1 -1
- package/dist/web/assets/{erDiagram-TEJ5UH35-MBy10Qfr.js → erDiagram-TEJ5UH35-WbZOwkSY.js} +1 -1
- package/dist/web/assets/{flowDiagram-I6XJVG4X-CgVoK-B7.js → flowDiagram-I6XJVG4X-DkXzWb1H.js} +1 -1
- package/dist/web/assets/{ganttDiagram-6RSMTGT7-DZZ43-Du.js → ganttDiagram-6RSMTGT7-CUvI4hDd.js} +1 -1
- package/dist/web/assets/{gitGraphDiagram-PVQCEYII-BwYPxvng.js → gitGraphDiagram-PVQCEYII-DQ5Z5DTr.js} +1 -1
- package/dist/web/assets/{index-DrmDilPO.js → index-DJa2Qm_q.js} +5 -5
- package/dist/web/assets/{index.es-DpqYSimZ.js → index.es-DU_7oRoK.js} +1 -1
- package/dist/web/assets/{infoDiagram-5YYISTIA-j7zbBRny.js → infoDiagram-5YYISTIA-CVl3bX4h.js} +1 -1
- package/dist/web/assets/{ishikawaDiagram-YF4QCWOH-DAp6W4Gj.js → ishikawaDiagram-YF4QCWOH-CQs9MZtd.js} +1 -1
- package/dist/web/assets/{journeyDiagram-JHISSGLW-Dde2JSR2.js → journeyDiagram-JHISSGLW-B9emRTSL.js} +1 -1
- package/dist/web/assets/{jspdf.es.min-tC6T-F7r.js → jspdf.es.min-DO9eBtyx.js} +3 -3
- package/dist/web/assets/{kanban-definition-UN3LZRKU-os60zjrz.js → kanban-definition-UN3LZRKU-CU4PXBkO.js} +1 -1
- package/dist/web/assets/{linear-f3DePitM.js → linear-Djd98ym6.js} +1 -1
- package/dist/web/assets/{markdown-Feo1eGLy.js → markdown-Dtbihta2.js} +1 -1
- package/dist/web/assets/{mermaid.core-DoXF1I4r.js → mermaid.core--5B4uu7H.js} +4 -4
- package/dist/web/assets/{mindmap-definition-RKZ34NQL-D6K4uyrn.js → mindmap-definition-RKZ34NQL-DBa-qOvW.js} +1 -1
- package/dist/web/assets/{pieDiagram-4H26LBE5-C4UX0DPX.js → pieDiagram-4H26LBE5-BgO03eBD.js} +1 -1
- package/dist/web/assets/{quadrantDiagram-W4KKPZXB-iSE2IF5i.js → quadrantDiagram-W4KKPZXB-D5qnQqxO.js} +1 -1
- package/dist/web/assets/{requirementDiagram-4Y6WPE33-D_lHCX3z.js → requirementDiagram-4Y6WPE33-CvFTU_QP.js} +1 -1
- package/dist/web/assets/{sankeyDiagram-5OEKKPKP-B0-DYq8M.js → sankeyDiagram-5OEKKPKP-BSwt6J0r.js} +1 -1
- package/dist/web/assets/{sequenceDiagram-3UESZ5HK-BQM0i8wy.js → sequenceDiagram-3UESZ5HK-B6xwt7gx.js} +1 -1
- package/dist/web/assets/{stateDiagram-AJRCARHV-DD0djwwD.js → stateDiagram-AJRCARHV-B4aBLe9A.js} +1 -1
- package/dist/web/assets/stateDiagram-v2-BHNVJYJU-D1iGL3Mj.js +1 -0
- package/dist/web/assets/{time-BczydnL9.js → time-VmDaOXzG.js} +1 -1
- package/dist/web/assets/{timeline-definition-PNZ67QCA-BjCNA-ke.js → timeline-definition-PNZ67QCA-Bp46ZbZu.js} +1 -1
- package/dist/web/assets/{vennDiagram-CIIHVFJN-G2L4S-_F.js → vennDiagram-CIIHVFJN-ObB0ozDF.js} +1 -1
- package/dist/web/assets/{wardley-L42UT6IY-cmE8YucU.js → wardley-L42UT6IY-DZQGppGX.js} +1 -1
- package/dist/web/assets/{wardleyDiagram-YWT4CUSO-BM_S_KMT.js → wardleyDiagram-YWT4CUSO-B3dCDfV5.js} +1 -1
- package/dist/web/assets/{xychartDiagram-2RQKCTM6-B_aQbaAw.js → xychartDiagram-2RQKCTM6-CpxmkRi4.js} +1 -1
- package/dist/web/index.html +1 -1
- package/package.json +65 -56
- package/src/schema.ts +1 -1
- package/src/vendored-canvas-catalog.ts +108 -0
- package/dist/web/assets/channel-BXI2S8ym.js +0 -1
- package/dist/web/assets/classDiagram-4FO5ZUOK-Dm1vuLfb.js +0 -1
- package/dist/web/assets/classDiagram-v2-Q7XG4LA2-Dm1vuLfb.js +0 -1
- package/dist/web/assets/stateDiagram-v2-BHNVJYJU-C-OF3f9a.js +0 -1
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
|
|
3
|
+
// `$ref` shapes accepted in any prop slot. Resolved at render time by the
|
|
4
|
+
// json-render runtime — Zod here only enforces structural shape; path /
|
|
5
|
+
// action-name validity is enforced by superRefine in apps/studio/src/schema.ts.
|
|
6
|
+
const StateRef = z.object({ $state: z.string().min(1) });
|
|
7
|
+
const ActionRef = z.object({ $action: z.string().min(1) });
|
|
8
|
+
const CondRef = z.object({
|
|
9
|
+
$cond: z.unknown(),
|
|
10
|
+
$then: z.unknown(),
|
|
11
|
+
$else: z.unknown().optional(),
|
|
12
|
+
});
|
|
13
|
+
const refOr = <T extends z.ZodTypeAny>(t: T) => z.union([t, StateRef, ActionRef, CondRef]);
|
|
14
|
+
|
|
15
|
+
const StringProp = refOr(z.string());
|
|
16
|
+
const NumberProp = refOr(z.number());
|
|
17
|
+
const BoolProp = refOr(z.boolean());
|
|
18
|
+
|
|
19
|
+
const PropsSchemas = {
|
|
20
|
+
Card: z.object({ title: StringProp.optional() }),
|
|
21
|
+
Separator: z.object({ orientation: refOr(z.enum(['horizontal', 'vertical'])).optional() }),
|
|
22
|
+
Tabs: z.object({
|
|
23
|
+
value: StringProp.optional(),
|
|
24
|
+
items: z.array(z.object({ id: z.string(), label: z.string() })),
|
|
25
|
+
onChange: ActionRef.optional(),
|
|
26
|
+
}),
|
|
27
|
+
Accordion: z.object({
|
|
28
|
+
items: z.array(z.object({ id: z.string(), title: z.string(), content: z.string() })),
|
|
29
|
+
}),
|
|
30
|
+
Badge: z.object({
|
|
31
|
+
label: StringProp,
|
|
32
|
+
variant: refOr(z.enum(['default', 'secondary', 'destructive', 'outline'])).optional(),
|
|
33
|
+
}),
|
|
34
|
+
Avatar: z.object({
|
|
35
|
+
src: StringProp.optional(),
|
|
36
|
+
alt: StringProp.optional(),
|
|
37
|
+
fallback: StringProp.optional(),
|
|
38
|
+
}),
|
|
39
|
+
Progress: z.object({ value: NumberProp }),
|
|
40
|
+
Skeleton: z.object({ width: NumberProp.optional(), height: NumberProp.optional() }),
|
|
41
|
+
Label: z.object({ text: StringProp }),
|
|
42
|
+
Heading: z.object({
|
|
43
|
+
level: refOr(z.union([z.literal(1), z.literal(2), z.literal(3), z.literal(4)])).optional(),
|
|
44
|
+
text: StringProp,
|
|
45
|
+
}),
|
|
46
|
+
Text: z.object({ text: StringProp, muted: BoolProp.optional() }),
|
|
47
|
+
Icon: z.object({ name: StringProp, size: NumberProp.optional() }),
|
|
48
|
+
Chart: z.object({
|
|
49
|
+
kind: refOr(z.enum(['bar', 'line', 'area', 'pie'])),
|
|
50
|
+
data: refOr(z.array(z.record(z.string(), z.unknown()))),
|
|
51
|
+
xKey: StringProp.optional(),
|
|
52
|
+
series: z.array(z.object({ key: z.string(), label: z.string().optional() })).optional(),
|
|
53
|
+
}),
|
|
54
|
+
Table: z.object({
|
|
55
|
+
columns: z.array(z.object({ key: z.string(), label: z.string() })),
|
|
56
|
+
rows: refOr(z.array(z.record(z.string(), z.unknown()))),
|
|
57
|
+
}),
|
|
58
|
+
Metric: z.object({ label: StringProp, value: refOr(z.union([z.string(), z.number()])) }),
|
|
59
|
+
CodeBlock: z.object({ code: StringProp, language: StringProp.optional() }),
|
|
60
|
+
Markdown: z.object({ content: StringProp }),
|
|
61
|
+
Button: z.object({
|
|
62
|
+
label: StringProp,
|
|
63
|
+
variant: refOr(
|
|
64
|
+
z.enum(['default', 'destructive', 'outline', 'secondary', 'ghost', 'link']),
|
|
65
|
+
).optional(),
|
|
66
|
+
onClick: ActionRef.optional(),
|
|
67
|
+
disabled: BoolProp.optional(),
|
|
68
|
+
}),
|
|
69
|
+
Input: z.object({
|
|
70
|
+
value: StringProp.optional(),
|
|
71
|
+
placeholder: StringProp.optional(),
|
|
72
|
+
onChange: ActionRef.optional(),
|
|
73
|
+
}),
|
|
74
|
+
Checkbox: z.object({
|
|
75
|
+
checked: BoolProp.optional(),
|
|
76
|
+
onChange: ActionRef.optional(),
|
|
77
|
+
label: StringProp.optional(),
|
|
78
|
+
}),
|
|
79
|
+
Switch: z.object({ checked: BoolProp.optional(), onChange: ActionRef.optional() }),
|
|
80
|
+
Select: z.object({
|
|
81
|
+
value: StringProp.optional(),
|
|
82
|
+
items: z.array(z.object({ value: z.string(), label: z.string() })),
|
|
83
|
+
onChange: ActionRef.optional(),
|
|
84
|
+
}),
|
|
85
|
+
Textarea: z.object({
|
|
86
|
+
value: StringProp.optional(),
|
|
87
|
+
placeholder: StringProp.optional(),
|
|
88
|
+
rows: NumberProp.optional(),
|
|
89
|
+
onChange: ActionRef.optional(),
|
|
90
|
+
}),
|
|
91
|
+
Slider: z.object({
|
|
92
|
+
value: NumberProp.optional(),
|
|
93
|
+
min: NumberProp.optional(),
|
|
94
|
+
max: NumberProp.optional(),
|
|
95
|
+
step: NumberProp.optional(),
|
|
96
|
+
onChange: ActionRef.optional(),
|
|
97
|
+
}),
|
|
98
|
+
} as const;
|
|
99
|
+
|
|
100
|
+
export const COMPONENT_NAMES = Object.keys(PropsSchemas) as Array<keyof typeof PropsSchemas>;
|
|
101
|
+
|
|
102
|
+
export const componentCatalog = {
|
|
103
|
+
components: Object.fromEntries(
|
|
104
|
+
COMPONENT_NAMES.map((name) => [name, { props: PropsSchemas[name], description: name }]),
|
|
105
|
+
) as Record<string, { props: z.ZodTypeAny; description: string }>,
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
export type ComponentName = (typeof COMPONENT_NAMES)[number];
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{U as a,C as n}from"./mermaid.core-DoXF1I4r.js";const t=(r,o)=>a.lang.round(n.parse(r)[o]);export{t as c};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{s as a,a as s,c as e,C as t}from"./chunk-727SXJPM-DT7H_Ach.js";import{a as i}from"./mermaid.core-DoXF1I4r.js";import"./index-DrmDilPO.js";import"./chunk-FMBD7UC4-Cl6A8JUa.js";import"./chunk-ND2GUHAM-LRV96SE3.js";import"./chunk-55IACEB6-Bf2GGBjw.js";import"./chunk-2J33WTMH-DBOxtwXe.js";import"./purify.es-CLGrRn1w.js";import"./step-CWvwoXpJ.js";var b={parser:e,get db(){return new t},renderer:s,styles:a,init:i(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{b as diagram};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{s as a,a as s,c as e,C as t}from"./chunk-727SXJPM-DT7H_Ach.js";import{a as i}from"./mermaid.core-DoXF1I4r.js";import"./index-DrmDilPO.js";import"./chunk-FMBD7UC4-Cl6A8JUa.js";import"./chunk-ND2GUHAM-LRV96SE3.js";import"./chunk-55IACEB6-Bf2GGBjw.js";import"./chunk-2J33WTMH-DBOxtwXe.js";import"./purify.es-CLGrRn1w.js";import"./step-CWvwoXpJ.js";var b={parser:e,get db(){return new t},renderer:s,styles:a,init:i(r=>{r.class||(r.class={}),r.class.arrowMarkerAbsolute=r.arrowMarkerAbsolute},"init")};export{b as diagram};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{b as r,a as e,s as a,S as s}from"./chunk-AQP2D5EJ-VrM-sHKP.js";import{a as i}from"./mermaid.core-DoXF1I4r.js";import"./index-DrmDilPO.js";import"./chunk-55IACEB6-Bf2GGBjw.js";import"./chunk-2J33WTMH-DBOxtwXe.js";import"./purify.es-CLGrRn1w.js";import"./step-CWvwoXpJ.js";var n={parser:a,get db(){return new s(2)},renderer:e,styles:r,init:i(t=>{t.state||(t.state={}),t.state.arrowMarkerAbsolute=t.arrowMarkerAbsolute},"init")};export{n as diagram};
|