@stigmer/react 0.5.1 → 1.0.1

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 (625) hide show
  1. package/activity/group-activity.d.ts +13 -0
  2. package/activity/group-activity.d.ts.map +1 -0
  3. package/activity/group-activity.js +54 -0
  4. package/activity/group-activity.js.map +1 -0
  5. package/activity/index.d.ts +4 -0
  6. package/activity/index.d.ts.map +1 -0
  7. package/activity/index.js +3 -0
  8. package/activity/index.js.map +1 -0
  9. package/activity/types.d.ts +34 -0
  10. package/activity/types.d.ts.map +1 -0
  11. package/activity/types.js +2 -0
  12. package/activity/types.js.map +1 -0
  13. package/activity/useRecentActivity.d.ts +35 -0
  14. package/activity/useRecentActivity.d.ts.map +1 -0
  15. package/activity/useRecentActivity.js +73 -0
  16. package/activity/useRecentActivity.js.map +1 -0
  17. package/agent/AgentPicker.d.ts.map +1 -1
  18. package/agent/AgentPicker.js +4 -2
  19. package/agent/AgentPicker.js.map +1 -1
  20. package/billing/BillingSection.d.ts.map +1 -1
  21. package/billing/BillingSection.js +1 -1
  22. package/billing/BillingSection.js.map +1 -1
  23. package/composer/ComposerToolbar.d.ts +5 -1
  24. package/composer/ComposerToolbar.d.ts.map +1 -1
  25. package/composer/ComposerToolbar.js +4 -3
  26. package/composer/ComposerToolbar.js.map +1 -1
  27. package/composer/InteractionModePicker.d.ts +40 -0
  28. package/composer/InteractionModePicker.d.ts.map +1 -0
  29. package/composer/InteractionModePicker.js +76 -0
  30. package/composer/InteractionModePicker.js.map +1 -0
  31. package/composer/SessionComposer.d.ts +53 -64
  32. package/composer/SessionComposer.d.ts.map +1 -1
  33. package/composer/SessionComposer.js +20 -8
  34. package/composer/SessionComposer.js.map +1 -1
  35. package/composer/__tests__/SessionComposer-memo.test.js +10 -5
  36. package/composer/__tests__/SessionComposer-memo.test.js.map +1 -1
  37. package/composer/index.d.ts +3 -1
  38. package/composer/index.d.ts.map +1 -1
  39. package/composer/index.js +1 -0
  40. package/composer/index.js.map +1 -1
  41. package/dashboard/DashboardFailedRuns.d.ts +19 -0
  42. package/dashboard/DashboardFailedRuns.d.ts.map +1 -0
  43. package/dashboard/DashboardFailedRuns.js +35 -0
  44. package/dashboard/DashboardFailedRuns.js.map +1 -0
  45. package/dashboard/DashboardKPICards.d.ts +19 -0
  46. package/dashboard/DashboardKPICards.d.ts.map +1 -0
  47. package/dashboard/DashboardKPICards.js +80 -0
  48. package/dashboard/DashboardKPICards.js.map +1 -0
  49. package/dashboard/OperationalDashboard.d.ts +37 -0
  50. package/dashboard/OperationalDashboard.d.ts.map +1 -0
  51. package/dashboard/OperationalDashboard.js +48 -0
  52. package/dashboard/OperationalDashboard.js.map +1 -0
  53. package/dashboard/index.d.ts +8 -0
  54. package/dashboard/index.d.ts.map +1 -0
  55. package/dashboard/index.js +9 -0
  56. package/dashboard/index.js.map +1 -0
  57. package/dashboard/types.d.ts +49 -0
  58. package/dashboard/types.d.ts.map +1 -0
  59. package/dashboard/types.js +2 -0
  60. package/dashboard/types.js.map +1 -0
  61. package/dashboard/useAgentExecutionSummary.d.ts +33 -0
  62. package/dashboard/useAgentExecutionSummary.d.ts.map +1 -0
  63. package/dashboard/useAgentExecutionSummary.js +32 -0
  64. package/dashboard/useAgentExecutionSummary.js.map +1 -0
  65. package/dashboard/useDashboardFailedRuns.d.ts +18 -0
  66. package/dashboard/useDashboardFailedRuns.d.ts.map +1 -0
  67. package/dashboard/useDashboardFailedRuns.js +86 -0
  68. package/dashboard/useDashboardFailedRuns.js.map +1 -0
  69. package/dashboard/useDashboardSummary.d.ts +32 -0
  70. package/dashboard/useDashboardSummary.d.ts.map +1 -0
  71. package/dashboard/useDashboardSummary.js +67 -0
  72. package/dashboard/useDashboardSummary.js.map +1 -0
  73. package/execution/ContextGauge.d.ts +45 -0
  74. package/execution/ContextGauge.d.ts.map +1 -0
  75. package/execution/ContextGauge.js +82 -0
  76. package/execution/ContextGauge.js.map +1 -0
  77. package/execution/InteractionModeBadge.d.ts +24 -0
  78. package/execution/InteractionModeBadge.d.ts.map +1 -0
  79. package/execution/InteractionModeBadge.js +29 -0
  80. package/execution/InteractionModeBadge.js.map +1 -0
  81. package/execution/MessageThread.d.ts +33 -3
  82. package/execution/MessageThread.d.ts.map +1 -1
  83. package/execution/MessageThread.js +51 -9
  84. package/execution/MessageThread.js.map +1 -1
  85. package/execution/PlanCompletionCard.d.ts +23 -0
  86. package/execution/PlanCompletionCard.d.ts.map +1 -0
  87. package/execution/PlanCompletionCard.js +28 -0
  88. package/execution/PlanCompletionCard.js.map +1 -0
  89. package/execution/SummarizationBadge.d.ts +30 -0
  90. package/execution/SummarizationBadge.d.ts.map +1 -0
  91. package/execution/SummarizationBadge.js +61 -0
  92. package/execution/SummarizationBadge.js.map +1 -0
  93. package/execution/SummarizationCard.d.ts +27 -0
  94. package/execution/SummarizationCard.d.ts.map +1 -0
  95. package/execution/SummarizationCard.js +47 -0
  96. package/execution/SummarizationCard.js.map +1 -0
  97. package/execution/__tests__/PlanCompletionCard.test.d.ts +2 -0
  98. package/execution/__tests__/PlanCompletionCard.test.d.ts.map +1 -0
  99. package/execution/__tests__/PlanCompletionCard.test.js +53 -0
  100. package/execution/__tests__/PlanCompletionCard.test.js.map +1 -0
  101. package/execution/__tests__/buildThreadItems-plan-completion.test.d.ts +2 -0
  102. package/execution/__tests__/buildThreadItems-plan-completion.test.d.ts.map +1 -0
  103. package/execution/__tests__/buildThreadItems-plan-completion.test.js +137 -0
  104. package/execution/__tests__/buildThreadItems-plan-completion.test.js.map +1 -0
  105. package/execution/__tests__/useContextWindow.test.d.ts +2 -0
  106. package/execution/__tests__/useContextWindow.test.d.ts.map +1 -0
  107. package/execution/__tests__/useContextWindow.test.js +121 -0
  108. package/execution/__tests__/useContextWindow.test.js.map +1 -0
  109. package/execution/index.d.ts +12 -0
  110. package/execution/index.d.ts.map +1 -1
  111. package/execution/index.js +6 -0
  112. package/execution/index.js.map +1 -1
  113. package/execution/useContextWindow.d.ts +71 -0
  114. package/execution/useContextWindow.d.ts.map +1 -0
  115. package/execution/useContextWindow.js +91 -0
  116. package/execution/useContextWindow.js.map +1 -0
  117. package/execution/useCreateAgentExecution.d.ts +9 -0
  118. package/execution/useCreateAgentExecution.d.ts.map +1 -1
  119. package/execution/useCreateAgentExecution.js +15 -3
  120. package/execution/useCreateAgentExecution.js.map +1 -1
  121. package/index.d.ts +9 -4
  122. package/index.d.ts.map +1 -1
  123. package/index.js +12 -2
  124. package/index.js.map +1 -1
  125. package/internal/VirtualizedThread.d.ts +2 -1
  126. package/internal/VirtualizedThread.d.ts.map +1 -1
  127. package/internal/VirtualizedThread.js +3 -2
  128. package/internal/VirtualizedThread.js.map +1 -1
  129. package/internal/store/index.d.ts +1 -0
  130. package/internal/store/index.d.ts.map +1 -1
  131. package/internal/store/index.js +1 -0
  132. package/internal/store/index.js.map +1 -1
  133. package/internal/store/workflow-execution-event-store.d.ts +92 -0
  134. package/internal/store/workflow-execution-event-store.d.ts.map +1 -0
  135. package/internal/store/workflow-execution-event-store.js +298 -0
  136. package/internal/store/workflow-execution-event-store.js.map +1 -0
  137. package/library/ScopeToggle.d.ts +13 -9
  138. package/library/ScopeToggle.d.ts.map +1 -1
  139. package/library/ScopeToggle.js +43 -22
  140. package/library/ScopeToggle.js.map +1 -1
  141. package/library/VisibilityToggle.js +14 -5
  142. package/library/VisibilityToggle.js.map +1 -1
  143. package/library/index.d.ts +1 -0
  144. package/library/index.d.ts.map +1 -1
  145. package/library/index.js +1 -0
  146. package/library/index.js.map +1 -1
  147. package/library/useExportResource.d.ts +3 -2
  148. package/library/useExportResource.d.ts.map +1 -1
  149. package/library/useExportResource.js +11 -6
  150. package/library/useExportResource.js.map +1 -1
  151. package/mcp-server/McpServerDetailView.d.ts.map +1 -1
  152. package/mcp-server/McpServerDetailView.js +25 -13
  153. package/mcp-server/McpServerDetailView.js.map +1 -1
  154. package/mcp-server/McpServerPicker.d.ts.map +1 -1
  155. package/mcp-server/McpServerPicker.js +4 -2
  156. package/mcp-server/McpServerPicker.js.map +1 -1
  157. package/package.json +16 -5
  158. package/provider.d.ts.map +1 -1
  159. package/provider.js +164 -1
  160. package/provider.js.map +1 -1
  161. package/resource-detail/ResourceDetailShell.d.ts +1 -1
  162. package/resource-detail/ResourceDetailShell.d.ts.map +1 -1
  163. package/resource-detail/ResourceDetailShell.js +6 -6
  164. package/resource-detail/ResourceDetailShell.js.map +1 -1
  165. package/resource-detail/types.d.ts +23 -0
  166. package/resource-detail/types.d.ts.map +1 -1
  167. package/resource-detail/useDeleteResource.d.ts +1 -1
  168. package/resource-detail/useDeleteResource.d.ts.map +1 -1
  169. package/resource-detail/useDeleteResource.js +5 -0
  170. package/resource-detail/useDeleteResource.js.map +1 -1
  171. package/resource-workbench/components/ResourceWorkbench.d.ts.map +1 -1
  172. package/resource-workbench/components/ResourceWorkbench.js +2 -1
  173. package/resource-workbench/components/ResourceWorkbench.js.map +1 -1
  174. package/session/useNewSessionFlow.d.ts.map +1 -1
  175. package/session/useNewSessionFlow.js +1 -0
  176. package/session/useNewSessionFlow.js.map +1 -1
  177. package/session/useSessionConversation.d.ts +7 -0
  178. package/session/useSessionConversation.d.ts.map +1 -1
  179. package/session/useSessionConversation.js +1 -0
  180. package/session/useSessionConversation.js.map +1 -1
  181. package/session/useSessionPageFlow.d.ts.map +1 -1
  182. package/session/useSessionPageFlow.js +1 -0
  183. package/session/useSessionPageFlow.js.map +1 -1
  184. package/session/useSessionUsage.d.ts.map +1 -1
  185. package/session/useSessionUsage.js +65 -4
  186. package/session/useSessionUsage.js.map +1 -1
  187. package/settings/UsageSection.d.ts.map +1 -1
  188. package/settings/UsageSection.js +1 -4
  189. package/settings/UsageSection.js.map +1 -1
  190. package/skill/SkillPicker.d.ts.map +1 -1
  191. package/skill/SkillPicker.js +4 -2
  192. package/skill/SkillPicker.js.map +1 -1
  193. package/src/activity/group-activity.ts +65 -0
  194. package/src/activity/index.ts +13 -0
  195. package/src/activity/types.ts +35 -0
  196. package/src/activity/useRecentActivity.ts +131 -0
  197. package/src/agent/AgentPicker.tsx +6 -1
  198. package/src/billing/BillingSection.tsx +3 -2
  199. package/src/composer/ComposerToolbar.tsx +19 -1
  200. package/src/composer/InteractionModePicker.tsx +189 -0
  201. package/src/composer/SessionComposer.tsx +85 -8
  202. package/src/composer/__tests__/SessionComposer-memo.test.ts +11 -6
  203. package/src/composer/index.ts +7 -0
  204. package/src/dashboard/DashboardFailedRuns.tsx +109 -0
  205. package/src/dashboard/DashboardKPICards.tsx +128 -0
  206. package/src/dashboard/OperationalDashboard.tsx +96 -0
  207. package/src/dashboard/index.ts +37 -0
  208. package/src/dashboard/types.ts +50 -0
  209. package/src/dashboard/useAgentExecutionSummary.ts +71 -0
  210. package/src/dashboard/useDashboardFailedRuns.ts +122 -0
  211. package/src/dashboard/useDashboardSummary.ts +109 -0
  212. package/src/execution/ContextGauge.tsx +243 -0
  213. package/src/execution/InteractionModeBadge.tsx +70 -0
  214. package/src/execution/MessageThread.tsx +88 -3
  215. package/src/execution/PlanCompletionCard.tsx +105 -0
  216. package/src/execution/SummarizationBadge.tsx +188 -0
  217. package/src/execution/SummarizationCard.tsx +126 -0
  218. package/src/execution/__tests__/PlanCompletionCard.test.tsx +67 -0
  219. package/src/execution/__tests__/buildThreadItems-plan-completion.test.ts +197 -0
  220. package/src/execution/__tests__/useContextWindow.test.ts +167 -0
  221. package/src/execution/index.ts +22 -0
  222. package/src/execution/useContextWindow.ts +148 -0
  223. package/src/execution/useCreateAgentExecution.ts +26 -3
  224. package/src/index.ts +222 -0
  225. package/src/internal/VirtualizedThread.tsx +4 -1
  226. package/src/internal/store/index.ts +6 -0
  227. package/src/internal/store/workflow-execution-event-store.ts +391 -0
  228. package/src/library/ScopeToggle.tsx +88 -20
  229. package/src/library/VisibilityToggle.tsx +54 -13
  230. package/src/library/index.ts +2 -0
  231. package/src/library/useExportResource.ts +12 -9
  232. package/src/mcp-server/McpServerDetailView.tsx +80 -148
  233. package/src/mcp-server/McpServerPicker.tsx +6 -1
  234. package/src/provider.tsx +195 -8
  235. package/src/resource-detail/ResourceDetailShell.tsx +21 -4
  236. package/src/resource-detail/types.ts +25 -0
  237. package/src/resource-detail/useDeleteResource.ts +6 -1
  238. package/src/resource-workbench/components/ResourceWorkbench.tsx +4 -0
  239. package/src/session/useNewSessionFlow.ts +1 -0
  240. package/src/session/useSessionConversation.ts +8 -0
  241. package/src/session/useSessionPageFlow.ts +1 -0
  242. package/src/session/useSessionUsage.ts +72 -4
  243. package/src/settings/UsageSection.tsx +1 -9
  244. package/src/skill/SkillPicker.tsx +6 -1
  245. package/src/workflow/ApprovalFormBuilder.tsx +1017 -0
  246. package/src/workflow/BranchConditionBuilder.tsx +451 -0
  247. package/src/workflow/CanvasActionsContext.ts +12 -0
  248. package/src/workflow/CanvasContextMenu.tsx +364 -0
  249. package/src/workflow/CanvasTaskNode.tsx +372 -0
  250. package/src/workflow/CanvasTransitionEdge.tsx +122 -0
  251. package/src/workflow/CostByWorkflowChart.tsx +120 -0
  252. package/src/workflow/ExecutionSummaryWidget.tsx +194 -0
  253. package/src/workflow/ExecutionTrendChart.tsx +157 -0
  254. package/src/workflow/FailedRunsWidget.tsx +109 -0
  255. package/src/workflow/PendingApprovalsWidget.tsx +115 -0
  256. package/src/workflow/TaskConfigForm.tsx +618 -0
  257. package/src/workflow/TaskKindRegistryContext.ts +36 -0
  258. package/src/workflow/TaskPickerPopover.tsx +326 -0
  259. package/src/workflow/WorkflowArchitectDialog.tsx +505 -0
  260. package/src/workflow/WorkflowCanvasEditor.tsx +651 -0
  261. package/src/workflow/WorkflowCanvasInner.tsx +160 -0
  262. package/src/workflow/WorkflowDashboard.tsx +124 -0
  263. package/src/workflow/WorkflowDetailView.tsx +527 -0
  264. package/src/workflow/WorkflowEditorView.tsx +547 -0
  265. package/src/workflow/WorkflowExecutionApprovalCard.tsx +129 -0
  266. package/src/workflow/WorkflowExecutionArtifactPanel.tsx +112 -0
  267. package/src/workflow/WorkflowExecutionCostPanel.tsx +131 -0
  268. package/src/workflow/WorkflowExecutionHeader.tsx +194 -0
  269. package/src/workflow/WorkflowExecutionPhaseBadge.tsx +188 -0
  270. package/src/workflow/WorkflowExecutionTaskPanel.tsx +135 -0
  271. package/src/workflow/WorkflowExecutionTimeline.tsx +118 -0
  272. package/src/workflow/WorkflowExecutionTimelineEvent.tsx +488 -0
  273. package/src/workflow/WorkflowExecutionViewer.tsx +248 -0
  274. package/src/workflow/WorkflowInspectorPanel.tsx +568 -0
  275. package/src/workflow/WorkflowRefinePanel.tsx +411 -0
  276. package/src/workflow/WorkflowRepairCard.tsx +433 -0
  277. package/src/workflow/WorkflowRunDialog.tsx +220 -0
  278. package/src/workflow/WorkflowRunForm.tsx +245 -0
  279. package/src/workflow/WorkflowTaskList.tsx +177 -0
  280. package/src/workflow/WorkflowTaskPalette.tsx +248 -0
  281. package/src/workflow/WorkflowTopologyGraph.tsx +250 -0
  282. package/src/workflow/WorkflowYamlEditor.tsx +271 -0
  283. package/src/workflow/__tests__/starter-workflow-yaml.test.ts +57 -0
  284. package/src/workflow/canvas-constants.ts +87 -0
  285. package/src/workflow/canvas-icons.tsx +36 -0
  286. package/src/workflow/extract-workflow-yaml.ts +87 -0
  287. package/src/workflow/graph-commands.ts +675 -0
  288. package/src/workflow/index.ts +375 -0
  289. package/src/workflow/serialize-workflow-yaml.ts +546 -0
  290. package/src/workflow/starter-workflow-yaml.ts +29 -0
  291. package/src/workflow/types.ts +99 -0
  292. package/src/workflow/useCanvasKeyboardShortcuts.ts +134 -0
  293. package/src/workflow/useDiagnoseExecutionFlow.ts +378 -0
  294. package/src/workflow/useGraphHistory.ts +138 -0
  295. package/src/workflow/usePendingApprovals.ts +89 -0
  296. package/src/workflow/useRefineWorkflowFlow.ts +321 -0
  297. package/src/workflow/useResolveAgentExecutionSession.ts +57 -0
  298. package/src/workflow/useRunWorkflowFlow.ts +235 -0
  299. package/src/workflow/useTaskKindRegistry.ts +135 -0
  300. package/src/workflow/useWorkflow.ts +78 -0
  301. package/src/workflow/useWorkflowArchitectFlow.ts +303 -0
  302. package/src/workflow/useWorkflowCanvas.ts +882 -0
  303. package/src/workflow/useWorkflowCount.ts +66 -0
  304. package/src/workflow/useWorkflowDashboardSummary.ts +71 -0
  305. package/src/workflow/useWorkflowEditor.ts +106 -0
  306. package/src/workflow/useWorkflowExecution.ts +67 -0
  307. package/src/workflow/useWorkflowExecutionActions.ts +179 -0
  308. package/src/workflow/useWorkflowExecutionArtifacts.ts +57 -0
  309. package/src/workflow/useWorkflowExecutionEventLog.ts +111 -0
  310. package/src/workflow/useWorkflowExecutionEventStream.ts +244 -0
  311. package/src/workflow/useWorkflowExecutionList.ts +121 -0
  312. package/src/workflow/useWorkflowInstances.ts +62 -0
  313. package/src/workflow/useWorkflowList.ts +79 -0
  314. package/src/workflow/useWorkflowSave.ts +84 -0
  315. package/src/workflow/useWorkflowTopology.ts +229 -0
  316. package/src/workflow/useWorkflowValidation.ts +329 -0
  317. package/src/workflow/useWorkflowYaml.ts +49 -0
  318. package/src/workflow/workflow-graph-conversions.ts +796 -0
  319. package/src/workflow/workflow-graph-model.ts +83 -0
  320. package/src/workflow/workflow-yaml-diff.ts +132 -0
  321. package/styles.css +1 -1
  322. package/workflow/ApprovalFormBuilder.d.ts +24 -0
  323. package/workflow/ApprovalFormBuilder.d.ts.map +1 -0
  324. package/workflow/ApprovalFormBuilder.js +347 -0
  325. package/workflow/ApprovalFormBuilder.js.map +1 -0
  326. package/workflow/BranchConditionBuilder.d.ts +29 -0
  327. package/workflow/BranchConditionBuilder.d.ts.map +1 -0
  328. package/workflow/BranchConditionBuilder.js +170 -0
  329. package/workflow/BranchConditionBuilder.js.map +1 -0
  330. package/workflow/CanvasActionsContext.d.ts +8 -0
  331. package/workflow/CanvasActionsContext.d.ts.map +1 -0
  332. package/workflow/CanvasActionsContext.js +4 -0
  333. package/workflow/CanvasActionsContext.js.map +1 -0
  334. package/workflow/CanvasContextMenu.d.ts +59 -0
  335. package/workflow/CanvasContextMenu.d.ts.map +1 -0
  336. package/workflow/CanvasContextMenu.js +98 -0
  337. package/workflow/CanvasContextMenu.js.map +1 -0
  338. package/workflow/CanvasTaskNode.d.ts +21 -0
  339. package/workflow/CanvasTaskNode.d.ts.map +1 -0
  340. package/workflow/CanvasTaskNode.js +125 -0
  341. package/workflow/CanvasTaskNode.js.map +1 -0
  342. package/workflow/CanvasTransitionEdge.d.ts +24 -0
  343. package/workflow/CanvasTransitionEdge.d.ts.map +1 -0
  344. package/workflow/CanvasTransitionEdge.js +50 -0
  345. package/workflow/CanvasTransitionEdge.js.map +1 -0
  346. package/workflow/CostByWorkflowChart.d.ts +15 -0
  347. package/workflow/CostByWorkflowChart.d.ts.map +1 -0
  348. package/workflow/CostByWorkflowChart.js +45 -0
  349. package/workflow/CostByWorkflowChart.js.map +1 -0
  350. package/workflow/ExecutionSummaryWidget.d.ts +16 -0
  351. package/workflow/ExecutionSummaryWidget.d.ts.map +1 -0
  352. package/workflow/ExecutionSummaryWidget.js +93 -0
  353. package/workflow/ExecutionSummaryWidget.js.map +1 -0
  354. package/workflow/ExecutionTrendChart.d.ts +14 -0
  355. package/workflow/ExecutionTrendChart.d.ts.map +1 -0
  356. package/workflow/ExecutionTrendChart.js +67 -0
  357. package/workflow/ExecutionTrendChart.js.map +1 -0
  358. package/workflow/FailedRunsWidget.d.ts +19 -0
  359. package/workflow/FailedRunsWidget.d.ts.map +1 -0
  360. package/workflow/FailedRunsWidget.js +37 -0
  361. package/workflow/FailedRunsWidget.js.map +1 -0
  362. package/workflow/PendingApprovalsWidget.d.ts +19 -0
  363. package/workflow/PendingApprovalsWidget.d.ts.map +1 -0
  364. package/workflow/PendingApprovalsWidget.js +35 -0
  365. package/workflow/PendingApprovalsWidget.js.map +1 -0
  366. package/workflow/TaskConfigForm.d.ts +29 -0
  367. package/workflow/TaskConfigForm.d.ts.map +1 -0
  368. package/workflow/TaskConfigForm.js +230 -0
  369. package/workflow/TaskConfigForm.js.map +1 -0
  370. package/workflow/TaskKindRegistryContext.d.ts +24 -0
  371. package/workflow/TaskKindRegistryContext.d.ts.map +1 -0
  372. package/workflow/TaskKindRegistryContext.js +25 -0
  373. package/workflow/TaskKindRegistryContext.js.map +1 -0
  374. package/workflow/TaskPickerPopover.d.ts +33 -0
  375. package/workflow/TaskPickerPopover.d.ts.map +1 -0
  376. package/workflow/TaskPickerPopover.js +110 -0
  377. package/workflow/TaskPickerPopover.js.map +1 -0
  378. package/workflow/WorkflowArchitectDialog.d.ts +48 -0
  379. package/workflow/WorkflowArchitectDialog.d.ts.map +1 -0
  380. package/workflow/WorkflowArchitectDialog.js +129 -0
  381. package/workflow/WorkflowArchitectDialog.js.map +1 -0
  382. package/workflow/WorkflowCanvasEditor.d.ts +38 -0
  383. package/workflow/WorkflowCanvasEditor.d.ts.map +1 -0
  384. package/workflow/WorkflowCanvasEditor.js +287 -0
  385. package/workflow/WorkflowCanvasEditor.js.map +1 -0
  386. package/workflow/WorkflowCanvasInner.d.ts +32 -0
  387. package/workflow/WorkflowCanvasInner.d.ts.map +1 -0
  388. package/workflow/WorkflowCanvasInner.js +49 -0
  389. package/workflow/WorkflowCanvasInner.js.map +1 -0
  390. package/workflow/WorkflowDashboard.d.ts +35 -0
  391. package/workflow/WorkflowDashboard.d.ts.map +1 -0
  392. package/workflow/WorkflowDashboard.js +59 -0
  393. package/workflow/WorkflowDashboard.js.map +1 -0
  394. package/workflow/WorkflowDetailView.d.ts +63 -0
  395. package/workflow/WorkflowDetailView.d.ts.map +1 -0
  396. package/workflow/WorkflowDetailView.js +202 -0
  397. package/workflow/WorkflowDetailView.js.map +1 -0
  398. package/workflow/WorkflowEditorView.d.ts +43 -0
  399. package/workflow/WorkflowEditorView.d.ts.map +1 -0
  400. package/workflow/WorkflowEditorView.js +165 -0
  401. package/workflow/WorkflowEditorView.js.map +1 -0
  402. package/workflow/WorkflowExecutionApprovalCard.d.ts +27 -0
  403. package/workflow/WorkflowExecutionApprovalCard.d.ts.map +1 -0
  404. package/workflow/WorkflowExecutionApprovalCard.js +32 -0
  405. package/workflow/WorkflowExecutionApprovalCard.js.map +1 -0
  406. package/workflow/WorkflowExecutionArtifactPanel.d.ts +15 -0
  407. package/workflow/WorkflowExecutionArtifactPanel.d.ts.map +1 -0
  408. package/workflow/WorkflowExecutionArtifactPanel.js +53 -0
  409. package/workflow/WorkflowExecutionArtifactPanel.js.map +1 -0
  410. package/workflow/WorkflowExecutionCostPanel.d.ts +18 -0
  411. package/workflow/WorkflowExecutionCostPanel.d.ts.map +1 -0
  412. package/workflow/WorkflowExecutionCostPanel.js +44 -0
  413. package/workflow/WorkflowExecutionCostPanel.js.map +1 -0
  414. package/workflow/WorkflowExecutionHeader.d.ts +26 -0
  415. package/workflow/WorkflowExecutionHeader.d.ts.map +1 -0
  416. package/workflow/WorkflowExecutionHeader.js +68 -0
  417. package/workflow/WorkflowExecutionHeader.js.map +1 -0
  418. package/workflow/WorkflowExecutionPhaseBadge.d.ts +23 -0
  419. package/workflow/WorkflowExecutionPhaseBadge.d.ts.map +1 -0
  420. package/workflow/WorkflowExecutionPhaseBadge.js +99 -0
  421. package/workflow/WorkflowExecutionPhaseBadge.js.map +1 -0
  422. package/workflow/WorkflowExecutionTaskPanel.d.ts +24 -0
  423. package/workflow/WorkflowExecutionTaskPanel.d.ts.map +1 -0
  424. package/workflow/WorkflowExecutionTaskPanel.js +59 -0
  425. package/workflow/WorkflowExecutionTaskPanel.js.map +1 -0
  426. package/workflow/WorkflowExecutionTimeline.d.ts +27 -0
  427. package/workflow/WorkflowExecutionTimeline.d.ts.map +1 -0
  428. package/workflow/WorkflowExecutionTimeline.js +51 -0
  429. package/workflow/WorkflowExecutionTimeline.js.map +1 -0
  430. package/workflow/WorkflowExecutionTimelineEvent.d.ts +18 -0
  431. package/workflow/WorkflowExecutionTimelineEvent.d.ts.map +1 -0
  432. package/workflow/WorkflowExecutionTimelineEvent.js +210 -0
  433. package/workflow/WorkflowExecutionTimelineEvent.js.map +1 -0
  434. package/workflow/WorkflowExecutionViewer.d.ts +45 -0
  435. package/workflow/WorkflowExecutionViewer.d.ts.map +1 -0
  436. package/workflow/WorkflowExecutionViewer.js +75 -0
  437. package/workflow/WorkflowExecutionViewer.js.map +1 -0
  438. package/workflow/WorkflowInspectorPanel.d.ts +46 -0
  439. package/workflow/WorkflowInspectorPanel.d.ts.map +1 -0
  440. package/workflow/WorkflowInspectorPanel.js +152 -0
  441. package/workflow/WorkflowInspectorPanel.js.map +1 -0
  442. package/workflow/WorkflowRefinePanel.d.ts +30 -0
  443. package/workflow/WorkflowRefinePanel.d.ts.map +1 -0
  444. package/workflow/WorkflowRefinePanel.js +107 -0
  445. package/workflow/WorkflowRefinePanel.js.map +1 -0
  446. package/workflow/WorkflowRepairCard.d.ts +35 -0
  447. package/workflow/WorkflowRepairCard.d.ts.map +1 -0
  448. package/workflow/WorkflowRepairCard.js +113 -0
  449. package/workflow/WorkflowRepairCard.js.map +1 -0
  450. package/workflow/WorkflowRunDialog.d.ts +51 -0
  451. package/workflow/WorkflowRunDialog.d.ts.map +1 -0
  452. package/workflow/WorkflowRunDialog.js +75 -0
  453. package/workflow/WorkflowRunDialog.js.map +1 -0
  454. package/workflow/WorkflowRunForm.d.ts +62 -0
  455. package/workflow/WorkflowRunForm.d.ts.map +1 -0
  456. package/workflow/WorkflowRunForm.js +64 -0
  457. package/workflow/WorkflowRunForm.js.map +1 -0
  458. package/workflow/WorkflowTaskList.d.ts +25 -0
  459. package/workflow/WorkflowTaskList.d.ts.map +1 -0
  460. package/workflow/WorkflowTaskList.js +89 -0
  461. package/workflow/WorkflowTaskList.js.map +1 -0
  462. package/workflow/WorkflowTaskPalette.d.ts +22 -0
  463. package/workflow/WorkflowTaskPalette.d.ts.map +1 -0
  464. package/workflow/WorkflowTaskPalette.js +83 -0
  465. package/workflow/WorkflowTaskPalette.js.map +1 -0
  466. package/workflow/WorkflowTopologyGraph.d.ts +22 -0
  467. package/workflow/WorkflowTopologyGraph.d.ts.map +1 -0
  468. package/workflow/WorkflowTopologyGraph.js +123 -0
  469. package/workflow/WorkflowTopologyGraph.js.map +1 -0
  470. package/workflow/WorkflowYamlEditor.d.ts +43 -0
  471. package/workflow/WorkflowYamlEditor.d.ts.map +1 -0
  472. package/workflow/WorkflowYamlEditor.js +215 -0
  473. package/workflow/WorkflowYamlEditor.js.map +1 -0
  474. package/workflow/__tests__/starter-workflow-yaml.test.d.ts +2 -0
  475. package/workflow/__tests__/starter-workflow-yaml.test.d.ts.map +1 -0
  476. package/workflow/__tests__/starter-workflow-yaml.test.js +44 -0
  477. package/workflow/__tests__/starter-workflow-yaml.test.js.map +1 -0
  478. package/workflow/canvas-constants.d.ts +56 -0
  479. package/workflow/canvas-constants.d.ts.map +1 -0
  480. package/workflow/canvas-constants.js +74 -0
  481. package/workflow/canvas-constants.js.map +1 -0
  482. package/workflow/canvas-icons.d.ts +13 -0
  483. package/workflow/canvas-icons.d.ts.map +1 -0
  484. package/workflow/canvas-icons.js +21 -0
  485. package/workflow/canvas-icons.js.map +1 -0
  486. package/workflow/extract-workflow-yaml.d.ts +22 -0
  487. package/workflow/extract-workflow-yaml.d.ts.map +1 -0
  488. package/workflow/extract-workflow-yaml.js +63 -0
  489. package/workflow/extract-workflow-yaml.js.map +1 -0
  490. package/workflow/graph-commands.d.ts +209 -0
  491. package/workflow/graph-commands.d.ts.map +1 -0
  492. package/workflow/graph-commands.js +516 -0
  493. package/workflow/graph-commands.js.map +1 -0
  494. package/workflow/index.d.ts +66 -0
  495. package/workflow/index.d.ts.map +1 -0
  496. package/workflow/index.js +88 -0
  497. package/workflow/index.js.map +1 -0
  498. package/workflow/serialize-workflow-yaml.d.ts +39 -0
  499. package/workflow/serialize-workflow-yaml.d.ts.map +1 -0
  500. package/workflow/serialize-workflow-yaml.js +413 -0
  501. package/workflow/serialize-workflow-yaml.js.map +1 -0
  502. package/workflow/starter-workflow-yaml.d.ts +12 -0
  503. package/workflow/starter-workflow-yaml.d.ts.map +1 -0
  504. package/workflow/starter-workflow-yaml.js +30 -0
  505. package/workflow/starter-workflow-yaml.js.map +1 -0
  506. package/workflow/types.d.ts +80 -0
  507. package/workflow/types.d.ts.map +1 -0
  508. package/workflow/types.js +2 -0
  509. package/workflow/types.js.map +1 -0
  510. package/workflow/useCanvasKeyboardShortcuts.d.ts +34 -0
  511. package/workflow/useCanvasKeyboardShortcuts.d.ts.map +1 -0
  512. package/workflow/useCanvasKeyboardShortcuts.js +108 -0
  513. package/workflow/useCanvasKeyboardShortcuts.js.map +1 -0
  514. package/workflow/useDiagnoseExecutionFlow.d.ts +87 -0
  515. package/workflow/useDiagnoseExecutionFlow.d.ts.map +1 -0
  516. package/workflow/useDiagnoseExecutionFlow.js +257 -0
  517. package/workflow/useDiagnoseExecutionFlow.js.map +1 -0
  518. package/workflow/useGraphHistory.d.ts +28 -0
  519. package/workflow/useGraphHistory.d.ts.map +1 -0
  520. package/workflow/useGraphHistory.js +106 -0
  521. package/workflow/useGraphHistory.js.map +1 -0
  522. package/workflow/usePendingApprovals.d.ts +35 -0
  523. package/workflow/usePendingApprovals.d.ts.map +1 -0
  524. package/workflow/usePendingApprovals.js +50 -0
  525. package/workflow/usePendingApprovals.js.map +1 -0
  526. package/workflow/useRefineWorkflowFlow.d.ts +75 -0
  527. package/workflow/useRefineWorkflowFlow.d.ts.map +1 -0
  528. package/workflow/useRefineWorkflowFlow.js +216 -0
  529. package/workflow/useRefineWorkflowFlow.js.map +1 -0
  530. package/workflow/useResolveAgentExecutionSession.d.ts +33 -0
  531. package/workflow/useResolveAgentExecutionSession.d.ts.map +1 -0
  532. package/workflow/useResolveAgentExecutionSession.js +37 -0
  533. package/workflow/useResolveAgentExecutionSession.js.map +1 -0
  534. package/workflow/useRunWorkflowFlow.d.ts +82 -0
  535. package/workflow/useRunWorkflowFlow.d.ts.map +1 -0
  536. package/workflow/useRunWorkflowFlow.js +145 -0
  537. package/workflow/useRunWorkflowFlow.js.map +1 -0
  538. package/workflow/useTaskKindRegistry.d.ts +96 -0
  539. package/workflow/useTaskKindRegistry.d.ts.map +1 -0
  540. package/workflow/useTaskKindRegistry.js +75 -0
  541. package/workflow/useTaskKindRegistry.js.map +1 -0
  542. package/workflow/useWorkflow.d.ts +47 -0
  543. package/workflow/useWorkflow.d.ts.map +1 -0
  544. package/workflow/useWorkflow.js +53 -0
  545. package/workflow/useWorkflow.js.map +1 -0
  546. package/workflow/useWorkflowArchitectFlow.d.ts +96 -0
  547. package/workflow/useWorkflowArchitectFlow.d.ts.map +1 -0
  548. package/workflow/useWorkflowArchitectFlow.js +179 -0
  549. package/workflow/useWorkflowArchitectFlow.js.map +1 -0
  550. package/workflow/useWorkflowCanvas.d.ts +66 -0
  551. package/workflow/useWorkflowCanvas.d.ts.map +1 -0
  552. package/workflow/useWorkflowCanvas.js +628 -0
  553. package/workflow/useWorkflowCanvas.js.map +1 -0
  554. package/workflow/useWorkflowCount.d.ts +47 -0
  555. package/workflow/useWorkflowCount.d.ts.map +1 -0
  556. package/workflow/useWorkflowCount.js +26 -0
  557. package/workflow/useWorkflowCount.js.map +1 -0
  558. package/workflow/useWorkflowDashboardSummary.d.ts +34 -0
  559. package/workflow/useWorkflowDashboardSummary.d.ts.map +1 -0
  560. package/workflow/useWorkflowDashboardSummary.js +33 -0
  561. package/workflow/useWorkflowDashboardSummary.js.map +1 -0
  562. package/workflow/useWorkflowEditor.d.ts +45 -0
  563. package/workflow/useWorkflowEditor.d.ts.map +1 -0
  564. package/workflow/useWorkflowEditor.js +52 -0
  565. package/workflow/useWorkflowEditor.js.map +1 -0
  566. package/workflow/useWorkflowExecution.d.ts +37 -0
  567. package/workflow/useWorkflowExecution.d.ts.map +1 -0
  568. package/workflow/useWorkflowExecution.js +43 -0
  569. package/workflow/useWorkflowExecution.js.map +1 -0
  570. package/workflow/useWorkflowExecutionActions.d.ts +41 -0
  571. package/workflow/useWorkflowExecutionActions.d.ts.map +1 -0
  572. package/workflow/useWorkflowExecutionActions.js +86 -0
  573. package/workflow/useWorkflowExecutionActions.js.map +1 -0
  574. package/workflow/useWorkflowExecutionArtifacts.d.ts +26 -0
  575. package/workflow/useWorkflowExecutionArtifacts.d.ts.map +1 -0
  576. package/workflow/useWorkflowExecutionArtifacts.js +29 -0
  577. package/workflow/useWorkflowExecutionArtifacts.js.map +1 -0
  578. package/workflow/useWorkflowExecutionEventLog.d.ts +47 -0
  579. package/workflow/useWorkflowExecutionEventLog.d.ts.map +1 -0
  580. package/workflow/useWorkflowExecutionEventLog.js +59 -0
  581. package/workflow/useWorkflowExecutionEventLog.js.map +1 -0
  582. package/workflow/useWorkflowExecutionEventStream.d.ts +61 -0
  583. package/workflow/useWorkflowExecutionEventStream.d.ts.map +1 -0
  584. package/workflow/useWorkflowExecutionEventStream.js +161 -0
  585. package/workflow/useWorkflowExecutionEventStream.js.map +1 -0
  586. package/workflow/useWorkflowExecutionList.d.ts +49 -0
  587. package/workflow/useWorkflowExecutionList.d.ts.map +1 -0
  588. package/workflow/useWorkflowExecutionList.js +65 -0
  589. package/workflow/useWorkflowExecutionList.js.map +1 -0
  590. package/workflow/useWorkflowInstances.d.ts +30 -0
  591. package/workflow/useWorkflowInstances.d.ts.map +1 -0
  592. package/workflow/useWorkflowInstances.js +33 -0
  593. package/workflow/useWorkflowInstances.js.map +1 -0
  594. package/workflow/useWorkflowList.d.ts +57 -0
  595. package/workflow/useWorkflowList.d.ts.map +1 -0
  596. package/workflow/useWorkflowList.js +29 -0
  597. package/workflow/useWorkflowList.js.map +1 -0
  598. package/workflow/useWorkflowSave.d.ts +25 -0
  599. package/workflow/useWorkflowSave.d.ts.map +1 -0
  600. package/workflow/useWorkflowSave.js +61 -0
  601. package/workflow/useWorkflowSave.js.map +1 -0
  602. package/workflow/useWorkflowTopology.d.ts +40 -0
  603. package/workflow/useWorkflowTopology.d.ts.map +1 -0
  604. package/workflow/useWorkflowTopology.js +163 -0
  605. package/workflow/useWorkflowTopology.js.map +1 -0
  606. package/workflow/useWorkflowValidation.d.ts +27 -0
  607. package/workflow/useWorkflowValidation.d.ts.map +1 -0
  608. package/workflow/useWorkflowValidation.js +253 -0
  609. package/workflow/useWorkflowValidation.js.map +1 -0
  610. package/workflow/useWorkflowYaml.d.ts +26 -0
  611. package/workflow/useWorkflowYaml.d.ts.map +1 -0
  612. package/workflow/useWorkflowYaml.js +26 -0
  613. package/workflow/useWorkflowYaml.js.map +1 -0
  614. package/workflow/workflow-graph-conversions.d.ts +70 -0
  615. package/workflow/workflow-graph-conversions.d.ts.map +1 -0
  616. package/workflow/workflow-graph-conversions.js +634 -0
  617. package/workflow/workflow-graph-conversions.js.map +1 -0
  618. package/workflow/workflow-graph-model.d.ts +83 -0
  619. package/workflow/workflow-graph-model.d.ts.map +1 -0
  620. package/workflow/workflow-graph-model.js +5 -0
  621. package/workflow/workflow-graph-model.js.map +1 -0
  622. package/workflow/workflow-yaml-diff.d.ts +24 -0
  623. package/workflow/workflow-yaml-diff.d.ts.map +1 -0
  624. package/workflow/workflow-yaml-diff.js +96 -0
  625. package/workflow/workflow-yaml-diff.js.map +1 -0
