@principal-ai/principal-view-react 0.14.13 → 0.14.15
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 +15 -0
- package/dist/components/GraphRenderer.d.ts.map +1 -1
- package/dist/components/GraphRenderer.js +34 -4
- package/dist/components/GraphRenderer.js.map +1 -1
- package/dist/components/dashboard/DashboardRenderer.d.ts +9 -0
- package/dist/components/dashboard/DashboardRenderer.d.ts.map +1 -0
- package/dist/components/dashboard/DashboardRenderer.js +179 -0
- package/dist/components/dashboard/DashboardRenderer.js.map +1 -0
- package/dist/components/dashboard/MetricPanel.d.ts +9 -0
- package/dist/components/dashboard/MetricPanel.d.ts.map +1 -0
- package/dist/components/dashboard/MetricPanel.js +103 -0
- package/dist/components/dashboard/MetricPanel.js.map +1 -0
- package/dist/components/dashboard/MockDataProvider.d.ts +30 -0
- package/dist/components/dashboard/MockDataProvider.d.ts.map +1 -0
- package/dist/components/dashboard/MockDataProvider.js +270 -0
- package/dist/components/dashboard/MockDataProvider.js.map +1 -0
- package/dist/components/dashboard/components/BarChart.d.ts +9 -0
- package/dist/components/dashboard/components/BarChart.d.ts.map +1 -0
- package/dist/components/dashboard/components/BarChart.js +167 -0
- package/dist/components/dashboard/components/BarChart.js.map +1 -0
- package/dist/components/dashboard/components/LineChart.d.ts +9 -0
- package/dist/components/dashboard/components/LineChart.d.ts.map +1 -0
- package/dist/components/dashboard/components/LineChart.js +141 -0
- package/dist/components/dashboard/components/LineChart.js.map +1 -0
- package/dist/components/dashboard/components/MetricCard.d.ts +8 -0
- package/dist/components/dashboard/components/MetricCard.d.ts.map +1 -0
- package/dist/components/dashboard/components/MetricCard.js +163 -0
- package/dist/components/dashboard/components/MetricCard.js.map +1 -0
- package/dist/components/dashboard/components/SourceLink.d.ts +8 -0
- package/dist/components/dashboard/components/SourceLink.d.ts.map +1 -0
- package/dist/components/dashboard/components/SourceLink.js +39 -0
- package/dist/components/dashboard/components/SourceLink.js.map +1 -0
- package/dist/components/dashboard/components/TimeRangeSelector.d.ts +8 -0
- package/dist/components/dashboard/components/TimeRangeSelector.d.ts.map +1 -0
- package/dist/components/dashboard/components/TimeRangeSelector.js +167 -0
- package/dist/components/dashboard/components/TimeRangeSelector.js.map +1 -0
- package/dist/components/dashboard/components/index.d.ts +6 -0
- package/dist/components/dashboard/components/index.d.ts.map +1 -0
- package/dist/components/dashboard/components/index.js +6 -0
- package/dist/components/dashboard/components/index.js.map +1 -0
- package/dist/components/dashboard/index.d.ts +6 -0
- package/dist/components/dashboard/index.d.ts.map +1 -0
- package/dist/components/dashboard/index.js +8 -0
- package/dist/components/dashboard/index.js.map +1 -0
- package/dist/components/dashboard/types.d.ts +74 -0
- package/dist/components/dashboard/types.d.ts.map +1 -0
- package/dist/components/dashboard/types.js +8 -0
- package/dist/components/dashboard/types.js.map +1 -0
- package/dist/edges/CustomEdge.d.ts.map +1 -1
- package/dist/edges/CustomEdge.js +1 -0
- package/dist/edges/CustomEdge.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
- package/src/components/GraphRenderer.tsx +65 -1
- package/src/components/dashboard/DashboardRenderer.tsx +317 -0
- package/src/components/dashboard/MetricPanel.tsx +243 -0
- package/src/components/dashboard/MockDataProvider.ts +330 -0
- package/src/components/dashboard/components/BarChart.tsx +299 -0
- package/src/components/dashboard/components/LineChart.tsx +279 -0
- package/src/components/dashboard/components/MetricCard.tsx +270 -0
- package/src/components/dashboard/components/SourceLink.tsx +63 -0
- package/src/components/dashboard/components/TimeRangeSelector.tsx +280 -0
- package/src/components/dashboard/components/index.ts +5 -0
- package/src/components/dashboard/index.ts +47 -0
- package/src/components/dashboard/types.ts +126 -0
- package/src/edges/CustomEdge.tsx +1 -0
- package/src/index.ts +49 -0
- package/src/stories/CanvasEdgeTypes.stories.tsx +159 -2
- package/src/stories/dashboard/DashboardRenderer.stories.tsx +263 -0
- package/src/stories/dashboard/sample-dashboards/activity-feed-analytics.dashboard.json +300 -0
- package/src/stories/data/graph-converter-test-execution.json +49 -49
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BarChart
|
|
3
|
+
*
|
|
4
|
+
* Simple SVG-based bar chart for grouped/stacked data.
|
|
5
|
+
* For prototyping - can be replaced with a more robust charting library later.
|
|
6
|
+
*/
|
|
7
|
+
import type { BarChartProps } from '../types';
|
|
8
|
+
export declare function BarChart({ title, data, xKey, series, stacked, unit, height, onClick, }: BarChartProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=BarChart.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BarChart.d.ts","sourceRoot":"","sources":["../../../../src/components/dashboard/components/BarChart.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAW9C,wBAAgB,QAAQ,CAAC,EACvB,KAAK,EACL,IAAI,EACJ,IAAa,EACb,MAAM,EACN,OAAe,EACf,IAAI,EACJ,MAAY,EACZ,OAAO,GACR,EAAE,aAAa,2CAsQf"}
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* BarChart
|
|
4
|
+
*
|
|
5
|
+
* Simple SVG-based bar chart for grouped/stacked data.
|
|
6
|
+
* For prototyping - can be replaced with a more robust charting library later.
|
|
7
|
+
*/
|
|
8
|
+
import { useMemo } from 'react';
|
|
9
|
+
import { useTheme } from '@principal-ade/industry-theme';
|
|
10
|
+
const CHART_COLORS = [
|
|
11
|
+
'#3b82f6',
|
|
12
|
+
'#22c55e',
|
|
13
|
+
'#f59e0b',
|
|
14
|
+
'#ef4444',
|
|
15
|
+
'#8b5cf6',
|
|
16
|
+
'#ec4899', // pink
|
|
17
|
+
];
|
|
18
|
+
export function BarChart({ title, data, xKey = 'date', series, stacked = false, unit, height = 200, onClick, }) {
|
|
19
|
+
const { theme } = useTheme();
|
|
20
|
+
const padding = { top: 20, right: 20, bottom: 40, left: 60 };
|
|
21
|
+
const chartWidth = 400;
|
|
22
|
+
const chartHeight = height;
|
|
23
|
+
const { bars, yAxisLabels, xAxisLabels } = useMemo(() => {
|
|
24
|
+
if (!data || data.length === 0 || !series || series.length === 0) {
|
|
25
|
+
return { bars: [], yAxisLabels: [], xAxisLabels: [], maxValue: 0 };
|
|
26
|
+
}
|
|
27
|
+
// Find max value
|
|
28
|
+
let max = 0;
|
|
29
|
+
for (const point of data) {
|
|
30
|
+
if (stacked) {
|
|
31
|
+
// Sum all series for stacked bars
|
|
32
|
+
let sum = 0;
|
|
33
|
+
for (const key of series) {
|
|
34
|
+
const val = point[key];
|
|
35
|
+
if (typeof val === 'number')
|
|
36
|
+
sum += val;
|
|
37
|
+
}
|
|
38
|
+
if (sum > max)
|
|
39
|
+
max = sum;
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
// Max of individual values for grouped bars
|
|
43
|
+
for (const key of series) {
|
|
44
|
+
const val = point[key];
|
|
45
|
+
if (typeof val === 'number' && val > max)
|
|
46
|
+
max = val;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
max = max * 1.1; // Add padding
|
|
51
|
+
const innerWidth = chartWidth - padding.left - padding.right;
|
|
52
|
+
const innerHeight = chartHeight - padding.top - padding.bottom;
|
|
53
|
+
const barGroupWidth = innerWidth / data.length;
|
|
54
|
+
const barPadding = barGroupWidth * 0.2;
|
|
55
|
+
const barAreaWidth = barGroupWidth - barPadding;
|
|
56
|
+
const barsResult = [];
|
|
57
|
+
data.forEach((point, i) => {
|
|
58
|
+
const groupX = padding.left + i * barGroupWidth + barPadding / 2;
|
|
59
|
+
if (stacked) {
|
|
60
|
+
// Stacked bars
|
|
61
|
+
let currentY = padding.top + innerHeight;
|
|
62
|
+
series.forEach((key, keyIndex) => {
|
|
63
|
+
const val = point[key];
|
|
64
|
+
if (typeof val === 'number') {
|
|
65
|
+
const barHeight = (val / max) * innerHeight;
|
|
66
|
+
currentY -= barHeight;
|
|
67
|
+
barsResult.push({
|
|
68
|
+
x: groupX,
|
|
69
|
+
y: currentY,
|
|
70
|
+
width: barAreaWidth,
|
|
71
|
+
height: barHeight,
|
|
72
|
+
color: CHART_COLORS[keyIndex % CHART_COLORS.length],
|
|
73
|
+
label: key,
|
|
74
|
+
value: val,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
// Grouped bars
|
|
81
|
+
const singleBarWidth = barAreaWidth / series.length;
|
|
82
|
+
series.forEach((key, keyIndex) => {
|
|
83
|
+
const val = point[key];
|
|
84
|
+
if (typeof val === 'number') {
|
|
85
|
+
const barHeight = (val / max) * innerHeight;
|
|
86
|
+
const barX = groupX + keyIndex * singleBarWidth;
|
|
87
|
+
const barY = padding.top + innerHeight - barHeight;
|
|
88
|
+
barsResult.push({
|
|
89
|
+
x: barX,
|
|
90
|
+
y: barY,
|
|
91
|
+
width: singleBarWidth * 0.9,
|
|
92
|
+
height: barHeight,
|
|
93
|
+
color: CHART_COLORS[keyIndex % CHART_COLORS.length],
|
|
94
|
+
label: key,
|
|
95
|
+
value: val,
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
// Y-axis labels
|
|
102
|
+
const yLabels = [];
|
|
103
|
+
for (let i = 0; i <= 4; i++) {
|
|
104
|
+
const value = (max / 4) * (4 - i);
|
|
105
|
+
const y = padding.top + (i / 4) * innerHeight;
|
|
106
|
+
yLabels.push({
|
|
107
|
+
value: formatNumber(value),
|
|
108
|
+
y,
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
// X-axis labels
|
|
112
|
+
const xLabels = [];
|
|
113
|
+
data.forEach((point, i) => {
|
|
114
|
+
const x = padding.left + i * barGroupWidth + barGroupWidth / 2;
|
|
115
|
+
xLabels.push({
|
|
116
|
+
value: String(point[xKey] || '').slice(-5),
|
|
117
|
+
x,
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
return {
|
|
121
|
+
bars: barsResult,
|
|
122
|
+
yAxisLabels: yLabels,
|
|
123
|
+
xAxisLabels: xLabels,
|
|
124
|
+
maxValue: max,
|
|
125
|
+
};
|
|
126
|
+
}, [data, series, xKey, stacked, chartWidth, chartHeight]);
|
|
127
|
+
return (_jsxs("div", { onClick: onClick, style: {
|
|
128
|
+
backgroundColor: theme.colors.surface || theme.colors.background,
|
|
129
|
+
border: `1px solid ${theme.colors.border}`,
|
|
130
|
+
borderRadius: theme.radii?.[2] || 8,
|
|
131
|
+
padding: theme.space?.[3] || 16,
|
|
132
|
+
cursor: onClick ? 'pointer' : 'default',
|
|
133
|
+
fontFamily: theme.fonts.body,
|
|
134
|
+
}, children: [_jsxs("div", { style: {
|
|
135
|
+
fontSize: theme.fontSizes[1],
|
|
136
|
+
fontWeight: theme.fontWeights.medium,
|
|
137
|
+
color: theme.colors.text,
|
|
138
|
+
marginBottom: theme.space?.[3] || 16,
|
|
139
|
+
}, children: [title, unit && (_jsxs("span", { style: { color: theme.colors.textSecondary, fontWeight: theme.fontWeights.body }, children: [' ', "(", unit, ")"] }))] }), _jsxs("svg", { width: "100%", height: chartHeight, viewBox: `0 0 ${chartWidth} ${chartHeight}`, preserveAspectRatio: "xMidYMid meet", children: [yAxisLabels.map((label, i) => (_jsx("line", { x1: padding.left, y1: label.y, x2: chartWidth - padding.right, y2: label.y, stroke: theme.colors.border, strokeDasharray: "4 4", opacity: 0.5 }, i))), yAxisLabels.map((label, i) => (_jsx("text", { x: padding.left - 8, y: label.y, textAnchor: "end", dominantBaseline: "middle", fontSize: theme.fontSizes[0], fontFamily: theme.fonts.monospace, fill: theme.colors.textSecondary, children: label.value }, i))), xAxisLabels.map((label, i) => (_jsx("text", { x: label.x, y: chartHeight - padding.bottom + 20, textAnchor: "middle", fontSize: theme.fontSizes[0], fontFamily: theme.fonts.monospace, fill: theme.colors.textSecondary, children: label.value }, i))), bars.map((bar, i) => (_jsx("rect", { x: bar.x, y: bar.y, width: bar.width, height: bar.height, fill: bar.color, rx: 2 }, i)))] }), series && series.length > 1 && (_jsx("div", { style: {
|
|
140
|
+
display: 'flex',
|
|
141
|
+
gap: theme.space?.[3] || 16,
|
|
142
|
+
marginTop: theme.space?.[3] || 12,
|
|
143
|
+
justifyContent: 'center',
|
|
144
|
+
}, children: series.map((s, i) => (_jsxs("div", { style: {
|
|
145
|
+
display: 'flex',
|
|
146
|
+
alignItems: 'center',
|
|
147
|
+
gap: 6,
|
|
148
|
+
fontSize: theme.fontSizes[0],
|
|
149
|
+
color: theme.colors.textSecondary,
|
|
150
|
+
fontFamily: theme.fonts.body,
|
|
151
|
+
}, children: [_jsx("div", { style: {
|
|
152
|
+
width: 12,
|
|
153
|
+
height: 12,
|
|
154
|
+
backgroundColor: CHART_COLORS[i % CHART_COLORS.length],
|
|
155
|
+
borderRadius: 2,
|
|
156
|
+
} }), s] }, s))) }))] }));
|
|
157
|
+
}
|
|
158
|
+
function formatNumber(value) {
|
|
159
|
+
if (value >= 1000000)
|
|
160
|
+
return `${(value / 1000000).toFixed(1)}M`;
|
|
161
|
+
if (value >= 1000)
|
|
162
|
+
return `${(value / 1000).toFixed(1)}K`;
|
|
163
|
+
if (value % 1 !== 0)
|
|
164
|
+
return value.toFixed(1);
|
|
165
|
+
return Math.round(value).toString();
|
|
166
|
+
}
|
|
167
|
+
//# sourceMappingURL=BarChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BarChart.js","sourceRoot":"","sources":["../../../../src/components/dashboard/components/BarChart.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LineChart
|
|
3
|
+
*
|
|
4
|
+
* Simple SVG-based line chart for time series data.
|
|
5
|
+
* For prototyping - can be replaced with a more robust charting library later.
|
|
6
|
+
*/
|
|
7
|
+
import type { LineChartProps } from '../types';
|
|
8
|
+
export declare function LineChart({ title, data, xKey, yKey, series, unit, height, onClick, }: LineChartProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=LineChart.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LineChart.d.ts","sourceRoot":"","sources":["../../../../src/components/dashboard/components/LineChart.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAW/C,wBAAgB,SAAS,CAAC,EACxB,KAAK,EACL,IAAI,EACJ,IAAa,EACb,IAAc,EACd,MAAM,EACN,IAAI,EACJ,MAAY,EACZ,OAAO,GACR,EAAE,cAAc,2CAkPhB"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* LineChart
|
|
4
|
+
*
|
|
5
|
+
* Simple SVG-based line chart for time series data.
|
|
6
|
+
* For prototyping - can be replaced with a more robust charting library later.
|
|
7
|
+
*/
|
|
8
|
+
import { useMemo } from 'react';
|
|
9
|
+
import { useTheme } from '@principal-ade/industry-theme';
|
|
10
|
+
const CHART_COLORS = [
|
|
11
|
+
'#3b82f6',
|
|
12
|
+
'#22c55e',
|
|
13
|
+
'#f59e0b',
|
|
14
|
+
'#ef4444',
|
|
15
|
+
'#8b5cf6',
|
|
16
|
+
'#ec4899', // pink
|
|
17
|
+
];
|
|
18
|
+
export function LineChart({ title, data, xKey = 'date', yKey = 'value', series, unit, height = 200, onClick, }) {
|
|
19
|
+
const { theme } = useTheme();
|
|
20
|
+
const padding = { top: 20, right: 20, bottom: 40, left: 60 };
|
|
21
|
+
const chartWidth = 400;
|
|
22
|
+
const chartHeight = height;
|
|
23
|
+
const { paths, yAxisLabels, xAxisLabels } = useMemo(() => {
|
|
24
|
+
if (!data || data.length === 0) {
|
|
25
|
+
return { paths: [], yAxisLabels: [], xAxisLabels: [], maxValue: 0 };
|
|
26
|
+
}
|
|
27
|
+
// Determine which keys to plot
|
|
28
|
+
const keys = series || [yKey];
|
|
29
|
+
// Find max value across all series
|
|
30
|
+
let max = 0;
|
|
31
|
+
for (const point of data) {
|
|
32
|
+
for (const key of keys) {
|
|
33
|
+
const val = point[key];
|
|
34
|
+
if (typeof val === 'number' && val > max) {
|
|
35
|
+
max = val;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
// Add 10% padding to max
|
|
40
|
+
max = max * 1.1;
|
|
41
|
+
const innerWidth = chartWidth - padding.left - padding.right;
|
|
42
|
+
const innerHeight = chartHeight - padding.top - padding.bottom;
|
|
43
|
+
// Generate paths for each series
|
|
44
|
+
const pathsResult = [];
|
|
45
|
+
keys.forEach((key, keyIndex) => {
|
|
46
|
+
const points = [];
|
|
47
|
+
data.forEach((point, i) => {
|
|
48
|
+
const val = point[key];
|
|
49
|
+
if (typeof val === 'number') {
|
|
50
|
+
const x = padding.left + (i / (data.length - 1 || 1)) * innerWidth;
|
|
51
|
+
const y = padding.top + innerHeight - (val / max) * innerHeight;
|
|
52
|
+
points.push({ x, y });
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
if (points.length > 0) {
|
|
56
|
+
const pathD = points
|
|
57
|
+
.map((p, i) => `${i === 0 ? 'M' : 'L'} ${p.x} ${p.y}`)
|
|
58
|
+
.join(' ');
|
|
59
|
+
pathsResult.push({
|
|
60
|
+
path: pathD,
|
|
61
|
+
color: CHART_COLORS[keyIndex % CHART_COLORS.length],
|
|
62
|
+
label: key,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
// Y-axis labels (5 ticks)
|
|
67
|
+
const yLabels = [];
|
|
68
|
+
for (let i = 0; i <= 4; i++) {
|
|
69
|
+
const value = (max / 4) * (4 - i);
|
|
70
|
+
const y = padding.top + (i / 4) * innerHeight;
|
|
71
|
+
yLabels.push({
|
|
72
|
+
value: formatNumber(value),
|
|
73
|
+
y,
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
// X-axis labels (show first, middle, last)
|
|
77
|
+
const xLabels = [];
|
|
78
|
+
const indices = [0, Math.floor(data.length / 2), data.length - 1];
|
|
79
|
+
for (const idx of indices) {
|
|
80
|
+
if (data[idx]) {
|
|
81
|
+
const x = padding.left + (idx / (data.length - 1 || 1)) * innerWidth;
|
|
82
|
+
xLabels.push({
|
|
83
|
+
value: String(data[idx][xKey] || ''),
|
|
84
|
+
x,
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
return {
|
|
89
|
+
paths: pathsResult,
|
|
90
|
+
yAxisLabels: yLabels,
|
|
91
|
+
xAxisLabels: xLabels,
|
|
92
|
+
maxValue: max,
|
|
93
|
+
};
|
|
94
|
+
}, [data, series, yKey, xKey, chartWidth, chartHeight]);
|
|
95
|
+
return (_jsxs("div", { onClick: onClick, style: {
|
|
96
|
+
backgroundColor: theme.colors.surface || theme.colors.background,
|
|
97
|
+
border: `1px solid ${theme.colors.border}`,
|
|
98
|
+
borderRadius: theme.radii?.[2] || 8,
|
|
99
|
+
padding: theme.space?.[3] || 16,
|
|
100
|
+
cursor: onClick ? 'pointer' : 'default',
|
|
101
|
+
fontFamily: theme.fonts.body,
|
|
102
|
+
}, children: [_jsxs("div", { style: {
|
|
103
|
+
fontSize: theme.fontSizes[1],
|
|
104
|
+
fontWeight: theme.fontWeights.medium,
|
|
105
|
+
color: theme.colors.text,
|
|
106
|
+
marginBottom: theme.space?.[3] || 16,
|
|
107
|
+
}, children: [title, unit && (_jsxs("span", { style: { color: theme.colors.textSecondary, fontWeight: theme.fontWeights.body }, children: [' ', "(", unit, ")"] }))] }), _jsxs("svg", { width: "100%", height: chartHeight, viewBox: `0 0 ${chartWidth} ${chartHeight}`, preserveAspectRatio: "xMidYMid meet", children: [yAxisLabels.map((label, i) => (_jsx("line", { x1: padding.left, y1: label.y, x2: chartWidth - padding.right, y2: label.y, stroke: theme.colors.border, strokeDasharray: "4 4", opacity: 0.5 }, i))), yAxisLabels.map((label, i) => (_jsx("text", { x: padding.left - 8, y: label.y, textAnchor: "end", dominantBaseline: "middle", fontSize: theme.fontSizes[0], fontFamily: theme.fonts.monospace, fill: theme.colors.textSecondary, children: label.value }, i))), xAxisLabels.map((label, i) => (_jsx("text", { x: label.x, y: chartHeight - padding.bottom + 20, textAnchor: "middle", fontSize: theme.fontSizes[0], fontFamily: theme.fonts.monospace, fill: theme.colors.textSecondary, children: label.value }, i))), paths.map((p, i) => (_jsx("path", { d: p.path, fill: "none", stroke: p.color, strokeWidth: 2, strokeLinecap: "round", strokeLinejoin: "round" }, i))), paths.map((p, pathIndex) => {
|
|
108
|
+
const points = p.path.split(/[ML]/).filter(Boolean);
|
|
109
|
+
return points.map((point, i) => {
|
|
110
|
+
const [x, y] = point.trim().split(' ').map(Number);
|
|
111
|
+
return (_jsx("circle", { cx: x, cy: y, r: 3, fill: p.color }, `${pathIndex}-${i}`));
|
|
112
|
+
});
|
|
113
|
+
})] }), series && series.length > 1 && (_jsx("div", { style: {
|
|
114
|
+
display: 'flex',
|
|
115
|
+
gap: theme.space?.[3] || 16,
|
|
116
|
+
marginTop: theme.space?.[3] || 12,
|
|
117
|
+
justifyContent: 'center',
|
|
118
|
+
}, children: series.map((s, i) => (_jsxs("div", { style: {
|
|
119
|
+
display: 'flex',
|
|
120
|
+
alignItems: 'center',
|
|
121
|
+
gap: 6,
|
|
122
|
+
fontSize: theme.fontSizes[0],
|
|
123
|
+
color: theme.colors.textSecondary,
|
|
124
|
+
fontFamily: theme.fonts.body,
|
|
125
|
+
}, children: [_jsx("div", { style: {
|
|
126
|
+
width: 12,
|
|
127
|
+
height: 3,
|
|
128
|
+
backgroundColor: CHART_COLORS[i % CHART_COLORS.length],
|
|
129
|
+
borderRadius: 2,
|
|
130
|
+
} }), s] }, s))) }))] }));
|
|
131
|
+
}
|
|
132
|
+
function formatNumber(value) {
|
|
133
|
+
if (value >= 1000000)
|
|
134
|
+
return `${(value / 1000000).toFixed(1)}M`;
|
|
135
|
+
if (value >= 1000)
|
|
136
|
+
return `${(value / 1000).toFixed(1)}K`;
|
|
137
|
+
if (value % 1 !== 0)
|
|
138
|
+
return value.toFixed(1);
|
|
139
|
+
return Math.round(value).toString();
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=LineChart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LineChart.js","sourceRoot":"","sources":["../../../../src/components/dashboard/components/LineChart.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MetricCard
|
|
3
|
+
*
|
|
4
|
+
* Displays a single metric value with optional trend indicator and sparkline.
|
|
5
|
+
*/
|
|
6
|
+
import type { MetricCardProps } from '../types';
|
|
7
|
+
export declare function MetricCard({ title, value, unit, description, trend, changePercent, showTrend, showSparkline, sparklineData, thresholds, size, onClick, }: MetricCardProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=MetricCard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetricCard.d.ts","sourceRoot":"","sources":["../../../../src/components/dashboard/components/MetricCard.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAEhD,wBAAgB,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,IAAI,EACJ,WAAW,EACX,KAAK,EACL,aAAa,EACb,SAAgB,EAChB,aAAqB,EACrB,aAAa,EACb,UAAU,EACV,IAAe,EACf,OAAO,GACR,EAAE,eAAe,2CAuPjB"}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* MetricCard
|
|
4
|
+
*
|
|
5
|
+
* Displays a single metric value with optional trend indicator and sparkline.
|
|
6
|
+
*/
|
|
7
|
+
import { useTheme } from '@principal-ade/industry-theme';
|
|
8
|
+
export function MetricCard({ title, value, unit, description, trend, changePercent, showTrend = true, showSparkline = false, sparklineData, thresholds, size = 'medium', onClick, }) {
|
|
9
|
+
const { theme } = useTheme();
|
|
10
|
+
// Font size indices into theme.fontSizes array
|
|
11
|
+
// Typical array: [12, 14, 16, 20, 24, 32, 48]
|
|
12
|
+
const sizeConfig = {
|
|
13
|
+
small: {
|
|
14
|
+
padding: '12px 16px',
|
|
15
|
+
titleIndex: 0,
|
|
16
|
+
valueIndex: 4,
|
|
17
|
+
unitIndex: 0,
|
|
18
|
+
trendIndex: 0, // ~12px
|
|
19
|
+
},
|
|
20
|
+
medium: {
|
|
21
|
+
padding: '16px 20px',
|
|
22
|
+
titleIndex: 1,
|
|
23
|
+
valueIndex: 5,
|
|
24
|
+
unitIndex: 1,
|
|
25
|
+
trendIndex: 0, // ~12px
|
|
26
|
+
},
|
|
27
|
+
large: {
|
|
28
|
+
padding: '20px 24px',
|
|
29
|
+
titleIndex: 2,
|
|
30
|
+
valueIndex: 6,
|
|
31
|
+
unitIndex: 2,
|
|
32
|
+
trendIndex: 1, // ~14px
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
const config = sizeConfig[size];
|
|
36
|
+
const getValueColor = () => {
|
|
37
|
+
if (!thresholds || typeof value !== 'number') {
|
|
38
|
+
return theme.colors.text;
|
|
39
|
+
}
|
|
40
|
+
if (thresholds.critical !== undefined && value >= thresholds.critical) {
|
|
41
|
+
return theme.colors.error;
|
|
42
|
+
}
|
|
43
|
+
if (thresholds.warning !== undefined && value >= thresholds.warning) {
|
|
44
|
+
return theme.colors.warning;
|
|
45
|
+
}
|
|
46
|
+
return theme.colors.success;
|
|
47
|
+
};
|
|
48
|
+
const getTrendIcon = () => {
|
|
49
|
+
if (!trend || !showTrend)
|
|
50
|
+
return null;
|
|
51
|
+
const iconSize = size === 'small' ? 12 : 16;
|
|
52
|
+
const iconStyle = {
|
|
53
|
+
width: iconSize,
|
|
54
|
+
height: iconSize,
|
|
55
|
+
marginRight: 4,
|
|
56
|
+
};
|
|
57
|
+
if (trend === 'up') {
|
|
58
|
+
return (_jsx("svg", { style: iconStyle, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, children: _jsx("path", { d: "M7 17l5-5 5 5M7 7l5 5 5-5" }) }));
|
|
59
|
+
}
|
|
60
|
+
if (trend === 'down') {
|
|
61
|
+
return (_jsx("svg", { style: iconStyle, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, children: _jsx("path", { d: "M7 7l5 5 5-5M7 17l5-5 5 5" }) }));
|
|
62
|
+
}
|
|
63
|
+
return (_jsx("svg", { style: iconStyle, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, children: _jsx("path", { d: "M5 12h14" }) }));
|
|
64
|
+
};
|
|
65
|
+
const getTrendColor = () => {
|
|
66
|
+
if (!trend)
|
|
67
|
+
return theme.colors.textSecondary;
|
|
68
|
+
if (trend === 'up')
|
|
69
|
+
return theme.colors.success;
|
|
70
|
+
if (trend === 'down')
|
|
71
|
+
return theme.colors.error;
|
|
72
|
+
return theme.colors.textSecondary;
|
|
73
|
+
};
|
|
74
|
+
const formatValue = (val) => {
|
|
75
|
+
if (typeof val === 'string')
|
|
76
|
+
return val;
|
|
77
|
+
if (val >= 1000000)
|
|
78
|
+
return `${(val / 1000000).toFixed(1)}M`;
|
|
79
|
+
if (val >= 1000)
|
|
80
|
+
return `${(val / 1000).toFixed(1)}K`;
|
|
81
|
+
if (val % 1 !== 0)
|
|
82
|
+
return val.toFixed(1);
|
|
83
|
+
return val.toString();
|
|
84
|
+
};
|
|
85
|
+
const renderSparkline = () => {
|
|
86
|
+
if (!showSparkline || !sparklineData || sparklineData.length < 2)
|
|
87
|
+
return null;
|
|
88
|
+
const values = sparklineData
|
|
89
|
+
.map((point) => point.value)
|
|
90
|
+
.filter((v) => typeof v === 'number');
|
|
91
|
+
if (values.length < 2)
|
|
92
|
+
return null;
|
|
93
|
+
const minVal = Math.min(...values);
|
|
94
|
+
const maxVal = Math.max(...values);
|
|
95
|
+
const range = maxVal - minVal || 1;
|
|
96
|
+
const width = size === 'small' ? 100 : size === 'medium' ? 140 : 180;
|
|
97
|
+
const height = size === 'small' ? 24 : size === 'medium' ? 32 : 40;
|
|
98
|
+
const padding = 2;
|
|
99
|
+
const points = values.map((val, i) => {
|
|
100
|
+
const x = padding + (i / (values.length - 1)) * (width - padding * 2);
|
|
101
|
+
const y = height - padding - ((val - minVal) / range) * (height - padding * 2);
|
|
102
|
+
return `${x},${y}`;
|
|
103
|
+
});
|
|
104
|
+
const pathD = `M ${points.join(' L ')}`;
|
|
105
|
+
// Create gradient fill path
|
|
106
|
+
const fillPoints = [
|
|
107
|
+
`${padding},${height - padding}`,
|
|
108
|
+
...points,
|
|
109
|
+
`${width - padding},${height - padding}`,
|
|
110
|
+
];
|
|
111
|
+
const fillD = `M ${fillPoints.join(' L ')} Z`;
|
|
112
|
+
const lineColor = trend === 'up' ? theme.colors.success : trend === 'down' ? theme.colors.error : theme.colors.primary || theme.colors.accent;
|
|
113
|
+
return (_jsx("div", { style: { marginTop: theme.space?.[2] || 8 }, children: _jsxs("svg", { width: width, height: height, style: { display: 'block' }, children: [_jsx("defs", { children: _jsxs("linearGradient", { id: `sparkline-gradient-${title}`, x1: "0%", y1: "0%", x2: "0%", y2: "100%", children: [_jsx("stop", { offset: "0%", stopColor: lineColor, stopOpacity: 0.3 }), _jsx("stop", { offset: "100%", stopColor: lineColor, stopOpacity: 0.05 })] }) }), _jsx("path", { d: fillD, fill: `url(#sparkline-gradient-${title})` }), _jsx("path", { d: pathD, fill: "none", stroke: lineColor, strokeWidth: 1.5, strokeLinecap: "round", strokeLinejoin: "round" })] }) }));
|
|
114
|
+
};
|
|
115
|
+
return (_jsxs("div", { onClick: onClick, style: {
|
|
116
|
+
backgroundColor: theme.colors.surface || theme.colors.background,
|
|
117
|
+
border: `1px solid ${theme.colors.border}`,
|
|
118
|
+
borderRadius: theme.radii?.[2] || 8,
|
|
119
|
+
padding: config.padding,
|
|
120
|
+
cursor: onClick ? 'pointer' : 'default',
|
|
121
|
+
transition: 'border-color 0.2s, box-shadow 0.2s',
|
|
122
|
+
minWidth: size === 'small' ? 140 : size === 'medium' ? 180 : 220,
|
|
123
|
+
fontFamily: theme.fonts.body,
|
|
124
|
+
}, onMouseEnter: (e) => {
|
|
125
|
+
if (onClick) {
|
|
126
|
+
e.currentTarget.style.borderColor = theme.colors.primary || theme.colors.accent;
|
|
127
|
+
}
|
|
128
|
+
}, onMouseLeave: (e) => {
|
|
129
|
+
e.currentTarget.style.borderColor = theme.colors.border;
|
|
130
|
+
}, children: [_jsx("div", { style: {
|
|
131
|
+
fontSize: theme.fontSizes[config.titleIndex],
|
|
132
|
+
color: theme.colors.textSecondary,
|
|
133
|
+
marginBottom: theme.space?.[2] || 8,
|
|
134
|
+
fontWeight: theme.fontWeights.medium,
|
|
135
|
+
}, children: title }), _jsxs("div", { style: {
|
|
136
|
+
display: 'flex',
|
|
137
|
+
alignItems: 'baseline',
|
|
138
|
+
gap: 4,
|
|
139
|
+
}, children: [_jsx("span", { style: {
|
|
140
|
+
fontSize: theme.fontSizes[config.valueIndex],
|
|
141
|
+
fontWeight: theme.fontWeights.semibold,
|
|
142
|
+
color: getValueColor(),
|
|
143
|
+
fontVariantNumeric: 'tabular-nums',
|
|
144
|
+
fontFamily: theme.fonts.monospace,
|
|
145
|
+
}, children: formatValue(value) }), unit && (_jsx("span", { style: {
|
|
146
|
+
fontSize: theme.fontSizes[config.unitIndex],
|
|
147
|
+
color: theme.colors.textSecondary,
|
|
148
|
+
}, children: unit }))] }), showTrend && (trend || changePercent !== undefined) && (_jsxs("div", { style: {
|
|
149
|
+
display: 'flex',
|
|
150
|
+
alignItems: 'center',
|
|
151
|
+
marginTop: theme.space?.[2] || 8,
|
|
152
|
+
fontSize: theme.fontSizes[config.trendIndex],
|
|
153
|
+
color: getTrendColor(),
|
|
154
|
+
fontFamily: theme.fonts.monospace,
|
|
155
|
+
}, children: [getTrendIcon(), changePercent !== undefined && (_jsxs("span", { children: [changePercent > 0 ? '+' : '', changePercent.toFixed(1), "%"] }))] })), description && (_jsx("div", { style: {
|
|
156
|
+
fontSize: theme.fontSizes[config.trendIndex],
|
|
157
|
+
color: theme.colors.textSecondary,
|
|
158
|
+
marginTop: theme.space?.[2] || 8,
|
|
159
|
+
lineHeight: theme.lineHeights.body,
|
|
160
|
+
opacity: 0.8,
|
|
161
|
+
}, children: description })), renderSparkline()] }));
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=MetricCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetricCard.js","sourceRoot":"","sources":["../../../../src/components/dashboard/components/MetricCard.tsx"],"names":[],"mappings":";AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AAGzD,MAAM,UAAU,UAAU,CAAC,EACzB,KAAK,EACL,KAAK,EACL,IAAI,EACJ,WAAW,EACX,KAAK,EACL,aAAa,EACb,SAAS,GAAG,IAAI,EAChB,aAAa,GAAG,KAAK,EACrB,aAAa,EACb,UAAU,EACV,IAAI,GAAG,QAAQ,EACf,OAAO,GACS;IAChB,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAC;IAE7B,+CAA+C;IAC/C,8CAA8C;IAC9C,MAAM,UAAU,GAAG;QACjB,KAAK,EAAE;YACL,OAAO,EAAE,WAAW;YACpB,UAAU,EAAE,CAAC;YACb,UAAU,EAAE,CAAC;YACb,SAAS,EAAE,CAAC;YACZ,UAAU,EAAE,CAAC,EAAK,QAAQ;SAC3B;QACD,MAAM,EAAE;YACN,OAAO,EAAE,WAAW;YACpB,UAAU,EAAE,CAAC;YACb,UAAU,EAAE,CAAC;YACb,SAAS,EAAE,CAAC;YACZ,UAAU,EAAE,CAAC,EAAK,QAAQ;SAC3B;QACD,KAAK,EAAE;YACL,OAAO,EAAE,WAAW;YACpB,UAAU,EAAE,CAAC;YACb,UAAU,EAAE,CAAC;YACb,SAAS,EAAE,CAAC;YACZ,UAAU,EAAE,CAAC,EAAK,QAAQ;SAC3B;KACF,CAAC;IAEF,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;IAEhC,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,IAAI,CAAC,UAAU,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC5C,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC;SAC1B;QACD,IAAI,UAAU,CAAC,QAAQ,KAAK,SAAS,IAAI,KAAK,IAAI,UAAU,CAAC,QAAQ,EAAE;YACrE,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;SAC3B;QACD,IAAI,UAAU,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,IAAI,UAAU,CAAC,OAAO,EAAE;YACnE,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;SAC7B;QACD,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;IAC9B,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QAEtC,MAAM,QAAQ,GAAG,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5C,MAAM,SAAS,GAAwB;YACrC,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,WAAW,EAAE,CAAC;SACf,CAAC;QAEF,IAAI,KAAK,KAAK,IAAI,EAAE;YAClB,OAAO,CACL,cAAK,KAAK,EAAE,SAAS,EAAE,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,CAAC,YACzF,eAAM,CAAC,EAAC,2BAA2B,GAAG,GAClC,CACP,CAAC;SACH;QACD,IAAI,KAAK,KAAK,MAAM,EAAE;YACpB,OAAO,CACL,cAAK,KAAK,EAAE,SAAS,EAAE,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,CAAC,YACzF,eAAM,CAAC,EAAC,2BAA2B,GAAG,GAClC,CACP,CAAC;SACH;QACD,OAAO,CACL,cAAK,KAAK,EAAE,SAAS,EAAE,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAE,CAAC,YACzF,eAAM,CAAC,EAAC,UAAU,GAAG,GACjB,CACP,CAAC;IACJ,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC;QAC9C,IAAI,KAAK,KAAK,IAAI;YAAE,OAAO,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;QAChD,IAAI,KAAK,KAAK,MAAM;YAAE,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAChD,OAAO,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC;IACpC,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,CAAC,GAAoB,EAAU,EAAE;QACnD,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,GAAG,CAAC;QACxC,IAAI,GAAG,IAAI,OAAO;YAAE,OAAO,GAAG,CAAC,GAAG,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;QAC5D,IAAI,GAAG,IAAI,IAAI;YAAE,OAAO,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;QACtD,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC;YAAE,OAAO,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACzC,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;IACxB,CAAC,CAAC;IAEF,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,IAAI,CAAC,aAAa,IAAI,CAAC,aAAa,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAE9E,MAAM,MAAM,GAAG,aAAa;aACzB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC;aAC3B,MAAM,CAAC,CAAC,CAAC,EAAe,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC;QAErD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAEnC,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QACnC,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QACnC,MAAM,KAAK,GAAG,MAAM,GAAG,MAAM,IAAI,CAAC,CAAC;QAEnC,MAAM,KAAK,GAAG,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QACrE,MAAM,MAAM,GAAG,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACnE,MAAM,OAAO,GAAG,CAAC,CAAC;QAElB,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;YACnC,MAAM,CAAC,GAAG,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC;YACtE,MAAM,CAAC,GAAG,MAAM,GAAG,OAAO,GAAG,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,MAAM,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC;YAC/E,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QAExC,4BAA4B;QAC5B,MAAM,UAAU,GAAG;YACjB,GAAG,OAAO,IAAI,MAAM,GAAG,OAAO,EAAE;YAChC,GAAG,MAAM;YACT,GAAG,KAAK,GAAG,OAAO,IAAI,MAAM,GAAG,OAAO,EAAE;SACzC,CAAC;QACF,MAAM,KAAK,GAAG,KAAK,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QAE9C,MAAM,SAAS,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;QAE9I,OAAO,CACL,cAAK,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,YAC9C,eAAK,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,aAC5D,yBACE,0BAAgB,EAAE,EAAE,sBAAsB,KAAK,EAAE,EAAE,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,MAAM,aAClF,eAAM,MAAM,EAAC,IAAI,EAAC,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,GAAI,EAC5D,eAAM,MAAM,EAAC,MAAM,EAAC,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,GAAI,IAChD,GACZ,EACP,eAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,2BAA2B,KAAK,GAAG,GAAI,EAC7D,eAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,EAAC,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,EAAE,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,GAAG,IAC5G,GACF,CACP,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO,CACL,eACE,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE;YACL,eAAe,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,UAAU;YAChE,MAAM,EAAE,aAAa,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE;YAC1C,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YACnC,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;YACvC,UAAU,EAAE,oCAAoC;YAChD,QAAQ,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;YAChE,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI;SAC7B,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,IAAI,OAAO,EAAE;gBACX,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;aACjF;QACH,CAAC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;QAC1D,CAAC,aAGD,cACE,KAAK,EAAE;oBACL,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC;oBAC5C,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,aAAa;oBACjC,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;oBACnC,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,MAAM;iBACrC,YAEA,KAAK,GACF,EAGN,eACE,KAAK,EAAE;oBACL,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,UAAU;oBACtB,GAAG,EAAE,CAAC;iBACP,aAED,eACE,KAAK,EAAE;4BACL,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC;4BAC5C,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,QAAQ;4BACtC,KAAK,EAAE,aAAa,EAAE;4BACtB,kBAAkB,EAAE,cAAc;4BAClC,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS;yBAClC,YAEA,WAAW,CAAC,KAAK,CAAC,GACd,EACN,IAAI,IAAI,CACP,eACE,KAAK,EAAE;4BACL,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;4BAC3C,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,aAAa;yBAClC,YAEA,IAAI,GACA,CACR,IACG,EAGL,SAAS,IAAI,CAAC,KAAK,IAAI,aAAa,KAAK,SAAS,CAAC,IAAI,CACtD,eACE,KAAK,EAAE;oBACL,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,SAAS,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;oBAChC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC;oBAC5C,KAAK,EAAE,aAAa,EAAE;oBACtB,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS;iBAClC,aAEA,YAAY,EAAE,EACd,aAAa,KAAK,SAAS,IAAI,CAC9B,2BACG,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAC5B,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,SACpB,CACR,IACG,CACP,EAGA,WAAW,IAAI,CACd,cACE,KAAK,EAAE;oBACL,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC;oBAC5C,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,aAAa;oBACjC,SAAS,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;oBAChC,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,IAAI;oBAClC,OAAO,EAAE,GAAG;iBACb,YAEA,WAAW,GACR,CACP,EAGA,eAAe,EAAE,IACd,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SourceLink
|
|
3
|
+
*
|
|
4
|
+
* Displays a link to the workflow/canvas that sources a metric.
|
|
5
|
+
*/
|
|
6
|
+
import type { SourceLinkProps } from '../types';
|
|
7
|
+
export declare function SourceLink({ source, onClick }: SourceLinkProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=SourceLink.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceLink.d.ts","sourceRoot":"","sources":["../../../../src/components/dashboard/components/SourceLink.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAEhD,wBAAgB,UAAU,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,eAAe,2CAqD9D"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* SourceLink
|
|
4
|
+
*
|
|
5
|
+
* Displays a link to the workflow/canvas that sources a metric.
|
|
6
|
+
*/
|
|
7
|
+
import { useTheme } from '@principal-ade/industry-theme';
|
|
8
|
+
export function SourceLink({ source, onClick }) {
|
|
9
|
+
const { theme } = useTheme();
|
|
10
|
+
const formatSource = () => {
|
|
11
|
+
const parts = [source.storyboard, source.workflow];
|
|
12
|
+
if (source.nodes && source.nodes.length > 0) {
|
|
13
|
+
parts.push(source.nodes.join(', '));
|
|
14
|
+
}
|
|
15
|
+
if (source.event) {
|
|
16
|
+
parts.push(source.event);
|
|
17
|
+
}
|
|
18
|
+
return parts.join(' → ');
|
|
19
|
+
};
|
|
20
|
+
return (_jsxs("button", { onClick: () => onClick?.(source), style: {
|
|
21
|
+
display: 'inline-flex',
|
|
22
|
+
alignItems: 'center',
|
|
23
|
+
gap: 6,
|
|
24
|
+
padding: '4px 8px',
|
|
25
|
+
fontSize: theme.fontSizes[0],
|
|
26
|
+
fontFamily: theme.fonts.body,
|
|
27
|
+
color: theme.colors.primary || theme.colors.accent,
|
|
28
|
+
backgroundColor: 'transparent',
|
|
29
|
+
border: `1px solid ${theme.colors.border}`,
|
|
30
|
+
borderRadius: theme.radii?.[1] || 4,
|
|
31
|
+
cursor: 'pointer',
|
|
32
|
+
transition: 'background-color 0.2s',
|
|
33
|
+
}, onMouseEnter: (e) => {
|
|
34
|
+
e.currentTarget.style.backgroundColor = theme.colors.surface || theme.colors.background;
|
|
35
|
+
}, onMouseLeave: (e) => {
|
|
36
|
+
e.currentTarget.style.backgroundColor = 'transparent';
|
|
37
|
+
}, children: [_jsxs("svg", { width: 12, height: 12, viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: 2, children: [_jsx("path", { d: "M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71" }), _jsx("path", { d: "M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71" })] }), _jsx("span", { style: { fontFamily: theme.fonts.monospace }, children: formatSource() })] }));
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=SourceLink.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SourceLink.js","sourceRoot":"","sources":["../../../../src/components/dashboard/components/SourceLink.tsx"],"names":[],"mappings":";AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AAGzD,MAAM,UAAU,UAAU,CAAC,EAAE,MAAM,EAAE,OAAO,EAAmB;IAC7D,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAC;IAE7B,MAAM,YAAY,GAAG,GAAG,EAAE;QACxB,MAAM,KAAK,GAAG,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3C,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SACrC;QACD,IAAI,MAAM,CAAC,KAAK,EAAE;YAChB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SAC1B;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC,CAAC;IAEF,OAAO,CACL,kBACE,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,EAChC,KAAK,EAAE;YACL,OAAO,EAAE,aAAa;YACtB,UAAU,EAAE,QAAQ;YACpB,GAAG,EAAE,CAAC;YACN,OAAO,EAAE,SAAS;YAClB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;YAC5B,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI;YAC5B,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM;YAClD,eAAe,EAAE,aAAa;YAC9B,MAAM,EAAE,aAAa,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE;YAC1C,YAAY,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YACnC,MAAM,EAAE,SAAS;YACjB,UAAU,EAAE,uBAAuB;SACpC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC;QAC1F,CAAC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,eAAe,GAAG,aAAa,CAAC;QACxD,CAAC,aAGD,eACE,KAAK,EAAE,EAAE,EACT,MAAM,EAAE,EAAE,EACV,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,MAAM,EAAC,cAAc,EACrB,WAAW,EAAE,CAAC,aAEd,eAAM,CAAC,EAAC,6DAA6D,GAAG,EACxE,eAAM,CAAC,EAAC,8DAA8D,GAAG,IACrE,EACN,eAAM,KAAK,EAAE,EAAE,UAAU,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,EAAE,YAAG,YAAY,EAAE,GAAQ,IACpE,CACV,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TimeRangeSelector
|
|
3
|
+
*
|
|
4
|
+
* Dropdown selector for time range and auto-refresh interval.
|
|
5
|
+
*/
|
|
6
|
+
import type { TimeRangeSelectorProps } from '../types';
|
|
7
|
+
export declare function TimeRangeSelector({ timeRange, onTimeRangeChange, refreshInterval, onRefreshIntervalChange, config, }: TimeRangeSelectorProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=TimeRangeSelector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TimeRangeSelector.d.ts","sourceRoot":"","sources":["../../../../src/components/dashboard/components/TimeRangeSelector.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,OAAO,KAAK,EAAE,sBAAsB,EAAoC,MAAM,UAAU,CAAC;AAyCzF,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,iBAAiB,EACjB,eAAuB,EACvB,uBAAuB,EACvB,MAAM,GACP,EAAE,sBAAsB,2CAgOxB"}
|