@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.
Files changed (148) hide show
  1. package/LICENSE.md +21 -0
  2. package/README.md +76 -0
  3. package/dist/api/workflow-api-client.d.ts +303 -0
  4. package/dist/api/workflow-api-client.d.ts.map +1 -0
  5. package/dist/api/workflow-api-client.js +797 -0
  6. package/dist/api/workflow-api-client.js.map +1 -0
  7. package/dist/api/workflow-server-actions.d.ts +97 -0
  8. package/dist/api/workflow-server-actions.d.ts.map +1 -0
  9. package/dist/api/workflow-server-actions.js +329 -0
  10. package/dist/api/workflow-server-actions.js.map +1 -0
  11. package/dist/components/ui/alert.d.ts +9 -0
  12. package/dist/components/ui/alert.d.ts.map +1 -0
  13. package/dist/components/ui/alert.jsx +22 -0
  14. package/dist/components/ui/alert.jsx.map +1 -0
  15. package/dist/index.d.ts +7 -0
  16. package/dist/index.d.ts.map +1 -0
  17. package/dist/index.js +5 -0
  18. package/dist/index.js.map +1 -0
  19. package/dist/lib/utils.d.ts +11 -0
  20. package/dist/lib/utils.d.ts.map +1 -0
  21. package/dist/lib/utils.js +19 -0
  22. package/dist/lib/utils.js.map +1 -0
  23. package/dist/run-trace-view.d.ts +8 -0
  24. package/dist/run-trace-view.d.ts.map +1 -0
  25. package/dist/run-trace-view.jsx +25 -0
  26. package/dist/run-trace-view.jsx.map +1 -0
  27. package/dist/sidebar/attribute-panel.d.ts +11 -0
  28. package/dist/sidebar/attribute-panel.d.ts.map +1 -0
  29. package/dist/sidebar/attribute-panel.jsx +153 -0
  30. package/dist/sidebar/attribute-panel.jsx.map +1 -0
  31. package/dist/sidebar/detail-card.d.ts +6 -0
  32. package/dist/sidebar/detail-card.d.ts.map +1 -0
  33. package/dist/sidebar/detail-card.jsx +13 -0
  34. package/dist/sidebar/detail-card.jsx.map +1 -0
  35. package/dist/sidebar/events-list.d.ts +8 -0
  36. package/dist/sidebar/events-list.d.ts.map +1 -0
  37. package/dist/sidebar/events-list.jsx +67 -0
  38. package/dist/sidebar/events-list.jsx.map +1 -0
  39. package/dist/sidebar/workflow-detail-panel.d.ts +8 -0
  40. package/dist/sidebar/workflow-detail-panel.d.ts.map +1 -0
  41. package/dist/sidebar/workflow-detail-panel.jsx +59 -0
  42. package/dist/sidebar/workflow-detail-panel.jsx.map +1 -0
  43. package/dist/trace-viewer/components/map.d.ts +8 -0
  44. package/dist/trace-viewer/components/map.d.ts.map +1 -0
  45. package/dist/trace-viewer/components/map.jsx +164 -0
  46. package/dist/trace-viewer/components/map.jsx.map +1 -0
  47. package/dist/trace-viewer/components/markers.d.ts +22 -0
  48. package/dist/trace-viewer/components/markers.d.ts.map +1 -0
  49. package/dist/trace-viewer/components/markers.jsx +400 -0
  50. package/dist/trace-viewer/components/markers.jsx.map +1 -0
  51. package/dist/trace-viewer/components/node.d.ts +31 -0
  52. package/dist/trace-viewer/components/node.d.ts.map +1 -0
  53. package/dist/trace-viewer/components/node.jsx +116 -0
  54. package/dist/trace-viewer/components/node.jsx.map +1 -0
  55. package/dist/trace-viewer/components/search-input.d.ts +9 -0
  56. package/dist/trace-viewer/components/search-input.d.ts.map +1 -0
  57. package/dist/trace-viewer/components/search-input.jsx +16 -0
  58. package/dist/trace-viewer/components/search-input.jsx.map +1 -0
  59. package/dist/trace-viewer/components/search.d.ts +3 -0
  60. package/dist/trace-viewer/components/search.d.ts.map +1 -0
  61. package/dist/trace-viewer/components/search.jsx +27 -0
  62. package/dist/trace-viewer/components/search.jsx.map +1 -0
  63. package/dist/trace-viewer/components/span-detail-panel.d.ts +10 -0
  64. package/dist/trace-viewer/components/span-detail-panel.d.ts.map +1 -0
  65. package/dist/trace-viewer/components/span-detail-panel.jsx +388 -0
  66. package/dist/trace-viewer/components/span-detail-panel.jsx.map +1 -0
  67. package/dist/trace-viewer/components/ui.d.ts +28 -0
  68. package/dist/trace-viewer/components/ui.d.ts.map +1 -0
  69. package/dist/trace-viewer/components/ui.jsx +54 -0
  70. package/dist/trace-viewer/components/ui.jsx.map +1 -0
  71. package/dist/trace-viewer/components/zoom-button.d.ts +3 -0
  72. package/dist/trace-viewer/components/zoom-button.d.ts.map +1 -0
  73. package/dist/trace-viewer/components/zoom-button.jsx +40 -0
  74. package/dist/trace-viewer/components/zoom-button.jsx.map +1 -0
  75. package/dist/trace-viewer/components/zoom-icons.d.ts +11 -0
  76. package/dist/trace-viewer/components/zoom-icons.d.ts.map +1 -0
  77. package/dist/trace-viewer/components/zoom-icons.jsx +23 -0
  78. package/dist/trace-viewer/components/zoom-icons.jsx.map +1 -0
  79. package/dist/trace-viewer/context.d.ts +183 -0
  80. package/dist/trace-viewer/context.d.ts.map +1 -0
  81. package/dist/trace-viewer/context.jsx +326 -0
  82. package/dist/trace-viewer/context.jsx.map +1 -0
  83. package/dist/trace-viewer/index.d.ts +5 -0
  84. package/dist/trace-viewer/index.d.ts.map +1 -0
  85. package/dist/trace-viewer/index.jsx +4 -0
  86. package/dist/trace-viewer/index.jsx.map +1 -0
  87. package/dist/trace-viewer/trace-viewer.d.ts +22 -0
  88. package/dist/trace-viewer/trace-viewer.d.ts.map +1 -0
  89. package/dist/trace-viewer/trace-viewer.jsx +311 -0
  90. package/dist/trace-viewer/trace-viewer.jsx.map +1 -0
  91. package/dist/trace-viewer/trace-viewer.module.css +1275 -0
  92. package/dist/trace-viewer/types.d.ts +201 -0
  93. package/dist/trace-viewer/types.d.ts.map +1 -0
  94. package/dist/trace-viewer/types.js +2 -0
  95. package/dist/trace-viewer/types.js.map +1 -0
  96. package/dist/trace-viewer/util/constants.d.ts +9 -0
  97. package/dist/trace-viewer/util/constants.d.ts.map +1 -0
  98. package/dist/trace-viewer/util/constants.js +9 -0
  99. package/dist/trace-viewer/util/constants.js.map +1 -0
  100. package/dist/trace-viewer/util/scrollbar-width.d.ts +2 -0
  101. package/dist/trace-viewer/util/scrollbar-width.d.ts.map +1 -0
  102. package/dist/trace-viewer/util/scrollbar-width.js +14 -0
  103. package/dist/trace-viewer/util/scrollbar-width.js.map +1 -0
  104. package/dist/trace-viewer/util/timing.d.ts +8 -0
  105. package/dist/trace-viewer/util/timing.d.ts.map +1 -0
  106. package/dist/trace-viewer/util/timing.js +29 -0
  107. package/dist/trace-viewer/util/timing.js.map +1 -0
  108. package/dist/trace-viewer/util/tree.d.ts +13 -0
  109. package/dist/trace-viewer/util/tree.d.ts.map +1 -0
  110. package/dist/trace-viewer/util/tree.js +223 -0
  111. package/dist/trace-viewer/util/tree.js.map +1 -0
  112. package/dist/trace-viewer/util/use-immediate-style.d.ts +15 -0
  113. package/dist/trace-viewer/util/use-immediate-style.d.ts.map +1 -0
  114. package/dist/trace-viewer/util/use-immediate-style.js +22 -0
  115. package/dist/trace-viewer/util/use-immediate-style.js.map +1 -0
  116. package/dist/trace-viewer/util/use-streaming-spans.d.ts +8 -0
  117. package/dist/trace-viewer/util/use-streaming-spans.d.ts.map +1 -0
  118. package/dist/trace-viewer/util/use-streaming-spans.js +332 -0
  119. package/dist/trace-viewer/util/use-streaming-spans.js.map +1 -0
  120. package/dist/trace-viewer/util/use-trackpad-zoom.d.ts +6 -0
  121. package/dist/trace-viewer/util/use-trackpad-zoom.d.ts.map +1 -0
  122. package/dist/trace-viewer/util/use-trackpad-zoom.jsx +38 -0
  123. package/dist/trace-viewer/util/use-trackpad-zoom.jsx.map +1 -0
  124. package/dist/trace-viewer/worker.d.ts +2 -0
  125. package/dist/trace-viewer/worker.d.ts.map +1 -0
  126. package/dist/trace-viewer/worker.js +107 -0
  127. package/dist/trace-viewer/worker.js.map +1 -0
  128. package/dist/workflow-trace-view.d.ts +12 -0
  129. package/dist/workflow-trace-view.d.ts.map +1 -0
  130. package/dist/workflow-trace-view.jsx +129 -0
  131. package/dist/workflow-trace-view.jsx.map +1 -0
  132. package/dist/workflow-traces/event-colors.d.ts +31 -0
  133. package/dist/workflow-traces/event-colors.d.ts.map +1 -0
  134. package/dist/workflow-traces/event-colors.js +68 -0
  135. package/dist/workflow-traces/event-colors.js.map +1 -0
  136. package/dist/workflow-traces/trace-colors.d.ts +15 -0
  137. package/dist/workflow-traces/trace-colors.d.ts.map +1 -0
  138. package/dist/workflow-traces/trace-colors.js +89 -0
  139. package/dist/workflow-traces/trace-colors.js.map +1 -0
  140. package/dist/workflow-traces/trace-span-construction.d.ts +31 -0
  141. package/dist/workflow-traces/trace-span-construction.d.ts.map +1 -0
  142. package/dist/workflow-traces/trace-span-construction.js +173 -0
  143. package/dist/workflow-traces/trace-span-construction.js.map +1 -0
  144. package/dist/workflow-traces/trace-time-utils.d.ts +13 -0
  145. package/dist/workflow-traces/trace-time-utils.d.ts.map +1 -0
  146. package/dist/workflow-traces/trace-time-utils.js +34 -0
  147. package/dist/workflow-traces/trace-time-utils.js.map +1 -0
  148. 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,6 @@