@@ -0,0 +1,194 @@
1
+ "use client";
2
+
3
+ import { memo, useMemo } from "react";
4
+ import type { ExecutionSummary } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/io_pb";
5
+ import { ExecutionPhase } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/enum_pb";
6
+ import { cn } from "@stigmer/theme";
7
+
8
+ export interface ExecutionSummaryWidgetProps {
9
+ readonly summary: ExecutionSummary | null;
10
+ readonly isLoading: boolean;
11
+ readonly className?: string;
12
+ }
13
+
14
+ interface StatCardDef {
15
+ readonly label: string;
16
+ readonly valueClass: string;
17
+ readonly getValue: (s: ExecutionSummary) => string;
18
+ }
19
+
20
+ const PHASE_LABEL: ReadonlyMap<number, string> = new Map([
21
+ [ExecutionPhase.EXECUTION_PENDING, "Pending"],
22
+ [ExecutionPhase.EXECUTION_IN_PROGRESS, "Running"],
23
+ [ExecutionPhase.EXECUTION_COMPLETED, "Completed"],
24
+ [ExecutionPhase.EXECUTION_FAILED, "Failed"],
25
+ [ExecutionPhase.EXECUTION_CANCELLED, "Cancelled"],
26
+ [ExecutionPhase.EXECUTION_TERMINATED, "Terminated"],
27
+ [ExecutionPhase.EXECUTION_PAUSED, "Paused"],
28
+ ]);
29
+
30
+ const STAT_CARDS: readonly StatCardDef[] = [
31
+ {
32
+ label: "Active",
33
+ valueClass: "text-foreground",
34
+ getValue: (s) => String(s.activeCount),
35
+ },
36
+ {
37
+ label: "Completed",
38
+ valueClass: "text-success",
39
+ getValue: (s) =>
40
+ String(s.phaseCounts[ExecutionPhase.EXECUTION_COMPLETED] ?? 0),
41
+ },
42
+ {
43
+ label: "Failed",
44
+ valueClass: "text-destructive",
45
+ getValue: (s) =>
46
+ String(s.phaseCounts[ExecutionPhase.EXECUTION_FAILED] ?? 0),
47
+ },
48
+ {
49
+ label: "Total Cost",
50
+ valueClass: "text-foreground",
51
+ getValue: (s) =>
52
+ s.totalCost?.totalCostUsd
53
+ ? `$${s.totalCost.totalCostUsd.toFixed(2)}`
54
+ : "$0.00",
55
+ },
56
+ ];
57
+
58
+ function formatDuration(seconds: number): string {
59
+ if (seconds < 60) return `${Math.round(seconds)}s`;
60
+ if (seconds < 3600) return `${Math.round(seconds / 60)}m`;
61
+ return `${(seconds / 3600).toFixed(1)}h`;
62
+ }
63
+
64
+ /**
65
+ * Dashboard widget showing aggregate execution KPIs.
66
+ *
67
+ * Displays stat cards for active, completed, failed counts and total cost.
68
+ * Below the cards, shows average duration and a phase breakdown bar.
69
+ *
70
+ * All visuals use `--stgm-*` tokens. No hardcoded colors.
71
+ */
72
+ export const ExecutionSummaryWidget = memo(function ExecutionSummaryWidget({
73
+ summary,
74
+ isLoading,
75
+ className,
76
+ }: ExecutionSummaryWidgetProps) {
77
+ const phaseBreakdown = useMemo(() => {
78
+ if (!summary) return [];
79
+ const entries: { label: string; count: number; colorClass: string }[] = [];
80
+ const colorMap: Record<number, string> = {
81
+ [ExecutionPhase.EXECUTION_PENDING]: "bg-muted-foreground",
82
+ [ExecutionPhase.EXECUTION_IN_PROGRESS]: "bg-primary",
83
+ [ExecutionPhase.EXECUTION_COMPLETED]: "bg-success",
84
+ [ExecutionPhase.EXECUTION_FAILED]: "bg-destructive",
85
+ [ExecutionPhase.EXECUTION_CANCELLED]: "bg-muted-foreground",
86
+ [ExecutionPhase.EXECUTION_TERMINATED]: "bg-destructive",
87
+ [ExecutionPhase.EXECUTION_PAUSED]: "bg-muted-foreground",
88
+ };
89
+ for (const [phase, count] of Object.entries(summary.phaseCounts)) {
90
+ const p = Number(phase);
91
+ if (count > 0) {
92
+ entries.push({
93
+ label: PHASE_LABEL.get(p) ?? `Phase ${p}`,
94
+ count,
95
+ colorClass: colorMap[p] ?? "bg-muted",
96
+ });
97
+ }
98
+ }
99
+ return entries;
100
+ }, [summary]);
101
+
102
+ const totalExecutions = phaseBreakdown.reduce((sum, e) => sum + e.count, 0);
103
+
104
+ if (isLoading) {
105
+ return (
106
+ <div className={cn("space-y-3", className)} aria-busy="true">
107
+ <div className="grid gap-3 sm:grid-cols-2 lg:grid-cols-4">
108
+ {Array.from({ length: 4 }, (_, i) => (
109
+ <div
110
+ key={i}
111
+ className="h-[72px] animate-pulse rounded-lg border border-border bg-muted/50"
112
+ />
113
+ ))}
114
+ </div>
115
+ </div>
116
+ );
117
+ }
118
+
119
+ if (!summary) return null;
120
+
121
+ const avgSeconds = summary.avgDuration
122
+ ? Number(summary.avgDuration.seconds)
123
+ : 0;
124
+
125
+ return (
126
+ <div className={cn("space-y-4", className)}>
127
+ <div className="grid gap-3 sm:grid-cols-2 lg:grid-cols-4">
128
+ {STAT_CARDS.map((card) => (
129
+ <div
130
+ key={card.label}
131
+ className="rounded-lg border border-border bg-card px-4 py-3"
132
+ >
133
+ <p className="text-xs font-medium text-muted-foreground">
134
+ {card.label}
135
+ </p>
136
+ <p className={cn("mt-1 text-2xl font-semibold", card.valueClass)}>
137
+ {card.getValue(summary)}
138
+ </p>
139
+ </div>
140
+ ))}
141
+ </div>
142
+
143
+ {(avgSeconds > 0 || totalExecutions > 0) && (
144
+ <div className="flex items-center gap-6 text-xs text-muted-foreground">
145
+ {avgSeconds > 0 && (
146
+ <span>
147
+ Avg duration:{" "}
148
+ <span className="font-medium text-foreground">
149
+ {formatDuration(avgSeconds)}
150
+ </span>
151
+ </span>
152
+ )}
153
+ {totalExecutions > 0 && (
154
+ <span>
155
+ Total:{" "}
156
+ <span className="font-medium text-foreground">
157
+ {totalExecutions}
158
+ </span>{" "}
159
+ executions
160
+ </span>
161
+ )}
162
+ </div>
163
+ )}
164
+
165
+ {totalExecutions > 0 && (
166
+ <div className="space-y-2">
167
+ <div
168
+ className="flex h-2 overflow-hidden rounded-full bg-muted"
169
+ role="img"
170
+ aria-label="Execution phase breakdown"
171
+ >
172
+ {phaseBreakdown.map((entry) => (
173
+ <div
174
+ key={entry.label}
175
+ className={cn("h-full", entry.colorClass)}
176
+ style={{
177
+ width: `${(entry.count / totalExecutions) * 100}%`,
178
+ }}
179
+ />
180
+ ))}
181
+ </div>
182
+ <div className="flex flex-wrap gap-x-4 gap-y-1">
183
+ {phaseBreakdown.map((entry) => (
184
+ <span key={entry.label} className="flex items-center gap-1.5 text-xs text-muted-foreground">
185
+ <span className={cn("inline-block h-2 w-2 rounded-full", entry.colorClass)} />
186
+ {entry.label}: {entry.count}
187
+ </span>
188
+ ))}
189
+ </div>
190
+ </div>
191
+ )}
192
+ </div>
193
+ );
194
+ });
@@ -0,0 +1,157 @@
1
+ "use client";
2
+
3
+ import { memo, useMemo } from "react";
4
+ import type { ExecutionSummary } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/io_pb";
5
+ import { ExecutionPhase } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/enum_pb";
6
+ import { cn } from "@stigmer/theme";
7
+
8
+ export interface ExecutionTrendChartProps {
9
+ readonly summary: ExecutionSummary | null;
10
+ readonly isLoading: boolean;
11
+ readonly className?: string;
12
+ }
13
+
14
+ interface PhaseSegment {
15
+ readonly label: string;
16
+ readonly count: number;
17
+ readonly colorClass: string;
18
+ readonly bgColorClass: string;
19
+ }
20
+
21
+ const PHASE_DISPLAY: ReadonlyMap<
22
+ number,
23
+ { label: string; colorClass: string; bgColorClass: string }
24
+ > = new Map([
25
+ [
26
+ ExecutionPhase.EXECUTION_COMPLETED,
27
+ { label: "Completed", colorClass: "text-success", bgColorClass: "bg-success" },
28
+ ],
29
+ [
30
+ ExecutionPhase.EXECUTION_FAILED,
31
+ { label: "Failed", colorClass: "text-destructive", bgColorClass: "bg-destructive" },
32
+ ],
33
+ [
34
+ ExecutionPhase.EXECUTION_IN_PROGRESS,
35
+ { label: "Running", colorClass: "text-primary", bgColorClass: "bg-primary" },
36
+ ],
37
+ [
38
+ ExecutionPhase.EXECUTION_PENDING,
39
+ { label: "Pending", colorClass: "text-muted-foreground", bgColorClass: "bg-muted-foreground" },
40
+ ],
41
+ [
42
+ ExecutionPhase.EXECUTION_PAUSED,
43
+ { label: "Paused", colorClass: "text-muted-foreground", bgColorClass: "bg-muted-foreground/60" },
44
+ ],
45
+ [
46
+ ExecutionPhase.EXECUTION_CANCELLED,
47
+ { label: "Cancelled", colorClass: "text-muted-foreground", bgColorClass: "bg-muted-foreground/40" },
48
+ ],
49
+ [
50
+ ExecutionPhase.EXECUTION_TERMINATED,
51
+ { label: "Terminated", colorClass: "text-destructive", bgColorClass: "bg-destructive/60" },
52
+ ],
53
+ ]);
54
+
55
+ /**
56
+ * Phase distribution chart for workflow executions.
57
+ *
58
+ * Shows a stacked horizontal bar with a legend listing each phase
59
+ * and its count. Renders from `ExecutionSummary.phaseCounts`.
60
+ */
61
+ export const ExecutionTrendChart = memo(function ExecutionTrendChart({
62
+ summary,
63
+ isLoading,
64
+ className,
65
+ }: ExecutionTrendChartProps) {
66
+ const segments: PhaseSegment[] = useMemo(() => {
67
+ if (!summary) return [];
68
+ const result: PhaseSegment[] = [];
69
+ for (const [phase, count] of Object.entries(summary.phaseCounts)) {
70
+ const p = Number(phase);
71
+ if (count <= 0) continue;
72
+ const display = PHASE_DISPLAY.get(p);
73
+ if (!display) continue;
74
+ result.push({ ...display, count });
75
+ }
76
+ return result.sort((a, b) => b.count - a.count);
77
+ }, [summary]);
78
+
79
+ const total = useMemo(
80
+ () => segments.reduce((sum, s) => sum + s.count, 0),
81
+ [segments],
82
+ );
83
+
84
+ if (isLoading) {
85
+ return (
86
+ <div className={cn("space-y-3", className)} aria-busy="true">
87
+ <div className="h-4 w-36 animate-pulse rounded bg-muted" />
88
+ <div className="h-8 animate-pulse rounded-full bg-muted/50" />
89
+ <div className="flex gap-4">
90
+ {Array.from({ length: 3 }, (_, i) => (
91
+ <div key={i} className="h-3 w-16 animate-pulse rounded bg-muted" />
92
+ ))}
93
+ </div>
94
+ </div>
95
+ );
96
+ }
97
+
98
+ if (!summary || total === 0) {
99
+ return (
100
+ <div className={cn("space-y-3", className)}>
101
+ <h3 className="text-sm font-semibold text-foreground">
102
+ Execution Distribution
103
+ </h3>
104
+ <p className="py-6 text-center text-xs text-muted-foreground">
105
+ No execution data available
106
+ </p>
107
+ </div>
108
+ );
109
+ }
110
+
111
+ return (
112
+ <div className={cn("space-y-3", className)}>
113
+ <div className="flex items-baseline justify-between">
114
+ <h3 className="text-sm font-semibold text-foreground">
115
+ Execution Distribution
116
+ </h3>
117
+ <span className="text-xs tabular-nums text-muted-foreground">
118
+ {total} total
119
+ </span>
120
+ </div>
121
+
122
+ <div
123
+ className="flex h-3 overflow-hidden rounded-full bg-muted"
124
+ role="img"
125
+ aria-label="Execution phase distribution"
126
+ >
127
+ {segments.map((seg) => (
128
+ <div
129
+ key={seg.label}
130
+ className={cn("h-full transition-all duration-500", seg.bgColorClass)}
131
+ style={{ width: `${(seg.count / total) * 100}%` }}
132
+ />
133
+ ))}
134
+ </div>
135
+
136
+ <div className="flex flex-wrap gap-x-4 gap-y-1.5">
137
+ {segments.map((seg) => (
138
+ <span
139
+ key={seg.label}
140
+ className="flex items-center gap-1.5 text-xs text-muted-foreground"
141
+ >
142
+ <span
143
+ className={cn(
144
+ "inline-block h-2.5 w-2.5 rounded-sm",
145
+ seg.bgColorClass,
146
+ )}
147
+ />
148
+ <span>{seg.label}</span>
149
+ <span className={cn("font-semibold tabular-nums", seg.colorClass)}>
150
+ {seg.count}
151
+ </span>
152
+ </span>
153
+ ))}
154
+ </div>
155
+ </div>
156
+ );
157
+ });
@@ -0,0 +1,109 @@
1
+ "use client";
2
+
3
+ import { memo } from "react";
4
+ import type { WorkflowExecution } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/api_pb";
5
+ import { timestampDate } from "@bufbuild/protobuf/wkt";
6
+ import { cn } from "@stigmer/theme";
7
+
8
+ export interface FailedRunsWidgetProps {
9
+ /** Recent failed executions to display. */
10
+ readonly executions: readonly WorkflowExecution[];
11
+ readonly isLoading: boolean;
12
+ /** Called when the user clicks "View" on a failed execution. */
13
+ readonly onViewClick?: (executionId: string) => void;
14
+ readonly className?: string;
15
+ }
16
+
17
+ function formatTimeAgo(date: Date): string {
18
+ const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
19
+ if (seconds < 60) return "just now";
20
+ if (seconds < 3600) return `${Math.floor(seconds / 60)}m ago`;
21
+ if (seconds < 86400) return `${Math.floor(seconds / 3600)}h ago`;
22
+ return `${Math.floor(seconds / 86400)}d ago`;
23
+ }
24
+
25
+ /**
26
+ * Dashboard widget showing recent failed workflow executions.
27
+ *
28
+ * Consumes data from `useWorkflowExecutionList({ phase: EXECUTION_FAILED })`.
29
+ * Displays a compact list with execution name, error summary, and time of failure.
30
+ *
31
+ * All visuals use `--stgm-*` tokens. No hardcoded colors.
32
+ */
33
+ export const FailedRunsWidget = memo(function FailedRunsWidget({
34
+ executions,
35
+ isLoading,
36
+ onViewClick,
37
+ className,
38
+ }: FailedRunsWidgetProps) {
39
+ if (isLoading) {
40
+ return (
41
+ <div className={cn("space-y-2", className)} aria-busy="true">
42
+ <div className="h-4 w-24 animate-pulse rounded bg-muted" />
43
+ {Array.from({ length: 3 }, (_, i) => (
44
+ <div
45
+ key={i}
46
+ className="h-14 animate-pulse rounded-lg border border-border bg-muted/50"
47
+ />
48
+ ))}
49
+ </div>
50
+ );
51
+ }
52
+
53
+ return (
54
+ <div className={cn("space-y-3", className)}>
55
+ <h3 className="text-sm font-semibold text-foreground">
56
+ Recent Failures
57
+ </h3>
58
+
59
+ {executions.length === 0 ? (
60
+ <p className="py-4 text-center text-xs text-muted-foreground">
61
+ No recent failures
62
+ </p>
63
+ ) : (
64
+ <ul className="space-y-2" role="list">
65
+ {executions.map((exec) => {
66
+ const id = exec.metadata?.id;
67
+ const name =
68
+ exec.metadata?.name || exec.metadata?.slug || "Unnamed";
69
+ const errorMsg = exec.status?.error || "Unknown error";
70
+ const failedAt = exec.status?.audit?.specAudit?.updatedAt;
71
+ const failedDate = failedAt ? timestampDate(failedAt) : null;
72
+
73
+ return (
74
+ <li
75
+ key={id}
76
+ className="rounded-lg border border-destructive/20 bg-destructive/5 px-3 py-2.5"
77
+ >
78
+ <div className="flex items-start justify-between gap-2">
79
+ <div className="min-w-0 flex-1">
80
+ <p className="truncate text-sm font-medium text-foreground">
81
+ {name}
82
+ </p>
83
+ <p className="mt-0.5 line-clamp-1 text-xs text-destructive">
84
+ {errorMsg}
85
+ </p>
86
+ {failedDate && (
87
+ <p className="mt-0.5 text-xs text-muted-foreground">
88
+ {formatTimeAgo(failedDate)}
89
+ </p>
90
+ )}
91
+ </div>
92
+ {onViewClick && id && (
93
+ <button
94
+ type="button"
95
+ onClick={() => onViewClick(id)}
96
+ className="shrink-0 rounded-md border border-border bg-background px-2.5 py-1 text-xs font-medium text-foreground transition-colors hover:bg-accent hover:text-accent-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
97
+ >
98
+ View
99
+ </button>
100
+ )}
101
+ </div>
102
+ </li>
103
+ );
104
+ })}
105
+ </ul>
106
+ )}
107
+ </div>
108
+ );
109
+ });
@@ -0,0 +1,115 @@
1
+ "use client";
2
+
3
+ import { memo } from "react";
4
+ import type { PendingApproval } from "@stigmer/protos/ai/stigmer/agentic/workflowexecution/v1/io_pb";
5
+ import { timestampDate } from "@bufbuild/protobuf/wkt";
6
+ import { cn } from "@stigmer/theme";
7
+
8
+ export interface PendingApprovalsWidgetProps {
9
+ readonly approvals: readonly PendingApproval[];
10
+ readonly totalCount: number;
11
+ readonly isLoading: boolean;
12
+ /** Called when the user clicks "Review" on an approval. */
13
+ readonly onReviewClick?: (executionId: string) => void;
14
+ readonly className?: string;
15
+ }
16
+
17
+ function formatTimeAgo(date: Date): string {
18
+ const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
19
+ if (seconds < 60) return "just now";
20
+ if (seconds < 3600) return `${Math.floor(seconds / 60)}m ago`;
21
+ if (seconds < 86400) return `${Math.floor(seconds / 3600)}h ago`;
22
+ return `${Math.floor(seconds / 86400)}d ago`;
23
+ }
24
+
25
+ /**
26
+ * Dashboard widget showing pending human_input approvals.
27
+ *
28
+ * Displays a compact list of workflow tasks awaiting reviewer decisions,
29
+ * with workflow name, task name, waiting duration, and a review action.
30
+ *
31
+ * All visuals use `--stgm-*` tokens. No hardcoded colors.
32
+ */
33
+ export const PendingApprovalsWidget = memo(function PendingApprovalsWidget({
34
+ approvals,
35
+ totalCount,
36
+ isLoading,
37
+ onReviewClick,
38
+ className,
39
+ }: PendingApprovalsWidgetProps) {
40
+ if (isLoading) {
41
+ return (
42
+ <div className={cn("space-y-2", className)} aria-busy="true">
43
+ <div className="flex items-center justify-between">
44
+ <div className="h-4 w-32 animate-pulse rounded bg-muted" />
45
+ <div className="h-4 w-8 animate-pulse rounded bg-muted" />
46
+ </div>
47
+ {Array.from({ length: 3 }, (_, i) => (
48
+ <div
49
+ key={i}
50
+ className="h-14 animate-pulse rounded-lg border border-border bg-muted/50"
51
+ />
52
+ ))}
53
+ </div>
54
+ );
55
+ }
56
+
57
+ return (
58
+ <div className={cn("space-y-3", className)}>
59
+ <div className="flex items-center justify-between">
60
+ <h3 className="text-sm font-semibold text-foreground">
61
+ Pending Approvals
62
+ </h3>
63
+ {totalCount > 0 && (
64
+ <span className="rounded-full bg-warning/10 px-2 py-0.5 text-xs font-medium text-warning">
65
+ {totalCount}
66
+ </span>
67
+ )}
68
+ </div>
69
+
70
+ {approvals.length === 0 ? (
71
+ <p className="py-4 text-center text-xs text-muted-foreground">
72
+ No approvals pending
73
+ </p>
74
+ ) : (
75
+ <ul className="space-y-2" role="list">
76
+ {approvals.map((approval) => {
77
+ const requestedAt = approval.requestedAt
78
+ ? timestampDate(approval.requestedAt)
79
+ : null;
80
+
81
+ return (
82
+ <li
83
+ key={`${approval.executionId}-${approval.taskName}`}
84
+ className="rounded-lg border border-border px-3 py-2.5"
85
+ >
86
+ <div className="flex items-start justify-between gap-2">
87
+ <div className="min-w-0 flex-1">
88
+ <p className="truncate text-sm font-medium text-foreground">
89
+ {approval.workflowName || approval.executionId}
90
+ </p>
91
+ <p className="mt-0.5 truncate text-xs text-muted-foreground">
92
+ Task: {approval.taskName}
93
+ {requestedAt && (
94
+ <> &middot; {formatTimeAgo(requestedAt)}</>
95
+ )}
96
+ </p>
97
+ </div>
98
+ {onReviewClick && (
99
+ <button
100
+ type="button"
101
+ onClick={() => onReviewClick(approval.executionId)}
102
+ className="shrink-0 rounded-md bg-primary px-2.5 py-1 text-xs font-medium text-primary-foreground transition-colors hover:bg-primary-hover focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
103
+ >
104
+ Review
105
+ </button>
106
+ )}
107
+ </div>
108
+ </li>
109
+ );
110
+ })}
111
+ </ul>
112
+ )}
113
+ </div>
114
+ );
115
+ });