github-issue-tower-defence-management 1.36.3 → 1.37.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.
- package/.github/workflows/create-pr.yml +26 -5
- package/.github/workflows/umino-project.yml +4 -4
- package/CHANGELOG.md +19 -0
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js +3 -3
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js.map +1 -1
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js +30 -7
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js.map +1 -1
- package/bin/domain/usecases/ClearPastNextActionDateHourUseCase.js +59 -0
- package/bin/domain/usecases/ClearPastNextActionDateHourUseCase.js.map +1 -0
- package/bin/domain/usecases/HandleScheduledEventUseCase.js +3 -3
- package/bin/domain/usecases/HandleScheduledEventUseCase.js.map +1 -1
- package/package.json +1 -1
- package/src/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.test.ts +8 -3
- package/src/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.ts +3 -3
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.test.ts +21 -0
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.test.ts +175 -3
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.ts +73 -37
- package/src/domain/usecases/ClearPastNextActionDateHourUseCase.test.ts +325 -0
- package/src/domain/usecases/ClearPastNextActionDateHourUseCase.ts +88 -0
- package/src/domain/usecases/HandleScheduledEventUseCase.test.ts +4 -3
- package/src/domain/usecases/HandleScheduledEventUseCase.ts +3 -3
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts.map +1 -1
- package/types/domain/usecases/ClearPastNextActionDateHourUseCase.d.ts +14 -0
- package/types/domain/usecases/ClearPastNextActionDateHourUseCase.d.ts.map +1 -0
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts +3 -3
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts.map +1 -1
- package/src/domain/usecases/ClearNextActionHourUseCase.ts +0 -61
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
3
|
+
import { Project } from '../entities/Project';
|
|
4
|
+
|
|
5
|
+
export class ClearPastNextActionDateHourUseCase {
|
|
6
|
+
constructor(
|
|
7
|
+
readonly issueRepository: Pick<IssueRepository, 'clearProjectField'>,
|
|
8
|
+
) {}
|
|
9
|
+
|
|
10
|
+
run = async (input: {
|
|
11
|
+
targetDates: Date[];
|
|
12
|
+
project: Project;
|
|
13
|
+
issues: Issue[];
|
|
14
|
+
cacheUsed: boolean;
|
|
15
|
+
}): Promise<void> => {
|
|
16
|
+
if (input.targetDates.length === 0) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const now = input.targetDates[input.targetDates.length - 1];
|
|
20
|
+
|
|
21
|
+
const nextActionHour = input.project.nextActionHour;
|
|
22
|
+
if (nextActionHour) {
|
|
23
|
+
const nextActionDate = input.project.nextActionDate;
|
|
24
|
+
const targetDatesAtHour45 = input.targetDates
|
|
25
|
+
.filter((targetDate) => targetDate.getMinutes() === 45)
|
|
26
|
+
.reverse();
|
|
27
|
+
if (targetDatesAtHour45.length > 0) {
|
|
28
|
+
const targetDate = new Date(
|
|
29
|
+
targetDatesAtHour45[targetDatesAtHour45.length - 1].getTime() +
|
|
30
|
+
5 * 60 * 1000,
|
|
31
|
+
);
|
|
32
|
+
const targetHour = targetDate.getHours() + 1;
|
|
33
|
+
for (const issue of input.issues) {
|
|
34
|
+
if (
|
|
35
|
+
issue.nextActionHour === null ||
|
|
36
|
+
issue.nextActionHour > targetHour ||
|
|
37
|
+
(issue.nextActionDate !== null &&
|
|
38
|
+
issue.nextActionDate.getTime() > targetDate.getTime()) ||
|
|
39
|
+
issue.state !== 'OPEN'
|
|
40
|
+
) {
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
await this.issueRepository.clearProjectField(
|
|
44
|
+
input.project,
|
|
45
|
+
nextActionHour.fieldId,
|
|
46
|
+
issue,
|
|
47
|
+
);
|
|
48
|
+
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
49
|
+
if (!nextActionDate) {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
await this.issueRepository.clearProjectField(
|
|
53
|
+
input.project,
|
|
54
|
+
nextActionDate.fieldId,
|
|
55
|
+
issue,
|
|
56
|
+
);
|
|
57
|
+
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const nextActionDate = input.project.nextActionDate;
|
|
63
|
+
if (!nextActionDate) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const startOfTomorrow = new Date(
|
|
67
|
+
now.getFullYear(),
|
|
68
|
+
now.getMonth(),
|
|
69
|
+
now.getDate() + 1,
|
|
70
|
+
);
|
|
71
|
+
for (const issue of input.issues) {
|
|
72
|
+
if (
|
|
73
|
+
issue.nextActionHour !== null ||
|
|
74
|
+
(issue.nextActionDate?.getTime() ?? Infinity) >=
|
|
75
|
+
startOfTomorrow.getTime() ||
|
|
76
|
+
issue.state !== 'OPEN'
|
|
77
|
+
) {
|
|
78
|
+
continue;
|
|
79
|
+
}
|
|
80
|
+
await this.issueRepository.clearProjectField(
|
|
81
|
+
input.project,
|
|
82
|
+
nextActionDate.fieldId,
|
|
83
|
+
issue,
|
|
84
|
+
);
|
|
85
|
+
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
}
|
|
@@ -2,7 +2,7 @@ import { HandleScheduledEventUseCase } from './HandleScheduledEventUseCase';
|
|
|
2
2
|
import { mock } from 'jest-mock-extended';
|
|
3
3
|
import { ActionAnnouncementUseCase } from './ActionAnnouncementUseCase';
|
|
4
4
|
import { SetWorkflowManagementIssueToStoryUseCase } from './SetWorkflowManagementIssueToStoryUseCase';
|
|
5
|
-
import {
|
|
5
|
+
import { ClearPastNextActionDateHourUseCase } from './ClearPastNextActionDateHourUseCase';
|
|
6
6
|
import { AnalyzeProblemByIssueUseCase } from './AnalyzeProblemByIssueUseCase';
|
|
7
7
|
import { AnalyzeStoriesUseCase } from './AnalyzeStoriesUseCase';
|
|
8
8
|
import { ClearDependedIssueURLUseCase } from './ClearDependedIssueURLUseCase';
|
|
@@ -81,7 +81,8 @@ describe('HandleScheduledEventUseCase', () => {
|
|
|
81
81
|
const mockActionAnnouncementUseCase = mock<ActionAnnouncementUseCase>();
|
|
82
82
|
const mockSetWorkflowManagementIssueToStoryUseCase =
|
|
83
83
|
mock<SetWorkflowManagementIssueToStoryUseCase>();
|
|
84
|
-
const
|
|
84
|
+
const mockClearPastNextActionDateHourUseCase =
|
|
85
|
+
mock<ClearPastNextActionDateHourUseCase>();
|
|
85
86
|
const mockAnalyzeProblemByIssueUseCase =
|
|
86
87
|
mock<AnalyzeProblemByIssueUseCase>();
|
|
87
88
|
const mockAnalyzeStoriesUseCase = mock<AnalyzeStoriesUseCase>();
|
|
@@ -112,7 +113,7 @@ describe('HandleScheduledEventUseCase', () => {
|
|
|
112
113
|
const useCase = new HandleScheduledEventUseCase(
|
|
113
114
|
mockActionAnnouncementUseCase,
|
|
114
115
|
mockSetWorkflowManagementIssueToStoryUseCase,
|
|
115
|
-
|
|
116
|
+
mockClearPastNextActionDateHourUseCase,
|
|
116
117
|
mockAnalyzeProblemByIssueUseCase,
|
|
117
118
|
mockAnalyzeStoriesUseCase,
|
|
118
119
|
mockClearDependedIssueURLUseCase,
|
|
@@ -8,7 +8,7 @@ import { DateRepository } from './adapter-interfaces/DateRepository';
|
|
|
8
8
|
import { SpreadsheetRepository } from './adapter-interfaces/SpreadsheetRepository';
|
|
9
9
|
import { ActionAnnouncementUseCase } from './ActionAnnouncementUseCase';
|
|
10
10
|
import { SetWorkflowManagementIssueToStoryUseCase } from './SetWorkflowManagementIssueToStoryUseCase';
|
|
11
|
-
import {
|
|
11
|
+
import { ClearPastNextActionDateHourUseCase } from './ClearPastNextActionDateHourUseCase';
|
|
12
12
|
import { AnalyzeProblemByIssueUseCase } from './AnalyzeProblemByIssueUseCase';
|
|
13
13
|
import { AnalyzeStoriesUseCase } from './AnalyzeStoriesUseCase';
|
|
14
14
|
import { ClearDependedIssueURLUseCase } from './ClearDependedIssueURLUseCase';
|
|
@@ -33,7 +33,7 @@ export class HandleScheduledEventUseCase {
|
|
|
33
33
|
constructor(
|
|
34
34
|
readonly actionAnnouncementUseCase: ActionAnnouncementUseCase,
|
|
35
35
|
readonly setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase,
|
|
36
|
-
readonly
|
|
36
|
+
readonly clearPastNextActionUseCase: ClearPastNextActionDateHourUseCase,
|
|
37
37
|
readonly analyzeProblemByIssueUseCase: AnalyzeProblemByIssueUseCase,
|
|
38
38
|
readonly analyzeStoriesUseCase: AnalyzeStoriesUseCase,
|
|
39
39
|
readonly clearDependedIssueURLUseCase: ClearDependedIssueURLUseCase,
|
|
@@ -241,7 +241,7 @@ ${JSON.stringify(e)}
|
|
|
241
241
|
members: input.workingReport.members,
|
|
242
242
|
manager: input.manager,
|
|
243
243
|
});
|
|
244
|
-
await this.
|
|
244
|
+
await this.clearPastNextActionUseCase.run({
|
|
245
245
|
targetDates: targetDateTimes,
|
|
246
246
|
project,
|
|
247
247
|
issues,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GraphqlProjectItemRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/GraphqlProjectItemRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,EAAE,CAAC;CACL,CAAC;AACF,eAAO,MAAM,mBAAmB,OAAO,CAAC;AACxC,qBAAa,4BAA6B,SAAQ,oBAAoB;IACpE,WAAW,GACT,WAAW,MAAM,EACjB,OAAO,MAAM,EACb,gBAAgB,MAAM,EACtB,aAAa,MAAM,KAClB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA2D5B;IACF,iBAAiB,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,WAAW,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"GraphqlProjectItemRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/GraphqlProjectItemRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAC;AAC3D,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AACvD,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACpC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,EAAE,CAAC;CACL,CAAC;AACF,eAAO,MAAM,mBAAmB,OAAO,CAAC;AACxC,qBAAa,4BAA6B,SAAQ,oBAAoB;IACpE,WAAW,GACT,WAAW,MAAM,EACjB,OAAO,MAAM,EACb,gBAAgB,MAAM,EACtB,aAAa,MAAM,KAClB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA2D5B;IACF,iBAAiB,GAAU,WAAW,MAAM,KAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAyTnE;IACF,gCAAgC,GAC9B,UAAU,MAAM,KACf,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CAGC;IAEF,oBAAoB,GAClB,OAAO,MAAM,EACb,gBAAgB,MAAM,EACtB,aAAa,MAAM,KAClB,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CA4IC;IACF,qBAAqB,GACnB,UAAU,MAAM,KACf,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CA6K5B;IACF,iBAAiB,GAAI,OAAO,MAAM,KAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAQ/D;IAEF,kBAAkB,GAChB,WAAW,MAAM,EACjB,SAAS,MAAM,EACf,QAAQ,MAAM,EACd,OACI;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAChB;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,GAClB;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAChB;QAAE,oBAAoB,EAAE,MAAM,CAAA;KAAE,KACnC,OAAO,CAAC,IAAI,CAAC,CAgCd;IAEF,iBAAiB,GACf,WAAW,MAAM,EACjB,SAAS,MAAM,EACf,QAAQ,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CA+Bd;IACF,sBAAsB,GACpB,SAAS,OAAO,CAAC,IAAI,CAAC,EACtB,SAAS,MAAM,EACf,OAAO,KAAK,CAAC,QAAQ,CAAC,EACtB,MAAM,MAAM,KACX,OAAO,CAAC,IAAI,CAAC,CAEd;IAEF,qBAAqB,GACnB,WAAW,MAAM,EACjB,QAAQ,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CAgCd;IAEF,+BAA+B,GAC7B,UAAU,MAAM,EAChB,WAAW,MAAM,KAChB,OAAO,CAAC,IAAI,CAAC,CASd;CACH"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
3
|
+
import { Project } from '../entities/Project';
|
|
4
|
+
export declare class ClearPastNextActionDateHourUseCase {
|
|
5
|
+
readonly issueRepository: Pick<IssueRepository, 'clearProjectField'>;
|
|
6
|
+
constructor(issueRepository: Pick<IssueRepository, 'clearProjectField'>);
|
|
7
|
+
run: (input: {
|
|
8
|
+
targetDates: Date[];
|
|
9
|
+
project: Project;
|
|
10
|
+
issues: Issue[];
|
|
11
|
+
cacheUsed: boolean;
|
|
12
|
+
}) => Promise<void>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=ClearPastNextActionDateHourUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClearPastNextActionDateHourUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/ClearPastNextActionDateHourUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,qBAAa,kCAAkC;IAE3C,QAAQ,CAAC,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,CAAC;gBAA3D,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,CAAC;IAGtE,GAAG,GAAU,OAAO;QAClB,WAAW,EAAE,IAAI,EAAE,CAAC;QACpB,OAAO,EAAE,OAAO,CAAC;QACjB,MAAM,EAAE,KAAK,EAAE,CAAC;QAChB,SAAS,EAAE,OAAO,CAAC;KACpB,KAAG,OAAO,CAAC,IAAI,CAAC,CAwEf;CACH"}
|
|
@@ -8,7 +8,7 @@ import { DateRepository } from './adapter-interfaces/DateRepository';
|
|
|
8
8
|
import { SpreadsheetRepository } from './adapter-interfaces/SpreadsheetRepository';
|
|
9
9
|
import { ActionAnnouncementUseCase } from './ActionAnnouncementUseCase';
|
|
10
10
|
import { SetWorkflowManagementIssueToStoryUseCase } from './SetWorkflowManagementIssueToStoryUseCase';
|
|
11
|
-
import {
|
|
11
|
+
import { ClearPastNextActionDateHourUseCase } from './ClearPastNextActionDateHourUseCase';
|
|
12
12
|
import { AnalyzeProblemByIssueUseCase } from './AnalyzeProblemByIssueUseCase';
|
|
13
13
|
import { AnalyzeStoriesUseCase } from './AnalyzeStoriesUseCase';
|
|
14
14
|
import { ClearDependedIssueURLUseCase } from './ClearDependedIssueURLUseCase';
|
|
@@ -27,7 +27,7 @@ export declare class ProjectNotFoundError extends Error {
|
|
|
27
27
|
export declare class HandleScheduledEventUseCase {
|
|
28
28
|
readonly actionAnnouncementUseCase: ActionAnnouncementUseCase;
|
|
29
29
|
readonly setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase;
|
|
30
|
-
readonly
|
|
30
|
+
readonly clearPastNextActionUseCase: ClearPastNextActionDateHourUseCase;
|
|
31
31
|
readonly analyzeProblemByIssueUseCase: AnalyzeProblemByIssueUseCase;
|
|
32
32
|
readonly analyzeStoriesUseCase: AnalyzeStoriesUseCase;
|
|
33
33
|
readonly clearDependedIssueURLUseCase: ClearDependedIssueURLUseCase;
|
|
@@ -44,7 +44,7 @@ export declare class HandleScheduledEventUseCase {
|
|
|
44
44
|
readonly spreadsheetRepository: SpreadsheetRepository;
|
|
45
45
|
readonly projectRepository: ProjectRepository;
|
|
46
46
|
readonly issueRepository: IssueRepository;
|
|
47
|
-
constructor(actionAnnouncementUseCase: ActionAnnouncementUseCase, setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase,
|
|
47
|
+
constructor(actionAnnouncementUseCase: ActionAnnouncementUseCase, setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase, clearPastNextActionUseCase: ClearPastNextActionDateHourUseCase, analyzeProblemByIssueUseCase: AnalyzeProblemByIssueUseCase, analyzeStoriesUseCase: AnalyzeStoriesUseCase, clearDependedIssueURLUseCase: ClearDependedIssueURLUseCase, createEstimationIssueUseCase: CreateEstimationIssueUseCase, convertCheckboxToIssueInStoryIssueUseCase: ConvertCheckboxToIssueInStoryIssueUseCase, changeStatusByStoryColorUseCase: ChangeStatusByStoryColorUseCase, setNoStoryIssueToStoryUseCase: SetNoStoryIssueToStoryUseCase, createNewStoryByLabelUseCase: CreateNewStoryByLabelUseCase, assignNoAssigneeIssueToManagerUseCase: AssignNoAssigneeIssueToManagerUseCase, updateIssueStatusByLabelUseCase: UpdateIssueStatusByLabelUseCase, startPreparationUseCase: StartPreparationUseCase, notifyFinishedIssuePreparationUseCase: NotifyFinishedIssuePreparationUseCase, dateRepository: DateRepository, spreadsheetRepository: SpreadsheetRepository, projectRepository: ProjectRepository, issueRepository: IssueRepository);
|
|
48
48
|
run: (input: {
|
|
49
49
|
projectName: string;
|
|
50
50
|
org: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HandleScheduledEventUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/HandleScheduledEventUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACnF,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,wCAAwC,EAAE,MAAM,4CAA4C,CAAC;AACtG,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"HandleScheduledEventUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/HandleScheduledEventUseCase.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { Issue } from '../entities/Issue';
|
|
2
|
-
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
3
|
-
import { Project } from '../entities/Project';
|
|
4
|
-
|
|
5
|
-
export class ClearNextActionHourUseCase {
|
|
6
|
-
constructor(
|
|
7
|
-
readonly issueRepository: Pick<IssueRepository, 'clearProjectField'>,
|
|
8
|
-
) {}
|
|
9
|
-
|
|
10
|
-
run = async (input: {
|
|
11
|
-
targetDates: Date[];
|
|
12
|
-
project: Project;
|
|
13
|
-
issues: Issue[];
|
|
14
|
-
cacheUsed: boolean;
|
|
15
|
-
}): Promise<void> => {
|
|
16
|
-
const nextActionHour = input.project.nextActionHour;
|
|
17
|
-
if (!nextActionHour) {
|
|
18
|
-
return;
|
|
19
|
-
}
|
|
20
|
-
const nextActionDate = input.project.nextActionDate;
|
|
21
|
-
const targetDates = input.targetDates
|
|
22
|
-
.filter((targetDate) => targetDate.getMinutes() === 45)
|
|
23
|
-
.reverse();
|
|
24
|
-
if (targetDates.length === 0) {
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
const targetDate = new Date(
|
|
28
|
-
targetDates[targetDates.length - 1].getTime() + 5 * 60 * 1000,
|
|
29
|
-
);
|
|
30
|
-
const targetHour = targetDate.getHours() + 1;
|
|
31
|
-
const isTargetIssue = (issue: Issue): boolean => {
|
|
32
|
-
return (
|
|
33
|
-
issue.nextActionHour !== null &&
|
|
34
|
-
issue.nextActionHour <= targetHour &&
|
|
35
|
-
(issue.nextActionDate === null ||
|
|
36
|
-
issue.nextActionDate.getTime() <= targetDate.getTime()) &&
|
|
37
|
-
issue.state === 'OPEN'
|
|
38
|
-
);
|
|
39
|
-
};
|
|
40
|
-
for (const issue of input.issues) {
|
|
41
|
-
if (!isTargetIssue(issue)) {
|
|
42
|
-
continue;
|
|
43
|
-
}
|
|
44
|
-
await this.issueRepository.clearProjectField(
|
|
45
|
-
input.project,
|
|
46
|
-
nextActionHour.fieldId,
|
|
47
|
-
issue,
|
|
48
|
-
);
|
|
49
|
-
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
50
|
-
if (!nextActionDate) {
|
|
51
|
-
continue;
|
|
52
|
-
}
|
|
53
|
-
await this.issueRepository.clearProjectField(
|
|
54
|
-
input.project,
|
|
55
|
-
nextActionDate.fieldId,
|
|
56
|
-
issue,
|
|
57
|
-
);
|
|
58
|
-
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
}
|