1
+ import type { ReactNode } from 'react';
2
+ export declare function DetailCard({ summary, children, }: {
3
+ summary: ReactNode;
4
+ children?: ReactNode;
5
+ }): import("react").JSX.Element;
6
+ //# sourceMappingURL=detail-card.d.ts.map
@@ -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":"AAAA,YAAY,CAAC;AAGb,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAC;AAC/B,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AAErE,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD;;GAEG;AACH,MAAM,UAAU,mBAAmB,CAAC,EAClC,GAAG,GAGJ;IACC,MAAM,EAAE,KAAK,EAAE,GAAG,cAAc,EAAE,CAAC;IACnC,MAAM,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;IAE3B,MAAM,IAAI,GAAG,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE,IAI/B,CAAC;IAEV,qDAAqD;IACrD,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE;QACnD,MAAM,QAAQ,GAAG,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC;QACrD,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;YACxB,MAAM,IAAI,GAAG,IAAY,CAAC;YAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;QAC1E,CAAC;aAAM,IAAI,QAAQ,KAAK,KAAK,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,IAAmB,CAAC;YAChC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;QACtE,CAAC;aAAM,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;YAC/B,MAAM,IAAI,GAAG,IAAY,CAAC;YAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;QACzE,CAAC;aAAM,IAAI,QAAQ,KAAK,OAAO,EAAE,CAAC;YAChC,OAAO;gBACL,QAAQ,EAAE,OAAO;gBACjB,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM;gBAClC,KAAK,EAAE,SAAS;aACjB,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;IAC1E,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;IAErB,uCAAuC;IACvC,MAAM,EACJ,IAAI,EAAE,WAAW,EACjB,KAAK,EACL,OAAO,GACR,GAAG,uBAAuB,CACzB,GAAG,EACH,QAAmC,EACnC,UAAU,IAAI,EAAE,EAChB,EAAE,KAAK,EAAE,CACV,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,KAAK,IAAI,QAAQ,IAAI,QAAQ,EAAE,CAAC;YAClC,KAAK,CAAC,KAAK,CAAC,kBAAkB,QAAQ,UAAU,EAAE;gBAChD,WAAW,EAAE,KAAK,CAAC,OAAO;aAC3B,CAAC,CAAC;QACL,CAAC;IACH,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;IAEhC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,WAAW,GAAG,WAAW,IAAI,IAAI,CAAC;IAExC,OAAO,CACL,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CACzC;MAAA,CAAC,qBAAqB,CACtB;MAAA,CAAC,cAAc,CACb,IAAI,CAAC,CAAC,WAAW,CAAC,CAClB,SAAS,CAAC,CAAC,OAAO,CAAC,CACnB,KAAK,CAAC,CAAC,KAAK,IAAI,SAAS,CAAC,EAE5B;MAAA,CAAC,QAAQ,KAAK,KAAK,IAAI,CACrB,CAAC,UAAU,CACT,aAAa,CAAC,CAAC,UAAU,CAAC,CAC1B,GAAG,CAAC,CAAC,GAAG,CAAC,CACT,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAC7B,CACH,CACH;IAAA,EAAE,GAAG,CAAC,CACP,CAAC;AACJ,CAAC"}
@@ -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"}