npm-cli-gh-issue-preparator 1.17.0 → 1.18.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/.github/workflows/test.yml +2 -2
- package/CHANGELOG.md +7 -0
- package/bin/domain/usecases/NotifyFinishedIssuePreparationUseCase.js +4 -1
- package/bin/domain/usecases/NotifyFinishedIssuePreparationUseCase.js.map +1 -1
- package/bin/domain/usecases/StartPreparationUseCase.js +3 -1
- package/bin/domain/usecases/StartPreparationUseCase.js.map +1 -1
- package/package.json +1 -1
- package/src/domain/usecases/NotifyFinishedIssuePreparationUseCase.test.ts +60 -1
- package/src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts +17 -2
- package/src/domain/usecases/StartPreparationUseCase.test.ts +38 -1
- package/src/domain/usecases/StartPreparationUseCase.ts +13 -2
- package/types/domain/usecases/NotifyFinishedIssuePreparationUseCase.d.ts +1 -1
- package/types/domain/usecases/NotifyFinishedIssuePreparationUseCase.d.ts.map +1 -1
- package/types/domain/usecases/StartPreparationUseCase.d.ts +1 -1
- package/types/domain/usecases/StartPreparationUseCase.d.ts.map +1 -1
|
@@ -28,13 +28,13 @@ jobs:
|
|
|
28
28
|
GH_TOKEN: ${{ secrets.GH_TOKEN }}
|
|
29
29
|
|
|
30
30
|
- name: Upload test results
|
|
31
|
-
uses: actions/upload-artifact@
|
|
31
|
+
uses: actions/upload-artifact@v7
|
|
32
32
|
with:
|
|
33
33
|
name: jest-junit-report
|
|
34
34
|
path: reports/jest-junit
|
|
35
35
|
|
|
36
36
|
- name: Upload artifacts
|
|
37
|
-
uses: actions/upload-artifact@
|
|
37
|
+
uses: actions/upload-artifact@v7
|
|
38
38
|
with:
|
|
39
39
|
name: reports
|
|
40
40
|
path: reports
|
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
# [1.18.0](https://github.com/HiromiShikata/npm-cli-gh-issue-preparator/compare/v1.17.0...v1.18.0) (2026-02-28)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* **core:** call prepareStatus for all provided statuses before use ([c2739f3](https://github.com/HiromiShikata/npm-cli-gh-issue-preparator/commit/c2739f3a3adfa64e97bb37ed25a18999b0f54b7c))
|
|
7
|
+
|
|
1
8
|
# [1.17.0](https://github.com/HiromiShikata/npm-cli-gh-issue-preparator/compare/v1.16.1...v1.17.0) (2026-02-26)
|
|
2
9
|
|
|
3
10
|
|
|
@@ -21,7 +21,10 @@ class NotifyFinishedIssuePreparationUseCase {
|
|
|
21
21
|
this.issueRepository = issueRepository;
|
|
22
22
|
this.issueCommentRepository = issueCommentRepository;
|
|
23
23
|
this.run = async (params) => {
|
|
24
|
-
|
|
24
|
+
let project = await this.projectRepository.getByUrl(params.projectUrl);
|
|
25
|
+
project = await this.projectRepository.prepareStatus(params.preparationStatus, project);
|
|
26
|
+
project = await this.projectRepository.prepareStatus(params.awaitingWorkspaceStatus, project);
|
|
27
|
+
project = await this.projectRepository.prepareStatus(params.awaitingQualityCheckStatus, project);
|
|
25
28
|
const issue = await this.issueRepository.get(params.issueUrl, project);
|
|
26
29
|
if (!issue) {
|
|
27
30
|
throw new IssueNotFoundError(params.issueUrl);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NotifyFinishedIssuePreparationUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts"],"names":[],"mappings":";;;AAIA,MAAa,kBAAmB,SAAQ,KAAK;IAC3C,YAAY,QAAgB;QAC1B,KAAK,CAAC,oBAAoB,QAAQ,EAAE,CAAC,CAAC;QACtC,IAAI,CAAC,IAAI,GAAG,oBAAoB,CAAC;IACnC,CAAC;CACF;AALD,gDAKC;AACD,MAAa,uBAAwB,SAAQ,KAAK;IAChD,YACE,QAAgB,EAChB,aAA4B,EAC5B,cAA6B;QAE7B,KAAK,CACH,4BAA4B,QAAQ,cAAc,cAAc,aAAa,aAAa,EAAE,CAC7F,CAAC;QACF,IAAI,CAAC,IAAI,GAAG,yBAAyB,CAAC;IACxC,CAAC;CACF;AAXD,0DAWC;AASD,MAAa,qCAAqC;IAChD,YACmB,
|
|
1
|
+
{"version":3,"file":"NotifyFinishedIssuePreparationUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts"],"names":[],"mappings":"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"}
|
|
@@ -19,7 +19,9 @@ class StartPreparationUseCase {
|
|
|
19
19
|
console.warn('Failed to check Claude usage:', error);
|
|
20
20
|
}
|
|
21
21
|
const maximumPreparingIssuesCount = params.maximumPreparingIssuesCount ?? 6;
|
|
22
|
-
|
|
22
|
+
let project = await this.projectRepository.getByUrl(params.projectUrl);
|
|
23
|
+
project = await this.projectRepository.prepareStatus(params.awaitingWorkspaceStatus, project);
|
|
24
|
+
project = await this.projectRepository.prepareStatus(params.preparationStatus, project);
|
|
23
25
|
const storyObjectMap = await this.issueRepository.getStoryObjectMap(project);
|
|
24
26
|
const allIssues = await this.issueRepository.getAllOpened(project);
|
|
25
27
|
const repositoryBlockerIssues = this.createWorkflowBockerIsues(storyObjectMap);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StartPreparationUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/StartPreparationUseCase.ts"],"names":[],"mappings":";;;AAOA,MAAa,uBAAuB;IAClC,YACmB,
|
|
1
|
+
{"version":3,"file":"StartPreparationUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/StartPreparationUseCase.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -74,7 +74,11 @@ describe('NotifyFinishedIssuePreparationUseCase', () => {
|
|
|
74
74
|
|
|
75
75
|
mockProjectRepository = {
|
|
76
76
|
getByUrl: jest.fn(),
|
|
77
|
-
prepareStatus: jest
|
|
77
|
+
prepareStatus: jest
|
|
78
|
+
.fn()
|
|
79
|
+
.mockImplementation((_name: string, project: Project) =>
|
|
80
|
+
Promise.resolve(project),
|
|
81
|
+
),
|
|
78
82
|
};
|
|
79
83
|
|
|
80
84
|
mockIssueRepository = {
|
|
@@ -97,6 +101,61 @@ describe('NotifyFinishedIssuePreparationUseCase', () => {
|
|
|
97
101
|
);
|
|
98
102
|
});
|
|
99
103
|
|
|
104
|
+
it('should call prepareStatus for preparationStatus, awaitingWorkspaceStatus, and awaitingQualityCheckStatus with chained project objects', async () => {
|
|
105
|
+
const projectAfterFirstPrepare = createMockProject();
|
|
106
|
+
const projectAfterSecondPrepare = createMockProject();
|
|
107
|
+
const projectAfterThirdPrepare = createMockProject();
|
|
108
|
+
const issue = createMockIssue({
|
|
109
|
+
url: 'https://github.com/user/repo/issues/1',
|
|
110
|
+
status: 'Preparation',
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
mockProjectRepository.getByUrl.mockResolvedValue(mockProject);
|
|
114
|
+
mockProjectRepository.prepareStatus
|
|
115
|
+
.mockResolvedValueOnce(projectAfterFirstPrepare)
|
|
116
|
+
.mockResolvedValueOnce(projectAfterSecondPrepare)
|
|
117
|
+
.mockResolvedValueOnce(projectAfterThirdPrepare);
|
|
118
|
+
mockIssueRepository.get.mockResolvedValue(issue);
|
|
119
|
+
mockIssueCommentRepository.getCommentsFromIssue.mockResolvedValue([
|
|
120
|
+
createMockComment({ content: 'From: Test report' }),
|
|
121
|
+
]);
|
|
122
|
+
mockIssueRepository.findRelatedOpenPRs.mockResolvedValue([
|
|
123
|
+
{
|
|
124
|
+
url: 'https://github.com/user/repo/pull/1',
|
|
125
|
+
isConflicted: false,
|
|
126
|
+
isPassedAllCiJob: true,
|
|
127
|
+
isResolvedAllReviewComments: true,
|
|
128
|
+
isBranchOutOfDate: false,
|
|
129
|
+
},
|
|
130
|
+
]);
|
|
131
|
+
|
|
132
|
+
await useCase.run({
|
|
133
|
+
projectUrl: 'https://github.com/users/user/projects/1',
|
|
134
|
+
issueUrl: 'https://github.com/user/repo/issues/1',
|
|
135
|
+
preparationStatus: 'Preparation',
|
|
136
|
+
awaitingWorkspaceStatus: 'Awaiting Workspace',
|
|
137
|
+
awaitingQualityCheckStatus: 'Awaiting Quality Check',
|
|
138
|
+
thresholdForAutoReject: 3,
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenCalledTimes(3);
|
|
142
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenNthCalledWith(
|
|
143
|
+
1,
|
|
144
|
+
'Preparation',
|
|
145
|
+
mockProject,
|
|
146
|
+
);
|
|
147
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenNthCalledWith(
|
|
148
|
+
2,
|
|
149
|
+
'Awaiting Workspace',
|
|
150
|
+
projectAfterFirstPrepare,
|
|
151
|
+
);
|
|
152
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenNthCalledWith(
|
|
153
|
+
3,
|
|
154
|
+
'Awaiting Quality Check',
|
|
155
|
+
projectAfterSecondPrepare,
|
|
156
|
+
);
|
|
157
|
+
});
|
|
158
|
+
|
|
100
159
|
it('should update issue status from Preparation to Awaiting Quality Check when last comment starts with From:', async () => {
|
|
101
160
|
const issue = createMockIssue({
|
|
102
161
|
url: 'https://github.com/user/repo/issues/1',
|
|
@@ -30,7 +30,10 @@ type RejectedReasonType =
|
|
|
30
30
|
|
|
31
31
|
export class NotifyFinishedIssuePreparationUseCase {
|
|
32
32
|
constructor(
|
|
33
|
-
private readonly projectRepository: Pick<
|
|
33
|
+
private readonly projectRepository: Pick<
|
|
34
|
+
ProjectRepository,
|
|
35
|
+
'getByUrl' | 'prepareStatus'
|
|
36
|
+
>,
|
|
34
37
|
private readonly issueRepository: Pick<
|
|
35
38
|
IssueRepository,
|
|
36
39
|
'get' | 'update' | 'findRelatedOpenPRs'
|
|
@@ -49,7 +52,19 @@ export class NotifyFinishedIssuePreparationUseCase {
|
|
|
49
52
|
awaitingQualityCheckStatus: string;
|
|
50
53
|
thresholdForAutoReject: number;
|
|
51
54
|
}): Promise<void> => {
|
|
52
|
-
|
|
55
|
+
let project = await this.projectRepository.getByUrl(params.projectUrl);
|
|
56
|
+
project = await this.projectRepository.prepareStatus(
|
|
57
|
+
params.preparationStatus,
|
|
58
|
+
project,
|
|
59
|
+
);
|
|
60
|
+
project = await this.projectRepository.prepareStatus(
|
|
61
|
+
params.awaitingWorkspaceStatus,
|
|
62
|
+
project,
|
|
63
|
+
);
|
|
64
|
+
project = await this.projectRepository.prepareStatus(
|
|
65
|
+
params.awaitingQualityCheckStatus,
|
|
66
|
+
project,
|
|
67
|
+
);
|
|
53
68
|
|
|
54
69
|
const issue = await this.issueRepository.get(params.issueUrl, project);
|
|
55
70
|
|
|
@@ -83,7 +83,11 @@ describe('StartPreparationUseCase', () => {
|
|
|
83
83
|
mockProject = createMockProject();
|
|
84
84
|
mockProjectRepository = {
|
|
85
85
|
getByUrl: jest.fn(),
|
|
86
|
-
prepareStatus: jest
|
|
86
|
+
prepareStatus: jest
|
|
87
|
+
.fn()
|
|
88
|
+
.mockImplementation((_name: string, project: Project) =>
|
|
89
|
+
Promise.resolve(project),
|
|
90
|
+
),
|
|
87
91
|
};
|
|
88
92
|
mockIssueRepository = {
|
|
89
93
|
getAllOpened: jest.fn(),
|
|
@@ -105,6 +109,39 @@ describe('StartPreparationUseCase', () => {
|
|
|
105
109
|
mockLocalCommandRunner,
|
|
106
110
|
);
|
|
107
111
|
});
|
|
112
|
+
it('should call prepareStatus for awaitingWorkspaceStatus and preparationStatus with chained project objects', async () => {
|
|
113
|
+
const projectAfterFirstPrepare = createMockProject();
|
|
114
|
+
const projectAfterSecondPrepare = createMockProject();
|
|
115
|
+
mockProjectRepository.getByUrl.mockResolvedValue(mockProject);
|
|
116
|
+
mockProjectRepository.prepareStatus
|
|
117
|
+
.mockResolvedValueOnce(projectAfterFirstPrepare)
|
|
118
|
+
.mockResolvedValueOnce(projectAfterSecondPrepare);
|
|
119
|
+
mockIssueRepository.getStoryObjectMap.mockResolvedValue(
|
|
120
|
+
createMockStoryObjectMap([]),
|
|
121
|
+
);
|
|
122
|
+
mockIssueRepository.getAllOpened.mockResolvedValueOnce([]);
|
|
123
|
+
|
|
124
|
+
await useCase.run({
|
|
125
|
+
projectUrl: 'https://github.com/user/repo',
|
|
126
|
+
awaitingWorkspaceStatus: 'Awaiting Workspace',
|
|
127
|
+
preparationStatus: 'Preparation',
|
|
128
|
+
defaultAgentName: 'agent1',
|
|
129
|
+
maximumPreparingIssuesCount: null,
|
|
130
|
+
utilizationPercentageThreshold: 90,
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenCalledTimes(2);
|
|
134
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenNthCalledWith(
|
|
135
|
+
1,
|
|
136
|
+
'Awaiting Workspace',
|
|
137
|
+
mockProject,
|
|
138
|
+
);
|
|
139
|
+
expect(mockProjectRepository.prepareStatus).toHaveBeenNthCalledWith(
|
|
140
|
+
2,
|
|
141
|
+
'Preparation',
|
|
142
|
+
projectAfterFirstPrepare,
|
|
143
|
+
);
|
|
144
|
+
});
|
|
108
145
|
it('should run aw command for awaiting workspace issues', async () => {
|
|
109
146
|
const awaitingIssues: Issue[] = [
|
|
110
147
|
createMockIssue({
|
|
@@ -7,7 +7,10 @@ import { ClaudeRepository } from './adapter-interfaces/ClaudeRepository';
|
|
|
7
7
|
|
|
8
8
|
export class StartPreparationUseCase {
|
|
9
9
|
constructor(
|
|
10
|
-
private readonly projectRepository: Pick<
|
|
10
|
+
private readonly projectRepository: Pick<
|
|
11
|
+
ProjectRepository,
|
|
12
|
+
'getByUrl' | 'prepareStatus'
|
|
13
|
+
>,
|
|
11
14
|
private readonly issueRepository: Pick<
|
|
12
15
|
IssueRepository,
|
|
13
16
|
'getAllOpened' | 'getStoryObjectMap' | 'update'
|
|
@@ -43,7 +46,15 @@ export class StartPreparationUseCase {
|
|
|
43
46
|
}
|
|
44
47
|
|
|
45
48
|
const maximumPreparingIssuesCount = params.maximumPreparingIssuesCount ?? 6;
|
|
46
|
-
|
|
49
|
+
let project = await this.projectRepository.getByUrl(params.projectUrl);
|
|
50
|
+
project = await this.projectRepository.prepareStatus(
|
|
51
|
+
params.awaitingWorkspaceStatus,
|
|
52
|
+
project,
|
|
53
|
+
);
|
|
54
|
+
project = await this.projectRepository.prepareStatus(
|
|
55
|
+
params.preparationStatus,
|
|
56
|
+
project,
|
|
57
|
+
);
|
|
47
58
|
const storyObjectMap =
|
|
48
59
|
await this.issueRepository.getStoryObjectMap(project);
|
|
49
60
|
const allIssues = await this.issueRepository.getAllOpened(project);
|
|
@@ -11,7 +11,7 @@ export declare class NotifyFinishedIssuePreparationUseCase {
|
|
|
11
11
|
private readonly projectRepository;
|
|
12
12
|
private readonly issueRepository;
|
|
13
13
|
private readonly issueCommentRepository;
|
|
14
|
-
constructor(projectRepository: Pick<ProjectRepository, 'getByUrl'>, issueRepository: Pick<IssueRepository, 'get' | 'update' | 'findRelatedOpenPRs'>, issueCommentRepository: Pick<IssueCommentRepository, 'getCommentsFromIssue' | 'createComment'>);
|
|
14
|
+
constructor(projectRepository: Pick<ProjectRepository, 'getByUrl' | 'prepareStatus'>, issueRepository: Pick<IssueRepository, 'get' | 'update' | 'findRelatedOpenPRs'>, issueCommentRepository: Pick<IssueCommentRepository, 'getCommentsFromIssue' | 'createComment'>);
|
|
15
15
|
run: (params: {
|
|
16
16
|
projectUrl: string;
|
|
17
17
|
issueUrl: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NotifyFinishedIssuePreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AAErF,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,QAAQ,EAAE,MAAM;CAI7B;AACD,qBAAa,uBAAwB,SAAQ,KAAK;gBAE9C,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,GAAG,IAAI,EAC5B,cAAc,EAAE,MAAM,GAAG,IAAI;CAOhC;AASD,qBAAa,qCAAqC;IAE9C,OAAO,CAAC,QAAQ,CAAC,iBAAiB;
|
|
1
|
+
{"version":3,"file":"NotifyFinishedIssuePreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/NotifyFinishedIssuePreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;AAErF,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,QAAQ,EAAE,MAAM;CAI7B;AACD,qBAAa,uBAAwB,SAAQ,KAAK;gBAE9C,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,GAAG,IAAI,EAC5B,cAAc,EAAE,MAAM,GAAG,IAAI;CAOhC;AASD,qBAAa,qCAAqC;IAE9C,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAIlC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAIhC,OAAO,CAAC,QAAQ,CAAC,sBAAsB;gBARtB,iBAAiB,EAAE,IAAI,CACtC,iBAAiB,EACjB,UAAU,GAAG,eAAe,CAC7B,EACgB,eAAe,EAAE,IAAI,CACpC,eAAe,EACf,KAAK,GAAG,QAAQ,GAAG,oBAAoB,CACxC,EACgB,sBAAsB,EAAE,IAAI,CAC3C,sBAAsB,EACtB,sBAAsB,GAAG,eAAe,CACzC;IAGH,GAAG,GAAU,QAAQ;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,QAAQ,EAAE,MAAM,CAAC;QACjB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,uBAAuB,EAAE,MAAM,CAAC;QAChC,0BAA0B,EAAE,MAAM,CAAC;QACnC,sBAAsB,EAAE,MAAM,CAAC;KAChC,KAAG,OAAO,CAAC,IAAI,CAAC,CA6Ff;CACH"}
|
|
@@ -8,7 +8,7 @@ export declare class StartPreparationUseCase {
|
|
|
8
8
|
private readonly issueRepository;
|
|
9
9
|
private readonly claudeRepository;
|
|
10
10
|
private readonly localCommandRunner;
|
|
11
|
-
constructor(projectRepository: Pick<ProjectRepository, 'getByUrl'>, issueRepository: Pick<IssueRepository, 'getAllOpened' | 'getStoryObjectMap' | 'update'>, claudeRepository: Pick<ClaudeRepository, 'getUsage'>, localCommandRunner: LocalCommandRunner);
|
|
11
|
+
constructor(projectRepository: Pick<ProjectRepository, 'getByUrl' | 'prepareStatus'>, issueRepository: Pick<IssueRepository, 'getAllOpened' | 'getStoryObjectMap' | 'update'>, claudeRepository: Pick<ClaudeRepository, 'getUsage'>, localCommandRunner: LocalCommandRunner);
|
|
12
12
|
run: (params: {
|
|
13
13
|
projectUrl: string;
|
|
14
14
|
awaitingWorkspaceStatus: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StartPreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/StartPreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAE7E,OAAO,EAAe,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AAEzE,qBAAa,uBAAuB;IAEhC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;
|
|
1
|
+
{"version":3,"file":"StartPreparationUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/StartPreparationUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAE7E,OAAO,EAAe,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AAEzE,qBAAa,uBAAuB;IAEhC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAIlC,OAAO,CAAC,QAAQ,CAAC,eAAe;IAIhC,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IACjC,OAAO,CAAC,QAAQ,CAAC,kBAAkB;gBATlB,iBAAiB,EAAE,IAAI,CACtC,iBAAiB,EACjB,UAAU,GAAG,eAAe,CAC7B,EACgB,eAAe,EAAE,IAAI,CACpC,eAAe,EACf,cAAc,GAAG,mBAAmB,GAAG,QAAQ,CAChD,EACgB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,EACpD,kBAAkB,EAAE,kBAAkB;IAGzD,GAAG,GAAU,QAAQ;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,uBAAuB,EAAE,MAAM,CAAC;QAChC,iBAAiB,EAAE,MAAM,CAAC;QAC1B,gBAAgB,EAAE,MAAM,CAAC;QACzB,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,2BAA2B,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3C,8BAA8B,EAAE,MAAM,CAAC;KACxC,KAAG,OAAO,CAAC,IAAI,CAAC,CAsGf;IACF,yBAAyB,GACvB,gBAAgB,cAAc,KAC7B;QACD,OAAO,EAAE,MAAM,CAAC;QAChB,gBAAgB,EAAE,MAAM,EAAE,CAAC;KAC5B,EAAE,CAyBD;CACH"}
|