argustack 0.1.11 → 0.1.13
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/dist/adapters/board/index.d.ts +6 -0
- package/dist/adapters/board/index.d.ts.map +1 -0
- package/dist/adapters/board/index.js +6 -0
- package/dist/adapters/board/index.js.map +1 -0
- package/dist/adapters/board/mapper.d.ts +14 -0
- package/dist/adapters/board/mapper.d.ts.map +1 -0
- package/dist/adapters/board/mapper.js +25 -0
- package/dist/adapters/board/mapper.js.map +1 -0
- package/dist/adapters/board/md-parser.d.ts +16 -0
- package/dist/adapters/board/md-parser.d.ts.map +1 -0
- package/dist/adapters/board/md-parser.js +44 -0
- package/dist/adapters/board/md-parser.js.map +1 -0
- package/dist/adapters/board/skill-discovery.d.ts +8 -0
- package/dist/adapters/board/skill-discovery.d.ts.map +1 -0
- package/dist/adapters/board/skill-discovery.js +60 -0
- package/dist/adapters/board/skill-discovery.js.map +1 -0
- package/dist/adapters/board/skill-runner.d.ts +10 -0
- package/dist/adapters/board/skill-runner.d.ts.map +1 -0
- package/dist/adapters/board/skill-runner.js +65 -0
- package/dist/adapters/board/skill-runner.js.map +1 -0
- package/dist/adapters/board/store.d.ts +21 -0
- package/dist/adapters/board/store.d.ts.map +1 -0
- package/dist/adapters/board/store.js +176 -0
- package/dist/adapters/board/store.js.map +1 -0
- package/dist/adapters/postgres/storage.d.ts +2 -1
- package/dist/adapters/postgres/storage.d.ts.map +1 -1
- package/dist/adapters/postgres/storage.js +55 -0
- package/dist/adapters/postgres/storage.js.map +1 -1
- package/dist/board/assets/index-Bnh8GW_4.css +1 -0
- package/dist/board/assets/index-CEXc5QXH.js +68 -0
- package/dist/board/favicon.png +0 -0
- package/dist/board/index.html +14 -0
- package/dist/cli/board-server.d.ts +2 -0
- package/dist/cli/board-server.d.ts.map +1 -0
- package/dist/cli/board-server.js +124 -0
- package/dist/cli/board-server.js.map +1 -0
- package/dist/cli/board.d.ts +3 -0
- package/dist/cli/board.d.ts.map +1 -0
- package/dist/cli/board.js +26 -0
- package/dist/cli/board.js.map +1 -0
- package/dist/cli/mcp-install.d.ts +9 -0
- package/dist/cli/mcp-install.d.ts.map +1 -1
- package/dist/cli/mcp-install.js +3 -3
- package/dist/cli/mcp-install.js.map +1 -1
- package/dist/core/board/board-column.value-object.d.ts +14 -0
- package/dist/core/board/board-column.value-object.d.ts.map +1 -0
- package/dist/core/board/board-column.value-object.js +36 -0
- package/dist/core/board/board-column.value-object.js.map +1 -0
- package/dist/core/board/board-task.entity.d.ts +20 -0
- package/dist/core/board/board-task.entity.d.ts.map +1 -0
- package/dist/core/board/board-task.entity.js +51 -0
- package/dist/core/board/board-task.entity.js.map +1 -0
- package/dist/core/board/index.d.ts +6 -0
- package/dist/core/board/index.d.ts.map +1 -0
- package/dist/core/board/index.js +6 -0
- package/dist/core/board/index.js.map +1 -0
- package/dist/core/board/pipeline.value-object.d.ts +22 -0
- package/dist/core/board/pipeline.value-object.d.ts.map +1 -0
- package/dist/core/board/pipeline.value-object.js +50 -0
- package/dist/core/board/pipeline.value-object.js.map +1 -0
- package/dist/core/board/skill-execution.entity.d.ts +18 -0
- package/dist/core/board/skill-execution.entity.d.ts.map +1 -0
- package/dist/core/board/skill-execution.entity.js +57 -0
- package/dist/core/board/skill-execution.entity.js.map +1 -0
- package/dist/core/board/task-title.value-object.d.ts +7 -0
- package/dist/core/board/task-title.value-object.d.ts.map +1 -0
- package/dist/core/board/task-title.value-object.js +20 -0
- package/dist/core/board/task-title.value-object.js.map +1 -0
- package/dist/core/ports/board-store.d.ts +15 -0
- package/dist/core/ports/board-store.d.ts.map +1 -0
- package/dist/core/ports/board-store.js +2 -0
- package/dist/core/ports/board-store.js.map +1 -0
- package/dist/core/ports/skill-runner.d.ts +6 -0
- package/dist/core/ports/skill-runner.d.ts.map +1 -0
- package/dist/core/ports/skill-runner.js +2 -0
- package/dist/core/ports/skill-runner.js.map +1 -0
- package/dist/core/ports/storage.d.ts +9 -1
- package/dist/core/ports/storage.d.ts.map +1 -1
- package/dist/core/types/board.d.ts +21 -0
- package/dist/core/types/board.d.ts.map +1 -0
- package/dist/core/types/board.js +2 -0
- package/dist/core/types/board.js.map +1 -0
- package/dist/core/types/index.d.ts +1 -1
- package/dist/core/types/index.d.ts.map +1 -1
- package/dist/core/types/index.js.map +1 -1
- package/dist/core/types/issue.d.ts +5 -0
- package/dist/core/types/issue.d.ts.map +1 -1
- package/dist/mcp/tools/search.d.ts.map +1 -1
- package/dist/mcp/tools/search.js +17 -20
- package/dist/mcp/tools/search.js.map +1 -1
- package/dist/use-cases/move-task.d.ts +18 -0
- package/dist/use-cases/move-task.d.ts.map +1 -0
- package/dist/use-cases/move-task.js +45 -0
- package/dist/use-cases/move-task.js.map +1 -0
- package/dist/use-cases/sync-board.d.ts +13 -0
- package/dist/use-cases/sync-board.d.ts.map +1 -0
- package/dist/use-cases/sync-board.js +20 -0
- package/dist/use-cases/sync-board.js.map +1 -0
- package/package.json +13 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-title.value-object.d.ts","sourceRoot":"","sources":["../../../src/core/board/task-title.value-object.ts"],"names":[],"mappings":"AAEA,qBAAa,SAAS;IACpB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;gBAEX,GAAG,EAAE,MAAM;IAUvB,MAAM,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO;IAIjC,QAAQ,IAAI,MAAM;CAGnB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
const MAX_LENGTH = 200;
|
|
2
|
+
export class TaskTitle {
|
|
3
|
+
value;
|
|
4
|
+
constructor(raw) {
|
|
5
|
+
const trimmed = raw.trim();
|
|
6
|
+
if (!trimmed) {
|
|
7
|
+
throw new Error('Task title cannot be empty');
|
|
8
|
+
}
|
|
9
|
+
this.value = trimmed.length > MAX_LENGTH
|
|
10
|
+
? trimmed.slice(0, MAX_LENGTH)
|
|
11
|
+
: trimmed;
|
|
12
|
+
}
|
|
13
|
+
equals(other) {
|
|
14
|
+
return this.value === other.value;
|
|
15
|
+
}
|
|
16
|
+
toString() {
|
|
17
|
+
return this.value;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=task-title.value-object.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-title.value-object.js","sourceRoot":"","sources":["../../../src/core/board/task-title.value-object.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,GAAG,CAAC;AAEvB,MAAM,OAAO,SAAS;IACX,KAAK,CAAS;IAEvB,YAAY,GAAW;QACrB,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QACD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,MAAM,GAAG,UAAU;YACtC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC;YAC9B,CAAC,CAAC,OAAO,CAAC;IACd,CAAC;IAED,MAAM,CAAC,KAAgB;QACrB,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,KAAK,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { BoardTaskData } from '../types/board.js';
|
|
2
|
+
import type { PipelineConfig } from '../board/pipeline.value-object.js';
|
|
3
|
+
export interface IBoardStore {
|
|
4
|
+
initialize(): Promise<void>;
|
|
5
|
+
getAllTasks(): Promise<BoardTaskData[]>;
|
|
6
|
+
getTasksByColumn(column: string): Promise<BoardTaskData[]>;
|
|
7
|
+
createTask(task: Omit<BoardTaskData, 'id'>): Promise<BoardTaskData>;
|
|
8
|
+
updateTask(id: string, fields: Partial<BoardTaskData>): Promise<void>;
|
|
9
|
+
deleteTask(id: string): Promise<void>;
|
|
10
|
+
syncFromFiles(tasksDir: string): Promise<void>;
|
|
11
|
+
loadPipeline(): Promise<PipelineConfig>;
|
|
12
|
+
savePipeline(config: PipelineConfig): Promise<void>;
|
|
13
|
+
close(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=board-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"board-store.d.ts","sourceRoot":"","sources":["../../../src/core/ports/board-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AAExE,MAAM,WAAW,WAAW;IAC1B,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,WAAW,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IACxC,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IAC3D,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IACpE,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACtE,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACtC,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/C,YAAY,IAAI,OAAO,CAAC,cAAc,CAAC,CAAC;IACxC,YAAY,CAAC,MAAM,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpD,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"board-store.js","sourceRoot":"","sources":["../../../src/core/ports/board-store.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-runner.d.ts","sourceRoot":"","sources":["../../../src/core/ports/skill-runner.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IACnE,WAAW,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAChC,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;CACnC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill-runner.js","sourceRoot":"","sources":["../../../src/core/ports/skill-runner.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { IssueBatch } from '../types/index.js';
|
|
1
|
+
import type { IssueBatch, HybridSearchResult } from '../types/index.js';
|
|
2
2
|
import type { CommitBatch } from '../types/git.js';
|
|
3
3
|
import type { GitHubBatch, Release } from '../types/github.js';
|
|
4
4
|
import type { DbSchemaBatch } from '../types/database.js';
|
|
@@ -40,6 +40,14 @@ export interface IStorage {
|
|
|
40
40
|
issueKey: string;
|
|
41
41
|
similarity: number;
|
|
42
42
|
}[]>;
|
|
43
|
+
/**
|
|
44
|
+
* Hybrid search — combines full-text (tsvector) and vector similarity (pgvector) using Reciprocal Rank Fusion.
|
|
45
|
+
* @param query - text query for full-text search
|
|
46
|
+
* @param vector - embedding vector for similarity search (null = text-only mode)
|
|
47
|
+
* @param limit - max results
|
|
48
|
+
* @param threshold - minimum similarity score for vector results (default 0.5)
|
|
49
|
+
*/
|
|
50
|
+
hybridSearch(query: string, vector: number[] | null, limit: number, threshold?: number): Promise<HybridSearchResult[]>;
|
|
43
51
|
/** Execute a raw SQL query with parameterized values */
|
|
44
52
|
query(sql: string, params: unknown[]): Promise<QueryResult>;
|
|
45
53
|
/** Save external database schema metadata (upsert logic) */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/core/ports/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../src/core/ports/storage.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACxE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAE1D,+CAA+C;AAC/C,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;CACjC;AAED;;;;;GAKG;AACH,MAAM,WAAW,QAAQ;IACvB,wDAAwD;IACxD,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IAEtB,mEAAmE;IACnE,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5B,2DAA2D;IAC3D,SAAS,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5C,kEAAkE;IAClE,eAAe,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnD,8EAA8E;IAC9E,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAE3D,yEAAyE;IACzE,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IAE1D,6EAA6E;IAC7E,eAAe,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnD,mCAAmC;IACnC,YAAY,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjD,+EAA+E;IAC/E,gBAAgB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IAE7D,sEAAsE;IACtE,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAEzD,oDAAoD;IACpD,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjE,mFAAmF;IACnF,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC,CAAC;IAEzH;;;;;;OAMG;IACH,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;IAEvH,wDAAwD;IACxD,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAE5D,4DAA4D;IAC5D,iBAAiB,CAAC,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3E,sEAAsE;IACtE,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAElD,iCAAiC;IACjC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACxB"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type SkillExecutionStatus = 'running' | 'done' | 'error';
|
|
2
|
+
export interface BoardTaskData {
|
|
3
|
+
id: string;
|
|
4
|
+
title: string;
|
|
5
|
+
mdPath: string;
|
|
6
|
+
column: string;
|
|
7
|
+
jiraKey: string | null;
|
|
8
|
+
assignee: string | null;
|
|
9
|
+
createdAt: string;
|
|
10
|
+
updatedAt: string;
|
|
11
|
+
}
|
|
12
|
+
export interface SkillExecutionData {
|
|
13
|
+
id: string;
|
|
14
|
+
taskId: string;
|
|
15
|
+
skillName: string;
|
|
16
|
+
status: SkillExecutionStatus;
|
|
17
|
+
output: string;
|
|
18
|
+
startedAt: string;
|
|
19
|
+
finishedAt: string | null;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=board.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"board.d.ts","sourceRoot":"","sources":["../../../src/core/types/board.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,oBAAoB,GAAG,SAAS,GAAG,MAAM,GAAG,OAAO,CAAC;AAEhE,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,oBAAoB,CAAC;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"board.js","sourceRoot":"","sources":["../../../src/core/types/board.ts"],"names":[],"mappings":""}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { Issue, IssueComment, IssueChangelog, IssueWorklog, IssueLink, IssueBatch, } from './issue.js';
|
|
1
|
+
export type { Issue, IssueComment, IssueChangelog, IssueWorklog, IssueLink, IssueBatch, HybridSearchResult, } from './issue.js';
|
|
2
2
|
export type { Project } from './project.js';
|
|
3
3
|
export type { Commit, CommitFile, CommitIssueRef, CommitBatch, GitRef, } from './git.js';
|
|
4
4
|
export type { PullRequest, PullRequestReview, PullRequestComment, PullRequestFile, PullRequestIssueRef, Release, GitHubBatch, } from './github.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,YAAY,EACZ,SAAS,EACT,UAAU,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/types/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,YAAY,EACZ,SAAS,EACT,UAAU,EACV,kBAAkB,GACnB,MAAM,YAAY,CAAC;AAEpB,YAAY,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAE5C,YAAY,EACV,MAAM,EACN,UAAU,EACV,cAAc,EACd,WAAW,EACX,MAAM,GACP,MAAM,UAAU,CAAC;AAElB,YAAY,EACV,WAAW,EACX,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,mBAAmB,EACnB,OAAO,EACP,WAAW,GACZ,MAAM,aAAa,CAAC;AAErB,YAAY,EACV,UAAU,EACV,YAAY,EACZ,eAAe,GAChB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEvD,YAAY,EACV,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,YAAY,EACZ,OAAO,EACP,aAAa,GACd,MAAM,eAAe,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/types/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/types/index.ts"],"names":[],"mappings":"AAoCA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"issue.d.ts","sourceRoot":"","sources":["../../../src/core/types/issue.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"issue.d.ts","sourceRoot":"","sources":["../../../src/core/types/issue.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/search.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAYzE,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../../src/mcp/tools/search.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yCAAyC,CAAC;AAYzE,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI,CA2E3D"}
|
package/dist/mcp/tools/search.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { z } from 'zod/v4';
|
|
2
2
|
import { loadWorkspace, createAdapters, textResponse, errorResponse, getErrorMessage, str, } from '../helpers.js';
|
|
3
3
|
export function registerSearchTools(server) {
|
|
4
|
-
server.registerTool('
|
|
5
|
-
description: '
|
|
4
|
+
server.registerTool('hybrid_search', {
|
|
5
|
+
description: 'Hybrid search across issues combining full-text keyword matching and semantic vector similarity using Reciprocal Rank Fusion. Works without embeddings (text-only fallback). For best results, run "argustack embed" first.',
|
|
6
6
|
inputSchema: {
|
|
7
7
|
query: z.string().describe('Natural language search query (e.g. "authentication timeout problems")'),
|
|
8
8
|
limit: z.number().optional().describe('Max results (default: 10)'),
|
|
9
|
-
threshold: z.number().optional().describe('Minimum similarity score 0-1 (default: 0.5)'),
|
|
9
|
+
threshold: z.number().optional().describe('Minimum similarity score 0-1 for vector results (default: 0.5)'),
|
|
10
10
|
},
|
|
11
11
|
}, async ({ query, limit, threshold }) => {
|
|
12
12
|
const ws = loadWorkspace();
|
|
@@ -15,23 +15,19 @@ export function registerSearchTools(server) {
|
|
|
15
15
|
}
|
|
16
16
|
const { storage } = await createAdapters(ws.root);
|
|
17
17
|
try {
|
|
18
|
+
let queryVector = null;
|
|
18
19
|
const apiKey = process.env['OPENAI_API_KEY'];
|
|
19
|
-
if (
|
|
20
|
-
await
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
const embeddingProvider = new OpenAIEmbeddingProvider({ apiKey });
|
|
25
|
-
const vectors = await embeddingProvider.embed([query]);
|
|
26
|
-
const queryVector = vectors[0];
|
|
27
|
-
if (!queryVector) {
|
|
28
|
-
await storage.close();
|
|
29
|
-
return errorResponse('Failed to generate embedding for query.');
|
|
20
|
+
if (apiKey) {
|
|
21
|
+
const { OpenAIEmbeddingProvider } = await import('../../adapters/openai/index.js');
|
|
22
|
+
const embeddingProvider = new OpenAIEmbeddingProvider({ apiKey });
|
|
23
|
+
const vectors = await embeddingProvider.embed([query]);
|
|
24
|
+
queryVector = vectors[0] ?? null;
|
|
30
25
|
}
|
|
31
|
-
const results = await storage.
|
|
26
|
+
const results = await storage.hybridSearch(query, queryVector, limit ?? 10, threshold ?? 0.5);
|
|
32
27
|
if (results.length === 0) {
|
|
33
28
|
await storage.close();
|
|
34
|
-
|
|
29
|
+
const mode = queryVector ? 'hybrid (text + semantic)' : 'text-only';
|
|
30
|
+
return textResponse(`No issues found for "${query}" (${mode} search).`);
|
|
35
31
|
}
|
|
36
32
|
const issueKeys = results.map((r) => r.issueKey);
|
|
37
33
|
const placeholders = issueKeys.map((_, i) => `$${String(i + 1)}`).join(',');
|
|
@@ -42,15 +38,16 @@ export function registerSearchTools(server) {
|
|
|
42
38
|
const r = row;
|
|
43
39
|
issueMap.set(r.issue_key, row);
|
|
44
40
|
}
|
|
41
|
+
const mode = queryVector ? 'hybrid' : 'text-only';
|
|
45
42
|
const lines = results.map((r) => {
|
|
46
43
|
const issue = issueMap.get(r.issueKey);
|
|
47
|
-
const
|
|
44
|
+
const scoreStr = (r.score * 100).toFixed(1);
|
|
48
45
|
if (issue) {
|
|
49
|
-
return `${r.issueKey} [${str(issue.status)}] ${str(issue.summary)} (${
|
|
46
|
+
return `${r.issueKey} [${str(issue.status)}] ${str(issue.summary)} (${scoreStr}% | ${r.source})`;
|
|
50
47
|
}
|
|
51
|
-
return `${r.issueKey} (${
|
|
48
|
+
return `${r.issueKey} (${scoreStr}% | ${r.source})`;
|
|
52
49
|
});
|
|
53
|
-
return textResponse([`
|
|
50
|
+
return textResponse([`Search: "${query}" (${mode}, ${String(results.length)} results):`, '', ...lines].join('\n'));
|
|
54
51
|
}
|
|
55
52
|
catch (err) {
|
|
56
53
|
await storage.close();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../../src/mcp/tools/search.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,OAAO,EACL,aAAa,EACb,cAAc,EACd,YAAY,EACZ,aAAa,EACb,eAAe,EACf,GAAG,GACJ,MAAM,eAAe,CAAC;AAEvB,MAAM,UAAU,mBAAmB,CAAC,MAAiB;IACnD,MAAM,CAAC,YAAY,CACjB,
|
|
1
|
+
{"version":3,"file":"search.js","sourceRoot":"","sources":["../../../src/mcp/tools/search.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { IBoardStore } from '../core/ports/board-store.js';
|
|
2
|
+
import type { ISkillRunner } from '../core/ports/skill-runner.js';
|
|
3
|
+
import { BoardTaskEntity } from '../core/board/board-task.entity.js';
|
|
4
|
+
export interface MoveTaskInput {
|
|
5
|
+
taskId: string;
|
|
6
|
+
targetColumn: string;
|
|
7
|
+
}
|
|
8
|
+
export interface MoveTaskOutput {
|
|
9
|
+
task: ReturnType<BoardTaskEntity['toData']>;
|
|
10
|
+
skillTriggered: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare class MoveTaskUseCase {
|
|
13
|
+
private readonly store;
|
|
14
|
+
private readonly skillRunner;
|
|
15
|
+
constructor(store: IBoardStore, skillRunner: ISkillRunner);
|
|
16
|
+
execute(input: MoveTaskInput, onSkillOutput?: (chunk: string) => void): Promise<MoveTaskOutput>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=move-task.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"move-task.d.ts","sourceRoot":"","sources":["../../src/use-cases/move-task.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AAGrE,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,UAAU,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC5C,cAAc,EAAE,OAAO,CAAC;CACzB;AAED,qBAAa,eAAe;IAExB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,WAAW;gBADX,KAAK,EAAE,WAAW,EAClB,WAAW,EAAE,YAAY;IAGtC,OAAO,CACX,KAAK,EAAE,aAAa,EACpB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GACtC,OAAO,CAAC,cAAc,CAAC;CAyC3B"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { BoardTaskEntity } from '../core/board/board-task.entity.js';
|
|
2
|
+
import { Pipeline } from '../core/board/pipeline.value-object.js';
|
|
3
|
+
export class MoveTaskUseCase {
|
|
4
|
+
store;
|
|
5
|
+
skillRunner;
|
|
6
|
+
constructor(store, skillRunner) {
|
|
7
|
+
this.store = store;
|
|
8
|
+
this.skillRunner = skillRunner;
|
|
9
|
+
}
|
|
10
|
+
async execute(input, onSkillOutput) {
|
|
11
|
+
const tasks = await this.store.getAllTasks();
|
|
12
|
+
const taskData = tasks.find((t) => t.id === input.taskId);
|
|
13
|
+
if (!taskData) {
|
|
14
|
+
throw new Error(`Task not found: ${input.taskId}`);
|
|
15
|
+
}
|
|
16
|
+
const pipelineConfig = await this.store.loadPipeline();
|
|
17
|
+
const pipeline = Pipeline.fromConfig(pipelineConfig, []);
|
|
18
|
+
const targetCol = pipeline.findColumn(input.targetColumn);
|
|
19
|
+
if (!targetCol) {
|
|
20
|
+
throw new Error(`Column not found: ${input.targetColumn}`);
|
|
21
|
+
}
|
|
22
|
+
const entity = BoardTaskEntity.create(taskData);
|
|
23
|
+
const moved = entity.moveTo(targetCol, pipeline);
|
|
24
|
+
await this.store.updateTask(moved.id, {
|
|
25
|
+
column: moved.column,
|
|
26
|
+
});
|
|
27
|
+
let skillTriggered = false;
|
|
28
|
+
if (targetCol.isSkill()) {
|
|
29
|
+
const available = await this.skillRunner.isAvailable();
|
|
30
|
+
if (available) {
|
|
31
|
+
skillTriggered = true;
|
|
32
|
+
const skillName = targetCol.skillName() ?? targetCol.name;
|
|
33
|
+
const generator = this.skillRunner.execute(skillName, [moved.toData().mdPath]);
|
|
34
|
+
for await (const chunk of generator) {
|
|
35
|
+
onSkillOutput?.(chunk);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return {
|
|
40
|
+
task: moved.toData(),
|
|
41
|
+
skillTriggered,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=move-task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"move-task.js","sourceRoot":"","sources":["../../src/use-cases/move-task.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,wCAAwC,CAAC;AAYlE,MAAM,OAAO,eAAe;IAEP;IACA;IAFnB,YACmB,KAAkB,EAClB,WAAyB;QADzB,UAAK,GAAL,KAAK,CAAa;QAClB,gBAAW,GAAX,WAAW,CAAc;IACzC,CAAC;IAEJ,KAAK,CAAC,OAAO,CACX,KAAoB,EACpB,aAAuC;QAEvC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QAC7C,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,CAAC;QAC1D,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,mBAAmB,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QACrD,CAAC;QAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QACvD,MAAM,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC;QAEzD,MAAM,SAAS,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAC1D,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,qBAAqB,KAAK,CAAC,YAAY,EAAE,CAAC,CAAC;QAC7D,CAAC;QAED,MAAM,MAAM,GAAG,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QAEjD,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,EAAE;YACpC,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC,CAAC;QAEH,IAAI,cAAc,GAAG,KAAK,CAAC;QAE3B,IAAI,SAAS,CAAC,OAAO,EAAE,EAAE,CAAC;YACxB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;YACvD,IAAI,SAAS,EAAE,CAAC;gBACd,cAAc,GAAG,IAAI,CAAC;gBACtB,MAAM,SAAS,GAAG,SAAS,CAAC,SAAS,EAAE,IAAI,SAAS,CAAC,IAAI,CAAC;gBAC1D,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC/E,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,SAAS,EAAE,CAAC;oBACpC,aAAa,EAAE,CAAC,KAAK,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO;YACL,IAAI,EAAE,KAAK,CAAC,MAAM,EAAE;YACpB,cAAc;SACf,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { IBoardStore } from '../core/ports/board-store.js';
|
|
2
|
+
import type { BoardTaskData } from '../core/types/board.js';
|
|
3
|
+
import { type PipelineConfig } from '../core/board/pipeline.value-object.js';
|
|
4
|
+
export interface SyncBoardOutput {
|
|
5
|
+
tasks: BoardTaskData[];
|
|
6
|
+
pipeline: PipelineConfig;
|
|
7
|
+
}
|
|
8
|
+
export declare class SyncBoardUseCase {
|
|
9
|
+
private readonly store;
|
|
10
|
+
constructor(store: IBoardStore);
|
|
11
|
+
execute(tasksDir: string, availableSkills: string[]): Promise<SyncBoardOutput>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=sync-board.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-board.d.ts","sourceRoot":"","sources":["../../src/use-cases/sync-board.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAY,KAAK,cAAc,EAAE,MAAM,wCAAwC,CAAC;AAEvF,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,aAAa,EAAE,CAAC;IACvB,QAAQ,EAAE,cAAc,CAAC;CAC1B;AAED,qBAAa,gBAAgB;IACf,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,WAAW;IAEzC,OAAO,CACX,QAAQ,EAAE,MAAM,EAChB,eAAe,EAAE,MAAM,EAAE,GACxB,OAAO,CAAC,eAAe,CAAC;CAgB5B"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Pipeline } from '../core/board/pipeline.value-object.js';
|
|
2
|
+
export class SyncBoardUseCase {
|
|
3
|
+
store;
|
|
4
|
+
constructor(store) {
|
|
5
|
+
this.store = store;
|
|
6
|
+
}
|
|
7
|
+
async execute(tasksDir, availableSkills) {
|
|
8
|
+
await this.store.syncFromFiles(tasksDir);
|
|
9
|
+
const pipelineConfig = await this.store.loadPipeline();
|
|
10
|
+
const pipeline = Pipeline.fromConfig(pipelineConfig, availableSkills);
|
|
11
|
+
const updatedConfig = pipeline.toConfig(pipelineConfig.port);
|
|
12
|
+
await this.store.savePipeline(updatedConfig);
|
|
13
|
+
const tasks = await this.store.getAllTasks();
|
|
14
|
+
return {
|
|
15
|
+
tasks,
|
|
16
|
+
pipeline: updatedConfig,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=sync-board.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sync-board.js","sourceRoot":"","sources":["../../src/use-cases/sync-board.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAuB,MAAM,wCAAwC,CAAC;AAOvF,MAAM,OAAO,gBAAgB;IACE;IAA7B,YAA6B,KAAkB;QAAlB,UAAK,GAAL,KAAK,CAAa;IAAG,CAAC;IAEnD,KAAK,CAAC,OAAO,CACX,QAAgB,EAChB,eAAyB;QAEzB,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAEzC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QACvD,MAAM,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QAEtE,MAAM,aAAa,GAAG,QAAQ,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC7D,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAE7C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QAE7C,OAAO;YACL,KAAK;YACL,QAAQ,EAAE,aAAa;SACxB,CAAC;IACJ,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "argustack",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.13",
|
|
4
4
|
"description": "Project analysis platform — Jira + Git + DB",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -11,7 +11,8 @@
|
|
|
11
11
|
"templates/"
|
|
12
12
|
],
|
|
13
13
|
"scripts": {
|
|
14
|
-
"build": "tsc",
|
|
14
|
+
"build": "tsc && npm run build:board",
|
|
15
|
+
"build:board": "vite build --config src/board/vite.config.ts",
|
|
15
16
|
"dev": "tsx src/cli/index.ts",
|
|
16
17
|
"start": "node dist/cli/index.js",
|
|
17
18
|
"lint": "eslint src/ tests/",
|
|
@@ -46,6 +47,7 @@
|
|
|
46
47
|
"node": ">=20"
|
|
47
48
|
},
|
|
48
49
|
"dependencies": {
|
|
50
|
+
"@hello-pangea/dnd": "^18.0.1",
|
|
49
51
|
"@inquirer/prompts": "^8.3.0",
|
|
50
52
|
"@modelcontextprotocol/sdk": "^1.27.1",
|
|
51
53
|
"chalk": "^5.4.1",
|
|
@@ -55,22 +57,30 @@
|
|
|
55
57
|
"es-git": "^0.6.0",
|
|
56
58
|
"jira.js": "^5.3.1",
|
|
57
59
|
"knex": "^3.1.0",
|
|
60
|
+
"mysql2": "^3.20.0",
|
|
58
61
|
"octokit": "^5.0.5",
|
|
59
62
|
"ora": "^9.3.0",
|
|
60
|
-
"pg": "^8.13.1"
|
|
63
|
+
"pg": "^8.13.1",
|
|
64
|
+
"react": "^19.2.4",
|
|
65
|
+
"react-dom": "^19.2.4"
|
|
61
66
|
},
|
|
62
67
|
"devDependencies": {
|
|
63
68
|
"@eslint/js": "^10.0.1",
|
|
64
69
|
"@types/eslint__js": "^8.42.3",
|
|
65
70
|
"@types/node": "^24.12.0",
|
|
66
71
|
"@types/pg": "^8.11.10",
|
|
72
|
+
"@types/react": "^19.2.14",
|
|
73
|
+
"@types/react-dom": "^19.2.3",
|
|
74
|
+
"@vitejs/plugin-react": "^6.0.1",
|
|
67
75
|
"@vitest/coverage-v8": "^4.0.18",
|
|
76
|
+
"dependency-cruiser": "^17.3.9",
|
|
68
77
|
"eslint": "^10.0.3",
|
|
69
78
|
"husky": "^9.1.7",
|
|
70
79
|
"lint-staged": "^16.3.3",
|
|
71
80
|
"tsx": "^4.19.2",
|
|
72
81
|
"typescript": "^5.7.2",
|
|
73
82
|
"typescript-eslint": "^8.57.0",
|
|
83
|
+
"vite": "^8.0.3",
|
|
74
84
|
"vitest": "^4.0.18"
|
|
75
85
|
}
|
|
76
86
|
}
|