@cere/cere-design-system 0.0.44 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/WorkflowNode-BnxXO6t_.d.mts +46 -0
- package/dist/WorkflowNode-BnxXO6t_.d.ts +46 -0
- package/dist/buttons.d.mts +114 -0
- package/dist/buttons.d.ts +114 -0
- package/dist/buttons.js +19 -0
- package/dist/buttons.js.map +1 -0
- package/dist/buttons.mjs +19 -0
- package/dist/buttons.mjs.map +1 -0
- package/dist/carousel.d.mts +51 -0
- package/dist/carousel.d.ts +51 -0
- package/dist/carousel.js +185 -0
- package/dist/carousel.js.map +1 -0
- package/dist/carousel.mjs +185 -0
- package/dist/carousel.mjs.map +1 -0
- package/dist/charts.d.mts +209 -0
- package/dist/charts.d.ts +209 -0
- package/dist/charts.js +20 -0
- package/dist/charts.js.map +1 -0
- package/dist/charts.mjs +20 -0
- package/dist/charts.mjs.map +1 -0
- package/dist/chunk-27JEWSWA.mjs +233 -0
- package/dist/chunk-27JEWSWA.mjs.map +1 -0
- package/dist/chunk-2EBCST6X.js +25 -0
- package/dist/chunk-2EBCST6X.js.map +1 -0
- package/dist/chunk-3WCMINE5.mjs +490 -0
- package/dist/chunk-3WCMINE5.mjs.map +1 -0
- package/dist/chunk-463SRKKD.js +111 -0
- package/dist/chunk-463SRKKD.js.map +1 -0
- package/dist/chunk-5ASG6G6U.mjs +40 -0
- package/dist/chunk-5ASG6G6U.mjs.map +1 -0
- package/dist/chunk-6EUAU67C.mjs +374 -0
- package/dist/chunk-6EUAU67C.mjs.map +1 -0
- package/dist/chunk-AIY6222Q.js +11 -0
- package/dist/chunk-AIY6222Q.js.map +1 -0
- package/dist/chunk-AJBM7IE6.mjs +2366 -0
- package/dist/chunk-AJBM7IE6.mjs.map +1 -0
- package/dist/chunk-ATIFLPH6.mjs +278 -0
- package/dist/chunk-ATIFLPH6.mjs.map +1 -0
- package/dist/chunk-BIZK6FUD.js +37 -0
- package/dist/chunk-BIZK6FUD.js.map +1 -0
- package/dist/chunk-CCN6M4LI.js +103 -0
- package/dist/chunk-CCN6M4LI.js.map +1 -0
- package/dist/chunk-CUCKULYC.mjs +2658 -0
- package/dist/chunk-CUCKULYC.mjs.map +1 -0
- package/dist/chunk-CWJ4OU6W.mjs +45 -0
- package/dist/chunk-CWJ4OU6W.mjs.map +1 -0
- package/dist/chunk-EOF3QNPF.js +2366 -0
- package/dist/chunk-EOF3QNPF.js.map +1 -0
- package/dist/chunk-FFZ5S7PQ.mjs +146 -0
- package/dist/chunk-FFZ5S7PQ.mjs.map +1 -0
- package/dist/chunk-FN5YL4BK.js +278 -0
- package/dist/chunk-FN5YL4BK.js.map +1 -0
- package/dist/chunk-HLH2VWXL.js +2658 -0
- package/dist/chunk-HLH2VWXL.js.map +1 -0
- package/dist/chunk-IE6GCHDI.mjs +530 -0
- package/dist/chunk-IE6GCHDI.mjs.map +1 -0
- package/dist/chunk-JBHRAAN3.js +31 -0
- package/dist/chunk-JBHRAAN3.js.map +1 -0
- package/dist/chunk-JS4IB5IU.mjs +162 -0
- package/dist/chunk-JS4IB5IU.mjs.map +1 -0
- package/dist/chunk-KF2Y7HO3.js +595 -0
- package/dist/chunk-KF2Y7HO3.js.map +1 -0
- package/dist/chunk-KPDYKK3V.js +162 -0
- package/dist/chunk-KPDYKK3V.js.map +1 -0
- package/dist/chunk-KVBMZNWT.mjs +103 -0
- package/dist/chunk-KVBMZNWT.mjs.map +1 -0
- package/dist/chunk-L2TIGA7I.js +530 -0
- package/dist/chunk-L2TIGA7I.js.map +1 -0
- package/dist/chunk-MNM6HE72.js +146 -0
- package/dist/chunk-MNM6HE72.js.map +1 -0
- package/dist/chunk-NXTVJ6PY.js +374 -0
- package/dist/chunk-NXTVJ6PY.js.map +1 -0
- package/dist/chunk-OWWDNDF4.js +40 -0
- package/dist/chunk-OWWDNDF4.js.map +1 -0
- package/dist/chunk-PHMNZK2R.mjs +18 -0
- package/dist/chunk-PHMNZK2R.mjs.map +1 -0
- package/dist/chunk-PWF2NJDB.mjs +377 -0
- package/dist/chunk-PWF2NJDB.mjs.map +1 -0
- package/dist/chunk-QBCRH7YF.mjs +37 -0
- package/dist/chunk-QBCRH7YF.mjs.map +1 -0
- package/dist/chunk-QD6RLAO2.mjs +11 -0
- package/dist/chunk-QD6RLAO2.mjs.map +1 -0
- package/dist/chunk-QY65OUAC.mjs +111 -0
- package/dist/chunk-QY65OUAC.mjs.map +1 -0
- package/dist/chunk-QYYQYZHV.js +45 -0
- package/dist/chunk-QYYQYZHV.js.map +1 -0
- package/dist/chunk-T7LPABOL.mjs +595 -0
- package/dist/chunk-T7LPABOL.mjs.map +1 -0
- package/dist/chunk-THQKYTQE.js +490 -0
- package/dist/chunk-THQKYTQE.js.map +1 -0
- package/dist/chunk-U2QHFISG.js +18 -0
- package/dist/chunk-U2QHFISG.js.map +1 -0
- package/dist/chunk-UPGFBPFX.mjs +25 -0
- package/dist/chunk-UPGFBPFX.mjs.map +1 -0
- package/dist/chunk-X7E6GMFL.js +233 -0
- package/dist/chunk-X7E6GMFL.js.map +1 -0
- package/dist/chunk-XF66WQZE.mjs +1535 -0
- package/dist/chunk-XF66WQZE.mjs.map +1 -0
- package/dist/chunk-YQOZPLTY.js +1535 -0
- package/dist/chunk-YQOZPLTY.js.map +1 -0
- package/dist/chunk-ZGCN5WCG.js +377 -0
- package/dist/chunk-ZGCN5WCG.js.map +1 -0
- package/dist/chunk-ZP26PGMS.mjs +31 -0
- package/dist/chunk-ZP26PGMS.mjs.map +1 -0
- package/dist/feedback.d.mts +356 -0
- package/dist/feedback.d.ts +356 -0
- package/dist/feedback.js +43 -0
- package/dist/feedback.js.map +1 -0
- package/dist/feedback.mjs +43 -0
- package/dist/feedback.mjs.map +1 -0
- package/dist/icons.d.mts +22 -0
- package/dist/icons.d.ts +22 -0
- package/dist/icons.js +23 -0
- package/dist/icons.js.map +1 -0
- package/dist/icons.mjs +23 -0
- package/dist/icons.mjs.map +1 -0
- package/dist/index.d.mts +171 -3069
- package/dist/index.d.ts +171 -3069
- package/dist/index.js +320 -10077
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +262 -9978
- package/dist/index.mjs.map +1 -1
- package/dist/inputs.d.mts +109 -0
- package/dist/inputs.d.ts +109 -0
- package/dist/inputs.js +43 -0
- package/dist/inputs.js.map +1 -0
- package/dist/inputs.mjs +43 -0
- package/dist/inputs.mjs.map +1 -0
- package/dist/layout.d.mts +927 -0
- package/dist/layout.d.ts +927 -0
- package/dist/layout.js +122 -0
- package/dist/layout.js.map +1 -0
- package/dist/layout.mjs +122 -0
- package/dist/layout.mjs.map +1 -0
- package/dist/navigation.d.mts +716 -0
- package/dist/navigation.d.ts +716 -0
- package/dist/navigation.js +58 -0
- package/dist/navigation.js.map +1 -0
- package/dist/navigation.mjs +58 -0
- package/dist/navigation.mjs.map +1 -0
- package/dist/third-party.d.mts +637 -0
- package/dist/third-party.d.ts +637 -0
- package/dist/third-party.js +45 -0
- package/dist/third-party.js.map +1 -0
- package/dist/third-party.mjs +45 -0
- package/dist/third-party.mjs.map +1 -0
- package/dist/tokens.css +2 -1
- package/dist/utilities.d.mts +39 -0
- package/dist/utilities.d.ts +39 -0
- package/dist/utilities.js +19 -0
- package/dist/utilities.js.map +1 -0
- package/dist/utilities.mjs +19 -0
- package/dist/utilities.mjs.map +1 -0
- package/package.json +55 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/cere-design-system/cere-design-system/dist/charts.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACA;AACA;AACA;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACE;AACA;AACA;AACA;AACA;AACA;AACF,6UAAC","file":"/home/runner/work/cere-design-system/cere-design-system/dist/charts.js"}
|
package/dist/charts.mjs
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ChartWidget,
|
|
3
|
+
MetricsChart,
|
|
4
|
+
PeriodSelect,
|
|
5
|
+
SummaryStats,
|
|
6
|
+
TimeRangeSelect,
|
|
7
|
+
TimeSeriesGraph
|
|
8
|
+
} from "./chunk-T7LPABOL.mjs";
|
|
9
|
+
import "./chunk-QD6RLAO2.mjs";
|
|
10
|
+
import "./chunk-ATIFLPH6.mjs";
|
|
11
|
+
import "./chunk-PWF2NJDB.mjs";
|
|
12
|
+
export {
|
|
13
|
+
ChartWidget,
|
|
14
|
+
MetricsChart,
|
|
15
|
+
PeriodSelect,
|
|
16
|
+
SummaryStats,
|
|
17
|
+
TimeRangeSelect,
|
|
18
|
+
TimeSeriesGraph
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=charts.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
// src/components/layout/WorkflowNode/WorkflowNode.tsx
|
|
2
|
+
import { Paper, Box, Typography } from "@mui/material";
|
|
3
|
+
import PlayCircleOutlineIcon from "@mui/icons-material/PlayCircleOutline";
|
|
4
|
+
import CloudDownloadIcon from "@mui/icons-material/CloudDownload";
|
|
5
|
+
import WavesIcon from "@mui/icons-material/Waves";
|
|
6
|
+
import LinkIcon from "@mui/icons-material/Link";
|
|
7
|
+
import CloudIcon from "@mui/icons-material/Cloud";
|
|
8
|
+
import BoltIcon from "@mui/icons-material/Bolt";
|
|
9
|
+
import FlashOnIcon from "@mui/icons-material/FlashOn";
|
|
10
|
+
import PlayArrowIcon from "@mui/icons-material/PlayArrow";
|
|
11
|
+
import PsychologyIcon from "@mui/icons-material/Psychology";
|
|
12
|
+
import SmartToyOutlinedIcon from "@mui/icons-material/SmartToyOutlined";
|
|
13
|
+
import CallSplitIcon from "@mui/icons-material/CallSplit";
|
|
14
|
+
import SendIcon from "@mui/icons-material/Send";
|
|
15
|
+
import CheckCircleOutlineIcon from "@mui/icons-material/CheckCircleOutline";
|
|
16
|
+
import ForkRightIcon from "@mui/icons-material/ForkRight";
|
|
17
|
+
import CallMergeIcon from "@mui/icons-material/CallMerge";
|
|
18
|
+
import { useTheme } from "@mui/material";
|
|
19
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
20
|
+
var WORKFLOW_NODE_LABELS = {
|
|
21
|
+
start: "Start",
|
|
22
|
+
input: "Input",
|
|
23
|
+
stream: "Stream",
|
|
24
|
+
rafts: "Rafts",
|
|
25
|
+
cubbies: "Cubbies",
|
|
26
|
+
events: "Events",
|
|
27
|
+
trigger: "Trigger",
|
|
28
|
+
action: "Action",
|
|
29
|
+
aiModel: "AI Model",
|
|
30
|
+
aiAgent: "Agent",
|
|
31
|
+
condition: "Condition",
|
|
32
|
+
output: "Output",
|
|
33
|
+
end: "End",
|
|
34
|
+
parallel: "Parallel",
|
|
35
|
+
merge: "Merge"
|
|
36
|
+
};
|
|
37
|
+
var NODE_ICON_SIZE = 18;
|
|
38
|
+
var WORKFLOW_NODE_SHADOW = "0px 1px 3px rgba(0, 0, 0, 0.1), 0px 1px 2px rgba(0, 0, 0, 0.1)";
|
|
39
|
+
var WORKFLOW_NODE_ICONS = {
|
|
40
|
+
start: /* @__PURE__ */ jsx(PlayCircleOutlineIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
41
|
+
input: /* @__PURE__ */ jsx(CloudDownloadIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
42
|
+
stream: /* @__PURE__ */ jsx(WavesIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
43
|
+
rafts: /* @__PURE__ */ jsx(LinkIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
44
|
+
cubbies: /* @__PURE__ */ jsx(CloudIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
45
|
+
events: /* @__PURE__ */ jsx(BoltIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
46
|
+
trigger: /* @__PURE__ */ jsx(FlashOnIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
47
|
+
action: /* @__PURE__ */ jsx(PlayArrowIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
48
|
+
aiModel: /* @__PURE__ */ jsx(PsychologyIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
49
|
+
aiAgent: /* @__PURE__ */ jsx(SmartToyOutlinedIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
50
|
+
condition: /* @__PURE__ */ jsx(CallSplitIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
51
|
+
output: /* @__PURE__ */ jsx(SendIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
52
|
+
end: /* @__PURE__ */ jsx(CheckCircleOutlineIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
53
|
+
parallel: /* @__PURE__ */ jsx(ForkRightIcon, { sx: { fontSize: NODE_ICON_SIZE } }),
|
|
54
|
+
merge: /* @__PURE__ */ jsx(CallMergeIcon, { sx: { fontSize: NODE_ICON_SIZE } })
|
|
55
|
+
};
|
|
56
|
+
var BADGE_TYPOGRAPHY = {
|
|
57
|
+
fontSize: "12px",
|
|
58
|
+
fontWeight: 500,
|
|
59
|
+
lineHeight: 1.33
|
|
60
|
+
};
|
|
61
|
+
var SideConnectorDot = ({
|
|
62
|
+
accentColor,
|
|
63
|
+
side
|
|
64
|
+
}) => /* @__PURE__ */ jsx(
|
|
65
|
+
Box,
|
|
66
|
+
{
|
|
67
|
+
"data-testid": `workflow-node-dot-${side}`,
|
|
68
|
+
sx: (theme) => ({
|
|
69
|
+
position: "absolute",
|
|
70
|
+
top: "50%",
|
|
71
|
+
[side]: "-4px",
|
|
72
|
+
transform: "translateY(-50%)",
|
|
73
|
+
width: "8px",
|
|
74
|
+
height: "8px",
|
|
75
|
+
borderRadius: "999px",
|
|
76
|
+
border: `2px solid ${theme.palette.common.white}`,
|
|
77
|
+
backgroundColor: accentColor,
|
|
78
|
+
boxShadow: WORKFLOW_NODE_SHADOW,
|
|
79
|
+
zIndex: 1,
|
|
80
|
+
pointerEvents: "none"
|
|
81
|
+
})
|
|
82
|
+
}
|
|
83
|
+
);
|
|
84
|
+
var NodeTypeBadge = ({ nodeType, badgeBackground, badgeBorder, badgeText, icon, label }) => /* @__PURE__ */ jsxs(
|
|
85
|
+
Box,
|
|
86
|
+
{
|
|
87
|
+
sx: {
|
|
88
|
+
display: "inline-flex",
|
|
89
|
+
alignItems: "center",
|
|
90
|
+
justifyContent: "center",
|
|
91
|
+
gap: 1,
|
|
92
|
+
px: 1,
|
|
93
|
+
py: 0.5,
|
|
94
|
+
borderRadius: "999px",
|
|
95
|
+
backgroundColor: badgeBackground,
|
|
96
|
+
border: `1px solid ${badgeBorder}`,
|
|
97
|
+
flexShrink: 0
|
|
98
|
+
},
|
|
99
|
+
children: [
|
|
100
|
+
/* @__PURE__ */ jsx(Box, { sx: { color: badgeText, display: "flex", alignItems: "center" }, children: icon ?? WORKFLOW_NODE_ICONS[nodeType] }),
|
|
101
|
+
/* @__PURE__ */ jsx(
|
|
102
|
+
Typography,
|
|
103
|
+
{
|
|
104
|
+
variant: "body2",
|
|
105
|
+
component: "span",
|
|
106
|
+
sx: {
|
|
107
|
+
color: badgeText,
|
|
108
|
+
fontWeight: BADGE_TYPOGRAPHY.fontWeight,
|
|
109
|
+
fontSize: BADGE_TYPOGRAPHY.fontSize,
|
|
110
|
+
lineHeight: BADGE_TYPOGRAPHY.lineHeight
|
|
111
|
+
},
|
|
112
|
+
children: label ?? WORKFLOW_NODE_LABELS[nodeType]
|
|
113
|
+
}
|
|
114
|
+
)
|
|
115
|
+
]
|
|
116
|
+
}
|
|
117
|
+
);
|
|
118
|
+
var WorkflowNode = ({
|
|
119
|
+
nodeType,
|
|
120
|
+
title,
|
|
121
|
+
description,
|
|
122
|
+
icon,
|
|
123
|
+
badgeLabel,
|
|
124
|
+
selected = false,
|
|
125
|
+
className,
|
|
126
|
+
showSideDots = true,
|
|
127
|
+
sx,
|
|
128
|
+
...paperProps
|
|
129
|
+
}) => {
|
|
130
|
+
const theme = useTheme();
|
|
131
|
+
const nodeTokens = theme.palette.workflow.node[nodeType];
|
|
132
|
+
const chrome = theme.palette.workflow.chrome;
|
|
133
|
+
const accentColor = nodeTokens.accent;
|
|
134
|
+
return /* @__PURE__ */ jsxs(
|
|
135
|
+
Paper,
|
|
136
|
+
{
|
|
137
|
+
elevation: 0,
|
|
138
|
+
className,
|
|
139
|
+
sx: [
|
|
140
|
+
{
|
|
141
|
+
display: "flex",
|
|
142
|
+
flexDirection: "row",
|
|
143
|
+
position: "relative",
|
|
144
|
+
overflow: "visible",
|
|
145
|
+
border: `1px solid ${selected ? accentColor : nodeTokens.cardBorder}`,
|
|
146
|
+
borderRadius: "14px",
|
|
147
|
+
minWidth: 220,
|
|
148
|
+
maxWidth: 460,
|
|
149
|
+
minHeight: "76px",
|
|
150
|
+
backgroundColor: "common.white",
|
|
151
|
+
boxShadow: WORKFLOW_NODE_SHADOW,
|
|
152
|
+
transition: "border-color 0.15s ease"
|
|
153
|
+
},
|
|
154
|
+
...Array.isArray(sx) ? sx : [sx]
|
|
155
|
+
],
|
|
156
|
+
...paperProps,
|
|
157
|
+
children: [
|
|
158
|
+
showSideDots && /* @__PURE__ */ jsx(SideConnectorDot, { accentColor, side: "left" }),
|
|
159
|
+
showSideDots && /* @__PURE__ */ jsx(SideConnectorDot, { accentColor, side: "right" }),
|
|
160
|
+
/* @__PURE__ */ jsxs(
|
|
161
|
+
Box,
|
|
162
|
+
{
|
|
163
|
+
sx: {
|
|
164
|
+
flex: 1,
|
|
165
|
+
display: "flex",
|
|
166
|
+
justifyContent: "space-between",
|
|
167
|
+
alignItems: "center",
|
|
168
|
+
gap: 2,
|
|
169
|
+
px: 2,
|
|
170
|
+
py: 2,
|
|
171
|
+
minWidth: 0
|
|
172
|
+
},
|
|
173
|
+
children: [
|
|
174
|
+
/* @__PURE__ */ jsxs(Box, { sx: { minWidth: 0, flex: 1 }, children: [
|
|
175
|
+
/* @__PURE__ */ jsx(
|
|
176
|
+
Typography,
|
|
177
|
+
{
|
|
178
|
+
variant: "subtitle2",
|
|
179
|
+
noWrap: true,
|
|
180
|
+
sx: {
|
|
181
|
+
color: chrome.titleText,
|
|
182
|
+
fontSize: "16px",
|
|
183
|
+
fontWeight: 500,
|
|
184
|
+
lineHeight: "24px",
|
|
185
|
+
letterSpacing: "-0.3125px"
|
|
186
|
+
},
|
|
187
|
+
children: title
|
|
188
|
+
}
|
|
189
|
+
),
|
|
190
|
+
description && /* @__PURE__ */ jsx(
|
|
191
|
+
Typography,
|
|
192
|
+
{
|
|
193
|
+
variant: "body2",
|
|
194
|
+
sx: {
|
|
195
|
+
color: chrome.descriptionText,
|
|
196
|
+
fontSize: "12px",
|
|
197
|
+
lineHeight: "16px",
|
|
198
|
+
mt: 0.25,
|
|
199
|
+
overflow: "hidden",
|
|
200
|
+
textOverflow: "ellipsis",
|
|
201
|
+
display: "-webkit-box",
|
|
202
|
+
WebkitLineClamp: 2,
|
|
203
|
+
WebkitBoxOrient: "vertical"
|
|
204
|
+
},
|
|
205
|
+
children: description
|
|
206
|
+
}
|
|
207
|
+
)
|
|
208
|
+
] }),
|
|
209
|
+
/* @__PURE__ */ jsx(
|
|
210
|
+
NodeTypeBadge,
|
|
211
|
+
{
|
|
212
|
+
nodeType,
|
|
213
|
+
badgeBackground: nodeTokens.badgeBg,
|
|
214
|
+
badgeBorder: nodeTokens.badgeBorder,
|
|
215
|
+
badgeText: nodeTokens.badgeText,
|
|
216
|
+
icon,
|
|
217
|
+
label: badgeLabel
|
|
218
|
+
}
|
|
219
|
+
)
|
|
220
|
+
]
|
|
221
|
+
}
|
|
222
|
+
)
|
|
223
|
+
]
|
|
224
|
+
}
|
|
225
|
+
);
|
|
226
|
+
};
|
|
227
|
+
|
|
228
|
+
export {
|
|
229
|
+
WORKFLOW_NODE_LABELS,
|
|
230
|
+
WORKFLOW_NODE_SHADOW,
|
|
231
|
+
WorkflowNode
|
|
232
|
+
};
|
|
233
|
+
//# sourceMappingURL=chunk-27JEWSWA.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/layout/WorkflowNode/WorkflowNode.tsx"],"sourcesContent":["import React from 'react';\nimport { Paper, Box, Typography } from '@mui/material';\nimport type { PaperProps as MuiPaperProps } from '@mui/material/Paper';\nimport PlayCircleOutlineIcon from '@mui/icons-material/PlayCircleOutline';\nimport CloudDownloadIcon from '@mui/icons-material/CloudDownload';\nimport WavesIcon from '@mui/icons-material/Waves';\nimport LinkIcon from '@mui/icons-material/Link';\nimport CloudIcon from '@mui/icons-material/Cloud';\nimport BoltIcon from '@mui/icons-material/Bolt';\nimport FlashOnIcon from '@mui/icons-material/FlashOn';\nimport PlayArrowIcon from '@mui/icons-material/PlayArrow';\nimport PsychologyIcon from '@mui/icons-material/Psychology';\nimport SmartToyOutlinedIcon from '@mui/icons-material/SmartToyOutlined';\nimport CallSplitIcon from '@mui/icons-material/CallSplit';\nimport SendIcon from '@mui/icons-material/Send';\nimport CheckCircleOutlineIcon from '@mui/icons-material/CheckCircleOutline';\nimport ForkRightIcon from '@mui/icons-material/ForkRight';\nimport CallMergeIcon from '@mui/icons-material/CallMerge';\nimport { useTheme } from '@mui/material';\nimport type { Theme } from '@mui/material/styles';\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\n/** All supported workflow node types */\nexport type WorkflowNodeType =\n | 'start'\n | 'input'\n | 'stream'\n | 'rafts'\n | 'cubbies'\n | 'events'\n | 'trigger'\n | 'action'\n | 'aiModel'\n | 'aiAgent'\n | 'condition'\n | 'output'\n | 'end'\n | 'parallel'\n | 'merge';\n\nexport interface WorkflowNodeProps extends Omit<MuiPaperProps, 'title'> {\n /** The workflow node type — drives accent color, default icon, and badge label */\n nodeType: WorkflowNodeType;\n /** Primary title displayed in the node */\n title: string;\n /** Optional description text below the title */\n description?: string;\n /** Override the default icon for this node type */\n icon?: React.ReactNode;\n /** Override the default badge label for this node type */\n badgeLabel?: string;\n /** Whether the node is currently selected (highlights border with accent color) */\n selected?: boolean;\n /** Optional className */\n className?: string;\n /** Renders left/right connector dots to match the design spec */\n showSideDots?: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Constants\n// ---------------------------------------------------------------------------\n\n/** Human-readable labels for each node type (matches Figma badge text) */\nexport const WORKFLOW_NODE_LABELS: Record<WorkflowNodeType, string> = {\n start: 'Start',\n input: 'Input',\n stream: 'Stream',\n rafts: 'Rafts',\n cubbies: 'Cubbies',\n events: 'Events',\n trigger: 'Trigger',\n action: 'Action',\n aiModel: 'AI Model',\n aiAgent: 'Agent',\n condition: 'Condition',\n output: 'Output',\n end: 'End',\n parallel: 'Parallel',\n merge: 'Merge',\n};\n\nconst NODE_ICON_SIZE = 18;\n\n/** Shared elevation shadow for workflow node cards and connector handles (Figma 277-8244) */\nexport const WORKFLOW_NODE_SHADOW = '0px 1px 3px rgba(0, 0, 0, 0.1), 0px 1px 2px rgba(0, 0, 0, 0.1)';\n\n/** Default icon for each node type */\nconst WORKFLOW_NODE_ICONS: Record<WorkflowNodeType, React.ReactElement> = {\n start: <PlayCircleOutlineIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n input: <CloudDownloadIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n stream: <WavesIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n rafts: <LinkIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n cubbies: <CloudIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n events: <BoltIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n trigger: <FlashOnIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n action: <PlayArrowIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n aiModel: <PsychologyIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n aiAgent: <SmartToyOutlinedIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n condition: <CallSplitIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n output: <SendIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n end: <CheckCircleOutlineIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n parallel: <ForkRightIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n merge: <CallMergeIcon sx={{ fontSize: NODE_ICON_SIZE }} />,\n};\n\nconst BADGE_TYPOGRAPHY = {\n fontSize: '12px',\n fontWeight: 500,\n lineHeight: 1.33,\n} as const;\n\n// ---------------------------------------------------------------------------\n// Sub-components\n// ---------------------------------------------------------------------------\n\n/** Circular connector marker used on left and right sides of the node card */\nconst SideConnectorDot: React.FC<{ accentColor: string; side: 'left' | 'right' }> = ({\n accentColor,\n side,\n}) => (\n <Box\n data-testid={`workflow-node-dot-${side}`}\n sx={(theme) => ({\n position: 'absolute',\n top: '50%',\n [side]: '-4px',\n transform: 'translateY(-50%)',\n width: '8px',\n height: '8px',\n borderRadius: '999px',\n border: `2px solid ${theme.palette.common.white}`,\n backgroundColor: accentColor,\n boxShadow: WORKFLOW_NODE_SHADOW,\n zIndex: 1,\n pointerEvents: 'none',\n })}\n />\n);\n\n/** Outlined soft badge pill showing node type icon + label (Figma 277-8244) */\nconst NodeTypeBadge: React.FC<{\n nodeType: WorkflowNodeType;\n badgeBackground: string;\n badgeBorder: string;\n badgeText: string;\n icon?: React.ReactNode;\n label?: string;\n}> = ({ nodeType, badgeBackground, badgeBorder, badgeText, icon, label }) => (\n <Box\n sx={{\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: 1,\n px: 1,\n py: 0.5,\n borderRadius: '999px',\n backgroundColor: badgeBackground,\n border: `1px solid ${badgeBorder}`,\n flexShrink: 0,\n }}\n >\n <Box sx={{ color: badgeText, display: 'flex', alignItems: 'center' }}>\n {icon ?? WORKFLOW_NODE_ICONS[nodeType]}\n </Box>\n <Typography\n variant=\"body2\"\n component=\"span\"\n sx={{\n color: badgeText,\n fontWeight: BADGE_TYPOGRAPHY.fontWeight,\n fontSize: BADGE_TYPOGRAPHY.fontSize,\n lineHeight: BADGE_TYPOGRAPHY.lineHeight,\n }}\n >\n {label ?? WORKFLOW_NODE_LABELS[nodeType]}\n </Typography>\n </Box>\n);\n\n// ---------------------------------------------------------------------------\n// Main component\n// ---------------------------------------------------------------------------\n\n/**\n * WorkflowNode — visual card for a workflow editor node.\n *\n * Renders a card with a colored left border strip, title, optional description,\n * and a type badge/chip. Designed to integrate with FlowEditor (ReactFlow)\n * via the WorkflowNodeHandle wrapper.\n *\n * @example\n * ```tsx\n * <WorkflowNode\n * nodeType=\"trigger\"\n * title=\"HTTP Trigger\"\n * description=\"Listens for incoming webhook calls\"\n * />\n * ```\n */\nexport const WorkflowNode: React.FC<WorkflowNodeProps> = ({\n nodeType,\n title,\n description,\n icon,\n badgeLabel,\n selected = false,\n className,\n showSideDots = true,\n sx,\n ...paperProps\n}) => {\n const theme = useTheme() as Theme;\n const nodeTokens = theme.palette.workflow.node[nodeType];\n const chrome = theme.palette.workflow.chrome;\n const accentColor = nodeTokens.accent;\n\n return (\n <Paper\n elevation={0}\n className={className}\n sx={[\n {\n display: 'flex',\n flexDirection: 'row',\n position: 'relative',\n overflow: 'visible',\n border: `1px solid ${selected ? accentColor : nodeTokens.cardBorder}`,\n borderRadius: '14px',\n minWidth: 220,\n maxWidth: 460,\n minHeight: '76px',\n backgroundColor: 'common.white',\n boxShadow: WORKFLOW_NODE_SHADOW,\n transition: 'border-color 0.15s ease',\n },\n ...(Array.isArray(sx) ? sx : [sx]),\n ]}\n {...paperProps}\n >\n {showSideDots && <SideConnectorDot accentColor={accentColor} side=\"left\" />}\n {showSideDots && <SideConnectorDot accentColor={accentColor} side=\"right\" />}\n\n <Box\n sx={{\n flex: 1,\n display: 'flex',\n justifyContent: 'space-between',\n alignItems: 'center',\n gap: 2,\n px: 2,\n py: 2,\n minWidth: 0,\n }}\n >\n {/* Left: title + description */}\n <Box sx={{ minWidth: 0, flex: 1 }}>\n <Typography\n variant=\"subtitle2\"\n noWrap\n sx={{\n color: chrome.titleText,\n fontSize: '16px',\n fontWeight: 500,\n lineHeight: '24px',\n letterSpacing: '-0.3125px',\n }}\n >\n {title}\n </Typography>\n {description && (\n <Typography\n variant=\"body2\"\n sx={{\n color: chrome.descriptionText,\n fontSize: '12px',\n lineHeight: '16px',\n mt: 0.25,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n display: '-webkit-box',\n WebkitLineClamp: 2,\n WebkitBoxOrient: 'vertical',\n }}\n >\n {description}\n </Typography>\n )}\n </Box>\n\n {/* Right: filled type badge */}\n <NodeTypeBadge\n nodeType={nodeType}\n badgeBackground={nodeTokens.badgeBg}\n badgeBorder={nodeTokens.badgeBorder}\n badgeText={nodeTokens.badgeText}\n icon={icon}\n label={badgeLabel}\n />\n </Box>\n </Paper>\n );\n};\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }// src/components/icons/CereIcon.tsx
|
|
2
|
+
var _react = require('react'); var React = _interopRequireWildcard(_react);
|
|
3
|
+
var _SvgIcon = require('@mui/material/SvgIcon'); var _SvgIcon2 = _interopRequireDefault(_SvgIcon);
|
|
4
|
+
var _jsxruntime = require('react/jsx-runtime');
|
|
5
|
+
var CereIcon = React.forwardRef(
|
|
6
|
+
function CereIcon2(props, ref) {
|
|
7
|
+
const reactId = React.useId();
|
|
8
|
+
const clipId = `cere-icon-clip-${reactId}`;
|
|
9
|
+
return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, _SvgIcon2.default, { ref, ...props, viewBox: "0 0 24 28", children: [
|
|
10
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "g", { clipPath: `url(#${clipId})`, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
|
|
11
|
+
"path",
|
|
12
|
+
{
|
|
13
|
+
d: "M12.77 26.848c-5.95 0-10.572-2.88-12.063-7.515l-.334-1.037.978-.471c.103-.051 2.668-1.35 2.509-3.901-.169-2.695-2.339-3.96-2.431-4.012L.475 9.37l.412-1.025C2.838 3.601 7.28.77 12.77.77c4.314 0 8.095 1.698 10.37 4.658l.575.748-4.535 6.146-1.013-.984c-.02-.019-2.175-2.069-4.678-2.08-2.411-.012-3.362.902-3.401.941L8.3 8.473c.164-.175 1.695-1.733 5.199-1.707 2.232.01 4.161 1.084 5.3 1.896l1.778-2.41c-1.845-1.91-4.636-2.99-7.808-2.99-4.095 0-7.459 1.91-9.182 5.155 1.042.879 2.57 2.62 2.742 5.35.185 2.95-1.692 4.806-2.913 5.692 1.445 3.043 4.932 4.895 9.354 4.895 3.063 0 6.198-1.2 8.134-3.053l-2.023-2.55c-1.077.768-2.917 1.764-5.323 1.89-3.416.177-5.436-1.404-5.52-1.471l1.536-1.954c.047.035 1.42 1.065 3.855.936 2.884-.15 4.734-2.012 4.75-2.032l.98-1.002.874 1.094 4.088 5.155-.627.779c-2.3 2.856-6.508 4.702-10.726 4.702Z",
|
|
14
|
+
fill: "currentColor"
|
|
15
|
+
}
|
|
16
|
+
) }),
|
|
17
|
+
/* @__PURE__ */ _jsxruntime.jsx.call(void 0, "defs", { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "clipPath", { id: clipId, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "path", { fill: "currentColor", transform: "translate(.373 .77)", d: "M0 0h23.615v26.36H0z" }) }) })
|
|
18
|
+
] });
|
|
19
|
+
}
|
|
20
|
+
);
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
exports.CereIcon = CereIcon;
|
|
25
|
+
//# sourceMappingURL=chunk-2EBCST6X.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/cere-design-system/cere-design-system/dist/chunk-2EBCST6X.js","../src/components/icons/CereIcon.tsx"],"names":["CereIcon"],"mappings":"AAAA;ACAA,2EAAuB;AACvB,kGAA2C;AAOrC,+CAAA;AALC,IAAM,SAAA,EAAiB,KAAA,CAAA,UAAA;AAAA,EAC5B,SAASA,SAAAA,CAAS,KAAA,EAAO,GAAA,EAAK;AAC5B,IAAA,MAAM,QAAA,EAAgB,KAAA,CAAA,KAAA,CAAM,CAAA;AAC5B,IAAA,MAAM,OAAA,EAAS,CAAA,eAAA,EAAkB,OAAO,CAAA,CAAA;AAE7B,IAAA;AACM,sBAAA;AACV,QAAA;AAAA,QAAA;AACG,UAAA;AACG,UAAA;AAAA,QAAA;AAET,MAAA;AAEE,sBAAA;AAIJ,IAAA;AAEJ,EAAA;AACF;ADH6C;AACA;AACA;AACA","file":"/home/runner/work/cere-design-system/cere-design-system/dist/chunk-2EBCST6X.js","sourcesContent":[null,"import * as React from 'react';\nimport SvgIcon, { type SvgIconProps } from '@mui/material/SvgIcon';\n\nexport const CereIcon = React.forwardRef<SVGSVGElement, SvgIconProps>(\n function CereIcon(props, ref) {\n const reactId = React.useId();\n const clipId = `cere-icon-clip-${reactId}`;\n return (\n <SvgIcon ref={ref} {...props} viewBox=\"0 0 24 28\">\n <g clipPath={`url(#${clipId})`}>\n <path\n d=\"M12.77 26.848c-5.95 0-10.572-2.88-12.063-7.515l-.334-1.037.978-.471c.103-.051 2.668-1.35 2.509-3.901-.169-2.695-2.339-3.96-2.431-4.012L.475 9.37l.412-1.025C2.838 3.601 7.28.77 12.77.77c4.314 0 8.095 1.698 10.37 4.658l.575.748-4.535 6.146-1.013-.984c-.02-.019-2.175-2.069-4.678-2.08-2.411-.012-3.362.902-3.401.941L8.3 8.473c.164-.175 1.695-1.733 5.199-1.707 2.232.01 4.161 1.084 5.3 1.896l1.778-2.41c-1.845-1.91-4.636-2.99-7.808-2.99-4.095 0-7.459 1.91-9.182 5.155 1.042.879 2.57 2.62 2.742 5.35.185 2.95-1.692 4.806-2.913 5.692 1.445 3.043 4.932 4.895 9.354 4.895 3.063 0 6.198-1.2 8.134-3.053l-2.023-2.55c-1.077.768-2.917 1.764-5.323 1.89-3.416.177-5.436-1.404-5.52-1.471l1.536-1.954c.047.035 1.42 1.065 3.855.936 2.884-.15 4.734-2.012 4.75-2.032l.98-1.002.874 1.094 4.088 5.155-.627.779c-2.3 2.856-6.508 4.702-10.726 4.702Z\"\n fill=\"currentColor\"\n />\n </g>\n <defs>\n <clipPath id={clipId}>\n <path fill=\"currentColor\" transform=\"translate(.373 .77)\" d=\"M0 0h23.615v26.36H0z\" />\n </clipPath>\n </defs>\n </SvgIcon>\n );\n },\n);\n"]}
|