@exoscient/control-panel 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -0
- package/dist/AppControlPanel.d.ts +77 -0
- package/dist/AppControlPanel.d.ts.map +1 -0
- package/dist/AppControlPanel.js +1625 -0
- package/dist/AppControlPanel.js.map +1 -0
- package/dist/ControlPanelShell.d.ts +39 -0
- package/dist/ControlPanelShell.d.ts.map +1 -0
- package/dist/ControlPanelShell.js +152 -0
- package/dist/ControlPanelShell.js.map +1 -0
- package/dist/ExoLauncherSimulator.d.ts +36 -0
- package/dist/ExoLauncherSimulator.d.ts.map +1 -0
- package/dist/ExoLauncherSimulator.js +253 -0
- package/dist/ExoLauncherSimulator.js.map +1 -0
- package/dist/TaskDetail.d.ts +180 -0
- package/dist/TaskDetail.d.ts.map +1 -0
- package/dist/TaskDetail.js +889 -0
- package/dist/TaskDetail.js.map +1 -0
- package/dist/TaskListPage.d.ts +28 -0
- package/dist/TaskListPage.d.ts.map +1 -0
- package/dist/TaskListPage.js +16 -0
- package/dist/TaskListPage.js.map +1 -0
- package/dist/TaskWorkspace.d.ts +62 -0
- package/dist/TaskWorkspace.d.ts.map +1 -0
- package/dist/TaskWorkspace.js +592 -0
- package/dist/TaskWorkspace.js.map +1 -0
- package/dist/ai-plane.d.ts +75 -0
- package/dist/ai-plane.d.ts.map +1 -0
- package/dist/ai-plane.js +124 -0
- package/dist/ai-plane.js.map +1 -0
- package/dist/browser-icons.d.ts +25 -0
- package/dist/browser-icons.d.ts.map +1 -0
- package/dist/browser-icons.js +125 -0
- package/dist/browser-icons.js.map +1 -0
- package/dist/client-actions.d.ts +45 -0
- package/dist/client-actions.d.ts.map +1 -0
- package/dist/client-actions.js +48 -0
- package/dist/client-actions.js.map +1 -0
- package/dist/control-panel-shared.d.ts +58 -0
- package/dist/control-panel-shared.d.ts.map +1 -0
- package/dist/control-panel-shared.js +79 -0
- package/dist/control-panel-shared.js.map +1 -0
- package/dist/control-panel.css +4156 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/repository-workflow.d.ts +27 -0
- package/dist/repository-workflow.d.ts.map +1 -0
- package/dist/repository-workflow.js +24 -0
- package/dist/repository-workflow.js.map +1 -0
- package/dist/result.d.ts +6 -0
- package/dist/result.d.ts.map +1 -0
- package/dist/result.js +77 -0
- package/dist/result.js.map +1 -0
- package/dist/task-consistency.d.ts +28 -0
- package/dist/task-consistency.d.ts.map +1 -0
- package/dist/task-consistency.js +25 -0
- package/dist/task-consistency.js.map +1 -0
- package/dist/task-detail.browser.js +2709 -0
- package/dist/task-detail.css +1601 -0
- package/dist/task-state.d.ts +11 -0
- package/dist/task-state.d.ts.map +1 -0
- package/dist/task-state.js +103 -0
- package/dist/task-state.js.map +1 -0
- package/dist/telemetry.d.ts +39 -0
- package/dist/telemetry.d.ts.map +1 -0
- package/dist/telemetry.js +106 -0
- package/dist/telemetry.js.map +1 -0
- package/dist/trace.d.ts +80 -0
- package/dist/trace.d.ts.map +1 -0
- package/dist/trace.js +694 -0
- package/dist/trace.js.map +1 -0
- package/dist/updates.d.ts +72 -0
- package/dist/updates.d.ts.map +1 -0
- package/dist/updates.js +269 -0
- package/dist/updates.js.map +1 -0
- package/package.json +58 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export { ControlPanelNavigation, ControlPanelShell, } from './ControlPanelShell';
|
|
2
|
+
export type { ControlPanelNavigationItem, ControlPanelTaskDetailState, } from './ControlPanelShell';
|
|
3
|
+
export { AppControlPanel, } from './AppControlPanel';
|
|
4
|
+
export { ExoLauncherSimulator, } from './ExoLauncherSimulator';
|
|
5
|
+
export type { AppControlPanelAccessOverride, AppControlPanelConfig, AppControlPanelCustomView, AppControlPanelTaskDataSourceExtensions, AppControlPanelViewContext, DeviceLauncherHost, OutletSettings, } from './AppControlPanel';
|
|
6
|
+
export type { ExoLauncherDeviceApp, ExoLauncherDeviceAppRelease, ExoLauncherSimulatorTarget, } from './ExoLauncherSimulator';
|
|
7
|
+
export { AttachmentPicker, InlineSpinner, LoadingState, TaskDetail, TaskDetailPage, WorkingIndicator, capitalize, formatDateTime, formatTaskLabel, isTaskBusy, isTaskQueued, statusToneClass, taskStatusLabel, taskTitleText, useElapsedNow, } from './TaskDetail';
|
|
8
|
+
export { TaskListPage, } from './TaskListPage';
|
|
9
|
+
export { TaskWorkspace, } from './TaskWorkspace';
|
|
10
|
+
export { clientActionType, externalContinuation, isReloadClientAppAction, isUserDecisionAction, userDecisionAllowsOther, userDecisionOtherLabel, userDecisionOtherPlaceholder, userDecisionSelectionMode, } from './client-actions';
|
|
11
|
+
export type { AgentTask, AgentTaskAccessRequest, AgentTaskSteeringMessage, AgentTurn, PlatformStatus, TaskAttachment, TaskDetailPageProps, TaskDetailProps, } from './TaskDetail';
|
|
12
|
+
export type { AgentClientAction, AgentClientActionContinuation, AgentReloadClientAppAction, AgentUserDecisionAction, AgentUserDecisionOption, AgentUserDecisionOther, } from './client-actions';
|
|
13
|
+
export type { TaskListPageProps, } from './TaskListPage';
|
|
14
|
+
export type { TaskWorkspaceDataSource, TaskWorkspaceProps, TaskWorkspaceStateResponse, TaskWorkspaceTraceState, } from './TaskWorkspace';
|
|
15
|
+
export { dedupeTaskModelOptions, formatBytes, formatContainerPorts, normalizeSelectorValue, selectedTaskModelSelection, taskModelOptionValue, taskModelOptionsFromStatus, } from './control-panel-shared';
|
|
16
|
+
export type { ApiClient, ApiClientDocument, CodingAgentStatusModel, CodingAgentStatusResponse, CreateApiClientResponse, StateResponse, TaskModelOption, TaskModelSelection, UpdateCountStatus, } from './control-panel-shared';
|
|
17
|
+
export { buildTraceItems, latestContextPressure, traceItemMatchesFilter, } from './trace';
|
|
18
|
+
export { splitAgentResult, } from './result';
|
|
19
|
+
export type { SplitAgentResult, } from './result';
|
|
20
|
+
export { ClientTelemetryService, } from './telemetry';
|
|
21
|
+
export type { ClientTelemetryEvent, ClientTelemetryServiceOptions, ClientTelemetrySeverity, } from './telemetry';
|
|
22
|
+
export { ClientUpdateService, advanceCursor, combinedServerFilter, ephemeralMessage, parseUpdateStreamItem, subscriptionMatches, } from './updates';
|
|
23
|
+
export { appendTaskTraceEvent, lastTaskTurn, mergeTaskTrace, mergeTaskTraceEvents, mergeTasks, taskSyncVersion, turnHasTraceEvents, upsertTask, } from './task-state';
|
|
24
|
+
export { AiPlaneClient, aiPlaneEndpoints, } from './ai-plane';
|
|
25
|
+
export { emptyRepositoryWorktreeStatus, repositoryBranchOptions, repositoryTaskCompletionBehaviors, repositoryWorkflowModes, } from './repository-workflow';
|
|
26
|
+
export type { AiPlaneClientOptions, AiPlaneCreateTaskRequest, AiPlaneStateResponse, AiPlaneTaskTraceState, } from './ai-plane';
|
|
27
|
+
export type { AgentTraceEvent, TraceFilter, TraceItem, } from './trace';
|
|
28
|
+
export type { RepositoryTaskCompletionBehavior, RepositoryWorkflow, RepositoryWorkflowMode, RepositoryWorktreeStatus, } from './repository-workflow';
|
|
29
|
+
export type { UpdateFilter, UpdateSubscription, UserUpdate, UserUpdateStreamItem, } from './updates';
|
|
30
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export { ControlPanelNavigation, ControlPanelShell, } from './ControlPanelShell';
|
|
2
|
+
export { AppControlPanel, } from './AppControlPanel';
|
|
3
|
+
export { ExoLauncherSimulator, } from './ExoLauncherSimulator';
|
|
4
|
+
export { AttachmentPicker, InlineSpinner, LoadingState, TaskDetail, TaskDetailPage, WorkingIndicator, capitalize, formatDateTime, formatTaskLabel, isTaskBusy, isTaskQueued, statusToneClass, taskStatusLabel, taskTitleText, useElapsedNow, } from './TaskDetail';
|
|
5
|
+
export { TaskListPage, } from './TaskListPage';
|
|
6
|
+
export { TaskWorkspace, } from './TaskWorkspace';
|
|
7
|
+
export { clientActionType, externalContinuation, isReloadClientAppAction, isUserDecisionAction, userDecisionAllowsOther, userDecisionOtherLabel, userDecisionOtherPlaceholder, userDecisionSelectionMode, } from './client-actions';
|
|
8
|
+
export { dedupeTaskModelOptions, formatBytes, formatContainerPorts, normalizeSelectorValue, selectedTaskModelSelection, taskModelOptionValue, taskModelOptionsFromStatus, } from './control-panel-shared';
|
|
9
|
+
export { buildTraceItems, latestContextPressure, traceItemMatchesFilter, } from './trace';
|
|
10
|
+
export { splitAgentResult, } from './result';
|
|
11
|
+
export { ClientTelemetryService, } from './telemetry';
|
|
12
|
+
export { ClientUpdateService, advanceCursor, combinedServerFilter, ephemeralMessage, parseUpdateStreamItem, subscriptionMatches, } from './updates';
|
|
13
|
+
export { appendTaskTraceEvent, lastTaskTurn, mergeTaskTrace, mergeTaskTraceEvents, mergeTasks, taskSyncVersion, turnHasTraceEvents, upsertTask, } from './task-state';
|
|
14
|
+
export { AiPlaneClient, aiPlaneEndpoints, } from './ai-plane';
|
|
15
|
+
export { emptyRepositoryWorktreeStatus, repositoryBranchOptions, repositoryTaskCompletionBehaviors, repositoryWorkflowModes, } from './repository-workflow';
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,iBAAiB,GAClB,MAAM,qBAAqB,CAAA;AAO5B,OAAO,EACL,eAAe,GAChB,MAAM,mBAAmB,CAAA;AAE1B,OAAO,EACL,oBAAoB,GACrB,MAAM,wBAAwB,CAAA;AAkB/B,OAAO,EACL,gBAAgB,EAChB,aAAa,EACb,YAAY,EACZ,UAAU,EACV,cAAc,EACd,gBAAgB,EAChB,UAAU,EACV,cAAc,EACd,eAAe,EACf,UAAU,EACV,YAAY,EACZ,eAAe,EACf,eAAe,EACf,aAAa,EACb,aAAa,GACd,MAAM,cAAc,CAAA;AAErB,OAAO,EACL,YAAY,GACb,MAAM,gBAAgB,CAAA;AAEvB,OAAO,EACL,aAAa,GACd,MAAM,iBAAiB,CAAA;AAExB,OAAO,EACL,gBAAgB,EAChB,oBAAoB,EACpB,uBAAuB,EACvB,oBAAoB,EACpB,uBAAuB,EACvB,sBAAsB,EACtB,4BAA4B,EAC5B,yBAAyB,GAC1B,MAAM,kBAAkB,CAAA;AAiCzB,OAAO,EACL,sBAAsB,EACtB,WAAW,EACX,oBAAoB,EACpB,sBAAsB,EACtB,0BAA0B,EAC1B,oBAAoB,EACpB,0BAA0B,GAC3B,MAAM,wBAAwB,CAAA;AAc/B,OAAO,EACL,eAAe,EACf,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,SAAS,CAAA;AAEhB,OAAO,EACL,gBAAgB,GACjB,MAAM,UAAU,CAAA;AAMjB,OAAO,EACL,sBAAsB,GACvB,MAAM,aAAa,CAAA;AAQpB,OAAO,EACL,mBAAmB,EACnB,aAAa,EACb,oBAAoB,EACpB,gBAAgB,EAChB,qBAAqB,EACrB,mBAAmB,GACpB,MAAM,WAAW,CAAA;AAElB,OAAO,EACL,oBAAoB,EACpB,YAAY,EACZ,cAAc,EACd,oBAAoB,EACpB,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,UAAU,GACX,MAAM,cAAc,CAAA;AAErB,OAAO,EACL,aAAa,EACb,gBAAgB,GACjB,MAAM,YAAY,CAAA;AAEnB,OAAO,EACL,6BAA6B,EAC7B,uBAAuB,EACvB,iCAAiC,EACjC,uBAAuB,GACxB,MAAM,uBAAuB,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export type RepositoryWorkflowMode = 'code-merge-request' | 'code-merge' | 'code-merge-deploy';
|
|
2
|
+
export type RepositoryTaskCompletionBehavior = 'complete-if-possible' | 'work-only';
|
|
3
|
+
export type RepositoryWorktreeStatus = {
|
|
4
|
+
hasUncommittedChanges: boolean;
|
|
5
|
+
changeCount: number;
|
|
6
|
+
changedPaths: string[];
|
|
7
|
+
};
|
|
8
|
+
export type RepositoryWorkflow = {
|
|
9
|
+
workingBranch: string;
|
|
10
|
+
mode: RepositoryWorkflowMode | string;
|
|
11
|
+
stagingBranch?: string | null;
|
|
12
|
+
deployBranch?: string | null;
|
|
13
|
+
};
|
|
14
|
+
export declare const repositoryWorkflowModes: Array<{
|
|
15
|
+
value: RepositoryWorkflowMode;
|
|
16
|
+
label: string;
|
|
17
|
+
}>;
|
|
18
|
+
export declare const repositoryTaskCompletionBehaviors: Array<{
|
|
19
|
+
value: RepositoryTaskCompletionBehavior;
|
|
20
|
+
label: string;
|
|
21
|
+
}>;
|
|
22
|
+
export declare function emptyRepositoryWorktreeStatus(): RepositoryWorktreeStatus;
|
|
23
|
+
export declare function repositoryBranchOptions(repository: {
|
|
24
|
+
branches: string[];
|
|
25
|
+
workflow: RepositoryWorkflow;
|
|
26
|
+
}, selectedBranch?: string | null): string[];
|
|
27
|
+
//# sourceMappingURL=repository-workflow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository-workflow.d.ts","sourceRoot":"","sources":["../src/repository-workflow.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,sBAAsB,GAAG,oBAAoB,GAAG,YAAY,GAAG,mBAAmB,CAAA;AAE9F,MAAM,MAAM,gCAAgC,GAAG,sBAAsB,GAAG,WAAW,CAAA;AAEnF,MAAM,MAAM,wBAAwB,GAAG;IACrC,qBAAqB,EAAE,OAAO,CAAA;IAC9B,WAAW,EAAE,MAAM,CAAA;IACnB,YAAY,EAAE,MAAM,EAAE,CAAA;CACvB,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC/B,aAAa,EAAE,MAAM,CAAA;IACrB,IAAI,EAAE,sBAAsB,GAAG,MAAM,CAAA;IACrC,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAC7B,CAAA;AAED,eAAO,MAAM,uBAAuB,EAAE,KAAK,CAAC;IAAE,KAAK,EAAE,sBAAsB,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAI3F,CAAA;AAED,eAAO,MAAM,iCAAiC,EAAE,KAAK,CAAC;IAAE,KAAK,EAAE,gCAAgC,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAG/G,CAAA;AAED,wBAAgB,6BAA6B,IAAI,wBAAwB,CAMxE;AAED,wBAAgB,uBAAuB,CAAC,UAAU,EAAE;IAAE,QAAQ,EAAE,MAAM,EAAE,CAAC;IAAC,QAAQ,EAAE,kBAAkB,CAAA;CAAE,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,YAMvI"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export const repositoryWorkflowModes = [
|
|
2
|
+
{ value: 'code-merge-request', label: 'code and merge request' },
|
|
3
|
+
{ value: 'code-merge', label: 'code and merge' },
|
|
4
|
+
{ value: 'code-merge-deploy', label: 'code, merge, and deploy' },
|
|
5
|
+
];
|
|
6
|
+
export const repositoryTaskCompletionBehaviors = [
|
|
7
|
+
{ value: 'complete-if-possible', label: 'Complete Git Workflow if possible' },
|
|
8
|
+
{ value: 'work-only', label: 'Work only; leave branch for me' },
|
|
9
|
+
];
|
|
10
|
+
export function emptyRepositoryWorktreeStatus() {
|
|
11
|
+
return {
|
|
12
|
+
hasUncommittedChanges: false,
|
|
13
|
+
changeCount: 0,
|
|
14
|
+
changedPaths: [],
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export function repositoryBranchOptions(repository, selectedBranch) {
|
|
18
|
+
return Array.from(new Set([
|
|
19
|
+
...repository.branches,
|
|
20
|
+
repository.workflow.workingBranch,
|
|
21
|
+
selectedBranch,
|
|
22
|
+
].filter((branch) => Boolean(branch))));
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=repository-workflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository-workflow.js","sourceRoot":"","sources":["../src/repository-workflow.ts"],"names":[],"mappings":"AAiBA,MAAM,CAAC,MAAM,uBAAuB,GAA4D;IAC9F,EAAE,KAAK,EAAE,oBAAoB,EAAE,KAAK,EAAE,wBAAwB,EAAE;IAChE,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE;IAChD,EAAE,KAAK,EAAE,mBAAmB,EAAE,KAAK,EAAE,yBAAyB,EAAE;CACjE,CAAA;AAED,MAAM,CAAC,MAAM,iCAAiC,GAAsE;IAClH,EAAE,KAAK,EAAE,sBAAsB,EAAE,KAAK,EAAE,mCAAmC,EAAE;IAC7E,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,gCAAgC,EAAE;CAChE,CAAA;AAED,MAAM,UAAU,6BAA6B;IAC3C,OAAO;QACL,qBAAqB,EAAE,KAAK;QAC5B,WAAW,EAAE,CAAC;QACd,YAAY,EAAE,EAAE;KACjB,CAAA;AACH,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,UAAgE,EAAE,cAA8B;IACtI,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC;QACxB,GAAG,UAAU,CAAC,QAAQ;QACtB,UAAU,CAAC,QAAQ,CAAC,aAAa;QACjC,cAAc;KACf,CAAC,MAAM,CAAC,CAAC,MAAM,EAAoB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;AAC3D,CAAC"}
|
package/dist/result.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result.d.ts","sourceRoot":"","sources":["../src/result.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAuBD,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB,CA8B/D"}
|
package/dist/result.js
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
const ownerHeadings = ['Owner Result', 'Owner Message', 'Owner Summary', 'Result'];
|
|
2
|
+
const technicalHeadings = [
|
|
3
|
+
'Technical Change Summary',
|
|
4
|
+
'Technical Summary',
|
|
5
|
+
'Change Summary',
|
|
6
|
+
'What changed',
|
|
7
|
+
'Changed',
|
|
8
|
+
'Changes',
|
|
9
|
+
'Verification',
|
|
10
|
+
'Verified',
|
|
11
|
+
'Tests',
|
|
12
|
+
'Deployment',
|
|
13
|
+
'Known issues',
|
|
14
|
+
'Skipped checks',
|
|
15
|
+
];
|
|
16
|
+
export function splitAgentResult(text) {
|
|
17
|
+
const normalized = text.trim();
|
|
18
|
+
if (!normalized)
|
|
19
|
+
return { owner: '', technical: '' };
|
|
20
|
+
const ownerHeading = findFirstResultHeading(normalized, ownerHeadings);
|
|
21
|
+
const technicalHeading = findFirstResultHeading(normalized, technicalHeadings, ownerHeading ? ownerHeading.contentStart : 0);
|
|
22
|
+
if (ownerHeading && technicalHeading && ownerHeading.index <= technicalHeading.index) {
|
|
23
|
+
return {
|
|
24
|
+
owner: normalized.slice(ownerHeading.contentStart, technicalHeading.index).trim(),
|
|
25
|
+
technical: normalized.slice(technicalHeading.contentStart).trim(),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (technicalHeading) {
|
|
29
|
+
return {
|
|
30
|
+
owner: normalized.slice(0, technicalHeading.index).trim(),
|
|
31
|
+
technical: normalized.slice(technicalHeading.contentStart).trim(),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
if (ownerHeading) {
|
|
35
|
+
return { owner: normalized.slice(ownerHeading.contentStart).trim(), technical: '' };
|
|
36
|
+
}
|
|
37
|
+
return { owner: normalized, technical: '' };
|
|
38
|
+
}
|
|
39
|
+
function findFirstResultHeading(text, headings, minIndex = 0) {
|
|
40
|
+
return headings
|
|
41
|
+
.flatMap((heading) => findResultHeadings(text, heading))
|
|
42
|
+
.filter((heading) => heading.index >= minIndex)
|
|
43
|
+
.sort((left, right) => left.index - right.index)[0] ?? null;
|
|
44
|
+
}
|
|
45
|
+
function findResultHeadings(text, heading) {
|
|
46
|
+
const escapedHeading = heading.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
47
|
+
const matches = [];
|
|
48
|
+
const blockPattern = new RegExp(`(^|\\n)\\s*(?:#{1,6}\\s*)?\\*{0,2}${escapedHeading}\\*{0,2}:?\\s*(?:\\n|$)`, 'gi');
|
|
49
|
+
collectHeadingMatches(text, blockPattern, matches);
|
|
50
|
+
const lineInlinePattern = new RegExp(`(^|\\n)\\s*(?:#{1,6}\\s*)?\\*{0,2}${escapedHeading}\\*{0,2}:\\s*`, 'gi');
|
|
51
|
+
collectHeadingMatches(text, lineInlinePattern, matches);
|
|
52
|
+
if (heading !== 'Result') {
|
|
53
|
+
const markdownInlinePattern = new RegExp(`(^|\\s)(#{1,6}\\s+)\\*{0,2}${escapedHeading}\\*{0,2}:?\\s+`, 'gi');
|
|
54
|
+
collectHeadingMatches(text, markdownInlinePattern, matches);
|
|
55
|
+
}
|
|
56
|
+
return dedupeHeadingMatches(matches);
|
|
57
|
+
}
|
|
58
|
+
function collectHeadingMatches(text, pattern, matches) {
|
|
59
|
+
for (const match of text.matchAll(pattern)) {
|
|
60
|
+
const prefix = match[1] ?? '';
|
|
61
|
+
matches.push({
|
|
62
|
+
index: match.index + prefix.length,
|
|
63
|
+
contentStart: match.index + match[0].length,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
function dedupeHeadingMatches(matches) {
|
|
68
|
+
const seen = new Set();
|
|
69
|
+
return matches.filter((match) => {
|
|
70
|
+
const key = `${match.index}:${match.contentStart}`;
|
|
71
|
+
if (seen.has(key))
|
|
72
|
+
return false;
|
|
73
|
+
seen.add(key);
|
|
74
|
+
return true;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=result.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"result.js","sourceRoot":"","sources":["../src/result.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export type TaskConsistencyTask = {
|
|
2
|
+
status: string;
|
|
3
|
+
busy: boolean;
|
|
4
|
+
startedAt?: string | null;
|
|
5
|
+
completedAt?: string | null;
|
|
6
|
+
turns: Array<{
|
|
7
|
+
id: string;
|
|
8
|
+
status: string;
|
|
9
|
+
startedAt?: string | null;
|
|
10
|
+
completedAt?: string | null;
|
|
11
|
+
error?: string | null;
|
|
12
|
+
}>;
|
|
13
|
+
};
|
|
14
|
+
export type TaskConsistencySignature = ReturnType<typeof taskConsistencySignature>;
|
|
15
|
+
export declare function taskConsistencySignature(task: TaskConsistencyTask): {
|
|
16
|
+
status: string;
|
|
17
|
+
busy: boolean;
|
|
18
|
+
startedAt: string | null;
|
|
19
|
+
completedAt: string | null;
|
|
20
|
+
turnCount: number;
|
|
21
|
+
latestTurnId: string;
|
|
22
|
+
latestTurnStatus: string;
|
|
23
|
+
latestTurnStartedAt: string | null;
|
|
24
|
+
latestTurnCompletedAt: string | null;
|
|
25
|
+
latestTurnError: string | null;
|
|
26
|
+
};
|
|
27
|
+
export declare function sameTaskConsistencySignature(left: TaskConsistencySignature, right: TaskConsistencySignature): boolean;
|
|
28
|
+
//# sourceMappingURL=task-consistency.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-consistency.d.ts","sourceRoot":"","sources":["../src/task-consistency.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,OAAO,CAAA;IACb,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACzB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3B,KAAK,EAAE,KAAK,CAAC;QACX,EAAE,EAAE,MAAM,CAAA;QACV,MAAM,EAAE,MAAM,CAAA;QACd,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QACzB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QAC3B,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;KACtB,CAAC,CAAA;CACH,CAAA;AAED,MAAM,MAAM,wBAAwB,GAAG,UAAU,CAAC,OAAO,wBAAwB,CAAC,CAAA;AAElF,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,mBAAmB;;;;;;;;;;;EAcjE;AAED,wBAAgB,4BAA4B,CAAC,IAAI,EAAE,wBAAwB,EAAE,KAAK,EAAE,wBAAwB,WAE3G"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export function taskConsistencySignature(task) {
|
|
2
|
+
const latestTurn = task.turns[task.turns.length - 1];
|
|
3
|
+
return {
|
|
4
|
+
status: task.status,
|
|
5
|
+
busy: task.busy,
|
|
6
|
+
startedAt: normalizedDate(task.startedAt),
|
|
7
|
+
completedAt: normalizedDate(task.completedAt),
|
|
8
|
+
turnCount: task.turns.length,
|
|
9
|
+
latestTurnId: latestTurn?.id ?? null,
|
|
10
|
+
latestTurnStatus: latestTurn?.status ?? null,
|
|
11
|
+
latestTurnStartedAt: normalizedDate(latestTurn?.startedAt),
|
|
12
|
+
latestTurnCompletedAt: normalizedDate(latestTurn?.completedAt),
|
|
13
|
+
latestTurnError: latestTurn?.error ?? null,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
export function sameTaskConsistencySignature(left, right) {
|
|
17
|
+
return JSON.stringify(left) === JSON.stringify(right);
|
|
18
|
+
}
|
|
19
|
+
function normalizedDate(value) {
|
|
20
|
+
if (!value)
|
|
21
|
+
return null;
|
|
22
|
+
const timestamp = Date.parse(value);
|
|
23
|
+
return Number.isFinite(timestamp) ? new Date(timestamp).toISOString() : value;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=task-consistency.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-consistency.js","sourceRoot":"","sources":["../src/task-consistency.ts"],"names":[],"mappings":"AAgBA,MAAM,UAAU,wBAAwB,CAAC,IAAyB;IAChE,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IACpD,OAAO;QACL,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,SAAS,EAAE,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC;QACzC,WAAW,EAAE,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC;QAC7C,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;QAC5B,YAAY,EAAE,UAAU,EAAE,EAAE,IAAI,IAAI;QACpC,gBAAgB,EAAE,UAAU,EAAE,MAAM,IAAI,IAAI;QAC5C,mBAAmB,EAAE,cAAc,CAAC,UAAU,EAAE,SAAS,CAAC;QAC1D,qBAAqB,EAAE,cAAc,CAAC,UAAU,EAAE,WAAW,CAAC;QAC9D,eAAe,EAAE,UAAU,EAAE,KAAK,IAAI,IAAI;KAC3C,CAAA;AACH,CAAC;AAED,MAAM,UAAU,4BAA4B,CAAC,IAA8B,EAAE,KAA+B;IAC1G,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;AACvD,CAAC;AAED,SAAS,cAAc,CAAC,KAAgC;IACtD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAA;IACvB,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACnC,OAAO,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,KAAK,CAAA;AAC/E,CAAC"}
|