@principal-ai/principal-view-react 0.14.31 → 0.14.33
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.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OtelEventNode.d.ts","sourceRoot":"","sources":["../../../src/nodes/otel/OtelEventNode.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAoBrD,MAAM,WAAW,iBAAkB,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAChE,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC5E,CAAC;IACF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,IAAI,EAAE;QACJ,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,GAAG,UAAU,GAAG,aAAa,CAAC;QAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;QACtB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC3E,KAAK,CAAC,EAAE;YAAE,IAAI,CAAC,EAAE,MAAM,CAAC;YAAC,WAAW,CAAC,EAAE,MAAM,CAAC;YAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;SAAE,CAAC;QACtF,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,IAAI,CAAC,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC;KAC7B,CAAC;IACF,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,IAAI,CAAC;IAC7D,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"OtelEventNode.d.ts","sourceRoot":"","sources":["../../../src/nodes/otel/OtelEventNode.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAoBrD,MAAM,WAAW,iBAAkB,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAChE,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,EAAE;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;KAC5E,CAAC;IACF,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,IAAI,EAAE;QACJ,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,GAAG,UAAU,GAAG,aAAa,CAAC;QAC9C,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;QACtB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,KAAK,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC,CAAC;QAC3E,KAAK,CAAC,EAAE;YAAE,IAAI,CAAC,EAAE,MAAM,CAAC;YAAC,WAAW,CAAC,EAAE,MAAM,CAAC;YAAC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;SAAE,CAAC;QACtF,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,IAAI,CAAC,EAAE;YAAE,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC;KAC7B,CAAC;IACF,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,IAAI,CAAC;IAC7D,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CA2KtE,CAAC"}
|
|
@@ -25,9 +25,10 @@ export const OtelEventNode = ({ data, selected, dragging, }) => {
|
|
|
25
25
|
// Color resolution
|
|
26
26
|
const scopeColor = nodeData.scopeColor;
|
|
27
27
|
const spanColor = nodeData.spanColor;
|
|
28
|
-
|
|
29
|
-
//
|
|
30
|
-
|
|
28
|
+
// OTEL nodes use scope-based coloring exclusively
|
|
29
|
+
// Priority: scopeColor (from library.yaml) → typeDefinition.color → default
|
|
30
|
+
// Note: node.fill and node.color fields are intentionally ignored (validation enforces this)
|
|
31
|
+
const baseFillColor = scopeColor || typeDefinition.color || '#3b82f6';
|
|
31
32
|
const fillColor = baseFillColor;
|
|
32
33
|
// Stroke color priority: explicit stroke > span color (workflow context) > fill color
|
|
33
34
|
const nodeDataStroke = nodeData.stroke;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OtelEventNode.js","sourceRoot":"","sources":["../../../src/nodes/otel/OtelEventNode.tsx"],"names":[],"mappings":";AAUA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE9D,OAAO,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAE3D,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D,SAAS,eAAe,CAAC,QAAgB,EAAE,SAAS,GAAG,IAAI;IACzD,MAAM,GAAG,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC5C,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;IACnD,MAAM,KAAK,GAAG,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC7D,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;AACvD,CAAC;AAoCD,MAAM,CAAC,MAAM,aAAa,GAAiD,CAAC,EAC1E,IAAI,EACJ,QAAQ,EACR,QAAQ,GACT,EAAE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAC;IAC7B,MAAM,SAAS,GAAG,IAAI,CAAC;IACvB,MAAM,EACJ,cAAc,EACd,KAAK,EACL,aAAa,EACb,IAAI,EAAE,QAAQ,EACd,QAAQ,GAAG,KAAK,EAChB,eAAe,GAAG,IAAI,EACtB,eAAe,GAAG,KAAK,EACvB,aAAa,GAAG,KAAK,EACrB,QAAQ,GAAG,IAAI,EACf,QAAQ,GAAG,KAAK,EAChB,aAAa,EACb,iBAAiB,GAAG,IAAI,GACzB,GAAG,SAAS,CAAC;IAEd,MAAM,EACJ,OAAO,EACP,WAAW,EACX,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,GAChB,GAAG,eAAe,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE,eAAe,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IAExF,MAAM,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAExD,mBAAmB;IACnB,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAgC,CAAC;IAC7D,MAAM,SAAS,GAAG,QAAQ,CAAC,SAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"OtelEventNode.js","sourceRoot":"","sources":["../../../src/nodes/otel/OtelEventNode.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@principal-ai/principal-view-react",
|
|
3
|
-
"version": "0.14.
|
|
3
|
+
"version": "0.14.33",
|
|
4
4
|
"description": "React components for graph-based principal view framework",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -32,12 +32,12 @@
|
|
|
32
32
|
},
|
|
33
33
|
"peerDependencies": {
|
|
34
34
|
"@principal-ade/industry-theme": "^0.1.7",
|
|
35
|
-
"@principal-ai/principal-view-core": "^0.26.
|
|
35
|
+
"@principal-ai/principal-view-core": "^0.26.31",
|
|
36
36
|
"react": "^18.0.0 || ^19.0.0",
|
|
37
37
|
"react-dom": "^18.0.0 || ^19.0.0"
|
|
38
38
|
},
|
|
39
39
|
"devDependencies": {
|
|
40
|
-
"@principal-ai/principal-view-core": "0.26.
|
|
40
|
+
"@principal-ai/principal-view-core": "0.26.31",
|
|
41
41
|
"@principal-ade/industry-theme": "0.1.7",
|
|
42
42
|
"@storybook/addon-docs": "10.1.2",
|
|
43
43
|
"@storybook/addon-links": "10.1.2",
|
|
@@ -99,9 +99,11 @@ export const OtelEventNode: React.FC<NodeProps<Node<OtelEventNodeData>>> = ({
|
|
|
99
99
|
// Color resolution
|
|
100
100
|
const scopeColor = nodeData.scopeColor as string | undefined;
|
|
101
101
|
const spanColor = nodeData.spanColor as string | undefined;
|
|
102
|
-
|
|
103
|
-
//
|
|
104
|
-
|
|
102
|
+
|
|
103
|
+
// OTEL nodes use scope-based coloring exclusively
|
|
104
|
+
// Priority: scopeColor (from library.yaml) → typeDefinition.color → default
|
|
105
|
+
// Note: node.fill and node.color fields are intentionally ignored (validation enforces this)
|
|
106
|
+
const baseFillColor = scopeColor || typeDefinition.color || '#3b82f6';
|
|
105
107
|
const fillColor = baseFillColor;
|
|
106
108
|
// Stroke color priority: explicit stroke > span color (workflow context) > fill color
|
|
107
109
|
const nodeDataStroke = nodeData.stroke as string | undefined;
|
|
@@ -140,7 +142,7 @@ export const OtelEventNode: React.FC<NodeProps<Node<OtelEventNodeData>>> = ({
|
|
|
140
142
|
|
|
141
143
|
const rectangleStyle: React.CSSProperties = {
|
|
142
144
|
padding: '12px 16px',
|
|
143
|
-
backgroundColor:
|
|
145
|
+
backgroundColor: fillColor,
|
|
144
146
|
color: '#000',
|
|
145
147
|
border: `2px ${borderStyle} ${hasViolations ? '#D0021B' : strokeColor}`,
|
|
146
148
|
fontSize: theme.fontSizes[0],
|
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
3
|
+
import '@xyflow/react/dist/style.css';
|
|
4
|
+
import { GraphRenderer } from '../components/GraphRenderer';
|
|
5
|
+
import type { ExtendedCanvas } from '@principal-ai/principal-view-core';
|
|
6
|
+
import { ThemeProvider, defaultEditorTheme } from '@principal-ade/industry-theme';
|
|
7
|
+
|
|
8
|
+
// Import the validation events canvas
|
|
9
|
+
import validationEventsCanvasUrl from '../../../../.principal-views/validation/validation.events.canvas?url';
|
|
10
|
+
|
|
11
|
+
// Helper to load canvas from URL
|
|
12
|
+
async function loadCanvas(url: string): Promise<ExtendedCanvas> {
|
|
13
|
+
const response = await fetch(url);
|
|
14
|
+
return await response.json();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
// Wrapper component that loads canvas data
|
|
18
|
+
function CanvasLoader({ url, children }: { url: string; children: (canvas: ExtendedCanvas) => React.ReactNode }) {
|
|
19
|
+
const [canvas, setCanvas] = useState<ExtendedCanvas | null>(null);
|
|
20
|
+
const [error, setError] = useState<string | null>(null);
|
|
21
|
+
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
loadCanvas(url)
|
|
24
|
+
.then(setCanvas)
|
|
25
|
+
.catch((err) => setError(err.message));
|
|
26
|
+
}, [url]);
|
|
27
|
+
|
|
28
|
+
if (error) {
|
|
29
|
+
return <div style={{ padding: 20, color: 'red' }}>Error loading canvas: {error}</div>;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (!canvas) {
|
|
33
|
+
return <div style={{ padding: 20 }}>Loading canvas...</div>;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
return (
|
|
37
|
+
<div style={{ width: '100%', height: '100vh' }}>
|
|
38
|
+
{children(canvas)}
|
|
39
|
+
</div>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const meta = {
|
|
44
|
+
title: 'Validation/Event Namespace Canvas',
|
|
45
|
+
component: GraphRenderer,
|
|
46
|
+
parameters: {
|
|
47
|
+
layout: 'fullscreen',
|
|
48
|
+
},
|
|
49
|
+
tags: ['autodocs'],
|
|
50
|
+
decorators: [
|
|
51
|
+
(Story) => (
|
|
52
|
+
<ThemeProvider theme={defaultEditorTheme}>
|
|
53
|
+
<div style={{ width: '100vw', height: '100vh' }}>
|
|
54
|
+
<Story />
|
|
55
|
+
</div>
|
|
56
|
+
</ThemeProvider>
|
|
57
|
+
),
|
|
58
|
+
],
|
|
59
|
+
} satisfies Meta<typeof GraphRenderer>;
|
|
60
|
+
|
|
61
|
+
export default meta;
|
|
62
|
+
type Story = StoryObj<typeof meta>;
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Validation Event Namespace Canvas
|
|
66
|
+
*
|
|
67
|
+
* File: .principal-views/validation/validation.events.canvas
|
|
68
|
+
* Type: event-namespace nodes
|
|
69
|
+
* Purpose: Shows the vocabulary of events emitted during validation workflows
|
|
70
|
+
*/
|
|
71
|
+
export const EventNamespaceVocabulary: Story = {
|
|
72
|
+
render: () => (
|
|
73
|
+
<CanvasLoader url={validationEventsCanvasUrl}>
|
|
74
|
+
{(canvas) => <GraphRenderer canvas={canvas} showBackground={false} editable={true} />}
|
|
75
|
+
</CanvasLoader>
|
|
76
|
+
),
|
|
77
|
+
parameters: {
|
|
78
|
+
docs: {
|
|
79
|
+
description: {
|
|
80
|
+
story: `
|
|
81
|
+
Renders the **validation.events.canvas** file - an event namespace vocabulary canvas.
|
|
82
|
+
|
|
83
|
+
## Event Namespace Canvas Concept
|
|
84
|
+
|
|
85
|
+
Unlike span canvases (which show user workflows) or OTEL event canvases (which show individual events),
|
|
86
|
+
this canvas shows the **vocabulary of event namespaces** and their adjacency relationships.
|
|
87
|
+
|
|
88
|
+
### Structure
|
|
89
|
+
|
|
90
|
+
**Nodes = Event Namespaces**
|
|
91
|
+
- \`analysis\` - Analysis pipeline lifecycle events
|
|
92
|
+
- \`validation\` - Validation lifecycle events (started, complete, error)
|
|
93
|
+
- \`file\` - File parsing events
|
|
94
|
+
- \`type\` - Type detection events
|
|
95
|
+
- etc.
|
|
96
|
+
|
|
97
|
+
Each namespace node documents all events within that namespace with their attributes.
|
|
98
|
+
|
|
99
|
+
**Edges = Adjacency**
|
|
100
|
+
- Edges represent when events from one namespace appear adjacent to events from another namespace in workflow scenarios
|
|
101
|
+
- Example: \`analysis → filetree\` because \`analysis.started → filetree.built\` in scenarios
|
|
102
|
+
- Example: \`file → validation\` because \`file.parsed → validation.error\` in scenarios
|
|
103
|
+
|
|
104
|
+
### Purpose
|
|
105
|
+
|
|
106
|
+
This canvas serves as:
|
|
107
|
+
1. **Event vocabulary documentation** - What events can be emitted
|
|
108
|
+
2. **Flow visualization** - How events from different namespaces connect
|
|
109
|
+
3. **Implementation guide** - What attributes each event requires
|
|
110
|
+
4. **Validation source** - Canvas edges must match actual workflow scenario adjacencies
|
|
111
|
+
|
|
112
|
+
### Conventions
|
|
113
|
+
|
|
114
|
+
As defined in \`.principal-views/architecture.events.md\`:
|
|
115
|
+
- Events follow \`{namespace}.{action}.{detail}\` naming
|
|
116
|
+
- Edges represent direct adjacency only (not transitive)
|
|
117
|
+
- Canvas is validated against workflow scenario files
|
|
118
|
+
- Namespaces group code-level implementation events (vs user-level workflow spans)
|
|
119
|
+
|
|
120
|
+
**Use this to:**
|
|
121
|
+
- Preview event namespace canvas rendering
|
|
122
|
+
- Understand event flow architecture
|
|
123
|
+
- Document which events your code emits
|
|
124
|
+
- Validate event relationships match actual code
|
|
125
|
+
`,
|
|
126
|
+
},
|
|
127
|
+
},
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
/**
|
|
132
|
+
* Event Namespace Canvas with Annotations
|
|
133
|
+
*
|
|
134
|
+
* Shows the canvas with additional context about what each namespace contains
|
|
135
|
+
*/
|
|
136
|
+
export const WithNamespaceDetails: Story = {
|
|
137
|
+
render: () => (
|
|
138
|
+
<CanvasLoader url={validationEventsCanvasUrl}>
|
|
139
|
+
{(canvas) => (
|
|
140
|
+
<div style={{ display: 'flex', height: '100vh' }}>
|
|
141
|
+
<div style={{ flex: 1 }}>
|
|
142
|
+
<GraphRenderer canvas={canvas} showBackground={false} editable={true} />
|
|
143
|
+
</div>
|
|
144
|
+
<div style={{
|
|
145
|
+
width: '350px',
|
|
146
|
+
padding: '20px',
|
|
147
|
+
backgroundColor: '#f5f5f5',
|
|
148
|
+
overflowY: 'auto',
|
|
149
|
+
fontFamily: 'system-ui, -apple-system, sans-serif'
|
|
150
|
+
}}>
|
|
151
|
+
<h2 style={{ marginTop: 0, fontSize: '18px' }}>Event Namespaces</h2>
|
|
152
|
+
<p style={{ fontSize: '14px', color: '#666' }}>
|
|
153
|
+
Each node represents a namespace grouping related events.
|
|
154
|
+
</p>
|
|
155
|
+
|
|
156
|
+
<div style={{ marginTop: '20px' }}>
|
|
157
|
+
<h3 style={{ fontSize: '14px', marginBottom: '8px' }}>Discovery Phase</h3>
|
|
158
|
+
<ul style={{ fontSize: '13px', lineHeight: '1.6', paddingLeft: '20px' }}>
|
|
159
|
+
<li><strong>analysis</strong> - Pipeline start</li>
|
|
160
|
+
<li><strong>filetree</strong> - Repository scanning</li>
|
|
161
|
+
<li><strong>packages</strong> - Package discovery</li>
|
|
162
|
+
<li><strong>canvases</strong> - Canvas file discovery</li>
|
|
163
|
+
<li><strong>executions</strong> - Execution file discovery</li>
|
|
164
|
+
<li><strong>library</strong> - Component library loading</li>
|
|
165
|
+
<li><strong>discovery</strong> - Phase completion</li>
|
|
166
|
+
</ul>
|
|
167
|
+
</div>
|
|
168
|
+
|
|
169
|
+
<div style={{ marginTop: '20px' }}>
|
|
170
|
+
<h3 style={{ fontSize: '14px', marginBottom: '8px' }}>Validation Phase</h3>
|
|
171
|
+
<ul style={{ fontSize: '13px', lineHeight: '1.6', paddingLeft: '20px' }}>
|
|
172
|
+
<li><strong>validation</strong> - Lifecycle (started, complete, error)</li>
|
|
173
|
+
<li><strong>file</strong> - Parsing operations</li>
|
|
174
|
+
<li><strong>type</strong> - Type detection</li>
|
|
175
|
+
<li><strong>canvas</strong> - Canvas validation</li>
|
|
176
|
+
<li><strong>workflow</strong> - Workflow validation</li>
|
|
177
|
+
<li><strong>execution</strong> - Execution validation</li>
|
|
178
|
+
<li><strong>rules</strong> - Lint rule execution</li>
|
|
179
|
+
<li><strong>results</strong> - Result aggregation</li>
|
|
180
|
+
</ul>
|
|
181
|
+
</div>
|
|
182
|
+
|
|
183
|
+
<div style={{ marginTop: '20px', padding: '12px', backgroundColor: '#fff3cd', borderRadius: '4px' }}>
|
|
184
|
+
<h4 style={{ fontSize: '13px', marginTop: 0 }}>Adjacency Edges</h4>
|
|
185
|
+
<p style={{ fontSize: '12px', margin: 0, color: '#856404' }}>
|
|
186
|
+
Edges show when events from one namespace appear next to events from another namespace
|
|
187
|
+
in workflow scenarios. These are validated against actual execution traces.
|
|
188
|
+
</p>
|
|
189
|
+
</div>
|
|
190
|
+
</div>
|
|
191
|
+
</div>
|
|
192
|
+
)}
|
|
193
|
+
</CanvasLoader>
|
|
194
|
+
),
|
|
195
|
+
parameters: {
|
|
196
|
+
docs: {
|
|
197
|
+
description: {
|
|
198
|
+
story: `
|
|
199
|
+
Same canvas with a side panel showing namespace details and explanations.
|
|
200
|
+
|
|
201
|
+
This view helps:
|
|
202
|
+
- Understand what each namespace contains
|
|
203
|
+
- See the phase groupings (discovery vs validation)
|
|
204
|
+
- Learn the event namespace canvas concept
|
|
205
|
+
`,
|
|
206
|
+
},
|
|
207
|
+
},
|
|
208
|
+
},
|
|
209
|
+
};
|