github-issue-tower-defence-management 1.1.0 → 1.2.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/commit-lint.yml +0 -2
- package/.github/workflows/empty-format-test-job.yml +28 -0
- package/.github/workflows/test.yml +1 -0
- package/CHANGELOG.md +20 -41
- package/bin/adapter/entry-points/cli/index.js +0 -0
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js +127 -16
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js.map +1 -1
- package/bin/adapter/repositories/BaseGitHubRepository.js +3 -2
- package/bin/adapter/repositories/BaseGitHubRepository.js.map +1 -1
- package/bin/adapter/repositories/GraphqlProjectRepository.js +16 -0
- package/bin/adapter/repositories/GraphqlProjectRepository.js.map +1 -1
- package/bin/adapter/repositories/LocalStorageRepository.js +6 -0
- package/bin/adapter/repositories/LocalStorageRepository.js.map +1 -1
- package/bin/adapter/repositories/SystemDateRepository.js +15 -3
- package/bin/adapter/repositories/SystemDateRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js +61 -9
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/CheerioIssueRepository.js +28 -2
- package/bin/adapter/repositories/issue/CheerioIssueRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js +7 -0
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js.map +1 -1
- package/bin/adapter/repositories/issue/RestIssueRepository.js +1 -0
- package/bin/adapter/repositories/issue/RestIssueRepository.js.map +1 -1
- package/bin/adapter/repositories/utils.js +1 -6
- package/bin/adapter/repositories/utils.js.map +1 -1
- package/bin/domain/usecases/AnalyzeProblemByIssueUseCase.js +98 -65
- package/bin/domain/usecases/AnalyzeProblemByIssueUseCase.js.map +1 -1
- package/bin/domain/usecases/AnalyzeStoriesUseCase.js +108 -0
- package/bin/domain/usecases/AnalyzeStoriesUseCase.js.map +1 -0
- package/bin/domain/usecases/ClearDependedIssueURLUseCase.js +66 -0
- package/bin/domain/usecases/ClearDependedIssueURLUseCase.js.map +1 -0
- package/bin/domain/usecases/CreateEstimationIssueUseCase.js +100 -0
- package/bin/domain/usecases/CreateEstimationIssueUseCase.js.map +1 -0
- package/bin/domain/usecases/HandleScheduledEventUseCase.js +124 -2
- package/bin/domain/usecases/HandleScheduledEventUseCase.js.map +1 -1
- package/bin/domain/usecases/utils.js +24 -0
- package/bin/domain/usecases/utils.js.map +1 -0
- package/package.json +2 -2
- package/src/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.ts +73 -7
- package/src/adapter/repositories/AxiosSlackRepository.test.ts +3 -0
- package/src/adapter/repositories/BaseGitHubRepository.test.ts +3 -1
- package/src/adapter/repositories/BaseGitHubRepository.ts +3 -1
- package/src/adapter/repositories/GraphqlProjectRepository.test.ts +5 -1
- package/src/adapter/repositories/GraphqlProjectRepository.ts +25 -0
- package/src/adapter/repositories/LocalStorageCacheRepository.test.ts +1 -0
- package/src/adapter/repositories/LocalStorageRepository.ts +6 -0
- package/src/adapter/repositories/SystemDateRepository.ts +17 -3
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.test.ts +8 -0
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts +103 -16
- package/src/adapter/repositories/issue/ApiV3IssueRepository.test.ts +3 -0
- package/src/adapter/repositories/issue/CheerioIssueRepository.test.ts +10 -0
- package/src/adapter/repositories/issue/CheerioIssueRepository.ts +37 -1
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.test.ts +7 -1
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.ts +15 -0
- package/src/adapter/repositories/issue/InternalGraphqlIssueRepository.test.ts +7 -1
- package/src/adapter/repositories/issue/RestIssueRepository.test.ts +3 -0
- package/src/adapter/repositories/issue/RestIssueRepository.ts +5 -2
- package/src/adapter/repositories/utils.test.ts +16 -1
- package/src/adapter/repositories/utils.ts +1 -6
- package/src/domain/entities/Issue.ts +4 -0
- package/src/domain/entities/Project.ts +15 -4
- package/src/domain/usecases/AnalyzeProblemByIssueUseCase.ts +151 -115
- package/src/domain/usecases/AnalyzeStoriesUseCase.ts +167 -0
- package/src/domain/usecases/ClearDependedIssueURLUseCase.test.ts +840 -0
- package/src/domain/usecases/ClearDependedIssueURLUseCase.ts +107 -0
- package/src/domain/usecases/CreateEstimationIssueUseCase.ts +157 -0
- package/src/domain/usecases/GenerateWorkingTimeReportUseCase.test.ts +8 -0
- package/src/domain/usecases/HandleScheduledEventUseCase.ts +171 -2
- package/src/domain/usecases/adapter-interfaces/DateRepository.ts +2 -0
- package/src/domain/usecases/adapter-interfaces/IssueRepository.ts +8 -1
- package/src/domain/usecases/utils.ts +28 -0
- package/types/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.d.ts.map +1 -1
- package/types/adapter/repositories/BaseGitHubRepository.d.ts +3 -1
- package/types/adapter/repositories/BaseGitHubRepository.d.ts.map +1 -1
- package/types/adapter/repositories/GraphqlProjectRepository.d.ts.map +1 -1
- package/types/adapter/repositories/LocalStorageRepository.d.ts +1 -0
- package/types/adapter/repositories/LocalStorageRepository.d.ts.map +1 -1
- package/types/adapter/repositories/SystemDateRepository.d.ts +2 -0
- package/types/adapter/repositories/SystemDateRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts +14 -5
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/CheerioIssueRepository.d.ts +7 -1
- package/types/adapter/repositories/issue/CheerioIssueRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts +3 -0
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts.map +1 -1
- package/types/adapter/repositories/issue/RestIssueRepository.d.ts +1 -1
- package/types/adapter/repositories/issue/RestIssueRepository.d.ts.map +1 -1
- package/types/adapter/repositories/utils.d.ts.map +1 -1
- package/types/domain/entities/Issue.d.ts +4 -0
- package/types/domain/entities/Issue.d.ts.map +1 -1
- package/types/domain/entities/Project.d.ts +15 -4
- package/types/domain/entities/Project.d.ts.map +1 -1
- package/types/domain/usecases/AnalyzeProblemByIssueUseCase.d.ts +13 -8
- package/types/domain/usecases/AnalyzeProblemByIssueUseCase.d.ts.map +1 -1
- package/types/domain/usecases/AnalyzeStoriesUseCase.d.ts +29 -0
- package/types/domain/usecases/AnalyzeStoriesUseCase.d.ts.map +1 -0
- package/types/domain/usecases/ClearDependedIssueURLUseCase.d.ts +13 -0
- package/types/domain/usecases/ClearDependedIssueURLUseCase.d.ts.map +1 -0
- package/types/domain/usecases/CreateEstimationIssueUseCase.d.ts +33 -0
- package/types/domain/usecases/CreateEstimationIssueUseCase.d.ts.map +1 -0
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts +26 -2
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts.map +1 -1
- package/types/domain/usecases/adapter-interfaces/DateRepository.d.ts +2 -0
- package/types/domain/usecases/adapter-interfaces/DateRepository.d.ts.map +1 -1
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts +3 -1
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts.map +1 -1
- package/types/domain/usecases/utils.d.ts +5 -0
- package/types/domain/usecases/utils.d.ts.map +1 -0
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AnalyzeStoriesUseCase = void 0;
|
|
4
|
+
const utils_1 = require("./utils");
|
|
5
|
+
class AnalyzeStoriesUseCase {
|
|
6
|
+
constructor(issueRepository, dateRepository) {
|
|
7
|
+
this.issueRepository = issueRepository;
|
|
8
|
+
this.dateRepository = dateRepository;
|
|
9
|
+
this.run = async (input) => {
|
|
10
|
+
const story = input.project.story;
|
|
11
|
+
if (!story ||
|
|
12
|
+
!input.targetDates.find((targetDate) => targetDate.getHours() === 7 && targetDate.getMinutes() === 0)) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
const phases = new Map();
|
|
16
|
+
phases.set('story:phase:requirement:opened', []);
|
|
17
|
+
phases.set('story:phase:requirement:finished-prd', []);
|
|
18
|
+
phases.set('story:phase:requirement:finished-figma', []);
|
|
19
|
+
phases.set('story:phase:requirement:finished-testcase', []);
|
|
20
|
+
phases.set('story:phase:requirement:finished-deviding-task', []);
|
|
21
|
+
phases.set('story:phase:implementation-finished', []);
|
|
22
|
+
phases.set('story:phase:finished-qa', []);
|
|
23
|
+
phases.set('others', []);
|
|
24
|
+
for (const story of input.project.story?.stories || []) {
|
|
25
|
+
const storyIssue = input.issues.find((issue) => story.name.startsWith(issue.title));
|
|
26
|
+
if (story.name.startsWith('regular / ')) {
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
else if (!storyIssue) {
|
|
30
|
+
throw new Error(`Story issue not found: ${story.name}`);
|
|
31
|
+
}
|
|
32
|
+
const storyIssueObject = {
|
|
33
|
+
...storyIssue,
|
|
34
|
+
...story,
|
|
35
|
+
};
|
|
36
|
+
if (storyIssue.status === input.disabledStatus) {
|
|
37
|
+
phases.get('others')?.push(storyIssueObject);
|
|
38
|
+
}
|
|
39
|
+
else if (storyIssue.labels.includes('story:phase:finished-qa')) {
|
|
40
|
+
phases.get('story:phase:finished-qa')?.push(storyIssueObject);
|
|
41
|
+
}
|
|
42
|
+
else if (storyIssue.labels.includes('story:phase:implementation-finished')) {
|
|
43
|
+
phases
|
|
44
|
+
.get('story:phase:implementation-finished')
|
|
45
|
+
?.push(storyIssueObject);
|
|
46
|
+
}
|
|
47
|
+
else if (storyIssue.labels.includes('story:phase:requirement:finished-deviding-task')) {
|
|
48
|
+
phases
|
|
49
|
+
.get('story:phase:requirement:finished-deviding-task')
|
|
50
|
+
?.push(storyIssueObject);
|
|
51
|
+
}
|
|
52
|
+
else if (storyIssue.labels.includes('story:phase:requirement:finished-testcase')) {
|
|
53
|
+
phases
|
|
54
|
+
.get('story:phase:requirement:finished-testcase')
|
|
55
|
+
?.push(storyIssueObject);
|
|
56
|
+
}
|
|
57
|
+
else if (storyIssue.labels.includes('story:phase:requirement:finished-figma')) {
|
|
58
|
+
phases
|
|
59
|
+
.get('story:phase:requirement:finished-figma')
|
|
60
|
+
?.push(storyIssueObject);
|
|
61
|
+
}
|
|
62
|
+
else if (storyIssue.labels.includes('story:phase:requirement:finished-prd')) {
|
|
63
|
+
phases
|
|
64
|
+
.get('story:phase:requirement:finished-prd')
|
|
65
|
+
?.push(storyIssueObject);
|
|
66
|
+
}
|
|
67
|
+
else if (storyIssue.labels.includes('story:phase:requirement:opened')) {
|
|
68
|
+
phases.get('story:phase:requirement:opened')?.push(storyIssueObject);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
phases.get('others')?.push(storyIssueObject);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
await this.issueRepository.createNewIssue(input.org, input.repo, `Story progress`, this.createSummaryIssueBody(phases, input.urlOfStoryView), [input.manager], ['story:workflow-management']);
|
|
75
|
+
};
|
|
76
|
+
this.createSummaryIssueBody = (summaryStoryIssue, urlOfStoryView) => {
|
|
77
|
+
return `
|
|
78
|
+
|
|
79
|
+
${Array.from(summaryStoryIssue.keys())
|
|
80
|
+
.map((key) => {
|
|
81
|
+
return `
|
|
82
|
+
## ${key}
|
|
83
|
+
${summaryStoryIssue
|
|
84
|
+
.get(key)
|
|
85
|
+
?.map((issue) => {
|
|
86
|
+
const storyColor = `:${issue.color === 'BLUE' ? 'large_' : ''}${issue.color === 'GRAY' ? 'black' : issue.color === 'PINK' ? 'red' : issue.color.toLowerCase()}_circle:`;
|
|
87
|
+
const stakeHolder = issue.labels.find((label) => label === 'story:stakeholder:user')
|
|
88
|
+
? `:bust_in_silhouette:`
|
|
89
|
+
: issue.labels.find((label) => label === 'story:stakeholder:engineer')
|
|
90
|
+
? `:gear:`
|
|
91
|
+
: issue.labels.find((label) => label === 'story:stakeholder:cs-team')
|
|
92
|
+
? `:headphones:`
|
|
93
|
+
: issue.labels.find((label) => label === 'story:stakeholder:potential-user')
|
|
94
|
+
? ':busts_in_silhouette:'
|
|
95
|
+
: issue.labels.find((label) => label === 'story:stakeholder:sales-team')
|
|
96
|
+
? ':briefcase:'
|
|
97
|
+
: ':question:';
|
|
98
|
+
const boardUrl = `${urlOfStoryView}?filterQuery=story%3A%22${(0, utils_1.encodeForURI)(issue.story)}%22+is%3Aopen`;
|
|
99
|
+
return `- ${storyColor} ${stakeHolder} ${issue.url} [:memo:](${boardUrl})`;
|
|
100
|
+
})
|
|
101
|
+
.join('\n')}`;
|
|
102
|
+
})
|
|
103
|
+
.join('\n')}`;
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
exports.AnalyzeStoriesUseCase = AnalyzeStoriesUseCase;
|
|
108
|
+
//# sourceMappingURL=AnalyzeStoriesUseCase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnalyzeStoriesUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/AnalyzeStoriesUseCase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ClearDependedIssueURLUseCase = void 0;
|
|
4
|
+
class ClearDependedIssueURLUseCase {
|
|
5
|
+
constructor(issueRepository) {
|
|
6
|
+
this.issueRepository = issueRepository;
|
|
7
|
+
this.run = async (input) => {
|
|
8
|
+
const dependedIssueUrlSeparatedByComma = input.project.dependedIssueUrlSeparatedByComma;
|
|
9
|
+
if (!dependedIssueUrlSeparatedByComma || input.cacheUsed) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
for (const issue of input.issues) {
|
|
13
|
+
if (issue.dependedIssueUrls.length <= 0 || issue.isClosed) {
|
|
14
|
+
continue;
|
|
15
|
+
}
|
|
16
|
+
const circularDependedIssueUrls = issue.dependedIssueUrls.filter((dependedIssueUrl) => {
|
|
17
|
+
// get all depended issues circularly
|
|
18
|
+
const circularDependedIssues = new Set();
|
|
19
|
+
const stack = [dependedIssueUrl];
|
|
20
|
+
while (stack.length > 0) {
|
|
21
|
+
const url = stack.pop();
|
|
22
|
+
if (!url) {
|
|
23
|
+
throw new Error('url is undefined');
|
|
24
|
+
}
|
|
25
|
+
if (circularDependedIssues.has(url)) {
|
|
26
|
+
continue;
|
|
27
|
+
}
|
|
28
|
+
circularDependedIssues.add(url);
|
|
29
|
+
const dependedIssue = input.issues.find((issue) => issue.url === url);
|
|
30
|
+
if (!dependedIssue) {
|
|
31
|
+
continue;
|
|
32
|
+
}
|
|
33
|
+
stack.push(...dependedIssue.dependedIssueUrls);
|
|
34
|
+
}
|
|
35
|
+
return circularDependedIssues.has(issue.url);
|
|
36
|
+
});
|
|
37
|
+
if (circularDependedIssueUrls.length > 0) {
|
|
38
|
+
await this.issueRepository.clearProjectField(input.project, dependedIssueUrlSeparatedByComma.fieldId, issue);
|
|
39
|
+
await this.issueRepository.createComment(issue, `Circular dependency removed:
|
|
40
|
+
${circularDependedIssueUrls.map((url) => `- ${url}`).join('\n')}`);
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
const remainingDependedIssueUrls = issue.dependedIssueUrls.filter((dependedIssueUrl) => input.issues.some((issue) => {
|
|
44
|
+
const r = issue.url === dependedIssueUrl && !issue.isClosed;
|
|
45
|
+
return r;
|
|
46
|
+
}));
|
|
47
|
+
const closedDependedIssueUrls = issue.dependedIssueUrls.filter((dependedIssueUrl) => remainingDependedIssueUrls.indexOf(dependedIssueUrl) === -1);
|
|
48
|
+
if (remainingDependedIssueUrls.length === issue.dependedIssueUrls.length) {
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
if (remainingDependedIssueUrls.length === 0) {
|
|
52
|
+
await this.issueRepository.clearProjectField(input.project, dependedIssueUrlSeparatedByComma.fieldId, issue);
|
|
53
|
+
await this.issueRepository.createComment(issue, `Closed all depended issues:
|
|
54
|
+
${closedDependedIssueUrls.map((url) => `- ${url}`).join('\n')}`);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
await this.issueRepository.updateProjectTextField(input.project, dependedIssueUrlSeparatedByComma.fieldId, issue, remainingDependedIssueUrls.join(','));
|
|
58
|
+
await this.issueRepository.createComment(issue, `Closed depended issues:
|
|
59
|
+
${closedDependedIssueUrls.map((url) => `- ${url}`).join('\n')}`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.ClearDependedIssueURLUseCase = ClearDependedIssueURLUseCase;
|
|
66
|
+
//# sourceMappingURL=ClearDependedIssueURLUseCase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClearDependedIssueURLUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/ClearDependedIssueURLUseCase.ts"],"names":[],"mappings":";;;AAIA,MAAa,4BAA4B;IACvC,YACW,eAGR;QAHQ,oBAAe,GAAf,eAAe,CAGvB;QAGH,QAAG,GAAG,KAAK,EAAE,KAIZ,EAAiB,EAAE;YAClB,MAAM,gCAAgC,GACpC,KAAK,CAAC,OAAO,CAAC,gCAAgC,CAAC;YACjD,IAAI,CAAC,gCAAgC,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBACzD,OAAO;YACT,CAAC;YACD,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjC,IAAI,KAAK,CAAC,iBAAiB,CAAC,MAAM,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;oBAC1D,SAAS;gBACX,CAAC;gBACD,MAAM,yBAAyB,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAC9D,CAAC,gBAAgB,EAAE,EAAE;oBACnB,qCAAqC;oBACrC,MAAM,sBAAsB,GAAG,IAAI,GAAG,EAAU,CAAC;oBACjD,MAAM,KAAK,GAAG,CAAC,gBAAgB,CAAC,CAAC;oBACjC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBACxB,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,EAAE,CAAC;wBACxB,IAAI,CAAC,GAAG,EAAE,CAAC;4BACT,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;wBACtC,CAAC;wBACD,IAAI,sBAAsB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;4BACpC,SAAS;wBACX,CAAC;wBACD,sBAAsB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;wBAChC,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CACrC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,KAAK,GAAG,CAC7B,CAAC;wBACF,IAAI,CAAC,aAAa,EAAE,CAAC;4BACnB,SAAS;wBACX,CAAC;wBACD,KAAK,CAAC,IAAI,CAAC,GAAG,aAAa,CAAC,iBAAiB,CAAC,CAAC;oBACjD,CAAC;oBACD,OAAO,sBAAsB,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBAC/C,CAAC,CACF,CAAC;gBACF,IAAI,yBAAyB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzC,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAC1C,KAAK,CAAC,OAAO,EACb,gCAAgC,CAAC,OAAO,EACxC,KAAK,CACN,CAAC;oBACF,MAAM,IAAI,CAAC,eAAe,CAAC,aAAa,CACtC,KAAK,EACL;EACR,yBAAyB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACxD,CAAC;oBACF,SAAS;gBACX,CAAC;gBACD,MAAM,0BAA0B,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAC/D,CAAC,gBAAgB,EAAE,EAAE,CACnB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;oBAC1B,MAAM,CAAC,GAAG,KAAK,CAAC,GAAG,KAAK,gBAAgB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;oBAC5D,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC,CACL,CAAC;gBACF,MAAM,uBAAuB,GAAG,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAC5D,CAAC,gBAAgB,EAAE,EAAE,CACnB,0BAA0B,CAAC,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAC9D,CAAC;gBACF,IACE,0BAA0B,CAAC,MAAM,KAAK,KAAK,CAAC,iBAAiB,CAAC,MAAM,EACpE,CAAC;oBACD,SAAS;gBACX,CAAC;gBACD,IAAI,0BAA0B,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC5C,MAAM,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAC1C,KAAK,CAAC,OAAO,EACb,gCAAgC,CAAC,OAAO,EACxC,KAAK,CACN,CAAC;oBACF,MAAM,IAAI,CAAC,eAAe,CAAC,aAAa,CACtC,KAAK,EACL;EACR,uBAAuB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACtD,CAAC;gBACJ,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,CAAC,eAAe,CAAC,sBAAsB,CAC/C,KAAK,CAAC,OAAO,EACb,gCAAgC,CAAC,OAAO,EACxC,KAAK,EACL,0BAA0B,CAAC,IAAI,CAAC,GAAG,CAAC,CACrC,CAAC;oBACF,MAAM,IAAI,CAAC,eAAe,CAAC,aAAa,CACtC,KAAK,EACL;EACR,uBAAuB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACtD,CAAC;gBACJ,CAAC;YACH,CAAC;QACH,CAAC,CAAC;IA/FC,CAAC;CAgGL;AAtGD,oEAsGC"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CreateEstimationIssueUseCase = void 0;
|
|
4
|
+
const utils_1 = require("./utils");
|
|
5
|
+
class CreateEstimationIssueUseCase {
|
|
6
|
+
constructor(issueRepository, dateRepository) {
|
|
7
|
+
this.issueRepository = issueRepository;
|
|
8
|
+
this.dateRepository = dateRepository;
|
|
9
|
+
this.run = async (input) => {
|
|
10
|
+
const story = input.project.story;
|
|
11
|
+
if (!story ||
|
|
12
|
+
!input.targetDates.find((targetDate) => targetDate.getHours() === 7 && targetDate.getMinutes() === 0)) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
for (const story of input.project.story?.stories || []) {
|
|
16
|
+
const storyIssue = input.issues.find((issue) => story.name.startsWith(issue.title));
|
|
17
|
+
const storyObject = input.storyObjectMap.get(story.name);
|
|
18
|
+
if (story.name.startsWith('regular / ')) {
|
|
19
|
+
continue;
|
|
20
|
+
}
|
|
21
|
+
else if (!storyIssue || !storyObject) {
|
|
22
|
+
throw new Error(`Story issue not found: ${story.name}`);
|
|
23
|
+
}
|
|
24
|
+
else if (!storyIssue.labels.includes('story:action:schedule-control')) {
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
const assignees = new Set();
|
|
28
|
+
for (const issueInStory of storyObject.issues) {
|
|
29
|
+
if (issueInStory.isClosed ||
|
|
30
|
+
issueInStory.isPr ||
|
|
31
|
+
issueInStory.labels.includes('story') ||
|
|
32
|
+
issueInStory.status === input.disabledStatus) {
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
for (const assignee of issueInStory.assignees) {
|
|
36
|
+
assignees.add(assignee);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
for (const assignee of assignees) {
|
|
40
|
+
await this.issueRepository.createNewIssue(input.org, input.repo, `Put estimation fields of \`${story.name}\` for ${assignee} :pray:`, this.createEstimationIssueBody({ storyIssue, issues: storyObject.issues }, input.urlOfStoryView, input.project), [assignee], ['story:workflow-management']);
|
|
41
|
+
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
this.createEstimationIssueBody = (storyObject, urlObStoryView, project) => {
|
|
46
|
+
return `
|
|
47
|
+
This issue is experimental workflow :pray:
|
|
48
|
+
- Target story: ${storyObject.storyIssue.url}
|
|
49
|
+
|
|
50
|
+
## Tasks
|
|
51
|
+
- [ ] 1. Fill \`50% confidence completion date\` to all issues on ${urlObStoryView}?filterQuery=story%3A%22${(0, utils_1.encodeForURI)(storyObject.storyIssue.story)}%22+is%3Aopen+no%3A%22${(0, utils_1.encodeForURI)(project.completionDate50PercentConfidence?.name)}%22+assignee%3A%40me
|
|
52
|
+
- [ ] 2. Fill \`Remaining Estimation (minutes)\` to all issues on ${urlObStoryView}?filterQuery=story%3A%22${(0, utils_1.encodeForURI)(storyObject.storyIssue.story)}%22+is%3Aopen+no%3A%22${(0, utils_1.encodeForURI)(project.remainingEstimationMinutes?.name)}%22+assignee%3A%40me
|
|
53
|
+
- [ ] 3. Take screenshot and comment to this issue about ${urlObStoryView}?filterQuery=story%3A%22${(0, utils_1.encodeForURI)(storyObject.storyIssue.story)}%22+is%3Aopen+assignee%3A%40me
|
|
54
|
+
- [ ] 4. Close
|
|
55
|
+
|
|
56
|
+
⚡⚡⚡
|
|
57
|
+
Dont forget, it's just 50% confidence :pray:
|
|
58
|
+
This is the date you think you have a 50-50 chance of completing the task. Think of it as "if everything goes normally (not best-case, not worst-case), when would this be done?"
|
|
59
|
+
|
|
60
|
+
Important: You will NOT be held accountable if you miss this date. We're using this for project planning, not for performance evaluation. We manage delays and risks at the project level with buffers.
|
|
61
|
+
|
|
62
|
+
Please give your honest estimate without adding any "just in case" padding. Focus only on the actual work time needed, assuming things go smoothly but not perfectly.
|
|
63
|
+
|
|
64
|
+
That's all! Let me know if you have any questions.
|
|
65
|
+
⚡⚡⚡
|
|
66
|
+
`;
|
|
67
|
+
};
|
|
68
|
+
this.createSummaryIssueBody = (summaryStoryIssue, urlOfStoryView) => {
|
|
69
|
+
return `
|
|
70
|
+
|
|
71
|
+
${Array.from(summaryStoryIssue.keys())
|
|
72
|
+
.map((key) => {
|
|
73
|
+
return `
|
|
74
|
+
## ${key}
|
|
75
|
+
${summaryStoryIssue
|
|
76
|
+
.get(key)
|
|
77
|
+
?.map((issue) => {
|
|
78
|
+
const storyColor = `:${issue.color === 'BLUE' ? 'large_' : ''}${issue.color === 'GRAY' ? 'black' : issue.color === 'PINK' ? 'red' : issue.color.toLowerCase()}_circle:`;
|
|
79
|
+
const stakeHolder = issue.labels.find((label) => label === 'story:stakeholder:user')
|
|
80
|
+
? `:bust_in_silhouette:`
|
|
81
|
+
: issue.labels.find((label) => label === 'story:stakeholder:engineer')
|
|
82
|
+
? `:gear:`
|
|
83
|
+
: issue.labels.find((label) => label === 'story:stakeholder:cs-team')
|
|
84
|
+
? `:headphones:`
|
|
85
|
+
: issue.labels.find((label) => label === 'story:stakeholder:potential-user')
|
|
86
|
+
? ':busts_in_silhouette:'
|
|
87
|
+
: issue.labels.find((label) => label === 'story:stakeholder:sales-team')
|
|
88
|
+
? ':briefcase:'
|
|
89
|
+
: ':question:';
|
|
90
|
+
const boardUrl = `${urlOfStoryView}?filterQuery=story%3A%22${(0, utils_1.encodeForURI)(issue.story)}%22+is%3Aopen`;
|
|
91
|
+
return `- ${storyColor} ${stakeHolder} ${issue.url} [:memo:](${boardUrl})`;
|
|
92
|
+
})
|
|
93
|
+
.join('\n')}`;
|
|
94
|
+
})
|
|
95
|
+
.join('\n')}`;
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
exports.CreateEstimationIssueUseCase = CreateEstimationIssueUseCase;
|
|
100
|
+
//# sourceMappingURL=CreateEstimationIssueUseCase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CreateEstimationIssueUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/CreateEstimationIssueUseCase.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,12 +9,15 @@ class ProjectNotFoundError extends Error {
|
|
|
9
9
|
}
|
|
10
10
|
exports.ProjectNotFoundError = ProjectNotFoundError;
|
|
11
11
|
class HandleScheduledEventUseCase {
|
|
12
|
-
constructor(generateWorkingTimeReportUseCase, actionAnnouncementUseCase, setWorkflowManagementIssueToStoryUseCase, clearNextActionHourUseCase, analyzeProblemByIssueUseCase, dateRepository, spreadsheetRepository, projectRepository, issueRepository) {
|
|
12
|
+
constructor(generateWorkingTimeReportUseCase, actionAnnouncementUseCase, setWorkflowManagementIssueToStoryUseCase, clearNextActionHourUseCase, analyzeProblemByIssueUseCase, analyzeStoriesUseCase, clearDependedIssueURLUseCase, createEstimationIssueUseCase, dateRepository, spreadsheetRepository, projectRepository, issueRepository) {
|
|
13
13
|
this.generateWorkingTimeReportUseCase = generateWorkingTimeReportUseCase;
|
|
14
14
|
this.actionAnnouncementUseCase = actionAnnouncementUseCase;
|
|
15
15
|
this.setWorkflowManagementIssueToStoryUseCase = setWorkflowManagementIssueToStoryUseCase;
|
|
16
16
|
this.clearNextActionHourUseCase = clearNextActionHourUseCase;
|
|
17
17
|
this.analyzeProblemByIssueUseCase = analyzeProblemByIssueUseCase;
|
|
18
|
+
this.analyzeStoriesUseCase = analyzeStoriesUseCase;
|
|
19
|
+
this.clearDependedIssueURLUseCase = clearDependedIssueURLUseCase;
|
|
20
|
+
this.createEstimationIssueUseCase = createEstimationIssueUseCase;
|
|
18
21
|
this.dateRepository = dateRepository;
|
|
19
22
|
this.spreadsheetRepository = spreadsheetRepository;
|
|
20
23
|
this.projectRepository = projectRepository;
|
|
@@ -31,6 +34,53 @@ class HandleScheduledEventUseCase {
|
|
|
31
34
|
const now = await this.dateRepository.now();
|
|
32
35
|
const allowIssueCacheMinutes = 60;
|
|
33
36
|
const { issues, cacheUsed } = await this.issueRepository.getAllIssues(projectId, allowIssueCacheMinutes);
|
|
37
|
+
const storyIssues = await this.storyIssues({
|
|
38
|
+
project,
|
|
39
|
+
issues,
|
|
40
|
+
});
|
|
41
|
+
for (const storyObject of storyIssues.values()) {
|
|
42
|
+
const projectStory = project.story;
|
|
43
|
+
if (!projectStory) {
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
if (storyObject.storyIssue ||
|
|
47
|
+
storyObject.story.name.startsWith('regular / ')) {
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
const issueNumber = await this.issueRepository.createNewIssue(input.org, input.workingReport.repo, storyObject.story.name, storyObject.story.description, [input.manager], ['story']);
|
|
51
|
+
const issueUrl = `https://github.com/${input.org}/${input.workingReport.repo}/issues/${issueNumber}`;
|
|
52
|
+
let issue = null;
|
|
53
|
+
for (let i = 0; i < 3; i++) {
|
|
54
|
+
await new Promise((resolve) => setTimeout(resolve, 30 * 1000));
|
|
55
|
+
issue = await this.issueRepository.getIssueByUrl(issueUrl);
|
|
56
|
+
if (!issue) {
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
else if (!issue.itemId) {
|
|
60
|
+
continue;
|
|
61
|
+
}
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
if (!issue) {
|
|
65
|
+
throw new Error(`Issue not found. URL: ${issueUrl}`);
|
|
66
|
+
}
|
|
67
|
+
else if (!issue.itemId) {
|
|
68
|
+
throw new Error(`Issue itemId not found. URL: ${issueUrl}`);
|
|
69
|
+
}
|
|
70
|
+
await this.issueRepository.updateStory({ ...project, story: projectStory }, issue, storyObject.story.id);
|
|
71
|
+
await new Promise((resolve) => setTimeout(resolve, 10 * 1000));
|
|
72
|
+
const newIssue = await this.issueRepository.getIssueByUrl(issueUrl);
|
|
73
|
+
if (!newIssue) {
|
|
74
|
+
throw new Error(`Issue not found. URL: ${issueUrl}`);
|
|
75
|
+
}
|
|
76
|
+
storyObject.storyIssue = newIssue;
|
|
77
|
+
issues.push(newIssue);
|
|
78
|
+
storyObject.issues.push({
|
|
79
|
+
...newIssue,
|
|
80
|
+
totalWorkingTime: 0,
|
|
81
|
+
totalWorkingTimeByAssignee: new Map(),
|
|
82
|
+
});
|
|
83
|
+
}
|
|
34
84
|
const targetDateTimes = await this.findTargetDateAndUpdateLastExecutionDateTime(input.workingReport.spreadsheetUrl, now);
|
|
35
85
|
for (const targetDateTime of targetDateTimes) {
|
|
36
86
|
await this.runForTargetDateTime({
|
|
@@ -48,8 +98,11 @@ class HandleScheduledEventUseCase {
|
|
|
48
98
|
issues,
|
|
49
99
|
cacheUsed,
|
|
50
100
|
manager: input.manager,
|
|
101
|
+
members: input.workingReport.members,
|
|
51
102
|
org: input.org,
|
|
52
103
|
repo: input.workingReport.repo,
|
|
104
|
+
storyObjectMap: storyIssues,
|
|
105
|
+
disabledStatus: input.disabledStatus,
|
|
53
106
|
});
|
|
54
107
|
await this.actionAnnouncementUseCase.run({
|
|
55
108
|
targetDates: targetDateTimes,
|
|
@@ -71,7 +124,35 @@ class HandleScheduledEventUseCase {
|
|
|
71
124
|
issues,
|
|
72
125
|
cacheUsed,
|
|
73
126
|
});
|
|
74
|
-
|
|
127
|
+
await this.analyzeStoriesUseCase.run({
|
|
128
|
+
targetDates: targetDateTimes,
|
|
129
|
+
project,
|
|
130
|
+
issues,
|
|
131
|
+
cacheUsed,
|
|
132
|
+
...input,
|
|
133
|
+
manager: input.manager,
|
|
134
|
+
org: input.org,
|
|
135
|
+
repo: input.workingReport.repo,
|
|
136
|
+
storyObjectMap: storyIssues,
|
|
137
|
+
});
|
|
138
|
+
await this.clearDependedIssueURLUseCase.run({
|
|
139
|
+
project,
|
|
140
|
+
issues,
|
|
141
|
+
cacheUsed,
|
|
142
|
+
});
|
|
143
|
+
await this.createEstimationIssueUseCase.run({
|
|
144
|
+
targetDates: targetDateTimes,
|
|
145
|
+
project,
|
|
146
|
+
issues,
|
|
147
|
+
cacheUsed,
|
|
148
|
+
manager: input.manager,
|
|
149
|
+
org: input.org,
|
|
150
|
+
repo: input.workingReport.repo,
|
|
151
|
+
urlOfStoryView: input.urlOfStoryView,
|
|
152
|
+
disabledStatus: input.disabledStatus,
|
|
153
|
+
storyObjectMap: storyIssues,
|
|
154
|
+
});
|
|
155
|
+
return { project, issues, cacheUsed, targetDateTimes, storyIssues };
|
|
75
156
|
};
|
|
76
157
|
this.runForTargetDateTime = async (input) => {
|
|
77
158
|
const targetHour = input.targetDateTime.getHours();
|
|
@@ -97,6 +178,47 @@ class HandleScheduledEventUseCase {
|
|
|
97
178
|
await this.spreadsheetRepository.updateCell(spreadsheetUrl, 'HandleScheduledEvent', 1, 2, targetDateTimes[targetDateTimes.length - 1].toISOString());
|
|
98
179
|
return targetDateTimes;
|
|
99
180
|
};
|
|
181
|
+
this.storyIssues = async (input) => {
|
|
182
|
+
const summaryStoryIssue = new Map();
|
|
183
|
+
const targetStory = input.project.story?.stories || [];
|
|
184
|
+
for (const story of targetStory) {
|
|
185
|
+
const storyIssue = input.issues.find((issue) => story.name.startsWith(issue.title));
|
|
186
|
+
summaryStoryIssue.set(story.name, {
|
|
187
|
+
story,
|
|
188
|
+
storyIssue: storyIssue || null,
|
|
189
|
+
issues: [],
|
|
190
|
+
});
|
|
191
|
+
for (const issue of input.issues) {
|
|
192
|
+
if (issue.story !== story.name) {
|
|
193
|
+
continue;
|
|
194
|
+
}
|
|
195
|
+
const totalWorkingTimeByAssignee = this.calculateTotalWorkingMinutesByAssignee(issue);
|
|
196
|
+
const totalWorkingTime = Math.round(Array.from(totalWorkingTimeByAssignee.values()).reduce((a, b) => a + b, 0));
|
|
197
|
+
const issueSummary = {
|
|
198
|
+
totalWorkingTime,
|
|
199
|
+
totalWorkingTimeByAssignee,
|
|
200
|
+
};
|
|
201
|
+
summaryStoryIssue
|
|
202
|
+
.get(story.name)
|
|
203
|
+
?.issues.push({ ...issue, ...issueSummary });
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
return summaryStoryIssue;
|
|
207
|
+
};
|
|
208
|
+
this.calculateTotalWorkingMinutesByAssignee = (issue) => {
|
|
209
|
+
const workingTimeLine = issue.workingTimeline;
|
|
210
|
+
const mapWorkingTimeByAssignee = new Map();
|
|
211
|
+
for (const workingTime of workingTimeLine) {
|
|
212
|
+
const author = workingTime.author;
|
|
213
|
+
const workingMinutes = workingTime.durationMinutes;
|
|
214
|
+
if (!mapWorkingTimeByAssignee.has(author)) {
|
|
215
|
+
mapWorkingTimeByAssignee.set(author, 0);
|
|
216
|
+
}
|
|
217
|
+
const currentWorkingMinutes = mapWorkingTimeByAssignee.get(author) || 0;
|
|
218
|
+
mapWorkingTimeByAssignee.set(author, currentWorkingMinutes + workingMinutes);
|
|
219
|
+
}
|
|
220
|
+
return mapWorkingTimeByAssignee;
|
|
221
|
+
};
|
|
100
222
|
}
|
|
101
223
|
}
|
|
102
224
|
exports.HandleScheduledEventUseCase = HandleScheduledEventUseCase;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"HandleScheduledEventUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/HandleScheduledEventUseCase.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"HandleScheduledEventUseCase.js","sourceRoot":"","sources":["../../../src/domain/usecases/HandleScheduledEventUseCase.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.encodeForURI = exports.isVisibleIssue = void 0;
|
|
4
|
+
const isVisibleIssue = (issue, member, targetDate, disabledStatus) => {
|
|
5
|
+
if ((issue.nextActionDate !== null &&
|
|
6
|
+
issue.nextActionDate.getTime() > targetDate.getTime()) ||
|
|
7
|
+
(issue.nextActionHour !== null &&
|
|
8
|
+
issue.nextActionHour > targetDate.getHours()) ||
|
|
9
|
+
issue.state !== 'OPEN' ||
|
|
10
|
+
!issue.assignees.includes(member) ||
|
|
11
|
+
issue.status === disabledStatus) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
return true;
|
|
15
|
+
};
|
|
16
|
+
exports.isVisibleIssue = isVisibleIssue;
|
|
17
|
+
const encodeForURI = (url) => {
|
|
18
|
+
if (!url) {
|
|
19
|
+
return '';
|
|
20
|
+
}
|
|
21
|
+
return encodeURI(url).replace('#', '%23').replace('&', '%26');
|
|
22
|
+
};
|
|
23
|
+
exports.encodeForURI = encodeForURI;
|
|
24
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/domain/usecases/utils.ts"],"names":[],"mappings":";;;AAGO,MAAM,cAAc,GAAG,CAC5B,KAAY,EACZ,MAAsB,EACtB,UAAgB,EAChB,cAAsB,EACb,EAAE;IACX,IACE,CAAC,KAAK,CAAC,cAAc,KAAK,IAAI;QAC5B,KAAK,CAAC,cAAc,CAAC,OAAO,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;QACxD,CAAC,KAAK,CAAC,cAAc,KAAK,IAAI;YAC5B,KAAK,CAAC,cAAc,GAAG,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC/C,KAAK,CAAC,KAAK,KAAK,MAAM;QACtB,CAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;QACjC,KAAK,CAAC,MAAM,KAAK,cAAc,EAC/B,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAlBW,QAAA,cAAc,kBAkBzB;AACK,MAAM,YAAY,GAAG,CAAC,GAAmB,EAAU,EAAE;IAC1D,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AAChE,CAAC,CAAC;AALW,QAAA,YAAY,gBAKvB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "github-issue-tower-defence-management",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "bin/index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -72,7 +72,7 @@
|
|
|
72
72
|
"commander": "^12.0.0",
|
|
73
73
|
"cookie": "^1.0.1",
|
|
74
74
|
"dotenv": "^16.4.5",
|
|
75
|
-
"gh-cookie": "^1.1
|
|
75
|
+
"gh-cookie": "^1.3.1",
|
|
76
76
|
"googleapis": "^144.0.0",
|
|
77
77
|
"typia": "^6.11.3",
|
|
78
78
|
"yaml": "^2.6.0"
|