@workflow/web-shared 4.0.1-beta.5
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/LICENSE.md +21 -0
- package/README.md +76 -0
- package/dist/api/workflow-api-client.d.ts +303 -0
- package/dist/api/workflow-api-client.d.ts.map +1 -0
- package/dist/api/workflow-api-client.js +797 -0
- package/dist/api/workflow-api-client.js.map +1 -0
- package/dist/api/workflow-server-actions.d.ts +97 -0
- package/dist/api/workflow-server-actions.d.ts.map +1 -0
- package/dist/api/workflow-server-actions.js +329 -0
- package/dist/api/workflow-server-actions.js.map +1 -0
- package/dist/components/ui/alert.d.ts +9 -0
- package/dist/components/ui/alert.d.ts.map +1 -0
- package/dist/components/ui/alert.jsx +22 -0
- package/dist/components/ui/alert.jsx.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/utils.d.ts +11 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +19 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/run-trace-view.d.ts +8 -0
- package/dist/run-trace-view.d.ts.map +1 -0
- package/dist/run-trace-view.jsx +25 -0
- package/dist/run-trace-view.jsx.map +1 -0
- package/dist/sidebar/attribute-panel.d.ts +11 -0
- package/dist/sidebar/attribute-panel.d.ts.map +1 -0
- package/dist/sidebar/attribute-panel.jsx +153 -0
- package/dist/sidebar/attribute-panel.jsx.map +1 -0
- package/dist/sidebar/detail-card.d.ts +6 -0
- package/dist/sidebar/detail-card.d.ts.map +1 -0
- package/dist/sidebar/detail-card.jsx +13 -0
- package/dist/sidebar/detail-card.jsx.map +1 -0
- package/dist/sidebar/events-list.d.ts +8 -0
- package/dist/sidebar/events-list.d.ts.map +1 -0
- package/dist/sidebar/events-list.jsx +67 -0
- package/dist/sidebar/events-list.jsx.map +1 -0
- package/dist/sidebar/workflow-detail-panel.d.ts +8 -0
- package/dist/sidebar/workflow-detail-panel.d.ts.map +1 -0
- package/dist/sidebar/workflow-detail-panel.jsx +59 -0
- package/dist/sidebar/workflow-detail-panel.jsx.map +1 -0
- package/dist/trace-viewer/components/map.d.ts +8 -0
- package/dist/trace-viewer/components/map.d.ts.map +1 -0
- package/dist/trace-viewer/components/map.jsx +164 -0
- package/dist/trace-viewer/components/map.jsx.map +1 -0
- package/dist/trace-viewer/components/markers.d.ts +22 -0
- package/dist/trace-viewer/components/markers.d.ts.map +1 -0
- package/dist/trace-viewer/components/markers.jsx +400 -0
- package/dist/trace-viewer/components/markers.jsx.map +1 -0
- package/dist/trace-viewer/components/node.d.ts +31 -0
- package/dist/trace-viewer/components/node.d.ts.map +1 -0
- package/dist/trace-viewer/components/node.jsx +116 -0
- package/dist/trace-viewer/components/node.jsx.map +1 -0
- package/dist/trace-viewer/components/search-input.d.ts +9 -0
- package/dist/trace-viewer/components/search-input.d.ts.map +1 -0
- package/dist/trace-viewer/components/search-input.jsx +16 -0
- package/dist/trace-viewer/components/search-input.jsx.map +1 -0
- package/dist/trace-viewer/components/search.d.ts +3 -0
- package/dist/trace-viewer/components/search.d.ts.map +1 -0
- package/dist/trace-viewer/components/search.jsx +27 -0
- package/dist/trace-viewer/components/search.jsx.map +1 -0
- package/dist/trace-viewer/components/span-detail-panel.d.ts +10 -0
- package/dist/trace-viewer/components/span-detail-panel.d.ts.map +1 -0
- package/dist/trace-viewer/components/span-detail-panel.jsx +388 -0
- package/dist/trace-viewer/components/span-detail-panel.jsx.map +1 -0
- package/dist/trace-viewer/components/ui.d.ts +28 -0
- package/dist/trace-viewer/components/ui.d.ts.map +1 -0
- package/dist/trace-viewer/components/ui.jsx +54 -0
- package/dist/trace-viewer/components/ui.jsx.map +1 -0
- package/dist/trace-viewer/components/zoom-button.d.ts +3 -0
- package/dist/trace-viewer/components/zoom-button.d.ts.map +1 -0
- package/dist/trace-viewer/components/zoom-button.jsx +40 -0
- package/dist/trace-viewer/components/zoom-button.jsx.map +1 -0
- package/dist/trace-viewer/components/zoom-icons.d.ts +11 -0
- package/dist/trace-viewer/components/zoom-icons.d.ts.map +1 -0
- package/dist/trace-viewer/components/zoom-icons.jsx +23 -0
- package/dist/trace-viewer/components/zoom-icons.jsx.map +1 -0
- package/dist/trace-viewer/context.d.ts +183 -0
- package/dist/trace-viewer/context.d.ts.map +1 -0
- package/dist/trace-viewer/context.jsx +326 -0
- package/dist/trace-viewer/context.jsx.map +1 -0
- package/dist/trace-viewer/index.d.ts +5 -0
- package/dist/trace-viewer/index.d.ts.map +1 -0
- package/dist/trace-viewer/index.jsx +4 -0
- package/dist/trace-viewer/index.jsx.map +1 -0
- package/dist/trace-viewer/trace-viewer.d.ts +22 -0
- package/dist/trace-viewer/trace-viewer.d.ts.map +1 -0
- package/dist/trace-viewer/trace-viewer.jsx +311 -0
- package/dist/trace-viewer/trace-viewer.jsx.map +1 -0
- package/dist/trace-viewer/trace-viewer.module.css +1275 -0
- package/dist/trace-viewer/types.d.ts +201 -0
- package/dist/trace-viewer/types.d.ts.map +1 -0
- package/dist/trace-viewer/types.js +2 -0
- package/dist/trace-viewer/types.js.map +1 -0
- package/dist/trace-viewer/util/constants.d.ts +9 -0
- package/dist/trace-viewer/util/constants.d.ts.map +1 -0
- package/dist/trace-viewer/util/constants.js +9 -0
- package/dist/trace-viewer/util/constants.js.map +1 -0
- package/dist/trace-viewer/util/scrollbar-width.d.ts +2 -0
- package/dist/trace-viewer/util/scrollbar-width.d.ts.map +1 -0
- package/dist/trace-viewer/util/scrollbar-width.js +14 -0
- package/dist/trace-viewer/util/scrollbar-width.js.map +1 -0
- package/dist/trace-viewer/util/timing.d.ts +8 -0
- package/dist/trace-viewer/util/timing.d.ts.map +1 -0
- package/dist/trace-viewer/util/timing.js +29 -0
- package/dist/trace-viewer/util/timing.js.map +1 -0
- package/dist/trace-viewer/util/tree.d.ts +13 -0
- package/dist/trace-viewer/util/tree.d.ts.map +1 -0
- package/dist/trace-viewer/util/tree.js +223 -0
- package/dist/trace-viewer/util/tree.js.map +1 -0
- package/dist/trace-viewer/util/use-immediate-style.d.ts +15 -0
- package/dist/trace-viewer/util/use-immediate-style.d.ts.map +1 -0
- package/dist/trace-viewer/util/use-immediate-style.js +22 -0
- package/dist/trace-viewer/util/use-immediate-style.js.map +1 -0
- package/dist/trace-viewer/util/use-streaming-spans.d.ts +8 -0
- package/dist/trace-viewer/util/use-streaming-spans.d.ts.map +1 -0
- package/dist/trace-viewer/util/use-streaming-spans.js +332 -0
- package/dist/trace-viewer/util/use-streaming-spans.js.map +1 -0
- package/dist/trace-viewer/util/use-trackpad-zoom.d.ts +6 -0
- package/dist/trace-viewer/util/use-trackpad-zoom.d.ts.map +1 -0
- package/dist/trace-viewer/util/use-trackpad-zoom.jsx +38 -0
- package/dist/trace-viewer/util/use-trackpad-zoom.jsx.map +1 -0
- package/dist/trace-viewer/worker.d.ts +2 -0
- package/dist/trace-viewer/worker.d.ts.map +1 -0
- package/dist/trace-viewer/worker.js +107 -0
- package/dist/trace-viewer/worker.js.map +1 -0
- package/dist/workflow-trace-view.d.ts +12 -0
- package/dist/workflow-trace-view.d.ts.map +1 -0
- package/dist/workflow-trace-view.jsx +129 -0
- package/dist/workflow-trace-view.jsx.map +1 -0
- package/dist/workflow-traces/event-colors.d.ts +31 -0
- package/dist/workflow-traces/event-colors.d.ts.map +1 -0
- package/dist/workflow-traces/event-colors.js +68 -0
- package/dist/workflow-traces/event-colors.js.map +1 -0
- package/dist/workflow-traces/trace-colors.d.ts +15 -0
- package/dist/workflow-traces/trace-colors.d.ts.map +1 -0
- package/dist/workflow-traces/trace-colors.js +89 -0
- package/dist/workflow-traces/trace-colors.js.map +1 -0
- package/dist/workflow-traces/trace-span-construction.d.ts +31 -0
- package/dist/workflow-traces/trace-span-construction.d.ts.map +1 -0
- package/dist/workflow-traces/trace-span-construction.js +173 -0
- package/dist/workflow-traces/trace-span-construction.js.map +1 -0
- package/dist/workflow-traces/trace-time-utils.d.ts +13 -0
- package/dist/workflow-traces/trace-time-utils.d.ts.map +1 -0
- package/dist/workflow-traces/trace-time-utils.js +34 -0
- package/dist/workflow-traces/trace-time-utils.js.map +1 -0
- package/package.json +59 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { AlertCircle } from 'lucide-react';
|
|
3
|
+
import { useWorkflowTraceViewerData } from './api/workflow-api-client';
|
|
4
|
+
import { WorkflowTraceViewer } from './workflow-trace-view';
|
|
5
|
+
export function RunTraceView({ env, runId }) {
|
|
6
|
+
// Fetch all run data with live updates
|
|
7
|
+
const { run: runData, steps: allSteps, hooks: allHooks, events: allEvents, loading, error, } = useWorkflowTraceViewerData(env, runId, { live: true });
|
|
8
|
+
const run = runData ?? {};
|
|
9
|
+
if (error && !runData) {
|
|
10
|
+
return (<div className="m-4">
|
|
11
|
+
<AlertCircle className="h-4 w-4"/>
|
|
12
|
+
<p>Error loading workflow run</p>
|
|
13
|
+
<p>{error.message}</p>
|
|
14
|
+
</div>);
|
|
15
|
+
}
|
|
16
|
+
return (<div className="space-y-6">
|
|
17
|
+
<div className="relative">
|
|
18
|
+
{loading && (<div className="absolute inset-0 bg-black/50 flex items-center justify-center">
|
|
19
|
+
<div className="animate-spin rounded-full h-10 w-10 border-b-2 border-white"></div>
|
|
20
|
+
</div>)}
|
|
21
|
+
<WorkflowTraceViewer error={error} steps={allSteps} events={allEvents} hooks={allHooks} env={env} run={run} isLoading={loading}/>
|
|
22
|
+
</div>
|
|
23
|
+
</div>);
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=run-trace-view.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-trace-view.jsx","sourceRoot":"","sources":["../src/run-trace-view.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAGb,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,0BAA0B,EAAE,MAAM,2BAA2B,CAAC;AAEvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAO5D,MAAM,UAAU,YAAY,CAAC,EAAE,GAAG,EAAE,KAAK,EAAqB;IAC5D,uCAAuC;IACvC,MAAM,EACJ,GAAG,EAAE,OAAO,EACZ,KAAK,EAAE,QAAQ,EACf,KAAK,EAAE,QAAQ,EACf,MAAM,EAAE,SAAS,EACjB,OAAO,EACP,KAAK,GACN,GAAG,0BAA0B,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3D,MAAM,GAAG,GAAG,OAAO,IAAK,EAAkB,CAAC;IAE3C,IAAI,KAAK,IAAI,CAAC,OAAO,EAAE,CAAC;QACtB,OAAO,CACL,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,CAClB;QAAA,CAAC,WAAW,CAAC,SAAS,CAAC,SAAS,EAChC;QAAA,CAAC,CAAC,CAAC,0BAA0B,EAAE,CAAC,CAChC;QAAA,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CACvB;MAAA,EAAE,GAAG,CAAC,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CACxB;MAAA,CAAC,GAAG,CAAC,SAAS,CAAC,UAAU,CACvB;QAAA,CAAC,OAAO,IAAI,CACV,CAAC,GAAG,CAAC,SAAS,CAAC,+DAA+D,CAC5E;YAAA,CAAC,GAAG,CAAC,SAAS,CAAC,6DAA6D,CAAC,EAAE,GAAG,CACpF;UAAA,EAAE,GAAG,CAAC,CACP,CACD;QAAA,CAAC,mBAAmB,CAClB,KAAK,CAAC,CAAC,KAAK,CAAC,CACb,KAAK,CAAC,CAAC,QAAQ,CAAC,CAChB,MAAM,CAAC,CAAC,SAAS,CAAC,CAClB,KAAK,CAAC,CAAC,QAAQ,CAAC,CAChB,GAAG,CAAC,CAAC,GAAG,CAAC,CACT,GAAG,CAAC,CAAC,GAAG,CAAC,CACT,SAAS,CAAC,CAAC,OAAO,CAAC,EAEvB;MAAA,EAAE,GAAG,CACP;IAAA,EAAE,GAAG,CAAC,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare const AttributeBlock: ({ attribute, value, isLoading, }: {
|
|
2
|
+
attribute: string;
|
|
3
|
+
value: unknown;
|
|
4
|
+
isLoading?: boolean;
|
|
5
|
+
}) => import("react").JSX.Element | null;
|
|
6
|
+
export declare const AttributePanel: ({ data, isLoading, error, }: {
|
|
7
|
+
data: Record<string, unknown>;
|
|
8
|
+
isLoading?: boolean;
|
|
9
|
+
error?: Error;
|
|
10
|
+
}) => import("react").JSX.Element;
|
|
11
|
+
//# sourceMappingURL=attribute-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attribute-panel.d.ts","sourceRoot":"","sources":["../../src/sidebar/attribute-panel.tsx"],"names":[],"mappings":"AA8IA,eAAO,MAAM,cAAc,GAAI,kCAI5B;IACD,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB,uCA4BA,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,6BAI5B;IACD,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,KAAK,CAAC;CACf,gCAsCA,CAAC"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { parseStepName, parseWorkflowName } from '@workflow/core/parse-name';
|
|
3
|
+
import { AlertCircle } from 'lucide-react';
|
|
4
|
+
import { Alert, AlertDescription, AlertTitle } from '../components/ui/alert';
|
|
5
|
+
import { DetailCard } from './detail-card';
|
|
6
|
+
const JsonBlock = (value) => {
|
|
7
|
+
return (<pre className="text-copy-12 overflow-x-auto rounded-md border p-4" style={{
|
|
8
|
+
borderColor: 'var(--ds-gray-300)',
|
|
9
|
+
backgroundColor: 'var(--ds-gray-100)',
|
|
10
|
+
color: 'var(--ds-gray-1000)',
|
|
11
|
+
}}>
|
|
12
|
+
<code>{JSON.stringify(value, null, 2)}</code>
|
|
13
|
+
</pre>);
|
|
14
|
+
};
|
|
15
|
+
const attributeOrder = [
|
|
16
|
+
'workflowName',
|
|
17
|
+
'stepName',
|
|
18
|
+
'status',
|
|
19
|
+
'stepId',
|
|
20
|
+
'hookId',
|
|
21
|
+
'eventId',
|
|
22
|
+
'runId',
|
|
23
|
+
'attempt',
|
|
24
|
+
'token',
|
|
25
|
+
'correlationId',
|
|
26
|
+
'eventType',
|
|
27
|
+
'deploymentId',
|
|
28
|
+
'ownerId',
|
|
29
|
+
'projectId',
|
|
30
|
+
'environment',
|
|
31
|
+
'executionContext',
|
|
32
|
+
'createdAt',
|
|
33
|
+
'startedAt',
|
|
34
|
+
'updatedAt',
|
|
35
|
+
'completedAt',
|
|
36
|
+
'retryAfter',
|
|
37
|
+
'error',
|
|
38
|
+
'errorCode',
|
|
39
|
+
'metadata',
|
|
40
|
+
'eventData',
|
|
41
|
+
'input',
|
|
42
|
+
'output',
|
|
43
|
+
'resumeAt',
|
|
44
|
+
];
|
|
45
|
+
const sortByAttributeOrder = (a, b) => {
|
|
46
|
+
const aIndex = attributeOrder.indexOf(a) || 0;
|
|
47
|
+
const bIndex = attributeOrder.indexOf(b) || 0;
|
|
48
|
+
return aIndex - bIndex;
|
|
49
|
+
};
|
|
50
|
+
const attributeToDisplayFn = {
|
|
51
|
+
// Names that need pretty-printing
|
|
52
|
+
workflowName: (value) => parseWorkflowName(String(value))?.shortName ?? '?',
|
|
53
|
+
stepName: (value) => parseStepName(String(value))?.shortName ?? '?',
|
|
54
|
+
// IDs
|
|
55
|
+
runId: (value) => String(value),
|
|
56
|
+
stepId: (value) => String(value),
|
|
57
|
+
hookId: (value) => String(value),
|
|
58
|
+
eventId: (value) => String(value),
|
|
59
|
+
// Run/step details
|
|
60
|
+
status: (value) => String(value),
|
|
61
|
+
attempt: (value) => String(value),
|
|
62
|
+
// Hook details
|
|
63
|
+
token: (value) => String(value),
|
|
64
|
+
// Event details
|
|
65
|
+
eventType: (value) => String(value),
|
|
66
|
+
correlationId: (value) => String(value),
|
|
67
|
+
// Project details
|
|
68
|
+
deploymentId: (value) => String(value),
|
|
69
|
+
// Tenancy (we don't show these)
|
|
70
|
+
ownerId: (_value) => null,
|
|
71
|
+
projectId: (_value) => null,
|
|
72
|
+
environment: (_value) => null,
|
|
73
|
+
executionContext: (_value) => null,
|
|
74
|
+
// Dates
|
|
75
|
+
// TODO: relative time with tooltips for ISO times
|
|
76
|
+
createdAt: (value) => new Date(String(value)).toLocaleString(),
|
|
77
|
+
startedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
78
|
+
updatedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
79
|
+
completedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
80
|
+
retryAfter: (value) => new Date(String(value)).toLocaleString(),
|
|
81
|
+
resumeAt: (value) => new Date(String(value)).toLocaleString(),
|
|
82
|
+
// Resolved attributes, won't actually use this function
|
|
83
|
+
metadata: JsonBlock,
|
|
84
|
+
input: (value) => {
|
|
85
|
+
const argCount = Array.isArray(value) ? value.length : 0;
|
|
86
|
+
return (<DetailCard summary={`Input (${argCount} arguments)`}>
|
|
87
|
+
{Array.isArray(value)
|
|
88
|
+
? value.map((v, i) => (<div className="mt-2" key={i}>
|
|
89
|
+
{JsonBlock(v)}
|
|
90
|
+
</div>))
|
|
91
|
+
: JsonBlock(value)}
|
|
92
|
+
</DetailCard>);
|
|
93
|
+
},
|
|
94
|
+
output: (value) => {
|
|
95
|
+
return <DetailCard summary="Output">{JsonBlock(value)}</DetailCard>;
|
|
96
|
+
},
|
|
97
|
+
error: (value) => {
|
|
98
|
+
return <DetailCard summary="Error">{JsonBlock(value)}</DetailCard>;
|
|
99
|
+
},
|
|
100
|
+
errorCode: JsonBlock,
|
|
101
|
+
eventData: (value) => {
|
|
102
|
+
return <DetailCard summary="Event Data">{JsonBlock(value)}</DetailCard>;
|
|
103
|
+
},
|
|
104
|
+
};
|
|
105
|
+
const resolvableAttributes = [
|
|
106
|
+
'input',
|
|
107
|
+
'output',
|
|
108
|
+
'error',
|
|
109
|
+
'errorCode',
|
|
110
|
+
'metadata',
|
|
111
|
+
'eventData',
|
|
112
|
+
];
|
|
113
|
+
export const AttributeBlock = ({ attribute, value, isLoading, }) => {
|
|
114
|
+
const displayFn = attributeToDisplayFn[attribute];
|
|
115
|
+
if (!displayFn) {
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
const displayValue = displayFn(value);
|
|
119
|
+
if (!displayValue) {
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
return (<div className="relative">
|
|
123
|
+
{typeof isLoading === 'boolean' && isLoading && (<div className="absolute top-9 right-4">
|
|
124
|
+
<div className="animate-spin rounded-full h-4 w-4 border-b-2" style={{ borderColor: 'var(--ds-gray-900)' }}/>
|
|
125
|
+
</div>)}
|
|
126
|
+
<div key={attribute} className="flex flex-col gap-0 my-2">
|
|
127
|
+
<span className="font-medium" style={{ color: 'var(--ds-gray-500)' }}>
|
|
128
|
+
{attribute}
|
|
129
|
+
</span>
|
|
130
|
+
<span style={{ color: 'var(--ds-gray-1000)' }}>{displayValue}</span>
|
|
131
|
+
</div>
|
|
132
|
+
</div>);
|
|
133
|
+
};
|
|
134
|
+
export const AttributePanel = ({ data, isLoading, error, }) => {
|
|
135
|
+
const displayData = data;
|
|
136
|
+
const basicAttributes = Object.keys(displayData)
|
|
137
|
+
.filter((key) => !resolvableAttributes.includes(key))
|
|
138
|
+
.sort(sortByAttributeOrder);
|
|
139
|
+
const resolvedAttributes = Object.keys(displayData)
|
|
140
|
+
.filter((key) => resolvableAttributes.includes(key))
|
|
141
|
+
.sort(sortByAttributeOrder);
|
|
142
|
+
return (<div>
|
|
143
|
+
{basicAttributes.map((attribute) => (<AttributeBlock key={attribute} attribute={attribute} value={displayData[attribute]}/>))}
|
|
144
|
+
{error ? (<Alert variant="destructive" className="my-4">
|
|
145
|
+
<AlertCircle className="h-4 w-4"/>
|
|
146
|
+
<AlertTitle>Failed to load resource details</AlertTitle>
|
|
147
|
+
<AlertDescription className="text-sm">
|
|
148
|
+
{error.message}
|
|
149
|
+
</AlertDescription>
|
|
150
|
+
</Alert>) : (resolvedAttributes.map((attribute) => (<AttributeBlock isLoading={isLoading} key={attribute} attribute={attribute} value={displayData[attribute]}/>)))}
|
|
151
|
+
</div>);
|
|
152
|
+
};
|
|
153
|
+
//# sourceMappingURL=attribute-panel.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attribute-panel.jsx","sourceRoot":"","sources":["../../src/sidebar/attribute-panel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail-card.d.ts","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,wBAAgB,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GACT,EAAE;IACD,OAAO,EAAE,SAAS,CAAC;IACnB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB,+BAgBA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function DetailCard({ summary, children, }) {
|
|
2
|
+
return (<details className="group">
|
|
3
|
+
<summary className="cursor-pointer rounded-md border px-3 py-2 text-copy-14 hover:brightness-95" style={{
|
|
4
|
+
borderColor: 'var(--ds-gray-300)',
|
|
5
|
+
backgroundColor: 'var(--ds-gray-100)',
|
|
6
|
+
color: 'var(--ds-gray-900)',
|
|
7
|
+
}}>
|
|
8
|
+
{summary}
|
|
9
|
+
</summary>
|
|
10
|
+
<div className="p-2">{children}</div>
|
|
11
|
+
</details>);
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=detail-card.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail-card.jsx","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":"AAEA,MAAM,UAAU,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GAIT;IACC,OAAO,CACL,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CACxB;MAAA,CAAC,OAAO,CACN,SAAS,CAAC,6EAA6E,CACvF,KAAK,CAAC,CAAC;YACL,WAAW,EAAE,oBAAoB;YACjC,eAAe,EAAE,oBAAoB;YACrC,KAAK,EAAE,oBAAoB;SAC5B,CAAC,CAEF;QAAA,CAAC,OAAO,CACV;MAAA,EAAE,OAAO,CACT;MAAA,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,EAAE,GAAG,CACtC;IAAA,EAAE,OAAO,CAAC,CACX,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type EnvMap } from '../api/workflow-server-actions';
|
|
2
|
+
import type { SpanEvent } from '../trace-viewer/types';
|
|
3
|
+
export declare function EventsList({ correlationId, env, events, }: {
|
|
4
|
+
correlationId: string;
|
|
5
|
+
env: EnvMap;
|
|
6
|
+
events: SpanEvent[];
|
|
7
|
+
}): import("react").JSX.Element;
|
|
8
|
+
//# sourceMappingURL=events-list.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-list.d.ts","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"AAKA,OAAO,EACL,KAAK,MAAM,EAEZ,MAAM,gCAAgC,CAAC;AAExC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAKvD,wBAAgB,UAAU,CAAC,EACzB,aAAa,EACb,GAAG,EACH,MAAM,GACP,EAAE;IACD,aAAa,EAAE,MAAM,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,SAAS,EAAE,CAAC;CACrB,+BAkGA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { AlertCircle } from 'lucide-react';
|
|
3
|
+
import { useCallback } from 'react';
|
|
4
|
+
import useSWR from 'swr';
|
|
5
|
+
import { fetchEventsByCorrelationId, } from '../api/workflow-server-actions';
|
|
6
|
+
import { Alert, AlertDescription, AlertTitle } from '../components/ui/alert';
|
|
7
|
+
import { convertEventsToSpanEvents } from '../workflow-traces/trace-span-construction';
|
|
8
|
+
import { AttributeBlock } from './attribute-panel';
|
|
9
|
+
import { DetailCard } from './detail-card';
|
|
10
|
+
export function EventsList({ correlationId, env, events, }) {
|
|
11
|
+
const fetchEvents = useCallback(() => {
|
|
12
|
+
return fetchEventsByCorrelationId(env, correlationId, {
|
|
13
|
+
sortOrder: 'asc',
|
|
14
|
+
limit: 100,
|
|
15
|
+
withData: true,
|
|
16
|
+
}).then((evts) => {
|
|
17
|
+
if (!evts.success) {
|
|
18
|
+
throw new Error(evts.error?.message || 'Failed to fetch events');
|
|
19
|
+
}
|
|
20
|
+
return convertEventsToSpanEvents(evts.data.data || [], false);
|
|
21
|
+
});
|
|
22
|
+
}, [env, correlationId]);
|
|
23
|
+
const { data, error: eventError, isLoading: eventsLoading, } = useSWR(['workflow', 'events', correlationId], fetchEvents, {
|
|
24
|
+
fallbackData: events,
|
|
25
|
+
revalidateOnFocus: false,
|
|
26
|
+
});
|
|
27
|
+
const displayData = (data?.length ? data : events) || [];
|
|
28
|
+
return (<div className="mt-2" style={{ color: 'var(--ds-gray-1000)' }}>
|
|
29
|
+
<h3 className="text-heading-16 font-medium mt-4 mb-2" style={{ color: 'var(--ds-gray-1000)' }}>
|
|
30
|
+
Events ({eventsLoading ? '...' : displayData.length})
|
|
31
|
+
</h3>
|
|
32
|
+
{/* Events section */}
|
|
33
|
+
{eventError ? (<Alert variant="destructive" className="my-4">
|
|
34
|
+
<AlertCircle className="h-4 w-4"/>
|
|
35
|
+
<AlertTitle>Failed to load event data</AlertTitle>
|
|
36
|
+
<AlertDescription className="text-sm">
|
|
37
|
+
{eventError.message}
|
|
38
|
+
</AlertDescription>
|
|
39
|
+
</Alert>) : null}
|
|
40
|
+
{eventsLoading ? <div>Loading events...</div> : null}
|
|
41
|
+
{!eventsLoading && !eventError && displayData.length === 0 && (<div className="text-sm">No events found</div>)}
|
|
42
|
+
{displayData.length > 0 && !eventError ? (<div className="flex flex-col gap-2">
|
|
43
|
+
{displayData.map((event, index) => (<DetailCard key={`${event.name}-${index}`} summary={<>
|
|
44
|
+
<span className="font-medium" style={{ color: 'var(--ds-gray-1000)' }}>
|
|
45
|
+
{event.name}
|
|
46
|
+
</span>{' '}
|
|
47
|
+
-{' '}
|
|
48
|
+
<span style={{ color: 'var(--ds-gray-700)' }}>
|
|
49
|
+
{new Date(event.timestamp[0] * 1000 + event.timestamp[1] / 1e6).toLocaleString()}
|
|
50
|
+
</span>
|
|
51
|
+
</>}>
|
|
52
|
+
<div className="mt-2 px-4">
|
|
53
|
+
{Object.entries(event.attributes)
|
|
54
|
+
.filter(([key]) => key !== 'eventData')
|
|
55
|
+
.map(([key, value]) => (<AttributeBlock key={key} attribute={key} value={value}/>))}
|
|
56
|
+
<div className="relative">
|
|
57
|
+
{eventError && <div>Error loading event data</div>}
|
|
58
|
+
{!eventError &&
|
|
59
|
+
!eventsLoading &&
|
|
60
|
+
event.attributes.eventData && (<AttributeBlock isLoading={eventsLoading} attribute="eventData" value={event.attributes.eventData}/>)}
|
|
61
|
+
</div>
|
|
62
|
+
</div>
|
|
63
|
+
</DetailCard>))}
|
|
64
|
+
</div>) : null}
|
|
65
|
+
</div>);
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=events-list.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-list.jsx","sourceRoot":"","sources":["../../src/sidebar/events-list.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { EnvMap } from '../api/workflow-server-actions';
|
|
2
|
+
/**
|
|
3
|
+
* Custom panel component for workflow traces that displays entity details
|
|
4
|
+
*/
|
|
5
|
+
export declare function WorkflowDetailPanel({ env, }: {
|
|
6
|
+
env: EnvMap;
|
|
7
|
+
}): React.JSX.Element | null;
|
|
8
|
+
//# sourceMappingURL=workflow-detail-panel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-detail-panel.d.ts","sourceRoot":"","sources":["../../src/sidebar/workflow-detail-panel.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAK7D;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,EAClC,GAAG,GACJ,EAAE;IACD,GAAG,EAAE,MAAM,CAAC;CACb,GAAG,KAAK,CAAC,GAAG,CAAC,OAAO,GAAG,IAAI,CA2E3B"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import clsx from 'clsx';
|
|
3
|
+
import { useEffect, useMemo } from 'react';
|
|
4
|
+
import { toast } from 'sonner';
|
|
5
|
+
import { useWorkflowResourceData } from '../api/workflow-api-client';
|
|
6
|
+
import { EventsList } from '../sidebar/events-list';
|
|
7
|
+
import { useTraceViewer } from '../trace-viewer';
|
|
8
|
+
import { AttributePanel } from './attribute-panel';
|
|
9
|
+
/**
|
|
10
|
+
* Custom panel component for workflow traces that displays entity details
|
|
11
|
+
*/
|
|
12
|
+
export function WorkflowDetailPanel({ env, }) {
|
|
13
|
+
const { state } = useTraceViewer();
|
|
14
|
+
const { selected } = state;
|
|
15
|
+
const data = selected?.span.attributes?.data;
|
|
16
|
+
// Determine resource ID and runId (needed for steps)
|
|
17
|
+
const { resource, resourceId, runId } = useMemo(() => {
|
|
18
|
+
const resource = selected?.span.attributes?.resource;
|
|
19
|
+
if (resource === 'step') {
|
|
20
|
+
const step = data;
|
|
21
|
+
return { resource: 'step', resourceId: step.stepId, runId: step.runId };
|
|
22
|
+
}
|
|
23
|
+
else if (resource === 'run') {
|
|
24
|
+
const run = data;
|
|
25
|
+
return { resource: 'run', resourceId: run.runId, runId: undefined };
|
|
26
|
+
}
|
|
27
|
+
else if (resource === 'hook') {
|
|
28
|
+
const hook = data;
|
|
29
|
+
return { resource: 'hook', resourceId: hook.hookId, runId: undefined };
|
|
30
|
+
}
|
|
31
|
+
else if (resource === 'sleep') {
|
|
32
|
+
return {
|
|
33
|
+
resource: 'sleep',
|
|
34
|
+
resourceId: selected?.span?.spanId,
|
|
35
|
+
runId: undefined,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
return { resource: undefined, resourceId: undefined, runId: undefined };
|
|
39
|
+
}, [selected, data]);
|
|
40
|
+
// Fetch full resource data with events
|
|
41
|
+
const { data: fetchedData, error, loading, } = useWorkflowResourceData(env, resource, resourceId ?? '', { runId });
|
|
42
|
+
useEffect(() => {
|
|
43
|
+
if (error && selected && resource) {
|
|
44
|
+
toast.error(`Failed to load ${resource} details`, {
|
|
45
|
+
description: error.message,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}, [error, resource, selected]);
|
|
49
|
+
if (!selected || !resource || !resourceId) {
|
|
50
|
+
return null;
|
|
51
|
+
}
|
|
52
|
+
const displayData = fetchedData || data;
|
|
53
|
+
return (<div className={clsx('flex flex-col px-2')}>
|
|
54
|
+
{/* Content display */}
|
|
55
|
+
<AttributePanel data={displayData} isLoading={loading} error={error ?? undefined}/>
|
|
56
|
+
{resource !== 'run' && (<EventsList correlationId={resourceId} env={env} events={selected.span.events}/>)}
|
|
57
|
+
</div>);
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=workflow-detail-panel.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-detail-panel.jsx","sourceRoot":"","sources":["../../src/sidebar/workflow-detail-panel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type MutableRefObject } from 'react';
|
|
2
|
+
import type { VisibleSpan } from '../types';
|
|
3
|
+
export declare const MiniMap: import("react").NamedExoticComponent<{
|
|
4
|
+
timelineRef: MutableRefObject<HTMLDivElement | null>;
|
|
5
|
+
rows: VisibleSpan[][];
|
|
6
|
+
scale: number;
|
|
7
|
+
}>;
|
|
8
|
+
//# sourceMappingURL=map.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map.d.ts","sourceRoot":"","sources":["../../../src/trace-viewer/components/map.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,gBAAgB,EAMtB,MAAM,OAAO,CAAC;AAGf,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AA4B5C,eAAO,MAAM,OAAO;iBAKL,gBAAgB,CAAC,cAAc,GAAG,IAAI,CAAC;UAC9C,WAAW,EAAE,EAAE;WACd,MAAM;EAoLb,CAAC"}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { memo, useEffect, useLayoutEffect, useRef, useState, } from 'react';
|
|
2
|
+
import { useTraceViewer } from '../context';
|
|
3
|
+
import styles from '../trace-viewer.module.css';
|
|
4
|
+
import { MAP_HEIGHT, TIMELINE_PADDING } from '../util/constants';
|
|
5
|
+
import { useImmediateStyle } from '../util/use-immediate-style';
|
|
6
|
+
const getDpi = () => {
|
|
7
|
+
if ('devicePixelRatio' in globalThis) {
|
|
8
|
+
return globalThis.devicePixelRatio || 1;
|
|
9
|
+
}
|
|
10
|
+
return 1;
|
|
11
|
+
};
|
|
12
|
+
const useDpi = () => {
|
|
13
|
+
const [dpi, setDpi] = useState(1);
|
|
14
|
+
useLayoutEffect(() => {
|
|
15
|
+
const onChange = () => setDpi(getDpi());
|
|
16
|
+
const media = matchMedia(`(resolution: ${dpi}dppx)`);
|
|
17
|
+
media.addEventListener('change', onChange);
|
|
18
|
+
onChange();
|
|
19
|
+
return () => {
|
|
20
|
+
media.removeEventListener('change', onChange);
|
|
21
|
+
};
|
|
22
|
+
}, [dpi]);
|
|
23
|
+
return dpi;
|
|
24
|
+
};
|
|
25
|
+
const padding = TIMELINE_PADDING;
|
|
26
|
+
export const MiniMap = memo(function MiniMap({ timelineRef, rows, scale, }) {
|
|
27
|
+
const { state: { root, baseScale, timelineWidth, width: fullWidth, scrollbarWidth }, } = useTraceViewer();
|
|
28
|
+
const mapWidth = fullWidth + TIMELINE_PADDING * 2;
|
|
29
|
+
const dpi = useDpi();
|
|
30
|
+
const containerRef = useRef(null);
|
|
31
|
+
const canvasRef = useRef(null);
|
|
32
|
+
const thumbRatio = (fullWidth / (fullWidth - scrollbarWidth)) *
|
|
33
|
+
Math.min(fullWidth / timelineWidth, baseScale / scale);
|
|
34
|
+
const thumbWidth = Math.min(fullWidth, (timelineWidth - scrollbarWidth) * thumbRatio);
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
let isHeld = false;
|
|
37
|
+
let clientX = 0;
|
|
38
|
+
let rect;
|
|
39
|
+
const isValidEventTarget = (target) => {
|
|
40
|
+
return Boolean(containerRef.current?.contains(target));
|
|
41
|
+
};
|
|
42
|
+
let nextFrame = 0;
|
|
43
|
+
const onFrame = () => {
|
|
44
|
+
if (!isHeld || !rect)
|
|
45
|
+
return;
|
|
46
|
+
const $timeline = timelineRef.current;
|
|
47
|
+
if (!$timeline)
|
|
48
|
+
return;
|
|
49
|
+
const x = clientX - thumbWidth * 0.5 - rect.left;
|
|
50
|
+
$timeline.scrollLeft = x / thumbRatio;
|
|
51
|
+
};
|
|
52
|
+
const onPointerMove = (event) => {
|
|
53
|
+
({ clientX } = event);
|
|
54
|
+
cancelAnimationFrame(nextFrame);
|
|
55
|
+
nextFrame = requestAnimationFrame(onFrame);
|
|
56
|
+
};
|
|
57
|
+
const onPointerDown = (event) => {
|
|
58
|
+
if (!isValidEventTarget(event.target))
|
|
59
|
+
return;
|
|
60
|
+
isHeld = true;
|
|
61
|
+
rect = containerRef.current?.getBoundingClientRect();
|
|
62
|
+
onPointerMove(event);
|
|
63
|
+
};
|
|
64
|
+
const onPointerUp = () => {
|
|
65
|
+
isHeld = false;
|
|
66
|
+
rect = undefined;
|
|
67
|
+
};
|
|
68
|
+
const onTouchStart = (event) => {
|
|
69
|
+
if (!isValidEventTarget(event.target))
|
|
70
|
+
return;
|
|
71
|
+
if (event.cancelable) {
|
|
72
|
+
event.preventDefault();
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
const onTouchMove = (event) => {
|
|
76
|
+
if (!isHeld)
|
|
77
|
+
return;
|
|
78
|
+
if (event.cancelable) {
|
|
79
|
+
event.preventDefault();
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
window.addEventListener('pointerdown', onPointerDown);
|
|
83
|
+
window.addEventListener('pointermove', onPointerMove);
|
|
84
|
+
window.addEventListener('pointerup', onPointerUp);
|
|
85
|
+
window.addEventListener('blur', onPointerUp);
|
|
86
|
+
window.addEventListener('touchstart', onTouchStart, { passive: false });
|
|
87
|
+
window.addEventListener('touchmove', onTouchMove, { passive: false });
|
|
88
|
+
return () => {
|
|
89
|
+
window.removeEventListener('pointerdown', onPointerDown);
|
|
90
|
+
window.removeEventListener('pointermove', onPointerMove);
|
|
91
|
+
window.removeEventListener('pointerup', onPointerUp);
|
|
92
|
+
window.removeEventListener('blur', onPointerUp);
|
|
93
|
+
window.removeEventListener('touchstart', onTouchStart);
|
|
94
|
+
window.removeEventListener('touchmove', onTouchMove);
|
|
95
|
+
cancelAnimationFrame(nextFrame);
|
|
96
|
+
};
|
|
97
|
+
}, [timelineRef, thumbRatio, thumbWidth]);
|
|
98
|
+
useEffect(() => {
|
|
99
|
+
const canvas = canvasRef.current;
|
|
100
|
+
const ctx = canvas?.getContext('2d');
|
|
101
|
+
if (!canvas || !ctx)
|
|
102
|
+
return;
|
|
103
|
+
const render = () => {
|
|
104
|
+
ctx.resetTransform();
|
|
105
|
+
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
|
106
|
+
ctx.scale(dpi, dpi);
|
|
107
|
+
const gap = 1;
|
|
108
|
+
const height = 3;
|
|
109
|
+
const ratio = (mapWidth - padding * 2) / root.duration;
|
|
110
|
+
// TODO: fill spans based on depth
|
|
111
|
+
ctx.fillStyle = '#ccc';
|
|
112
|
+
ctx.beginPath();
|
|
113
|
+
for (const row of rows) {
|
|
114
|
+
for (const span of row) {
|
|
115
|
+
const y = padding - gap + (gap + height) * span.row;
|
|
116
|
+
if (y >= MAP_HEIGHT - height - padding)
|
|
117
|
+
break;
|
|
118
|
+
const x = padding + (span.startTime - root.startTime) * ratio;
|
|
119
|
+
const width = span.duration * ratio;
|
|
120
|
+
ctx.roundRect(x, y, width, height, height);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
ctx.fill();
|
|
124
|
+
};
|
|
125
|
+
const nextFrame = requestAnimationFrame(render);
|
|
126
|
+
return () => cancelAnimationFrame(nextFrame);
|
|
127
|
+
}, [dpi, root, mapWidth, rows]);
|
|
128
|
+
const thumbRef = useRef(null);
|
|
129
|
+
const { style: thumbStyle, setStyle: setThumbStyle } = useImmediateStyle(thumbRef);
|
|
130
|
+
useLayoutEffect(() => {
|
|
131
|
+
const $timeline = timelineRef.current;
|
|
132
|
+
if (!$timeline)
|
|
133
|
+
return;
|
|
134
|
+
let nextFrame = 0;
|
|
135
|
+
const onFrame = () => {
|
|
136
|
+
setThumbStyle('transform', `translateX(${padding + $timeline.scrollLeft * thumbRatio}px)`);
|
|
137
|
+
};
|
|
138
|
+
onFrame();
|
|
139
|
+
const onScroll = () => {
|
|
140
|
+
cancelAnimationFrame(nextFrame);
|
|
141
|
+
nextFrame = requestAnimationFrame(onFrame);
|
|
142
|
+
};
|
|
143
|
+
$timeline.addEventListener('scroll', onScroll);
|
|
144
|
+
return () => {
|
|
145
|
+
cancelAnimationFrame(nextFrame);
|
|
146
|
+
$timeline.removeEventListener('scroll', onScroll);
|
|
147
|
+
};
|
|
148
|
+
}, [timelineRef, thumbRatio, setThumbStyle]);
|
|
149
|
+
return (<div className={styles.mapContainer} ref={containerRef} style={{
|
|
150
|
+
width: thumbWidth > 0 ? mapWidth : '100%',
|
|
151
|
+
height: MAP_HEIGHT,
|
|
152
|
+
}}>
|
|
153
|
+
<canvas className={styles.mapCanvas} height={MAP_HEIGHT * dpi} ref={canvasRef} style={{ width: mapWidth, height: MAP_HEIGHT }} width={mapWidth * dpi}/>
|
|
154
|
+
<div className={styles.mapThumb} ref={thumbRef} style={{
|
|
155
|
+
transform: thumbStyle.transform,
|
|
156
|
+
width: thumbWidth > 0
|
|
157
|
+
? thumbWidth
|
|
158
|
+
: `calc(100% - ${TIMELINE_PADDING * 2}px)`,
|
|
159
|
+
top: 2,
|
|
160
|
+
height: MAP_HEIGHT - 4,
|
|
161
|
+
}}/>
|
|
162
|
+
</div>);
|
|
163
|
+
});
|
|
164
|
+
//# sourceMappingURL=map.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map.jsx","sourceRoot":"","sources":["../../../src/trace-viewer/components/map.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Dispatch, MutableRefObject, ReactNode } from 'react';
|
|
2
|
+
import { type TraceViewerAction } from '../context';
|
|
3
|
+
import type { MemoCache, RootNode, ScrollSnapshot, VisibleSpan, VisibleSpanEvent } from '../types';
|
|
4
|
+
export declare function Markers({ scale }: {
|
|
5
|
+
scale: number;
|
|
6
|
+
}): ReactNode;
|
|
7
|
+
export declare function EventMarkers({ events, root, scale, }: {
|
|
8
|
+
events: VisibleSpanEvent[];
|
|
9
|
+
root: RootNode;
|
|
10
|
+
scale: number;
|
|
11
|
+
}): ReactNode;
|
|
12
|
+
export declare function CursorMarker({ memoCacheRef, timelineRef, root, spans, events, scale, dispatch, scrollSnapshotRef, }: {
|
|
13
|
+
memoCacheRef: MutableRefObject<MemoCache>;
|
|
14
|
+
timelineRef: MutableRefObject<HTMLDivElement | null>;
|
|
15
|
+
root: RootNode;
|
|
16
|
+
spans: VisibleSpan[];
|
|
17
|
+
events: VisibleSpanEvent[];
|
|
18
|
+
scale: number;
|
|
19
|
+
dispatch: Dispatch<TraceViewerAction>;
|
|
20
|
+
scrollSnapshotRef: MutableRefObject<ScrollSnapshot | undefined>;
|
|
21
|
+
}): ReactNode;
|
|
22
|
+
//# sourceMappingURL=markers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markers.d.ts","sourceRoot":"","sources":["../../../src/trace-viewer/components/markers.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAEV,QAAQ,EACR,gBAAgB,EAChB,SAAS,EACV,MAAM,OAAO,CAAC;AAEf,OAAO,EAAE,KAAK,iBAAiB,EAAkB,MAAM,YAAY,CAAC;AAEpE,OAAO,KAAK,EACV,SAAS,EACT,QAAQ,EACR,cAAc,EACd,WAAW,EACX,gBAAgB,EACjB,MAAM,UAAU,CAAC;AAalB,wBAAgB,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,GAAG,SAAS,CAwD/D;AAED,wBAAgB,YAAY,CAAC,EAC3B,MAAM,EACN,IAAI,EACJ,KAAK,GACN,EAAE;IACD,MAAM,EAAE,gBAAgB,EAAE,CAAC;IAC3B,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;CACf,GAAG,SAAS,CAiCZ;AASD,wBAAgB,YAAY,CAAC,EAC3B,YAAY,EACZ,WAAW,EACX,IAAI,EACJ,KAAK,EACL,MAAM,EACN,KAAK,EACL,QAAQ,EACR,iBAAiB,GAClB,EAAE;IACD,YAAY,EAAE,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAC1C,WAAW,EAAE,gBAAgB,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;IACrD,IAAI,EAAE,QAAQ,CAAC;IACf,KAAK,EAAE,WAAW,EAAE,CAAC;IACrB,MAAM,EAAE,gBAAgB,EAAE,CAAC;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAC;IACtC,iBAAiB,EAAE,gBAAgB,CAAC,cAAc,GAAG,SAAS,CAAC,CAAC;CACjE,GAAG,SAAS,CAsZZ"}
|