@principal-ai/principal-view-react 0.6.15 → 0.6.17
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/components/GraphRenderer.d.ts +10 -0
- package/dist/components/GraphRenderer.d.ts.map +1 -1
- package/dist/components/GraphRenderer.js +120 -21
- package/dist/components/GraphRenderer.js.map +1 -1
- package/dist/components/SelectionSidebar.d.ts +18 -0
- package/dist/components/SelectionSidebar.d.ts.map +1 -0
- package/dist/components/SelectionSidebar.js +183 -0
- package/dist/components/SelectionSidebar.js.map +1 -0
- package/dist/nodes/CustomNode.d.ts.map +1 -1
- package/dist/nodes/CustomNode.js +28 -11
- package/dist/nodes/CustomNode.js.map +1 -1
- package/package.json +1 -1
- package/src/components/GraphRenderer.tsx +168 -24
- package/src/components/PendingChanges.test.tsx +433 -0
- package/src/components/SelectionSidebar.tsx +341 -0
- package/src/nodes/CustomNode.tsx +43 -11
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SelectionSidebar = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const industry_theme_1 = require("@principal-ade/industry-theme");
|
|
7
|
+
const iconResolver_1 = require("../utils/iconResolver");
|
|
8
|
+
/**
|
|
9
|
+
* Sidebar that displays information about multiple selected nodes
|
|
10
|
+
* Shows name and description for each node, with expandable details
|
|
11
|
+
*/
|
|
12
|
+
const SelectionSidebar = ({ selectedNodeIds, nodes, nodeTypeDefinitions, onClose, }) => {
|
|
13
|
+
const { theme } = (0, industry_theme_1.useTheme)();
|
|
14
|
+
const [expandedNodes, setExpandedNodes] = (0, react_1.useState)({});
|
|
15
|
+
// Get the selected nodes in order
|
|
16
|
+
const selectedNodes = nodes.filter((n) => selectedNodeIds.has(n.id));
|
|
17
|
+
const toggleExpanded = (nodeId) => {
|
|
18
|
+
setExpandedNodes((prev) => ({
|
|
19
|
+
...prev,
|
|
20
|
+
[nodeId]: !prev[nodeId],
|
|
21
|
+
}));
|
|
22
|
+
};
|
|
23
|
+
// Internal fields that should not be displayed
|
|
24
|
+
const internalFields = [
|
|
25
|
+
'icon',
|
|
26
|
+
'name',
|
|
27
|
+
'description',
|
|
28
|
+
'sources',
|
|
29
|
+
'color',
|
|
30
|
+
'stroke',
|
|
31
|
+
'width',
|
|
32
|
+
'height',
|
|
33
|
+
'canvasType',
|
|
34
|
+
'text',
|
|
35
|
+
'file',
|
|
36
|
+
'url',
|
|
37
|
+
'shape',
|
|
38
|
+
'states',
|
|
39
|
+
'actions',
|
|
40
|
+
'nodeType',
|
|
41
|
+
];
|
|
42
|
+
return ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
43
|
+
position: 'absolute',
|
|
44
|
+
top: '60px',
|
|
45
|
+
right: '20px',
|
|
46
|
+
backgroundColor: theme.colors.background,
|
|
47
|
+
color: theme.colors.text,
|
|
48
|
+
borderRadius: '8px',
|
|
49
|
+
boxShadow: '0 4px 12px rgba(0,0,0,0.15)',
|
|
50
|
+
padding: '16px',
|
|
51
|
+
minWidth: '280px',
|
|
52
|
+
maxWidth: '350px',
|
|
53
|
+
maxHeight: 'calc(100vh - 120px)',
|
|
54
|
+
overflowY: 'auto',
|
|
55
|
+
zIndex: 1000,
|
|
56
|
+
border: `1px solid ${theme.colors.border}`,
|
|
57
|
+
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
58
|
+
display: 'flex',
|
|
59
|
+
justifyContent: 'space-between',
|
|
60
|
+
alignItems: 'center',
|
|
61
|
+
marginBottom: '12px',
|
|
62
|
+
paddingBottom: '8px',
|
|
63
|
+
borderBottom: `2px solid ${theme.colors.primary}`,
|
|
64
|
+
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: { fontWeight: 'bold', fontSize: '14px', color: theme.colors.primary }, children: [selectedNodes.length, " nodes selected"] }), (0, jsx_runtime_1.jsx)("button", { onClick: onClose, style: {
|
|
65
|
+
border: 'none',
|
|
66
|
+
background: 'none',
|
|
67
|
+
cursor: 'pointer',
|
|
68
|
+
fontSize: '18px',
|
|
69
|
+
color: theme.colors.textSecondary,
|
|
70
|
+
padding: '0',
|
|
71
|
+
width: '24px',
|
|
72
|
+
height: '24px',
|
|
73
|
+
display: 'flex',
|
|
74
|
+
alignItems: 'center',
|
|
75
|
+
justifyContent: 'center',
|
|
76
|
+
}, children: "x" })] }), (0, jsx_runtime_1.jsx)("div", { style: { display: 'flex', flexDirection: 'column', gap: '8px' }, children: selectedNodes.map((node) => {
|
|
77
|
+
const typeDefinition = nodeTypeDefinitions[node.type];
|
|
78
|
+
const nodeColor = node.data?.color || typeDefinition?.color || theme.colors.secondary;
|
|
79
|
+
const icon = node.data?.icon || typeDefinition?.icon;
|
|
80
|
+
const isExpanded = expandedNodes[node.id] || false;
|
|
81
|
+
const description = node.data?.description;
|
|
82
|
+
// Get displayable data entries
|
|
83
|
+
const dataEntries = node.data
|
|
84
|
+
? Object.entries(node.data).filter(([key]) => !internalFields.includes(key))
|
|
85
|
+
: [];
|
|
86
|
+
return ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
87
|
+
backgroundColor: theme.colors.surface,
|
|
88
|
+
borderRadius: '6px',
|
|
89
|
+
border: `1px solid ${theme.colors.border}`,
|
|
90
|
+
overflow: 'hidden',
|
|
91
|
+
}, children: [(0, jsx_runtime_1.jsxs)("button", { onClick: () => toggleExpanded(node.id), style: {
|
|
92
|
+
width: '100%',
|
|
93
|
+
padding: '10px 12px',
|
|
94
|
+
backgroundColor: 'transparent',
|
|
95
|
+
border: 'none',
|
|
96
|
+
cursor: 'pointer',
|
|
97
|
+
display: 'flex',
|
|
98
|
+
alignItems: 'flex-start',
|
|
99
|
+
gap: '10px',
|
|
100
|
+
textAlign: 'left',
|
|
101
|
+
}, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
102
|
+
width: '28px',
|
|
103
|
+
height: '28px',
|
|
104
|
+
borderRadius: '6px',
|
|
105
|
+
backgroundColor: nodeColor,
|
|
106
|
+
display: 'flex',
|
|
107
|
+
alignItems: 'center',
|
|
108
|
+
justifyContent: 'center',
|
|
109
|
+
flexShrink: 0,
|
|
110
|
+
color: 'white',
|
|
111
|
+
}, children: icon ? (0, iconResolver_1.resolveIcon)(icon, 16) : null }), (0, jsx_runtime_1.jsxs)("div", { style: { flex: 1, minWidth: 0 }, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
112
|
+
fontWeight: 600,
|
|
113
|
+
fontSize: '13px',
|
|
114
|
+
color: theme.colors.text,
|
|
115
|
+
marginBottom: description ? '2px' : 0,
|
|
116
|
+
}, children: node.name || node.id }), description && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
117
|
+
fontSize: '11px',
|
|
118
|
+
color: theme.colors.textSecondary,
|
|
119
|
+
overflow: 'hidden',
|
|
120
|
+
textOverflow: 'ellipsis',
|
|
121
|
+
display: '-webkit-box',
|
|
122
|
+
WebkitLineClamp: isExpanded ? 'unset' : 2,
|
|
123
|
+
WebkitBoxOrient: 'vertical',
|
|
124
|
+
}, children: description }))] }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
125
|
+
color: theme.colors.textSecondary,
|
|
126
|
+
fontSize: '10px',
|
|
127
|
+
transform: isExpanded ? 'rotate(180deg)' : 'rotate(0deg)',
|
|
128
|
+
transition: 'transform 0.2s',
|
|
129
|
+
flexShrink: 0,
|
|
130
|
+
}, children: "\u25BC" })] }), isExpanded && ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
131
|
+
padding: '0 12px 10px 12px',
|
|
132
|
+
borderTop: `1px solid ${theme.colors.border}`,
|
|
133
|
+
marginTop: '0',
|
|
134
|
+
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: { marginTop: '10px' }, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
135
|
+
fontSize: '10px',
|
|
136
|
+
color: theme.colors.textSecondary,
|
|
137
|
+
marginBottom: '4px',
|
|
138
|
+
}, children: "Type" }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
139
|
+
fontSize: '11px',
|
|
140
|
+
padding: '3px 8px',
|
|
141
|
+
backgroundColor: nodeColor,
|
|
142
|
+
color: 'white',
|
|
143
|
+
borderRadius: '4px',
|
|
144
|
+
display: 'inline-block',
|
|
145
|
+
}, children: node.type })] }), node.state && ((0, jsx_runtime_1.jsxs)("div", { style: { marginTop: '8px' }, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
146
|
+
fontSize: '10px',
|
|
147
|
+
color: theme.colors.textSecondary,
|
|
148
|
+
marginBottom: '4px',
|
|
149
|
+
}, children: "State" }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
150
|
+
fontSize: '11px',
|
|
151
|
+
padding: '3px 8px',
|
|
152
|
+
backgroundColor: typeDefinition?.states?.[node.state]?.color || theme.colors.secondary,
|
|
153
|
+
color: 'white',
|
|
154
|
+
borderRadius: '4px',
|
|
155
|
+
display: 'inline-block',
|
|
156
|
+
}, children: typeDefinition?.states?.[node.state]?.label || node.state })] })), dataEntries.length > 0 && ((0, jsx_runtime_1.jsxs)("div", { style: { marginTop: '8px' }, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
157
|
+
fontSize: '10px',
|
|
158
|
+
color: theme.colors.textSecondary,
|
|
159
|
+
marginBottom: '6px',
|
|
160
|
+
fontWeight: 'bold',
|
|
161
|
+
}, children: "Properties" }), dataEntries.map(([key, value]) => ((0, jsx_runtime_1.jsxs)("div", { style: { marginBottom: '6px' }, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
162
|
+
fontSize: '10px',
|
|
163
|
+
color: theme.colors.textSecondary,
|
|
164
|
+
marginBottom: '2px',
|
|
165
|
+
}, children: key }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
166
|
+
fontSize: '11px',
|
|
167
|
+
color: theme.colors.text,
|
|
168
|
+
wordBreak: 'break-word',
|
|
169
|
+
}, children: value !== undefined && value !== null
|
|
170
|
+
? typeof value === 'object'
|
|
171
|
+
? JSON.stringify(value, null, 2)
|
|
172
|
+
: String(value)
|
|
173
|
+
: '-' })] }, key)))] })), (0, jsx_runtime_1.jsxs)("div", { style: {
|
|
174
|
+
fontSize: '10px',
|
|
175
|
+
color: theme.colors.textMuted,
|
|
176
|
+
marginTop: '8px',
|
|
177
|
+
paddingTop: '6px',
|
|
178
|
+
borderTop: `1px solid ${theme.colors.border}`,
|
|
179
|
+
}, children: ["ID: ", node.id] })] }))] }, node.id));
|
|
180
|
+
}) })] }));
|
|
181
|
+
};
|
|
182
|
+
exports.SelectionSidebar = SelectionSidebar;
|
|
183
|
+
//# sourceMappingURL=SelectionSidebar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SelectionSidebar.js","sourceRoot":"","sources":["../../src/components/SelectionSidebar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CustomNode.d.ts","sourceRoot":"","sources":["../../src/nodes/CustomNode.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AAG5E,MAAM,WAAW,cAAe,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC7D,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,kBAAkB,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAE9B,aAAa,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,IAAI,CAAC;IAC7D,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;GAEG;AAEH,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,
|
|
1
|
+
{"version":3,"file":"CustomNode.d.ts","sourceRoot":"","sources":["../../src/nodes/CustomNode.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AAG5E,MAAM,WAAW,cAAe,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC7D,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,kBAAkB,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAE9B,aAAa,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,IAAI,CAAC;IAC7D,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED;;GAEG;AAEH,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAmd/C,CAAC"}
|
package/dist/nodes/CustomNode.js
CHANGED
|
@@ -61,6 +61,9 @@ const CustomNode = ({ data, selected }) => {
|
|
|
61
61
|
border: `2px solid ${hasViolations ? '#D0021B' : strokeColor}`,
|
|
62
62
|
fontSize: '12px',
|
|
63
63
|
fontWeight: 500,
|
|
64
|
+
// Use 100% width/height to fill the node container (for resizing support)
|
|
65
|
+
width: '100%',
|
|
66
|
+
height: '100%',
|
|
64
67
|
minWidth: typeDefinition.size?.width || 80,
|
|
65
68
|
minHeight: typeDefinition.size?.height || 40,
|
|
66
69
|
display: 'flex',
|
|
@@ -69,16 +72,15 @@ const CustomNode = ({ data, selected }) => {
|
|
|
69
72
|
justifyContent: isGroup ? 'flex-start' : 'center',
|
|
70
73
|
gap: '4px',
|
|
71
74
|
boxShadow: selected ? `0 0 0 2px ${strokeColor}` : '0 2px 4px rgba(0,0,0,0.1)',
|
|
72
|
-
transition: '
|
|
75
|
+
transition: 'box-shadow 0.2s ease',
|
|
73
76
|
animationDuration: animationType ? `${animationDuration}ms` : undefined,
|
|
77
|
+
boxSizing: 'border-box',
|
|
74
78
|
};
|
|
75
79
|
switch (typeDefinition.shape) {
|
|
76
80
|
case 'circle':
|
|
77
81
|
return {
|
|
78
82
|
...baseStyles,
|
|
79
83
|
borderRadius: '50%',
|
|
80
|
-
width: typeDefinition.size?.width || 80,
|
|
81
|
-
height: typeDefinition.size?.height || 80,
|
|
82
84
|
padding: '8px',
|
|
83
85
|
};
|
|
84
86
|
case 'hexagon':
|
|
@@ -96,13 +98,12 @@ const CustomNode = ({ data, selected }) => {
|
|
|
96
98
|
boxShadow: 'none', // Shadow handled by wrapper
|
|
97
99
|
};
|
|
98
100
|
case 'diamond':
|
|
99
|
-
// Rotated square -
|
|
100
|
-
const diamondSize = typeDefinition.size?.width || 70;
|
|
101
|
+
// Rotated square - use 100% to fill container
|
|
101
102
|
return {
|
|
102
103
|
...baseStyles,
|
|
103
104
|
transform: 'rotate(45deg)',
|
|
104
|
-
width:
|
|
105
|
-
height:
|
|
105
|
+
width: '100%',
|
|
106
|
+
height: '100%',
|
|
106
107
|
padding: '8px',
|
|
107
108
|
};
|
|
108
109
|
case 'rectangle':
|
|
@@ -115,6 +116,12 @@ const CustomNode = ({ data, selected }) => {
|
|
|
115
116
|
};
|
|
116
117
|
const isDiamond = typeDefinition.shape === 'diamond';
|
|
117
118
|
const isHexagon = typeDefinition.shape === 'hexagon';
|
|
119
|
+
const isCircle = typeDefinition.shape === 'circle';
|
|
120
|
+
// Determine if aspect ratio should be locked (circles and diamonds should maintain square aspect)
|
|
121
|
+
const keepAspectRatio = isCircle || isDiamond;
|
|
122
|
+
// Minimum dimensions for resizing
|
|
123
|
+
const minWidth = typeDefinition.size?.width || 80;
|
|
124
|
+
const minHeight = typeDefinition.size?.height || (isCircle ? minWidth : 40);
|
|
118
125
|
// Hexagon border wrapper styles (outer shape that acts as border)
|
|
119
126
|
// Hexagon with gentle diagonals
|
|
120
127
|
const hexagonClipPath = 'polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%)';
|
|
@@ -124,10 +131,14 @@ const CustomNode = ({ data, selected }) => {
|
|
|
124
131
|
position: 'relative',
|
|
125
132
|
clipPath: hexagonClipPath,
|
|
126
133
|
backgroundColor: hasViolations ? '#D0021B' : strokeColor,
|
|
127
|
-
|
|
128
|
-
|
|
134
|
+
// Use 100% to fill container for resizing support
|
|
135
|
+
width: '100%',
|
|
136
|
+
height: '100%',
|
|
137
|
+
minWidth: typeDefinition.size?.width || 120,
|
|
138
|
+
minHeight: typeDefinition.size?.height || 120,
|
|
129
139
|
boxShadow: selected ? `0 0 0 2px ${strokeColor}` : '0 2px 4px rgba(0,0,0,0.1)',
|
|
130
|
-
transition: '
|
|
140
|
+
transition: 'box-shadow 0.2s ease',
|
|
141
|
+
boxSizing: 'border-box',
|
|
131
142
|
}
|
|
132
143
|
: {};
|
|
133
144
|
// Hexagon inner fill styles (white background inset from border)
|
|
@@ -193,7 +204,13 @@ const CustomNode = ({ data, selected }) => {
|
|
|
193
204
|
}
|
|
194
205
|
return offsetStyle;
|
|
195
206
|
};
|
|
196
|
-
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [
|
|
207
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [editable && ((0, jsx_runtime_1.jsx)(react_1.NodeResizer, { color: strokeColor, isVisible: selected, minWidth: minWidth, minHeight: minHeight, keepAspectRatio: keepAspectRatio, handleStyle: {
|
|
208
|
+
width: 8,
|
|
209
|
+
height: 8,
|
|
210
|
+
borderRadius: 2,
|
|
211
|
+
}, lineStyle: {
|
|
212
|
+
borderWidth: 1,
|
|
213
|
+
} })), (0, jsx_runtime_1.jsx)(react_1.Handle, { type: "target", position: react_1.Position.Top, id: "top", style: getHandleStyle('top') }), (0, jsx_runtime_1.jsx)(react_1.Handle, { type: "target", position: react_1.Position.Bottom, id: "bottom", style: getHandleStyle('bottom') }), (0, jsx_runtime_1.jsx)(react_1.Handle, { type: "target", position: react_1.Position.Left, id: "left", style: getHandleStyle('left') }), (0, jsx_runtime_1.jsx)(react_1.Handle, { type: "target", position: react_1.Position.Right, id: "right", style: getHandleStyle('right') }), isHexagon ? ((0, jsx_runtime_1.jsx)("div", { style: hexagonBorderStyle, className: animationClass, children: (0, jsx_runtime_1.jsxs)("div", { style: hexagonInnerStyle, children: [icon && ((0, jsx_runtime_1.jsx)("div", { style: { display: 'flex', justifyContent: 'center', alignItems: 'center' }, children: (0, iconResolver_1.resolveIcon)(icon, 20) })), (0, jsx_runtime_1.jsx)("div", { style: { textAlign: 'center', wordBreak: 'break-word' }, children: displayName }), state && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
197
214
|
fontSize: '10px',
|
|
198
215
|
backgroundColor: color,
|
|
199
216
|
color: 'white',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CustomNode.js","sourceRoot":"","sources":["../../src/nodes/CustomNode.tsx"],"names":[],"mappings":";;;;AACA,
|
|
1
|
+
{"version":3,"file":"CustomNode.js","sourceRoot":"","sources":["../../src/nodes/CustomNode.tsx"],"names":[],"mappings":"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"}
|