@workflow/web-shared 4.0.1-beta.10
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 +201 -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 +328 -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.js +23 -0
- package/dist/components/ui/alert.js.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.js +15 -0
- package/dist/run-trace-view.js.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.js +129 -0
- package/dist/sidebar/attribute-panel.js.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.js +9 -0
- package/dist/sidebar/detail-card.js.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.js +35 -0
- package/dist/sidebar/events-list.js.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.js +56 -0
- package/dist/sidebar/workflow-detail-panel.js.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.js +162 -0
- package/dist/trace-viewer/components/map.js.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.js +376 -0
- package/dist/trace-viewer/components/markers.js.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.js +102 -0
- package/dist/trace-viewer/components/node.js.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.js +9 -0
- package/dist/trace-viewer/components/search-input.js.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.js +24 -0
- package/dist/trace-viewer/components/search.js.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.js +284 -0
- package/dist/trace-viewer/components/span-detail-panel.js.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.js +39 -0
- package/dist/trace-viewer/components/ui.js.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.js +29 -0
- package/dist/trace-viewer/components/zoom-button.js.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.js +11 -0
- package/dist/trace-viewer/components/zoom-icons.js.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.js +325 -0
- package/dist/trace-viewer/context.js.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.js +4 -0
- package/dist/trace-viewer/index.js.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.js +285 -0
- package/dist/trace-viewer/trace-viewer.js.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.js +38 -0
- package/dist/trace-viewer/util/use-trackpad-zoom.js.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 +13 -0
- package/dist/workflow-trace-view.d.ts.map +1 -0
- package/dist/workflow-trace-view.js +118 -0
- package/dist/workflow-trace-view.js.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 +62 -0
- package/server/README.md +1 -0
- package/server/package.json +4 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { AlertCircle } from 'lucide-react';
|
|
4
|
+
import { useWorkflowTraceViewerData } from './api/workflow-api-client';
|
|
5
|
+
import { WorkflowTraceViewer } from './workflow-trace-view';
|
|
6
|
+
export function RunTraceView({ env, runId }) {
|
|
7
|
+
// Fetch all run data with live updates
|
|
8
|
+
const { run: runData, steps: allSteps, hooks: allHooks, events: allEvents, loading, error, } = useWorkflowTraceViewerData(env, runId, { live: true });
|
|
9
|
+
const run = runData ?? {};
|
|
10
|
+
if (error && !runData) {
|
|
11
|
+
return (_jsxs("div", { className: "m-4", children: [_jsx(AlertCircle, { className: "h-4 w-4" }), _jsx("p", { children: "Error loading workflow run" }), _jsx("p", { children: error.message })] }));
|
|
12
|
+
}
|
|
13
|
+
return (_jsx("div", { className: "space-y-6", children: _jsxs("div", { className: "relative", children: [loading && (_jsx("div", { className: "absolute inset-0 bg-black/50 flex items-center justify-center", children: _jsx("div", { className: "animate-spin rounded-full h-10 w-10 border-b-2 border-white" }) })), _jsx(WorkflowTraceViewer, { error: error, steps: allSteps, events: allEvents, hooks: allHooks, env: env, run: run, isLoading: loading })] }) }));
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=run-trace-view.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-trace-view.js","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,eAAK,SAAS,EAAC,KAAK,aAClB,KAAC,WAAW,IAAC,SAAS,EAAC,SAAS,GAAG,EACnC,qDAAiC,EACjC,sBAAI,KAAK,CAAC,OAAO,GAAK,IAClB,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,cAAK,SAAS,EAAC,WAAW,YACxB,eAAK,SAAS,EAAC,UAAU,aACtB,OAAO,IAAI,CACV,cAAK,SAAS,EAAC,+DAA+D,YAC5E,cAAK,SAAS,EAAC,6DAA6D,GAAO,GAC/E,CACP,EACD,KAAC,mBAAmB,IAClB,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,QAAQ,EACf,MAAM,EAAE,SAAS,EACjB,KAAK,EAAE,QAAQ,EACf,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,OAAO,GAClB,IACE,GACF,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-runtime").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-runtime").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,mDA4BA,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,4CAsCA,CAAC"}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { parseStepName, parseWorkflowName } from '@workflow/core/parse-name';
|
|
4
|
+
import { AlertCircle } from 'lucide-react';
|
|
5
|
+
import { Alert, AlertDescription, AlertTitle } from '../components/ui/alert';
|
|
6
|
+
import { DetailCard } from './detail-card';
|
|
7
|
+
const JsonBlock = (value) => {
|
|
8
|
+
return (_jsx("pre", { className: "text-copy-12 overflow-x-auto rounded-md border p-4", style: {
|
|
9
|
+
borderColor: 'var(--ds-gray-300)',
|
|
10
|
+
backgroundColor: 'var(--ds-gray-100)',
|
|
11
|
+
color: 'var(--ds-gray-1000)',
|
|
12
|
+
}, children: _jsx("code", { children: JSON.stringify(value, null, 2) }) }));
|
|
13
|
+
};
|
|
14
|
+
const attributeOrder = [
|
|
15
|
+
'workflowName',
|
|
16
|
+
'stepName',
|
|
17
|
+
'status',
|
|
18
|
+
'stepId',
|
|
19
|
+
'hookId',
|
|
20
|
+
'eventId',
|
|
21
|
+
'runId',
|
|
22
|
+
'attempt',
|
|
23
|
+
'token',
|
|
24
|
+
'correlationId',
|
|
25
|
+
'eventType',
|
|
26
|
+
'deploymentId',
|
|
27
|
+
'ownerId',
|
|
28
|
+
'projectId',
|
|
29
|
+
'environment',
|
|
30
|
+
'executionContext',
|
|
31
|
+
'createdAt',
|
|
32
|
+
'startedAt',
|
|
33
|
+
'updatedAt',
|
|
34
|
+
'completedAt',
|
|
35
|
+
'retryAfter',
|
|
36
|
+
'error',
|
|
37
|
+
'errorCode',
|
|
38
|
+
'metadata',
|
|
39
|
+
'eventData',
|
|
40
|
+
'input',
|
|
41
|
+
'output',
|
|
42
|
+
'resumeAt',
|
|
43
|
+
];
|
|
44
|
+
const sortByAttributeOrder = (a, b) => {
|
|
45
|
+
const aIndex = attributeOrder.indexOf(a) || 0;
|
|
46
|
+
const bIndex = attributeOrder.indexOf(b) || 0;
|
|
47
|
+
return aIndex - bIndex;
|
|
48
|
+
};
|
|
49
|
+
const attributeToDisplayFn = {
|
|
50
|
+
// Names that need pretty-printing
|
|
51
|
+
workflowName: (value) => parseWorkflowName(String(value))?.shortName ?? '?',
|
|
52
|
+
stepName: (value) => parseStepName(String(value))?.shortName ?? '?',
|
|
53
|
+
// IDs
|
|
54
|
+
runId: (value) => String(value),
|
|
55
|
+
stepId: (value) => String(value),
|
|
56
|
+
hookId: (value) => String(value),
|
|
57
|
+
eventId: (value) => String(value),
|
|
58
|
+
// Run/step details
|
|
59
|
+
status: (value) => String(value),
|
|
60
|
+
attempt: (value) => String(value),
|
|
61
|
+
// Hook details
|
|
62
|
+
token: (value) => String(value),
|
|
63
|
+
// Event details
|
|
64
|
+
eventType: (value) => String(value),
|
|
65
|
+
correlationId: (value) => String(value),
|
|
66
|
+
// Project details
|
|
67
|
+
deploymentId: (value) => String(value),
|
|
68
|
+
// Tenancy (we don't show these)
|
|
69
|
+
ownerId: (_value) => null,
|
|
70
|
+
projectId: (_value) => null,
|
|
71
|
+
environment: (_value) => null,
|
|
72
|
+
executionContext: (_value) => null,
|
|
73
|
+
// Dates
|
|
74
|
+
// TODO: relative time with tooltips for ISO times
|
|
75
|
+
createdAt: (value) => new Date(String(value)).toLocaleString(),
|
|
76
|
+
startedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
77
|
+
updatedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
78
|
+
completedAt: (value) => new Date(String(value)).toLocaleString(),
|
|
79
|
+
retryAfter: (value) => new Date(String(value)).toLocaleString(),
|
|
80
|
+
resumeAt: (value) => new Date(String(value)).toLocaleString(),
|
|
81
|
+
// Resolved attributes, won't actually use this function
|
|
82
|
+
metadata: JsonBlock,
|
|
83
|
+
input: (value) => {
|
|
84
|
+
const argCount = Array.isArray(value) ? value.length : 0;
|
|
85
|
+
return (_jsx(DetailCard, { summary: `Input (${argCount} arguments)`, children: Array.isArray(value)
|
|
86
|
+
? value.map((v, i) => (_jsx("div", { className: "mt-2", children: JsonBlock(v) }, i)))
|
|
87
|
+
: JsonBlock(value) }));
|
|
88
|
+
},
|
|
89
|
+
output: (value) => {
|
|
90
|
+
return _jsx(DetailCard, { summary: "Output", children: JsonBlock(value) });
|
|
91
|
+
},
|
|
92
|
+
error: (value) => {
|
|
93
|
+
return _jsx(DetailCard, { summary: "Error", children: JsonBlock(value) });
|
|
94
|
+
},
|
|
95
|
+
errorCode: JsonBlock,
|
|
96
|
+
eventData: (value) => {
|
|
97
|
+
return _jsx(DetailCard, { summary: "Event Data", children: JsonBlock(value) });
|
|
98
|
+
},
|
|
99
|
+
};
|
|
100
|
+
const resolvableAttributes = [
|
|
101
|
+
'input',
|
|
102
|
+
'output',
|
|
103
|
+
'error',
|
|
104
|
+
'errorCode',
|
|
105
|
+
'metadata',
|
|
106
|
+
'eventData',
|
|
107
|
+
];
|
|
108
|
+
export const AttributeBlock = ({ attribute, value, isLoading, }) => {
|
|
109
|
+
const displayFn = attributeToDisplayFn[attribute];
|
|
110
|
+
if (!displayFn) {
|
|
111
|
+
return null;
|
|
112
|
+
}
|
|
113
|
+
const displayValue = displayFn(value);
|
|
114
|
+
if (!displayValue) {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
return (_jsxs("div", { className: "relative", children: [typeof isLoading === 'boolean' && isLoading && (_jsx("div", { className: "absolute top-9 right-4", children: _jsx("div", { className: "animate-spin rounded-full h-4 w-4 border-b-2", style: { borderColor: 'var(--ds-gray-900)' } }) })), _jsxs("div", { className: "flex flex-col gap-0 my-2", children: [_jsx("span", { className: "font-medium", style: { color: 'var(--ds-gray-500)' }, children: attribute }), _jsx("span", { style: { color: 'var(--ds-gray-1000)' }, children: displayValue })] }, attribute)] }));
|
|
118
|
+
};
|
|
119
|
+
export const AttributePanel = ({ data, isLoading, error, }) => {
|
|
120
|
+
const displayData = data;
|
|
121
|
+
const basicAttributes = Object.keys(displayData)
|
|
122
|
+
.filter((key) => !resolvableAttributes.includes(key))
|
|
123
|
+
.sort(sortByAttributeOrder);
|
|
124
|
+
const resolvedAttributes = Object.keys(displayData)
|
|
125
|
+
.filter((key) => resolvableAttributes.includes(key))
|
|
126
|
+
.sort(sortByAttributeOrder);
|
|
127
|
+
return (_jsxs("div", { children: [basicAttributes.map((attribute) => (_jsx(AttributeBlock, { attribute: attribute, value: displayData[attribute] }, attribute))), error ? (_jsxs(Alert, { variant: "destructive", className: "my-4", children: [_jsx(AlertCircle, { className: "h-4 w-4" }), _jsx(AlertTitle, { children: "Failed to load resource details" }), _jsx(AlertDescription, { className: "text-sm", children: error.message })] })) : (resolvedAttributes.map((attribute) => (_jsx(AttributeBlock, { isLoading: isLoading, attribute: attribute, value: displayData[attribute] }, attribute))))] }));
|
|
128
|
+
};
|
|
129
|
+
//# sourceMappingURL=attribute-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"attribute-panel.js","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,2CAgBA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
export function DetailCard({ summary, children, }) {
|
|
3
|
+
return (_jsxs("details", { className: "group", children: [_jsx("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
|
+
}, children: summary }), _jsx("div", { className: "p-2", children: children })] }));
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=detail-card.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail-card.js","sourceRoot":"","sources":["../../src/sidebar/detail-card.tsx"],"names":[],"mappings":";AAEA,MAAM,UAAU,UAAU,CAAC,EACzB,OAAO,EACP,QAAQ,GAIT;IACC,OAAO,CACL,mBAAS,SAAS,EAAC,OAAO,aACxB,kBACE,SAAS,EAAC,6EAA6E,EACvF,KAAK,EAAE;oBACL,WAAW,EAAE,oBAAoB;oBACjC,eAAe,EAAE,oBAAoB;oBACrC,KAAK,EAAE,oBAAoB;iBAC5B,YAEA,OAAO,GACA,EACV,cAAK,SAAS,EAAC,KAAK,YAAE,QAAQ,GAAO,IAC7B,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-runtime").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,2CAkGA"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { AlertCircle } from 'lucide-react';
|
|
4
|
+
import { useCallback } from 'react';
|
|
5
|
+
import useSWR from 'swr';
|
|
6
|
+
import { fetchEventsByCorrelationId, } from '../api/workflow-server-actions';
|
|
7
|
+
import { Alert, AlertDescription, AlertTitle } from '../components/ui/alert';
|
|
8
|
+
import { convertEventsToSpanEvents } from '../workflow-traces/trace-span-construction';
|
|
9
|
+
import { AttributeBlock } from './attribute-panel';
|
|
10
|
+
import { DetailCard } from './detail-card';
|
|
11
|
+
export function EventsList({ correlationId, env, events, }) {
|
|
12
|
+
const fetchEvents = useCallback(() => {
|
|
13
|
+
return fetchEventsByCorrelationId(env, correlationId, {
|
|
14
|
+
sortOrder: 'asc',
|
|
15
|
+
limit: 100,
|
|
16
|
+
withData: true,
|
|
17
|
+
}).then((evts) => {
|
|
18
|
+
if (!evts.success) {
|
|
19
|
+
throw new Error(evts.error?.message || 'Failed to fetch events');
|
|
20
|
+
}
|
|
21
|
+
return convertEventsToSpanEvents(evts.data.data || [], false);
|
|
22
|
+
});
|
|
23
|
+
}, [env, correlationId]);
|
|
24
|
+
const { data, error: eventError, isLoading: eventsLoading, } = useSWR(['workflow', 'events', correlationId], fetchEvents, {
|
|
25
|
+
fallbackData: events,
|
|
26
|
+
revalidateOnFocus: false,
|
|
27
|
+
});
|
|
28
|
+
const displayData = (data?.length ? data : events) || [];
|
|
29
|
+
return (_jsxs("div", { className: "mt-2", style: { color: 'var(--ds-gray-1000)' }, children: [_jsxs("h3", { className: "text-heading-16 font-medium mt-4 mb-2", style: { color: 'var(--ds-gray-1000)' }, children: ["Events (", eventsLoading ? '...' : displayData.length, ")"] }), eventError ? (_jsxs(Alert, { variant: "destructive", className: "my-4", children: [_jsx(AlertCircle, { className: "h-4 w-4" }), _jsx(AlertTitle, { children: "Failed to load event data" }), _jsx(AlertDescription, { className: "text-sm", children: eventError.message })] })) : null, eventsLoading ? _jsx("div", { children: "Loading events..." }) : null, !eventsLoading && !eventError && displayData.length === 0 && (_jsx("div", { className: "text-sm", children: "No events found" })), displayData.length > 0 && !eventError ? (_jsx("div", { className: "flex flex-col gap-2", children: displayData.map((event, index) => (_jsx(DetailCard, { summary: _jsxs(_Fragment, { children: [_jsx("span", { className: "font-medium", style: { color: 'var(--ds-gray-1000)' }, children: event.name }), ' ', "-", ' ', _jsx("span", { style: { color: 'var(--ds-gray-700)' }, children: new Date(event.timestamp[0] * 1000 + event.timestamp[1] / 1e6).toLocaleString() })] }), children: _jsxs("div", { className: "mt-2 px-4", children: [Object.entries(event.attributes)
|
|
30
|
+
.filter(([key]) => key !== 'eventData')
|
|
31
|
+
.map(([key, value]) => (_jsx(AttributeBlock, { attribute: key, value: value }, key))), _jsxs("div", { className: "relative", children: [eventError && _jsx("div", { children: "Error loading event data" }), !eventError &&
|
|
32
|
+
!eventsLoading &&
|
|
33
|
+
event.attributes.eventData && (_jsx(AttributeBlock, { isLoading: eventsLoading, attribute: "eventData", value: event.attributes.eventData }))] })] }) }, `${event.name}-${index}`))) })) : null] }));
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=events-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"events-list.js","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,56 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import clsx from 'clsx';
|
|
4
|
+
import { useEffect, useMemo } from 'react';
|
|
5
|
+
import { toast } from 'sonner';
|
|
6
|
+
import { useWorkflowResourceData } from '../api/workflow-api-client';
|
|
7
|
+
import { EventsList } from '../sidebar/events-list';
|
|
8
|
+
import { useTraceViewer } from '../trace-viewer';
|
|
9
|
+
import { AttributePanel } from './attribute-panel';
|
|
10
|
+
/**
|
|
11
|
+
* Custom panel component for workflow traces that displays entity details
|
|
12
|
+
*/
|
|
13
|
+
export function WorkflowDetailPanel({ env, }) {
|
|
14
|
+
const { state } = useTraceViewer();
|
|
15
|
+
const { selected } = state;
|
|
16
|
+
const data = selected?.span.attributes?.data;
|
|
17
|
+
// Determine resource ID and runId (needed for steps)
|
|
18
|
+
const { resource, resourceId, runId } = useMemo(() => {
|
|
19
|
+
const resource = selected?.span.attributes?.resource;
|
|
20
|
+
if (resource === 'step') {
|
|
21
|
+
const step = data;
|
|
22
|
+
return { resource: 'step', resourceId: step.stepId, runId: step.runId };
|
|
23
|
+
}
|
|
24
|
+
else if (resource === 'run') {
|
|
25
|
+
const run = data;
|
|
26
|
+
return { resource: 'run', resourceId: run.runId, runId: undefined };
|
|
27
|
+
}
|
|
28
|
+
else if (resource === 'hook') {
|
|
29
|
+
const hook = data;
|
|
30
|
+
return { resource: 'hook', resourceId: hook.hookId, runId: undefined };
|
|
31
|
+
}
|
|
32
|
+
else if (resource === 'sleep') {
|
|
33
|
+
return {
|
|
34
|
+
resource: 'sleep',
|
|
35
|
+
resourceId: selected?.span?.spanId,
|
|
36
|
+
runId: undefined,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
return { resource: undefined, resourceId: undefined, runId: undefined };
|
|
40
|
+
}, [selected, data]);
|
|
41
|
+
// Fetch full resource data with events
|
|
42
|
+
const { data: fetchedData, error, loading, } = useWorkflowResourceData(env, resource, resourceId ?? '', { runId });
|
|
43
|
+
useEffect(() => {
|
|
44
|
+
if (error && selected && resource) {
|
|
45
|
+
toast.error(`Failed to load ${resource} details`, {
|
|
46
|
+
description: error.message,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}, [error, resource, selected]);
|
|
50
|
+
if (!selected || !resource || !resourceId) {
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
const displayData = fetchedData || data;
|
|
54
|
+
return (_jsxs("div", { className: clsx('flex flex-col px-2'), children: [_jsx(AttributePanel, { data: displayData, isLoading: loading, error: error ?? undefined }), resource !== 'run' && (_jsx(EventsList, { correlationId: resourceId, env: env, events: selected.span.events }))] }));
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=workflow-detail-panel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-detail-panel.js","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,162 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { memo, useEffect, useLayoutEffect, useRef, useState, } from 'react';
|
|
3
|
+
import { useTraceViewer } from '../context';
|
|
4
|
+
import styles from '../trace-viewer.module.css';
|
|
5
|
+
import { MAP_HEIGHT, TIMELINE_PADDING } from '../util/constants';
|
|
6
|
+
import { useImmediateStyle } from '../util/use-immediate-style';
|
|
7
|
+
const getDpi = () => {
|
|
8
|
+
if ('devicePixelRatio' in globalThis) {
|
|
9
|
+
return globalThis.devicePixelRatio || 1;
|
|
10
|
+
}
|
|
11
|
+
return 1;
|
|
12
|
+
};
|
|
13
|
+
const useDpi = () => {
|
|
14
|
+
const [dpi, setDpi] = useState(1);
|
|
15
|
+
useLayoutEffect(() => {
|
|
16
|
+
const onChange = () => setDpi(getDpi());
|
|
17
|
+
const media = matchMedia(`(resolution: ${dpi}dppx)`);
|
|
18
|
+
media.addEventListener('change', onChange);
|
|
19
|
+
onChange();
|
|
20
|
+
return () => {
|
|
21
|
+
media.removeEventListener('change', onChange);
|
|
22
|
+
};
|
|
23
|
+
}, [dpi]);
|
|
24
|
+
return dpi;
|
|
25
|
+
};
|
|
26
|
+
const padding = TIMELINE_PADDING;
|
|
27
|
+
export const MiniMap = memo(function MiniMap({ timelineRef, rows, scale, }) {
|
|
28
|
+
const { state: { root, baseScale, timelineWidth, width: fullWidth, scrollbarWidth }, } = useTraceViewer();
|
|
29
|
+
const mapWidth = fullWidth + TIMELINE_PADDING * 2;
|
|
30
|
+
const dpi = useDpi();
|
|
31
|
+
const containerRef = useRef(null);
|
|
32
|
+
const canvasRef = useRef(null);
|
|
33
|
+
const thumbRatio = (fullWidth / (fullWidth - scrollbarWidth)) *
|
|
34
|
+
Math.min(fullWidth / timelineWidth, baseScale / scale);
|
|
35
|
+
const thumbWidth = Math.min(fullWidth, (timelineWidth - scrollbarWidth) * thumbRatio);
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
let isHeld = false;
|
|
38
|
+
let clientX = 0;
|
|
39
|
+
let rect;
|
|
40
|
+
const isValidEventTarget = (target) => {
|
|
41
|
+
return Boolean(containerRef.current?.contains(target));
|
|
42
|
+
};
|
|
43
|
+
let nextFrame = 0;
|
|
44
|
+
const onFrame = () => {
|
|
45
|
+
if (!isHeld || !rect)
|
|
46
|
+
return;
|
|
47
|
+
const $timeline = timelineRef.current;
|
|
48
|
+
if (!$timeline)
|
|
49
|
+
return;
|
|
50
|
+
const x = clientX - thumbWidth * 0.5 - rect.left;
|
|
51
|
+
$timeline.scrollLeft = x / thumbRatio;
|
|
52
|
+
};
|
|
53
|
+
const onPointerMove = (event) => {
|
|
54
|
+
({ clientX } = event);
|
|
55
|
+
cancelAnimationFrame(nextFrame);
|
|
56
|
+
nextFrame = requestAnimationFrame(onFrame);
|
|
57
|
+
};
|
|
58
|
+
const onPointerDown = (event) => {
|
|
59
|
+
if (!isValidEventTarget(event.target))
|
|
60
|
+
return;
|
|
61
|
+
isHeld = true;
|
|
62
|
+
rect = containerRef.current?.getBoundingClientRect();
|
|
63
|
+
onPointerMove(event);
|
|
64
|
+
};
|
|
65
|
+
const onPointerUp = () => {
|
|
66
|
+
isHeld = false;
|
|
67
|
+
rect = undefined;
|
|
68
|
+
};
|
|
69
|
+
const onTouchStart = (event) => {
|
|
70
|
+
if (!isValidEventTarget(event.target))
|
|
71
|
+
return;
|
|
72
|
+
if (event.cancelable) {
|
|
73
|
+
event.preventDefault();
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
const onTouchMove = (event) => {
|
|
77
|
+
if (!isHeld)
|
|
78
|
+
return;
|
|
79
|
+
if (event.cancelable) {
|
|
80
|
+
event.preventDefault();
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
window.addEventListener('pointerdown', onPointerDown);
|
|
84
|
+
window.addEventListener('pointermove', onPointerMove);
|
|
85
|
+
window.addEventListener('pointerup', onPointerUp);
|
|
86
|
+
window.addEventListener('blur', onPointerUp);
|
|
87
|
+
window.addEventListener('touchstart', onTouchStart, { passive: false });
|
|
88
|
+
window.addEventListener('touchmove', onTouchMove, { passive: false });
|
|
89
|
+
return () => {
|
|
90
|
+
window.removeEventListener('pointerdown', onPointerDown);
|
|
91
|
+
window.removeEventListener('pointermove', onPointerMove);
|
|
92
|
+
window.removeEventListener('pointerup', onPointerUp);
|
|
93
|
+
window.removeEventListener('blur', onPointerUp);
|
|
94
|
+
window.removeEventListener('touchstart', onTouchStart);
|
|
95
|
+
window.removeEventListener('touchmove', onTouchMove);
|
|
96
|
+
cancelAnimationFrame(nextFrame);
|
|
97
|
+
};
|
|
98
|
+
}, [timelineRef, thumbRatio, thumbWidth]);
|
|
99
|
+
useEffect(() => {
|
|
100
|
+
const canvas = canvasRef.current;
|
|
101
|
+
const ctx = canvas?.getContext('2d');
|
|
102
|
+
if (!canvas || !ctx)
|
|
103
|
+
return;
|
|
104
|
+
const render = () => {
|
|
105
|
+
ctx.resetTransform();
|
|
106
|
+
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
|
107
|
+
ctx.scale(dpi, dpi);
|
|
108
|
+
const gap = 1;
|
|
109
|
+
const height = 3;
|
|
110
|
+
const ratio = (mapWidth - padding * 2) / root.duration;
|
|
111
|
+
// TODO: fill spans based on depth
|
|
112
|
+
ctx.fillStyle = '#ccc';
|
|
113
|
+
ctx.beginPath();
|
|
114
|
+
for (const row of rows) {
|
|
115
|
+
for (const span of row) {
|
|
116
|
+
const y = padding - gap + (gap + height) * span.row;
|
|
117
|
+
if (y >= MAP_HEIGHT - height - padding)
|
|
118
|
+
break;
|
|
119
|
+
const x = padding + (span.startTime - root.startTime) * ratio;
|
|
120
|
+
const width = span.duration * ratio;
|
|
121
|
+
ctx.roundRect(x, y, width, height, height);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
ctx.fill();
|
|
125
|
+
};
|
|
126
|
+
const nextFrame = requestAnimationFrame(render);
|
|
127
|
+
return () => cancelAnimationFrame(nextFrame);
|
|
128
|
+
}, [dpi, root, mapWidth, rows]);
|
|
129
|
+
const thumbRef = useRef(null);
|
|
130
|
+
const { style: thumbStyle, setStyle: setThumbStyle } = useImmediateStyle(thumbRef);
|
|
131
|
+
useLayoutEffect(() => {
|
|
132
|
+
const $timeline = timelineRef.current;
|
|
133
|
+
if (!$timeline)
|
|
134
|
+
return;
|
|
135
|
+
let nextFrame = 0;
|
|
136
|
+
const onFrame = () => {
|
|
137
|
+
setThumbStyle('transform', `translateX(${padding + $timeline.scrollLeft * thumbRatio}px)`);
|
|
138
|
+
};
|
|
139
|
+
onFrame();
|
|
140
|
+
const onScroll = () => {
|
|
141
|
+
cancelAnimationFrame(nextFrame);
|
|
142
|
+
nextFrame = requestAnimationFrame(onFrame);
|
|
143
|
+
};
|
|
144
|
+
$timeline.addEventListener('scroll', onScroll);
|
|
145
|
+
return () => {
|
|
146
|
+
cancelAnimationFrame(nextFrame);
|
|
147
|
+
$timeline.removeEventListener('scroll', onScroll);
|
|
148
|
+
};
|
|
149
|
+
}, [timelineRef, thumbRatio, setThumbStyle]);
|
|
150
|
+
return (_jsxs("div", { className: styles.mapContainer, ref: containerRef, style: {
|
|
151
|
+
width: thumbWidth > 0 ? mapWidth : '100%',
|
|
152
|
+
height: MAP_HEIGHT,
|
|
153
|
+
}, children: [_jsx("canvas", { className: styles.mapCanvas, height: MAP_HEIGHT * dpi, ref: canvasRef, style: { width: mapWidth, height: MAP_HEIGHT }, width: mapWidth * dpi }), _jsx("div", { className: styles.mapThumb, ref: thumbRef, style: {
|
|
154
|
+
transform: thumbStyle.transform,
|
|
155
|
+
width: thumbWidth > 0
|
|
156
|
+
? thumbWidth
|
|
157
|
+
: `calc(100% - ${TIMELINE_PADDING * 2}px)`,
|
|
158
|
+
top: 2,
|
|
159
|
+
height: MAP_HEIGHT - 4,
|
|
160
|
+
} })] }));
|
|
161
|
+
});
|
|
162
|
+
//# sourceMappingURL=map.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"map.js","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"}
|