github-issue-tower-defence-management 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +6 -0
- package/.eslintrc.cjs +55 -0
- package/.github/CODEOWNERS +2 -0
- package/.github/workflows/assign-all-cards-to-owner.yml +14 -0
- package/.github/workflows/commit-lint.yml +54 -0
- package/.github/workflows/configs/commitlint.config.js +27 -0
- package/.github/workflows/create-pr.yml +64 -0
- package/.github/workflows/format.yml +25 -0
- package/.github/workflows/publish.yml +47 -0
- package/.github/workflows/test.yml +45 -0
- package/.github/workflows/umino-project.yml +181 -0
- package/.prettierignore +22 -0
- package/.prettierrc +5 -0
- package/CHANGELOG.md +49 -0
- package/CONTRIBUTING.md +107 -0
- package/README.md +108 -0
- package/bin/adapter/entry-points/cli/index.js +26 -0
- package/bin/adapter/entry-points/cli/index.js.map +1 -0
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js +142 -0
- package/bin/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.js.map +1 -0
- package/bin/adapter/repositories/AxiosSlackRepository.js +124 -0
- package/bin/adapter/repositories/AxiosSlackRepository.js.map +1 -0
- package/bin/adapter/repositories/BaseGitHubRepository.js +136 -0
- package/bin/adapter/repositories/BaseGitHubRepository.js.map +1 -0
- package/bin/adapter/repositories/GoogleSpreadsheetRepository.js +123 -0
- package/bin/adapter/repositories/GoogleSpreadsheetRepository.js.map +1 -0
- package/bin/adapter/repositories/GraphqlProjectRepository.js +167 -0
- package/bin/adapter/repositories/GraphqlProjectRepository.js.map +1 -0
- package/bin/adapter/repositories/LocalStorageCacheRepository.js +46 -0
- package/bin/adapter/repositories/LocalStorageCacheRepository.js.map +1 -0
- package/bin/adapter/repositories/LocalStorageRepository.js +30 -0
- package/bin/adapter/repositories/LocalStorageRepository.js.map +1 -0
- package/bin/adapter/repositories/SystemDateRepository.js +23 -0
- package/bin/adapter/repositories/SystemDateRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js +148 -0
- package/bin/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/ApiV3IssueRepository.js +48 -0
- package/bin/adapter/repositories/issue/ApiV3IssueRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/CheerioIssueRepository.js +120 -0
- package/bin/adapter/repositories/issue/CheerioIssueRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js +485 -0
- package/bin/adapter/repositories/issue/GraphqlProjectItemRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/InternalGraphqlIssueRepository.js +114 -0
- package/bin/adapter/repositories/issue/InternalGraphqlIssueRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/RestIssueRepository.js +79 -0
- package/bin/adapter/repositories/issue/RestIssueRepository.js.map +1 -0
- package/bin/adapter/repositories/issue/issueTimelineUtils.js +38 -0
- package/bin/adapter/repositories/issue/issueTimelineUtils.js.map +1 -0
- package/bin/adapter/repositories/utils.js +45 -0
- package/bin/adapter/repositories/utils.js.map +1 -0
- package/bin/domain/entities/Issue.js +3 -0
- package/bin/domain/entities/Issue.js.map +1 -0
- package/bin/domain/entities/Member.js +3 -0
- package/bin/domain/entities/Member.js.map +1 -0
- package/bin/domain/entities/Project.js +3 -0
- package/bin/domain/entities/Project.js.map +1 -0
- package/bin/domain/entities/ProjectField.js +3 -0
- package/bin/domain/entities/ProjectField.js.map +1 -0
- package/bin/domain/entities/ProjectFieldSingleSelect.js +3 -0
- package/bin/domain/entities/ProjectFieldSingleSelect.js.map +1 -0
- package/bin/domain/entities/ProjectFieldSingleSelectOption.js +3 -0
- package/bin/domain/entities/ProjectFieldSingleSelectOption.js.map +1 -0
- package/bin/domain/entities/WorkingTime.js +3 -0
- package/bin/domain/entities/WorkingTime.js.map +1 -0
- package/bin/domain/usecases/ActionAnnouncementUseCase.js +46 -0
- package/bin/domain/usecases/ActionAnnouncementUseCase.js.map +1 -0
- package/bin/domain/usecases/AnalyzeProblemByIssueUseCase.js +116 -0
- package/bin/domain/usecases/AnalyzeProblemByIssueUseCase.js.map +1 -0
- package/bin/domain/usecases/ClearNextActionHourUseCase.js +38 -0
- package/bin/domain/usecases/ClearNextActionHourUseCase.js.map +1 -0
- package/bin/domain/usecases/GenerateWorkingTimeReportUseCase.js +180 -0
- package/bin/domain/usecases/GenerateWorkingTimeReportUseCase.js.map +1 -0
- package/bin/domain/usecases/HandleScheduledEventUseCase.js +122 -0
- package/bin/domain/usecases/HandleScheduledEventUseCase.js.map +1 -0
- package/bin/domain/usecases/SetWorkflowManagementIssueToStoryUseCase.js +35 -0
- package/bin/domain/usecases/SetWorkflowManagementIssueToStoryUseCase.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/DateRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/DateRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/IssueRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/IssueRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/ProjectRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/ProjectRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/SlackRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/SlackRepository.js.map +1 -0
- package/bin/domain/usecases/adapter-interfaces/SpreadsheetRepository.js +3 -0
- package/bin/domain/usecases/adapter-interfaces/SpreadsheetRepository.js.map +1 -0
- package/bin/index.js +13 -0
- package/bin/index.js.map +1 -0
- package/commitlint.config.js +6 -0
- package/jest.config.js +19 -0
- package/package.json +80 -0
- package/renovate.json +37 -0
- package/src/adapter/entry-points/cli/index.test.ts +20 -0
- package/src/adapter/entry-points/cli/index.ts +36 -0
- package/src/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.ts +95 -0
- package/src/adapter/repositories/AxiosSlackRepository.test.ts +119 -0
- package/src/adapter/repositories/AxiosSlackRepository.ts +184 -0
- package/src/adapter/repositories/BaseGitHubRepository.test.ts +95 -0
- package/src/adapter/repositories/BaseGitHubRepository.ts +172 -0
- package/src/adapter/repositories/GoogleSpreadsheetRepository.test.ts +124 -0
- package/src/adapter/repositories/GoogleSpreadsheetRepository.ts +151 -0
- package/src/adapter/repositories/GraphqlProjectRepository.test.ts +46 -0
- package/src/adapter/repositories/GraphqlProjectRepository.ts +236 -0
- package/src/adapter/repositories/LocalStorageCacheRepository.test.ts +146 -0
- package/src/adapter/repositories/LocalStorageCacheRepository.ts +53 -0
- package/src/adapter/repositories/LocalStorageRepository.integration.test.ts +142 -0
- package/src/adapter/repositories/LocalStorageRepository.test.ts +161 -0
- package/src/adapter/repositories/LocalStorageRepository.ts +21 -0
- package/src/adapter/repositories/SystemDateRepository.ts +20 -0
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.test.ts +158 -0
- package/src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts +274 -0
- package/src/adapter/repositories/issue/ApiV3IssueRepository.test.ts +26 -0
- package/src/adapter/repositories/issue/ApiV3IssueRepository.ts +59 -0
- package/src/adapter/repositories/issue/CheerioIssueRepository.test.ts +6610 -0
- package/src/adapter/repositories/issue/CheerioIssueRepository.ts +127 -0
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.test.ts +49 -0
- package/src/adapter/repositories/issue/GraphqlProjectItemRepository.ts +745 -0
- package/src/adapter/repositories/issue/InternalGraphqlIssueRepository.test.ts +71 -0
- package/src/adapter/repositories/issue/InternalGraphqlIssueRepository.ts +263 -0
- package/src/adapter/repositories/issue/RestIssueRepository.test.ts +29 -0
- package/src/adapter/repositories/issue/RestIssueRepository.ts +105 -0
- package/src/adapter/repositories/issue/issueTimelineUtils.test.ts +79 -0
- package/src/adapter/repositories/issue/issueTimelineUtils.ts +52 -0
- package/src/adapter/repositories/utils.test.ts +40 -0
- package/src/adapter/repositories/utils.ts +50 -0
- package/src/domain/entities/Issue.ts +23 -0
- package/src/domain/entities/Member.ts +3 -0
- package/src/domain/entities/Project.ts +29 -0
- package/src/domain/entities/ProjectField.ts +3 -0
- package/src/domain/entities/ProjectFieldSingleSelect.ts +8 -0
- package/src/domain/entities/ProjectFieldSingleSelectOption.ts +8 -0
- package/src/domain/entities/WorkingTime.ts +8 -0
- package/src/domain/usecases/ActionAnnouncementUseCase.ts +76 -0
- package/src/domain/usecases/AnalyzeProblemByIssueUseCase.ts +209 -0
- package/src/domain/usecases/ClearNextActionHourUseCase.ts +51 -0
- package/src/domain/usecases/GenerateWorkingTimeReportUseCase.test.ts +382 -0
- package/src/domain/usecases/GenerateWorkingTimeReportUseCase.ts +284 -0
- package/src/domain/usecases/HandleScheduledEventUseCase.test.ts +58 -0
- package/src/domain/usecases/HandleScheduledEventUseCase.ts +209 -0
- package/src/domain/usecases/SetWorkflowManagementIssueToStoryUseCase.ts +46 -0
- package/src/domain/usecases/adapter-interfaces/DateRepository.ts +5 -0
- package/src/domain/usecases/adapter-interfaces/IssueRepository.ts +44 -0
- package/src/domain/usecases/adapter-interfaces/ProjectRepository.ts +6 -0
- package/src/domain/usecases/adapter-interfaces/SlackRepository.ts +20 -0
- package/src/domain/usecases/adapter-interfaces/SpreadsheetRepository.ts +18 -0
- package/src/index.test.ts +8 -0
- package/src/index.ts +7 -0
- package/tsconfig.build.json +11 -0
- package/tsconfig.json +22 -0
- package/types/adapter/entry-points/cli/index.d.ts +3 -0
- package/types/adapter/entry-points/cli/index.d.ts.map +1 -0
- package/types/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.d.ts +11 -0
- package/types/adapter/entry-points/handlers/HandleScheduledEventUseCaseHandler.d.ts.map +1 -0
- package/types/adapter/repositories/AxiosSlackRepository.d.ts +13 -0
- package/types/adapter/repositories/AxiosSlackRepository.d.ts.map +1 -0
- package/types/adapter/repositories/BaseGitHubRepository.d.ts +32 -0
- package/types/adapter/repositories/BaseGitHubRepository.d.ts.map +1 -0
- package/types/adapter/repositories/GoogleSpreadsheetRepository.d.ts +13 -0
- package/types/adapter/repositories/GoogleSpreadsheetRepository.d.ts.map +1 -0
- package/types/adapter/repositories/GraphqlProjectRepository.d.ts +13 -0
- package/types/adapter/repositories/GraphqlProjectRepository.d.ts.map +1 -0
- package/types/adapter/repositories/LocalStorageCacheRepository.d.ts +12 -0
- package/types/adapter/repositories/LocalStorageCacheRepository.d.ts.map +1 -0
- package/types/adapter/repositories/LocalStorageRepository.d.ts +7 -0
- package/types/adapter/repositories/LocalStorageRepository.d.ts.map +1 -0
- package/types/adapter/repositories/SystemDateRepository.d.ts +7 -0
- package/types/adapter/repositories/SystemDateRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts +38 -0
- package/types/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/ApiV3IssueRepository.d.ts +17 -0
- package/types/adapter/repositories/issue/ApiV3IssueRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/CheerioIssueRepository.d.ts +31 -0
- package/types/adapter/repositories/issue/CheerioIssueRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts +39 -0
- package/types/adapter/repositories/issue/GraphqlProjectItemRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/InternalGraphqlIssueRepository.d.ts +83 -0
- package/types/adapter/repositories/issue/InternalGraphqlIssueRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/RestIssueRepository.d.ts +16 -0
- package/types/adapter/repositories/issue/RestIssueRepository.d.ts.map +1 -0
- package/types/adapter/repositories/issue/issueTimelineUtils.d.ts +12 -0
- package/types/adapter/repositories/issue/issueTimelineUtils.d.ts.map +1 -0
- package/types/adapter/repositories/utils.d.ts +4 -0
- package/types/adapter/repositories/utils.d.ts.map +1 -0
- package/types/domain/entities/Issue.d.ts +24 -0
- package/types/domain/entities/Issue.d.ts.map +1 -0
- package/types/domain/entities/Member.d.ts +4 -0
- package/types/domain/entities/Member.d.ts.map +1 -0
- package/types/domain/entities/Project.d.ts +29 -0
- package/types/domain/entities/Project.d.ts.map +1 -0
- package/types/domain/entities/ProjectField.d.ts +3 -0
- package/types/domain/entities/ProjectField.d.ts.map +1 -0
- package/types/domain/entities/ProjectFieldSingleSelect.d.ts +8 -0
- package/types/domain/entities/ProjectFieldSingleSelect.d.ts.map +1 -0
- package/types/domain/entities/ProjectFieldSingleSelectOption.d.ts +8 -0
- package/types/domain/entities/ProjectFieldSingleSelectOption.d.ts.map +1 -0
- package/types/domain/entities/WorkingTime.d.ts +8 -0
- package/types/domain/entities/WorkingTime.d.ts.map +1 -0
- package/types/domain/usecases/ActionAnnouncementUseCase.d.ts +17 -0
- package/types/domain/usecases/ActionAnnouncementUseCase.d.ts.map +1 -0
- package/types/domain/usecases/AnalyzeProblemByIssueUseCase.d.ts +26 -0
- package/types/domain/usecases/AnalyzeProblemByIssueUseCase.d.ts.map +1 -0
- package/types/domain/usecases/ClearNextActionHourUseCase.d.ts +14 -0
- package/types/domain/usecases/ClearNextActionHourUseCase.d.ts.map +1 -0
- package/types/domain/usecases/GenerateWorkingTimeReportUseCase.d.ts +50 -0
- package/types/domain/usecases/GenerateWorkingTimeReportUseCase.d.ts.map +1 -0
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts +63 -0
- package/types/domain/usecases/HandleScheduledEventUseCase.d.ts.map +1 -0
- package/types/domain/usecases/SetWorkflowManagementIssueToStoryUseCase.d.ts +14 -0
- package/types/domain/usecases/SetWorkflowManagementIssueToStoryUseCase.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/DateRepository.d.ts +6 -0
- package/types/domain/usecases/adapter-interfaces/DateRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts +23 -0
- package/types/domain/usecases/adapter-interfaces/IssueRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/ProjectRepository.d.ts +6 -0
- package/types/domain/usecases/adapter-interfaces/ProjectRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/SlackRepository.d.ts +9 -0
- package/types/domain/usecases/adapter-interfaces/SlackRepository.d.ts.map +1 -0
- package/types/domain/usecases/adapter-interfaces/SpreadsheetRepository.d.ts +6 -0
- package/types/domain/usecases/adapter-interfaces/SpreadsheetRepository.d.ts.map +1 -0
- package/types/index.d.ts +10 -0
- package/types/index.d.ts.map +1 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { IssueRepository } from '../../../domain/usecases/adapter-interfaces/IssueRepository';
|
|
2
|
+
import { Project } from '../../../domain/entities/Project';
|
|
3
|
+
import { Issue } from '../../../domain/entities/Issue';
|
|
4
|
+
import { ApiV3IssueRepository } from './ApiV3IssueRepository';
|
|
5
|
+
import { CheerioIssueRepository, Issue as CheerioIssue } from './CheerioIssueRepository';
|
|
6
|
+
import { RestIssueRepository } from './RestIssueRepository';
|
|
7
|
+
import { GraphqlProjectItemRepository, ProjectItem } from './GraphqlProjectItemRepository';
|
|
8
|
+
import { LocalStorageCacheRepository } from '../LocalStorageCacheRepository';
|
|
9
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
10
|
+
export declare class ApiV3CheerioRestIssueRepository extends BaseGitHubRepository implements IssueRepository {
|
|
11
|
+
readonly apiV3IssueRepository: Pick<ApiV3IssueRepository, 'searchIssue'>;
|
|
12
|
+
readonly cheerioIssueRepository: Pick<CheerioIssueRepository, 'getIssue'>;
|
|
13
|
+
readonly restIssueRepository: Pick<RestIssueRepository, 'createNewIssue' | 'updateIssue'>;
|
|
14
|
+
readonly graphqlProjectItemRepository: Pick<GraphqlProjectItemRepository, 'fetchProjectItems' | 'fetchProjectItemByUrl' | 'updateProjectField' | 'clearProjectField'>;
|
|
15
|
+
readonly localStorageCacheRepository: Pick<LocalStorageCacheRepository, 'getLatest' | 'set'>;
|
|
16
|
+
constructor(apiV3IssueRepository: Pick<ApiV3IssueRepository, 'searchIssue'>, cheerioIssueRepository: Pick<CheerioIssueRepository, 'getIssue'>, restIssueRepository: Pick<RestIssueRepository, 'createNewIssue' | 'updateIssue'>, graphqlProjectItemRepository: Pick<GraphqlProjectItemRepository, 'fetchProjectItems' | 'fetchProjectItemByUrl' | 'updateProjectField' | 'clearProjectField'>, localStorageCacheRepository: Pick<LocalStorageCacheRepository, 'getLatest' | 'set'>);
|
|
17
|
+
convertProjectItemAndCheerioIssueToIssue: (item: ProjectItem, cheerioIssue: CheerioIssue) => Promise<Issue>;
|
|
18
|
+
getAllIssuesFromCache: (cacheKey: string, allowCacheMinutes: number) => Promise<Issue[] | null>;
|
|
19
|
+
getAllIssues: (projectId: Project["id"], allowCacheMinutes: number) => Promise<{
|
|
20
|
+
issues: Issue[];
|
|
21
|
+
cacheUsed: boolean;
|
|
22
|
+
}>;
|
|
23
|
+
getAllIssuesFromGitHub: (projectId: Project["id"]) => Promise<Issue[]>;
|
|
24
|
+
createNewIssue: (org: string, repo: string, title: string, body: string, assignees: string[], labels: string[]) => Promise<void>;
|
|
25
|
+
updateIssue: (issue: Issue) => Promise<void>;
|
|
26
|
+
getIssueByUrl: (url: string) => Promise<Issue | null>;
|
|
27
|
+
updateNextActionDate: (project: Project & {
|
|
28
|
+
nextActionDate: Required<Project["nextActionDate"]>;
|
|
29
|
+
}, issue: Issue, date: Date) => Promise<void>;
|
|
30
|
+
updateNextActionHour: (project: Project & {
|
|
31
|
+
nextActionHour: NonNullable<Project["nextActionHour"]>;
|
|
32
|
+
}, issue: Issue, hour: number) => Promise<void>;
|
|
33
|
+
updateStory: (project: Project & {
|
|
34
|
+
story: NonNullable<Project["story"]>;
|
|
35
|
+
}, issue: Issue, storyOptionId: string) => Promise<void>;
|
|
36
|
+
clearProjectField: (project: Project, fieldId: string, issue: Issue) => Promise<void>;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=ApiV3CheerioRestIssueRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ApiV3CheerioRestIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/ApiV3CheerioRestIssueRepository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
2
|
+
export declare class ApiV3IssueRepository extends BaseGitHubRepository {
|
|
3
|
+
searchIssue: (query: {
|
|
4
|
+
owner: string;
|
|
5
|
+
repositoryName: string;
|
|
6
|
+
type?: "issue" | "pr";
|
|
7
|
+
state?: "open" | "closed" | "all";
|
|
8
|
+
title?: string;
|
|
9
|
+
createdFrom?: string;
|
|
10
|
+
assignee?: string;
|
|
11
|
+
}) => Promise<{
|
|
12
|
+
url: string;
|
|
13
|
+
title: string;
|
|
14
|
+
number: string;
|
|
15
|
+
}[]>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=ApiV3IssueRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ApiV3IssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/ApiV3IssueRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAE/D,qBAAa,oBAAqB,SAAQ,oBAAoB;IAC5D,WAAW,UAAiB;QAC1B,KAAK,EAAE,MAAM,CAAC;QACd,cAAc,EAAE,MAAM,CAAC;QACvB,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;QACtB,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;QAClC,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,KAAG,OAAO,CACT;QACE,GAAG,EAAE,MAAM,CAAC;QACZ,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,MAAM,CAAC;KAChB,EAAE,CACJ,CAuCC;CACH"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import * as cheerio from 'cheerio';
|
|
2
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
3
|
+
import { WorkingTime } from '../../../domain/entities/WorkingTime';
|
|
4
|
+
import { IssueStatusTimeline } from './issueTimelineUtils';
|
|
5
|
+
import { InternalGraphqlIssueRepository } from './InternalGraphqlIssueRepository';
|
|
6
|
+
export type Issue = {
|
|
7
|
+
url: string;
|
|
8
|
+
title: string;
|
|
9
|
+
status: string;
|
|
10
|
+
assignees: string[];
|
|
11
|
+
labels: string[];
|
|
12
|
+
project: string;
|
|
13
|
+
statusTimeline: IssueStatusTimeline[];
|
|
14
|
+
inProgressTimeline: WorkingTime[];
|
|
15
|
+
};
|
|
16
|
+
export declare class CheerioIssueRepository extends BaseGitHubRepository {
|
|
17
|
+
readonly internalGraphqlIssueRepository: InternalGraphqlIssueRepository;
|
|
18
|
+
readonly jsonFilePath: string;
|
|
19
|
+
readonly ghToken: string;
|
|
20
|
+
constructor(internalGraphqlIssueRepository: InternalGraphqlIssueRepository, jsonFilePath?: string, ghToken?: string);
|
|
21
|
+
getIssue: (issueUrl: string) => Promise<Issue>;
|
|
22
|
+
getIssueFromNormalView: (issueUrl: string, $: cheerio.CheerioAPI) => Promise<Issue>;
|
|
23
|
+
getStatusTimelineEvents: ($: cheerio.CheerioAPI) => Promise<IssueStatusTimeline[]>;
|
|
24
|
+
protected getTitleFromCheerioObject: ($: cheerio.CheerioAPI) => string;
|
|
25
|
+
protected getStatusFromCheerioObject: ($: cheerio.CheerioAPI) => string;
|
|
26
|
+
protected getAssigneesFromCheerioObject: ($: cheerio.CheerioAPI) => string[];
|
|
27
|
+
protected getLabelsFromCheerioObject: ($: cheerio.CheerioAPI) => string[];
|
|
28
|
+
protected getProjectFromCheerioObject: ($: cheerio.CheerioAPI) => string;
|
|
29
|
+
protected getStatusTimelineEventsFromCheerioObject: ($: cheerio.CheerioAPI) => IssueStatusTimeline[];
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=CheerioIssueRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CheerioIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/CheerioIssueRepository.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AACnE,OAAO,EAEL,mBAAmB,EACpB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,8BAA8B,EAAE,MAAM,kCAAkC,CAAC;AAElF,MAAM,MAAM,KAAK,GAAG;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,cAAc,EAAE,mBAAmB,EAAE,CAAC;IACtC,kBAAkB,EAAE,WAAW,EAAE,CAAC;CACnC,CAAC;AAEF,qBAAa,sBAAuB,SAAQ,oBAAoB;IAE5D,QAAQ,CAAC,8BAA8B,EAAE,8BAA8B;IACvE,QAAQ,CAAC,YAAY,EAAE,MAAM;IAC7B,QAAQ,CAAC,OAAO,EAAE,MAAM;gBAFf,8BAA8B,EAAE,8BAA8B,EAC9D,YAAY,GAAE,MAAwC,EACtD,OAAO,GAAE,MAAwC;IAI5D,QAAQ,aAAoB,MAAM,KAAG,OAAO,CAAC,KAAK,CAAC,CAYjD;IACF,sBAAsB,aACV,MAAM,KACb,OAAO,CAAC,UAAU,KACpB,OAAO,CAAC,KAAK,CAAC,CA2Bf;IACF,uBAAuB,MAClB,OAAO,CAAC,UAAU,KACpB,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAE/B;IACF,SAAS,CAAC,yBAAyB,MAAO,OAAO,CAAC,UAAU,KAAG,MAAM,CAEnE;IACF,SAAS,CAAC,0BAA0B,MAAO,OAAO,CAAC,UAAU,KAAG,MAAM,CAEpE;IACF,SAAS,CAAC,6BAA6B,MAClC,OAAO,CAAC,UAAU,KACpB,MAAM,EAAE,CAKT;IACF,SAAS,CAAC,0BAA0B,MAAO,OAAO,CAAC,UAAU,KAAG,MAAM,EAAE,CAItE;IACF,SAAS,CAAC,2BAA2B,MAAO,OAAO,CAAC,UAAU,KAAG,MAAM,CAErE;IAEF,SAAS,CAAC,wCAAwC,MAC7C,OAAO,CAAC,UAAU,KACpB,mBAAmB,EAAE,CAsBtB;CACH"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
2
|
+
export type ProjectItem = {
|
|
3
|
+
id: string;
|
|
4
|
+
nameWithOwner: string;
|
|
5
|
+
number: number;
|
|
6
|
+
title: string;
|
|
7
|
+
state: 'OPEN' | 'CLOSED' | 'MERGED';
|
|
8
|
+
url: string;
|
|
9
|
+
body: string;
|
|
10
|
+
customFields: {
|
|
11
|
+
name: string;
|
|
12
|
+
value: string | null;
|
|
13
|
+
}[];
|
|
14
|
+
};
|
|
15
|
+
export declare class GraphqlProjectItemRepository extends BaseGitHubRepository {
|
|
16
|
+
fetchItemId: (projectId: string, owner: string, repositoryName: string, issueNumber: number) => Promise<string | undefined>;
|
|
17
|
+
fetchProjectItems: (projectId: string) => Promise<ProjectItem[]>;
|
|
18
|
+
getProjectItemFieldsFromIssueUrl: (issueUrl: string) => Promise<{
|
|
19
|
+
fieldName: string;
|
|
20
|
+
fieldValue: string;
|
|
21
|
+
}[]>;
|
|
22
|
+
getProjectItemFields: (owner: string, repositoryName: string, issueNumber: number) => Promise<{
|
|
23
|
+
fieldName: string;
|
|
24
|
+
fieldValue: string;
|
|
25
|
+
}[]>;
|
|
26
|
+
fetchProjectItemByUrl: (issueUrl: string) => Promise<ProjectItem | null>;
|
|
27
|
+
convertStrToState: (state: string) => "OPEN" | "CLOSED" | "MERGED";
|
|
28
|
+
updateProjectField: (projectId: string, fieldId: string, itemId: string, value: {
|
|
29
|
+
text: string;
|
|
30
|
+
} | {
|
|
31
|
+
number: number;
|
|
32
|
+
} | {
|
|
33
|
+
date: string;
|
|
34
|
+
} | {
|
|
35
|
+
singleSelectOptionId: string;
|
|
36
|
+
}) => Promise<void>;
|
|
37
|
+
clearProjectField: (projectId: string, fieldId: string, itemId: string) => Promise<void>;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=GraphqlProjectItemRepository.d.ts.map
|
|
@@ -0,0 +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,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,YAAY,EAAE;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,EAAE,CAAC;CACL,CAAC;AACF,qBAAa,4BAA6B,SAAQ,oBAAoB;IACpE,WAAW,cACE,MAAM,SACV,MAAM,kBACG,MAAM,eACT,MAAM,KAClB,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA4D5B;IACF,iBAAiB,cAAqB,MAAM,KAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAyPnE;IACF,gCAAgC,aACpB,MAAM,KACf,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CAGC;IAEF,oBAAoB,UACX,MAAM,kBACG,MAAM,eACT,MAAM,KAClB,OAAO,CACR;QACE,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CACJ,CA4IC;IACF,qBAAqB,aACT,MAAM,KACf,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAwJ5B;IACF,iBAAiB,UAAW,MAAM,KAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAQ/D;IAEF,kBAAkB,cACL,MAAM,WACR,MAAM,UACP,MAAM,SAEV;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,CAmCd;IAEF,iBAAiB,cACJ,MAAM,WACR,MAAM,UACP,MAAM,KACb,OAAO,CAAC,IAAI,CAAC,CAkCd;CACH"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
2
|
+
import { Issue } from './CheerioIssueRepository';
|
|
3
|
+
type GitHubBetaFeatureViewData = {
|
|
4
|
+
payload: {
|
|
5
|
+
preloadedQueries: [
|
|
6
|
+
{
|
|
7
|
+
variables: {
|
|
8
|
+
owner: string;
|
|
9
|
+
repo: string;
|
|
10
|
+
number: number;
|
|
11
|
+
};
|
|
12
|
+
result: {
|
|
13
|
+
data: {
|
|
14
|
+
repository: {
|
|
15
|
+
issue: {
|
|
16
|
+
id: string;
|
|
17
|
+
title: string;
|
|
18
|
+
state: string;
|
|
19
|
+
assignees: {
|
|
20
|
+
nodes: Array<{
|
|
21
|
+
login: string;
|
|
22
|
+
}>;
|
|
23
|
+
};
|
|
24
|
+
labels: {
|
|
25
|
+
edges: Array<{
|
|
26
|
+
node: {
|
|
27
|
+
name: string;
|
|
28
|
+
};
|
|
29
|
+
}>;
|
|
30
|
+
};
|
|
31
|
+
projectItemsNext: {
|
|
32
|
+
edges: Array<{
|
|
33
|
+
node: {
|
|
34
|
+
project: {
|
|
35
|
+
title: string;
|
|
36
|
+
};
|
|
37
|
+
};
|
|
38
|
+
}>;
|
|
39
|
+
};
|
|
40
|
+
frontTimelineItems: {
|
|
41
|
+
edges: Array<{
|
|
42
|
+
node: {
|
|
43
|
+
__typename: string;
|
|
44
|
+
id: string;
|
|
45
|
+
};
|
|
46
|
+
}>;
|
|
47
|
+
pageInfo: {
|
|
48
|
+
hasNextPage: boolean;
|
|
49
|
+
endCursor: string;
|
|
50
|
+
};
|
|
51
|
+
totalCount: number;
|
|
52
|
+
};
|
|
53
|
+
backTimelineItems: {
|
|
54
|
+
edges: Array<{
|
|
55
|
+
node: {
|
|
56
|
+
__typename: string;
|
|
57
|
+
id: string;
|
|
58
|
+
};
|
|
59
|
+
}>;
|
|
60
|
+
};
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
];
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
type GraphqlResponse = {
|
|
70
|
+
data: {
|
|
71
|
+
node: {
|
|
72
|
+
__typename: 'Issue';
|
|
73
|
+
frontTimelineItems: GitHubBetaFeatureViewData['payload']['preloadedQueries'][0]['result']['data']['repository']['issue']['frontTimelineItems'];
|
|
74
|
+
id: string;
|
|
75
|
+
};
|
|
76
|
+
};
|
|
77
|
+
};
|
|
78
|
+
export declare class InternalGraphqlIssueRepository extends BaseGitHubRepository {
|
|
79
|
+
getFrontTimelineItems: (issueUrl: string, cursor: string | null, issueId: string, maxCount?: number) => Promise<GraphqlResponse["data"]["node"]["frontTimelineItems"]["edges"]>;
|
|
80
|
+
getIssueFromBetaFeatureView: (issueUrl: string, html: string) => Promise<Issue>;
|
|
81
|
+
}
|
|
82
|
+
export {};
|
|
83
|
+
//# sourceMappingURL=InternalGraphqlIssueRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InternalGraphqlIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/InternalGraphqlIssueRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAM/D,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAC;AAEjD,KAAK,yBAAyB,GAAG;IAC/B,OAAO,EAAE;QACP,gBAAgB,EAAE;YAChB;gBACE,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,CAAC;oBACd,IAAI,EAAE,MAAM,CAAC;oBACb,MAAM,EAAE,MAAM,CAAC;iBAChB,CAAC;gBACF,MAAM,EAAE;oBACN,IAAI,EAAE;wBACJ,UAAU,EAAE;4BACV,KAAK,EAAE;gCACL,EAAE,EAAE,MAAM,CAAC;gCACX,KAAK,EAAE,MAAM,CAAC;gCACd,KAAK,EAAE,MAAM,CAAC;gCACd,SAAS,EAAE;oCACT,KAAK,EAAE,KAAK,CAAC;wCACX,KAAK,EAAE,MAAM,CAAC;qCACf,CAAC,CAAC;iCACJ,CAAC;gCACF,MAAM,EAAE;oCACN,KAAK,EAAE,KAAK,CAAC;wCACX,IAAI,EAAE;4CACJ,IAAI,EAAE,MAAM,CAAC;yCACd,CAAC;qCACH,CAAC,CAAC;iCACJ,CAAC;gCACF,gBAAgB,EAAE;oCAChB,KAAK,EAAE,KAAK,CAAC;wCACX,IAAI,EAAE;4CACJ,OAAO,EAAE;gDACP,KAAK,EAAE,MAAM,CAAC;6CACf,CAAC;yCACH,CAAC;qCACH,CAAC,CAAC;iCACJ,CAAC;gCACF,kBAAkB,EAAE;oCAClB,KAAK,EAAE,KAAK,CAAC;wCACX,IAAI,EAAE;4CACJ,UAAU,EAAE,MAAM,CAAC;4CACnB,EAAE,EAAE,MAAM,CAAC;yCACZ,CAAC;qCACH,CAAC,CAAC;oCACH,QAAQ,EAAE;wCACR,WAAW,EAAE,OAAO,CAAC;wCACrB,SAAS,EAAE,MAAM,CAAC;qCACnB,CAAC;oCACF,UAAU,EAAE,MAAM,CAAC;iCACpB,CAAC;gCACF,iBAAiB,EAAE;oCACjB,KAAK,EAAE,KAAK,CAAC;wCACX,IAAI,EAAE;4CACJ,UAAU,EAAE,MAAM,CAAC;4CACnB,EAAE,EAAE,MAAM,CAAC;yCACZ,CAAC;qCACH,CAAC,CAAC;iCACJ,CAAC;6BACH,CAAC;yBACH,CAAC;qBACH,CAAC;iBACH,CAAC;aACH;SACF,CAAC;KACH,CAAC;CACH,CAAC;AA+BF,KAAK,eAAe,GAAG;IACrB,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,UAAU,EAAE,OAAO,CAAC;YACpB,kBAAkB,EAAE,yBAAyB,CAAC,SAAS,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC;YAC/I,EAAE,EAAE,MAAM,CAAC;SACZ,CAAC;KACH,CAAC;CACH,CAAC;AACF,qBAAa,8BAA+B,SAAQ,oBAAoB;IACtE,qBAAqB,aACT,MAAM,UACR,MAAM,GAAG,IAAI,WACZ,MAAM,aACL,MAAM,KACf,OAAO,CACR,eAAe,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,CAC/D,CAmEC;IACF,2BAA2B,aACf,MAAM,QACV,MAAM,KACX,OAAO,CAAC,KAAK,CAAC,CAoEf;CACH"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseGitHubRepository } from '../BaseGitHubRepository';
|
|
2
|
+
import { Issue } from '../../../domain/entities/Issue';
|
|
3
|
+
export declare class RestIssueRepository extends BaseGitHubRepository {
|
|
4
|
+
createComment: (issueUrl: string, comment: string) => Promise<void>;
|
|
5
|
+
createNewIssue: (owner: string, repo: string, title: string, body: string, assignees: string[], labels: string[]) => Promise<void>;
|
|
6
|
+
getIssue: (issueUrl: string) => Promise<{
|
|
7
|
+
labels: string[];
|
|
8
|
+
assignees: string[];
|
|
9
|
+
title: string;
|
|
10
|
+
body: string;
|
|
11
|
+
number: number;
|
|
12
|
+
state: string;
|
|
13
|
+
}>;
|
|
14
|
+
updateIssue: (issue: Issue) => Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=RestIssueRepository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RestIssueRepository.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/RestIssueRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAC;AAEvD,qBAAa,mBAAoB,SAAQ,oBAAoB;IAC3D,aAAa,aAAoB,MAAM,WAAW,MAAM,mBAiBtD;IACF,cAAc,UACL,MAAM,QACP,MAAM,SACL,MAAM,QACP,MAAM,aACD,MAAM,EAAE,UACX,MAAM,EAAE,mBAoBhB;IACF,QAAQ,aACI,MAAM,KACf,OAAO,CAAC;QACT,MAAM,EAAE,MAAM,EAAE,CAAC;QACjB,SAAS,EAAE,MAAM,EAAE,CAAC;QACpB,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,EAAE,MAAM,CAAC;KACf,CAAC,CAuBA;IACF,WAAW,UAAiB,KAAK,mBAoB/B;CACH"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { WorkingTime } from '../../../domain/entities/WorkingTime';
|
|
2
|
+
export type IssueStatusTimeline = {
|
|
3
|
+
time: string;
|
|
4
|
+
author: string;
|
|
5
|
+
from: string;
|
|
6
|
+
to: string;
|
|
7
|
+
};
|
|
8
|
+
export type IssueInProgressTimeline = WorkingTime & {
|
|
9
|
+
issueUrl: string;
|
|
10
|
+
};
|
|
11
|
+
export declare const getInProgressTimeline: (timelines: IssueStatusTimeline[], issueUrl: string) => Promise<WorkingTime[]>;
|
|
12
|
+
//# sourceMappingURL=issueTimelineUtils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"issueTimelineUtils.d.ts","sourceRoot":"","sources":["../../../../src/adapter/repositories/issue/issueTimelineUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAEnE,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AACF,MAAM,MAAM,uBAAuB,GAAG,WAAW,GAAG;IAClD,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,qBAAqB,cACrB,mBAAmB,EAAE,YACtB,MAAM,KACf,OAAO,CAAC,WAAW,EAAE,CAoCvB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/adapter/repositories/utils.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,gBAAgB,UACpB,MAAM,OACR,MAAM,KACV,MAeF,CAAC;AACF,eAAO,MAAM,aAAa,cACb,MAAM,EAAE,KAClB,MAgBF,CAAC;AAEF,eAAO,MAAM,kBAAkB,cAAe,MAAM,WAOnD,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { WorkingTime } from './WorkingTime';
|
|
2
|
+
import { Member } from './Member';
|
|
3
|
+
export type Label = string;
|
|
4
|
+
export type Issue = {
|
|
5
|
+
nameWithOwner: string;
|
|
6
|
+
number: number;
|
|
7
|
+
title: string;
|
|
8
|
+
state: 'OPEN' | 'CLOSED' | 'MERGED';
|
|
9
|
+
status: string | null;
|
|
10
|
+
story: string | null;
|
|
11
|
+
nextActionDate: Date | null;
|
|
12
|
+
nextActionHour: number | null;
|
|
13
|
+
estimationMinutes: number | null;
|
|
14
|
+
url: string;
|
|
15
|
+
assignees: Member['name'][];
|
|
16
|
+
workingTimeline: WorkingTime[];
|
|
17
|
+
labels: Label[];
|
|
18
|
+
org: string;
|
|
19
|
+
repo: string;
|
|
20
|
+
body: string;
|
|
21
|
+
itemId: string;
|
|
22
|
+
isPr: boolean;
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=Issue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Issue.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Issue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,MAAM,MAAM,KAAK,GAAG,MAAM,CAAC;AAC3B,MAAM,MAAM,KAAK,GAAG;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACpC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,cAAc,EAAE,IAAI,GAAG,IAAI,CAAC;IAC5B,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;IAC5B,eAAe,EAAE,WAAW,EAAE,CAAC;IAC/B,MAAM,EAAE,KAAK,EAAE,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,OAAO,CAAC;CACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Member.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Member.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,MAAM,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export type Project = {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
nextActionDate: {
|
|
5
|
+
name: string;
|
|
6
|
+
fieldId: string;
|
|
7
|
+
} | null;
|
|
8
|
+
nextActionHour: {
|
|
9
|
+
name: string;
|
|
10
|
+
fieldId: string;
|
|
11
|
+
} | null;
|
|
12
|
+
story: {
|
|
13
|
+
name: string;
|
|
14
|
+
fieldId: string;
|
|
15
|
+
stories: {
|
|
16
|
+
id: string;
|
|
17
|
+
name: string;
|
|
18
|
+
}[];
|
|
19
|
+
workflowManagementStory: {
|
|
20
|
+
id: string;
|
|
21
|
+
name: string;
|
|
22
|
+
};
|
|
23
|
+
} | null;
|
|
24
|
+
remainingEstimationMinutes: {
|
|
25
|
+
name: string;
|
|
26
|
+
fieldId: string;
|
|
27
|
+
} | null;
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=Project.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Project.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/Project.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IAEb,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,cAAc,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;IACT,KAAK,EAAE;QACL,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE;YACP,EAAE,EAAE,MAAM,CAAC;YACX,IAAI,EAAE,MAAM,CAAC;SACd,EAAE,CAAC;QACJ,uBAAuB,EAAE;YACvB,EAAE,EAAE,MAAM,CAAC;YACX,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,GAAG,IAAI,CAAC;IACT,0BAA0B,EAAE;QAC1B,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;CACV,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProjectField.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/ProjectField.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAEtE,MAAM,MAAM,YAAY,GAAG,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ProjectFieldSingleSelectOption } from './ProjectFieldSingleSelectOption';
|
|
2
|
+
export type ProjectFieldSingleSelect = {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
projectFieldType: 'single_select';
|
|
6
|
+
options: ProjectFieldSingleSelectOption[];
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=ProjectFieldSingleSelect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProjectFieldSingleSelect.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/ProjectFieldSingleSelect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,8BAA8B,EAAE,MAAM,kCAAkC,CAAC;AAElF,MAAM,MAAM,wBAAwB,GAAG;IACrC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,EAAE,eAAe,CAAC;IAClC,OAAO,EAAE,8BAA8B,EAAE,CAAC;CAC3C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProjectFieldSingleSelectOption.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/ProjectFieldSingleSelectOption.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,MAAM,MAAM,8BAA8B,GAAG;IAC3C,cAAc,EAAE,YAAY,CAAC,IAAI,CAAC,CAAC;IACnC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WorkingTime.d.ts","sourceRoot":"","sources":["../../../src/domain/entities/WorkingTime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,MAAM,MAAM,WAAW,GAAG;IACxB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IACvB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;IACd,eAAe,EAAE,MAAM,CAAC;CACzB,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { Member } from '../entities/Member';
|
|
3
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
4
|
+
import { Project } from '../entities/Project';
|
|
5
|
+
export declare class ActionAnnouncementUseCase {
|
|
6
|
+
readonly issueRepository: Pick<IssueRepository, 'createNewIssue' | 'updateIssue'>;
|
|
7
|
+
constructor(issueRepository: Pick<IssueRepository, 'createNewIssue' | 'updateIssue'>);
|
|
8
|
+
run: (input: {
|
|
9
|
+
targetDates: Date[];
|
|
10
|
+
project: Project;
|
|
11
|
+
issues: Issue[];
|
|
12
|
+
cacheUsed: boolean;
|
|
13
|
+
members: Member["name"][];
|
|
14
|
+
manager: Member["name"];
|
|
15
|
+
}) => Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=ActionAnnouncementUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActionAnnouncementUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/ActionAnnouncementUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,qBAAa,yBAAyB;IAElC,QAAQ,CAAC,eAAe,EAAE,IAAI,CAC5B,eAAe,EACf,gBAAgB,GAAG,aAAa,CACjC;gBAHQ,eAAe,EAAE,IAAI,CAC5B,eAAe,EACf,gBAAgB,GAAG,aAAa,CACjC;IAGH,GAAG,UAAiB;QAClB,WAAW,EAAE,IAAI,EAAE,CAAC;QACpB,OAAO,EAAE,OAAO,CAAC;QACjB,MAAM,EAAE,KAAK,EAAE,CAAC;QAChB,SAAS,EAAE,OAAO,CAAC;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;KACzB,KAAG,OAAO,CAAC,IAAI,CAAC,CAsDf;CACH"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Issue } from '../entities/Issue';
|
|
2
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
3
|
+
import { Project } from '../entities/Project';
|
|
4
|
+
import { Member } from '../entities/Member';
|
|
5
|
+
import { DateRepository } from './adapter-interfaces/DateRepository';
|
|
6
|
+
export declare class AnalyzeProblemByIssueUseCase {
|
|
7
|
+
readonly issueRepository: Pick<IssueRepository, 'createNewIssue'>;
|
|
8
|
+
readonly dateRepository: Pick<DateRepository, 'formatDurationToHHMM'>;
|
|
9
|
+
constructor(issueRepository: Pick<IssueRepository, 'createNewIssue'>, dateRepository: Pick<DateRepository, 'formatDurationToHHMM'>);
|
|
10
|
+
run: (input: {
|
|
11
|
+
targetDates: Date[];
|
|
12
|
+
project: Project;
|
|
13
|
+
issues: Issue[];
|
|
14
|
+
cacheUsed: boolean;
|
|
15
|
+
manager: Member["name"];
|
|
16
|
+
org: string;
|
|
17
|
+
repo: string;
|
|
18
|
+
}) => Promise<void>;
|
|
19
|
+
createSummaryIssueBody: (summaryStoryIssue: Map<string, Map<Issue, {
|
|
20
|
+
totalWorkingTime: number;
|
|
21
|
+
totalWorkingTimeByAssignee: Map<string, number>;
|
|
22
|
+
}>>) => string;
|
|
23
|
+
createQuestionIssueBody: (issue: Issue, totalWorkingTime: number, totalWorkingTimeByAssignee: Map<string, number>) => string;
|
|
24
|
+
calculateTotalWorkingMinutesByAssignee: (issue: Issue) => Map<string, number>;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=AnalyzeProblemByIssueUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AnalyzeProblemByIssueUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/AnalyzeProblemByIssueUseCase.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,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AAErE,qBAAa,4BAA4B;IAErC,QAAQ,CAAC,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,gBAAgB,CAAC;IACjE,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,sBAAsB,CAAC;gBAD5D,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,gBAAgB,CAAC,EACxD,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,sBAAsB,CAAC;IAGvE,GAAG,UAAiB;QAClB,WAAW,EAAE,IAAI,EAAE,CAAC;QACpB,OAAO,EAAE,OAAO,CAAC;QACjB,MAAM,EAAE,KAAK,EAAE,CAAC;QAChB,SAAS,EAAE,OAAO,CAAC;QACnB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,EAAE,MAAM,CAAC;KACd,KAAG,OAAO,CAAC,IAAI,CAAC,CA+Ef;IACF,sBAAsB,sBACD,GAAG,CACpB,MAAM,EACN,GAAG,CACD,KAAK,EACL;QACE,gBAAgB,EAAE,MAAM,CAAC;QACzB,0BAA0B,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACjD,CACF,CACF,KACA,MAAM,CAwCP;IACF,uBAAuB,UACd,KAAK,oBACM,MAAM,8BACI,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,KAC9C,MAAM,CA+BP;IAEF,sCAAsC,UAC7B,KAAK,KACX,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAgBpB;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 ClearNextActionHourUseCase {
|
|
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=ClearNextActionHourUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ClearNextActionHourUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/ClearNextActionHourUseCase.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,0BAA0B;IAEnC,QAAQ,CAAC,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,CAAC;gBAA3D,eAAe,EAAE,IAAI,CAAC,eAAe,EAAE,mBAAmB,CAAC;IAGtE,GAAG,UAAiB;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,CAmCf;CACH"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Issue, Label } from '../entities/Issue';
|
|
2
|
+
import { Member } from '../entities/Member';
|
|
3
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
4
|
+
import { SpreadsheetRepository } from './adapter-interfaces/SpreadsheetRepository';
|
|
5
|
+
import { DateRepository } from './adapter-interfaces/DateRepository';
|
|
6
|
+
export type WorkingReportTimelineEvent = {
|
|
7
|
+
issueUrl: string;
|
|
8
|
+
issueTitle: string;
|
|
9
|
+
startHhmm: string;
|
|
10
|
+
endHhmm: string;
|
|
11
|
+
durationHhmm: string;
|
|
12
|
+
warnings: string[];
|
|
13
|
+
labels: string[];
|
|
14
|
+
nameWithOwner: string;
|
|
15
|
+
};
|
|
16
|
+
export declare class GenerateWorkingTimeReportUseCase {
|
|
17
|
+
readonly issueRepository: IssueRepository;
|
|
18
|
+
readonly spreadsheetRepository: SpreadsheetRepository;
|
|
19
|
+
readonly dateRepository: DateRepository;
|
|
20
|
+
constructor(issueRepository: IssueRepository, spreadsheetRepository: SpreadsheetRepository, dateRepository: DateRepository);
|
|
21
|
+
run: (input: {
|
|
22
|
+
issues: Issue[];
|
|
23
|
+
members: Member["name"][];
|
|
24
|
+
manager: Member["name"];
|
|
25
|
+
spreadsheetUrl: string;
|
|
26
|
+
reportIssueTemplate?: string;
|
|
27
|
+
org: string;
|
|
28
|
+
repo: string;
|
|
29
|
+
reportIssueLabels: Label[];
|
|
30
|
+
warningThresholdHour?: number;
|
|
31
|
+
targetDate: Date;
|
|
32
|
+
}) => Promise<void>;
|
|
33
|
+
getWorkingReportIssueTemplate: (input: {
|
|
34
|
+
reportIssueTemplate?: string;
|
|
35
|
+
manager: Member["name"];
|
|
36
|
+
spreadsheetUrl: string;
|
|
37
|
+
}) => Promise<string>;
|
|
38
|
+
createIssueForEachAuthor: (author: string, date: Date, issues: Issue[], org: string, repo: string, labels: Label[], workingReportIssueTemplate: string, workingTimeThresholdHour?: number) => Promise<string[][]>;
|
|
39
|
+
filterTimelineAndSortByAuthor: (issues: Issue[], targetDate: Date, author: Member["name"], workingTimeThresholdHour: number) => WorkingReportTimelineEvent[];
|
|
40
|
+
convertIsoToHhmm: (isoString: string) => string;
|
|
41
|
+
calculateDuration: (startIsoString: string, endIsoString: string) => string;
|
|
42
|
+
calculateTotalHhmm: (timelineEvents: WorkingReportTimelineEvent[]) => string;
|
|
43
|
+
applyToTimelineDetails: (timelineEvents: WorkingReportTimelineEvent[]) => string;
|
|
44
|
+
applyToTimelineDetail: (timelineEvents: WorkingReportTimelineEvent) => string;
|
|
45
|
+
applyReplacementToTemplate: (input: {
|
|
46
|
+
template: string;
|
|
47
|
+
replacement: Record<string, string>;
|
|
48
|
+
}) => string;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=GenerateWorkingTimeReportUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerateWorkingTimeReportUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/GenerateWorkingTimeReportUseCase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACnF,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AAErE,MAAM,MAAM,0BAA0B,GAAG;IACvC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,aAAa,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,qBAAa,gCAAgC;IAEzC,QAAQ,CAAC,eAAe,EAAE,eAAe;IACzC,QAAQ,CAAC,qBAAqB,EAAE,qBAAqB;IACrD,QAAQ,CAAC,cAAc,EAAE,cAAc;gBAF9B,eAAe,EAAE,eAAe,EAChC,qBAAqB,EAAE,qBAAqB,EAC5C,cAAc,EAAE,cAAc;IAGzC,GAAG,UAAiB;QAClB,MAAM,EAAE,KAAK,EAAE,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,cAAc,EAAE,MAAM,CAAC;QACvB,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,iBAAiB,EAAE,KAAK,EAAE,CAAC;QAC3B,oBAAoB,CAAC,EAAE,MAAM,CAAC;QAC9B,UAAU,EAAE,IAAI,CAAC;KAClB,KAAG,OAAO,CAAC,IAAI,CAAC,CAwCf;IACF,6BAA6B,UAAiB;QAC5C,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QACxB,cAAc,EAAE,MAAM,CAAC;KACxB,KAAG,OAAO,CAAC,MAAM,CAAC,CAoBjB;IACF,wBAAwB,WACd,MAAM,QACR,IAAI,UACF,KAAK,EAAE,OACV,MAAM,QACL,MAAM,UACJ,KAAK,EAAE,8BACa,MAAM,wCAEjC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAgDpB;IACF,6BAA6B,WACnB,KAAK,EAAE,cACH,IAAI,UACR,MAAM,CAAC,MAAM,CAAC,4BACI,MAAM,KAC/B,0BAA0B,EAAE,CAkD7B;IACF,gBAAgB,cAAe,MAAM,KAAG,MAAM,CAK5C;IACF,iBAAiB,mBACC,MAAM,gBACR,MAAM,KACnB,MAAM,CAWP;IACF,kBAAkB,mBACA,0BAA0B,EAAE,KAC3C,MAAM,CAMP;IACF,sBAAsB,mBACJ,0BAA0B,EAAE,KAC3C,MAAM,CAKP;IACF,qBAAqB,mBACH,0BAA0B,KACzC,MAAM,CAMP;IACF,0BAA0B,UAAW;QACnC,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACrC,KAAG,MAAM,CAiBR;CACH"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { Issue, Label } from '../entities/Issue';
|
|
2
|
+
import { IssueRepository } from './adapter-interfaces/IssueRepository';
|
|
3
|
+
import { Project } from '../entities/Project';
|
|
4
|
+
import { ProjectRepository } from './adapter-interfaces/ProjectRepository';
|
|
5
|
+
import { GenerateWorkingTimeReportUseCase } from './GenerateWorkingTimeReportUseCase';
|
|
6
|
+
import { Member } from '../entities/Member';
|
|
7
|
+
import { DateRepository } from './adapter-interfaces/DateRepository';
|
|
8
|
+
import { SpreadsheetRepository } from './adapter-interfaces/SpreadsheetRepository';
|
|
9
|
+
import { ActionAnnouncementUseCase } from './ActionAnnouncementUseCase';
|
|
10
|
+
import { SetWorkflowManagementIssueToStoryUseCase } from './SetWorkflowManagementIssueToStoryUseCase';
|
|
11
|
+
import { ClearNextActionHourUseCase } from './ClearNextActionHourUseCase';
|
|
12
|
+
import { AnalyzeProblemByIssueUseCase } from './AnalyzeProblemByIssueUseCase';
|
|
13
|
+
export declare class ProjectNotFoundError extends Error {
|
|
14
|
+
constructor(message: string);
|
|
15
|
+
}
|
|
16
|
+
export declare class HandleScheduledEventUseCase {
|
|
17
|
+
readonly generateWorkingTimeReportUseCase: GenerateWorkingTimeReportUseCase;
|
|
18
|
+
readonly actionAnnouncementUseCase: ActionAnnouncementUseCase;
|
|
19
|
+
readonly setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase;
|
|
20
|
+
readonly clearNextActionHourUseCase: ClearNextActionHourUseCase;
|
|
21
|
+
readonly analyzeProblemByIssueUseCase: AnalyzeProblemByIssueUseCase;
|
|
22
|
+
readonly dateRepository: DateRepository;
|
|
23
|
+
readonly spreadsheetRepository: SpreadsheetRepository;
|
|
24
|
+
readonly projectRepository: ProjectRepository;
|
|
25
|
+
readonly issueRepository: IssueRepository;
|
|
26
|
+
constructor(generateWorkingTimeReportUseCase: GenerateWorkingTimeReportUseCase, actionAnnouncementUseCase: ActionAnnouncementUseCase, setWorkflowManagementIssueToStoryUseCase: SetWorkflowManagementIssueToStoryUseCase, clearNextActionHourUseCase: ClearNextActionHourUseCase, analyzeProblemByIssueUseCase: AnalyzeProblemByIssueUseCase, dateRepository: DateRepository, spreadsheetRepository: SpreadsheetRepository, projectRepository: ProjectRepository, issueRepository: IssueRepository);
|
|
27
|
+
run: (input: {
|
|
28
|
+
org: string;
|
|
29
|
+
projectUrl: string;
|
|
30
|
+
manager: Member["name"];
|
|
31
|
+
workingReport: {
|
|
32
|
+
repo: string;
|
|
33
|
+
members: Member["name"][];
|
|
34
|
+
warningThresholdHour?: number;
|
|
35
|
+
spreadsheetUrl: string;
|
|
36
|
+
reportIssueTemplate?: string;
|
|
37
|
+
reportIssueLabels: Label[];
|
|
38
|
+
};
|
|
39
|
+
}) => Promise<{
|
|
40
|
+
project: Project;
|
|
41
|
+
issues: Issue[];
|
|
42
|
+
cacheUsed: boolean;
|
|
43
|
+
targetDateTimes: Date[];
|
|
44
|
+
}>;
|
|
45
|
+
runForTargetDateTime: (input: {
|
|
46
|
+
org: string;
|
|
47
|
+
manager: Member["name"];
|
|
48
|
+
workingReport: {
|
|
49
|
+
repo: string;
|
|
50
|
+
members: Member["name"][];
|
|
51
|
+
warningThresholdHour?: number;
|
|
52
|
+
spreadsheetUrl: string;
|
|
53
|
+
reportIssueTemplate?: string;
|
|
54
|
+
reportIssueLabels: Label[];
|
|
55
|
+
};
|
|
56
|
+
projectId: Project["id"];
|
|
57
|
+
issues: Issue[];
|
|
58
|
+
targetDateTime: Date;
|
|
59
|
+
}) => Promise<void>;
|
|
60
|
+
static createTargetDateTimes: (from: Date, to: Date) => Date[];
|
|
61
|
+
findTargetDateAndUpdateLastExecutionDateTime: (spreadsheetUrl: string, now: Date) => Promise<Date[]>;
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=HandleScheduledEventUseCase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HandleScheduledEventUseCase.d.ts","sourceRoot":"","sources":["../../../src/domain/usecases/HandleScheduledEventUseCase.ts"],"names":[],"mappings":"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"}
|