@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.
Files changed (74) hide show
  1. package/dist/components/GraphRenderer.d.ts +15 -0
  2. package/dist/components/GraphRenderer.d.ts.map +1 -1
  3. package/dist/components/GraphRenderer.js +34 -4
  4. package/dist/components/GraphRenderer.js.map +1 -1
  5. package/dist/components/dashboard/DashboardRenderer.d.ts +9 -0
  6. package/dist/components/dashboard/DashboardRenderer.d.ts.map +1 -0
  7. package/dist/components/dashboard/DashboardRenderer.js +179 -0
  8. package/dist/components/dashboard/DashboardRenderer.js.map +1 -0
  9. package/dist/components/dashboard/MetricPanel.d.ts +9 -0
  10. package/dist/components/dashboard/MetricPanel.d.ts.map +1 -0
  11. package/dist/components/dashboard/MetricPanel.js +103 -0
  12. package/dist/components/dashboard/MetricPanel.js.map +1 -0
  13. package/dist/components/dashboard/MockDataProvider.d.ts +30 -0
  14. package/dist/components/dashboard/MockDataProvider.d.ts.map +1 -0
  15. package/dist/components/dashboard/MockDataProvider.js +270 -0
  16. package/dist/components/dashboard/MockDataProvider.js.map +1 -0
  17. package/dist/components/dashboard/components/BarChart.d.ts +9 -0
  18. package/dist/components/dashboard/components/BarChart.d.ts.map +1 -0
  19. package/dist/components/dashboard/components/BarChart.js +167 -0
  20. package/dist/components/dashboard/components/BarChart.js.map +1 -0
  21. package/dist/components/dashboard/components/LineChart.d.ts +9 -0
  22. package/dist/components/dashboard/components/LineChart.d.ts.map +1 -0
  23. package/dist/components/dashboard/components/LineChart.js +141 -0
  24. package/dist/components/dashboard/components/LineChart.js.map +1 -0
  25. package/dist/components/dashboard/components/MetricCard.d.ts +8 -0
  26. package/dist/components/dashboard/components/MetricCard.d.ts.map +1 -0
  27. package/dist/components/dashboard/components/MetricCard.js +163 -0
  28. package/dist/components/dashboard/components/MetricCard.js.map +1 -0
  29. package/dist/components/dashboard/components/SourceLink.d.ts +8 -0
  30. package/dist/components/dashboard/components/SourceLink.d.ts.map +1 -0
  31. package/dist/components/dashboard/components/SourceLink.js +39 -0
  32. package/dist/components/dashboard/components/SourceLink.js.map +1 -0
  33. package/dist/components/dashboard/components/TimeRangeSelector.d.ts +8 -0
  34. package/dist/components/dashboard/components/TimeRangeSelector.d.ts.map +1 -0
  35. package/dist/components/dashboard/components/TimeRangeSelector.js +167 -0
  36. package/dist/components/dashboard/components/TimeRangeSelector.js.map +1 -0
  37. package/dist/components/dashboard/components/index.d.ts +6 -0
  38. package/dist/components/dashboard/components/index.d.ts.map +1 -0
  39. package/dist/components/dashboard/components/index.js +6 -0
  40. package/dist/components/dashboard/components/index.js.map +1 -0
  41. package/dist/components/dashboard/index.d.ts +6 -0
  42. package/dist/components/dashboard/index.d.ts.map +1 -0
  43. package/dist/components/dashboard/index.js +8 -0
  44. package/dist/components/dashboard/index.js.map +1 -0
  45. package/dist/components/dashboard/types.d.ts +74 -0
  46. package/dist/components/dashboard/types.d.ts.map +1 -0
  47. package/dist/components/dashboard/types.js +8 -0
  48. package/dist/components/dashboard/types.js.map +1 -0
  49. package/dist/edges/CustomEdge.d.ts.map +1 -1
  50. package/dist/edges/CustomEdge.js +1 -0
  51. package/dist/edges/CustomEdge.js.map +1 -1
  52. package/dist/index.d.ts +2 -0
  53. package/dist/index.d.ts.map +1 -1
  54. package/dist/index.js +2 -0
  55. package/dist/index.js.map +1 -1
  56. package/package.json +3 -3
  57. package/src/components/GraphRenderer.tsx +65 -1
  58. package/src/components/dashboard/DashboardRenderer.tsx +317 -0
  59. package/src/components/dashboard/MetricPanel.tsx +243 -0
  60. package/src/components/dashboard/MockDataProvider.ts +330 -0
  61. package/src/components/dashboard/components/BarChart.tsx +299 -0
  62. package/src/components/dashboard/components/LineChart.tsx +279 -0
  63. package/src/components/dashboard/components/MetricCard.tsx +270 -0
  64. package/src/components/dashboard/components/SourceLink.tsx +63 -0
  65. package/src/components/dashboard/components/TimeRangeSelector.tsx +280 -0
  66. package/src/components/dashboard/components/index.ts +5 -0
  67. package/src/components/dashboard/index.ts +47 -0
  68. package/src/components/dashboard/types.ts +126 -0
  69. package/src/edges/CustomEdge.tsx +1 -0
  70. package/src/index.ts +49 -0
  71. package/src/stories/CanvasEdgeTypes.stories.tsx +159 -2
  72. package/src/stories/dashboard/DashboardRenderer.stories.tsx +263 -0
  73. package/src/stories/dashboard/sample-dashboards/activity-feed-analytics.dashboard.json +300 -0
  74. 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":"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"}
@@ -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"}