@dssp/project 0.0.2 → 0.0.5

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.
Files changed (196) hide show
  1. package/client/pages/checklist/checklist-importer.ts +6 -8
  2. package/client/pages/checklist/checklist-list-page.ts +10 -25
  3. package/client/pages/project/popup/popup-plan-upload.ts +138 -0
  4. package/client/pages/project/{project-create-popup.ts → popup/popup-project-create.ts} +2 -3
  5. package/client/pages/project/project-detail.ts +8 -7
  6. package/client/pages/project/project-list.ts +17 -10
  7. package/client/pages/project/project-plan-management.ts +117 -39
  8. package/client/pages/project/project-schedule-list.ts +2 -0
  9. package/client/pages/project/project-schedule.ts +296 -7
  10. package/client/pages/project/project-setting-list.ts +10 -6
  11. package/client/pages/project/project-update.ts +5 -2
  12. package/client/pages/resource/construction-type-management.ts +192 -0
  13. package/client/pages/resource/manager-management.ts +181 -0
  14. package/client/pages/resource/worker-type-management.ts +194 -0
  15. package/client/pages/task/task-importer.ts +6 -8
  16. package/client/pages/task/task-list-page.ts +10 -25
  17. package/client/route.ts +8 -4
  18. package/dist-client/pages/checklist/checklist-importer.d.ts +1 -0
  19. package/dist-client/pages/checklist/checklist-importer.js +3 -2
  20. package/dist-client/pages/checklist/checklist-importer.js.map +1 -1
  21. package/dist-client/pages/checklist/checklist-list-page.d.ts +1 -0
  22. package/dist-client/pages/checklist/checklist-list-page.js +8 -16
  23. package/dist-client/pages/checklist/checklist-list-page.js.map +1 -1
  24. package/dist-client/pages/project/popup/popup-plan-upload.d.ts +10 -0
  25. package/dist-client/pages/project/popup/popup-plan-upload.js +139 -0
  26. package/dist-client/pages/project/popup/popup-plan-upload.js.map +1 -0
  27. package/dist-client/pages/project/{project-create-popup.d.ts → popup/popup-project-create.d.ts} +1 -3
  28. package/dist-client/pages/project/{project-create-popup.js → popup/popup-project-create.js} +9 -10
  29. package/dist-client/pages/project/popup/popup-project-create.js.map +1 -0
  30. package/dist-client/pages/project/project-detail.d.ts +5 -4
  31. package/dist-client/pages/project/project-detail.js +7 -6
  32. package/dist-client/pages/project/project-detail.js.map +1 -1
  33. package/dist-client/pages/project/project-list.d.ts +12 -2
  34. package/dist-client/pages/project/project-list.js +11 -14
  35. package/dist-client/pages/project/project-list.js.map +1 -1
  36. package/dist-client/pages/project/project-plan-management.d.ts +9 -4
  37. package/dist-client/pages/project/project-plan-management.js +105 -35
  38. package/dist-client/pages/project/project-plan-management.js.map +1 -1
  39. package/dist-client/pages/project/project-schedule-list.d.ts +1 -0
  40. package/dist-client/pages/project/project-schedule-list.js +1 -0
  41. package/dist-client/pages/project/project-schedule-list.js.map +1 -1
  42. package/dist-client/pages/project/project-schedule.d.ts +10 -3
  43. package/dist-client/pages/project/project-schedule.js +294 -7
  44. package/dist-client/pages/project/project-schedule.js.map +1 -1
  45. package/dist-client/pages/project/project-setting-list.d.ts +3 -2
  46. package/dist-client/pages/project/project-setting-list.js +9 -6
  47. package/dist-client/pages/project/project-setting-list.js.map +1 -1
  48. package/dist-client/pages/project/project-update.d.ts +3 -2
  49. package/dist-client/pages/project/project-update.js +4 -2
  50. package/dist-client/pages/project/project-update.js.map +1 -1
  51. package/dist-client/pages/resource/construction-type-management.d.ts +27 -0
  52. package/dist-client/pages/resource/construction-type-management.js +189 -0
  53. package/dist-client/pages/resource/construction-type-management.js.map +1 -0
  54. package/dist-client/pages/resource/manager-management.d.ts +31 -0
  55. package/dist-client/pages/resource/manager-management.js +175 -0
  56. package/dist-client/pages/resource/manager-management.js.map +1 -0
  57. package/dist-client/pages/resource/worker-type-management.d.ts +27 -0
  58. package/dist-client/pages/resource/worker-type-management.js +191 -0
  59. package/dist-client/pages/resource/worker-type-management.js.map +1 -0
  60. package/dist-client/pages/task/task-importer.d.ts +1 -0
  61. package/dist-client/pages/task/task-importer.js +3 -2
  62. package/dist-client/pages/task/task-importer.js.map +1 -1
  63. package/dist-client/pages/task/task-list-page.d.ts +1 -0
  64. package/dist-client/pages/task/task-list-page.js +8 -16
  65. package/dist-client/pages/task/task-list-page.js.map +1 -1
  66. package/dist-client/route.d.ts +1 -1
  67. package/dist-client/route.js +7 -4
  68. package/dist-client/route.js.map +1 -1
  69. package/dist-client/tsconfig.tsbuildinfo +1 -1
  70. package/dist-server/controllers/index.d.ts +0 -0
  71. package/dist-server/controllers/project-to-excel.d.ts +7 -0
  72. package/dist-server/index.d.ts +2 -0
  73. package/dist-server/middlewares/index.d.ts +1 -0
  74. package/dist-server/routes.d.ts +1 -0
  75. package/dist-server/service/check-item/check-item-mutation.d.ts +10 -0
  76. package/dist-server/service/check-item/check-item-query.d.ts +11 -0
  77. package/dist-server/service/check-item/check-item-type.d.ts +18 -0
  78. package/dist-server/service/check-item/check-item.d.ts +18 -0
  79. package/dist-server/service/check-item/index.d.ts +5 -0
  80. package/dist-server/service/checklist/checklist-mutation.d.ts +10 -0
  81. package/dist-server/service/checklist/checklist-query.d.ts +11 -0
  82. package/dist-server/service/checklist/checklist-type.d.ts +18 -0
  83. package/dist-server/service/checklist/checklist.d.ts +26 -0
  84. package/dist-server/service/checklist/index.d.ts +5 -0
  85. package/dist-server/service/construction-type/construction-type-mutation.d.ts +6 -0
  86. package/dist-server/service/construction-type/construction-type-mutation.js +64 -0
  87. package/dist-server/service/construction-type/construction-type-mutation.js.map +1 -0
  88. package/dist-server/service/construction-type/construction-type-query.d.ts +11 -0
  89. package/dist-server/service/construction-type/construction-type-query.js +78 -0
  90. package/dist-server/service/construction-type/construction-type-query.js.map +1 -0
  91. package/dist-server/service/construction-type/construction-type-type.d.ts +11 -0
  92. package/dist-server/service/construction-type/construction-type-type.js +43 -0
  93. package/dist-server/service/construction-type/construction-type-type.js.map +1 -0
  94. package/dist-server/service/construction-type/construction-type.d.ts +16 -0
  95. package/dist-server/service/construction-type/construction-type.js +77 -0
  96. package/dist-server/service/construction-type/construction-type.js.map +1 -0
  97. package/dist-server/service/construction-type/index.d.ts +5 -0
  98. package/dist-server/service/construction-type/index.js +9 -0
  99. package/dist-server/service/construction-type/index.js.map +1 -0
  100. package/dist-server/service/index.d.ts +12 -0
  101. package/dist-server/service/index.js +12 -4
  102. package/dist-server/service/index.js.map +1 -1
  103. package/dist-server/service/manager/index.d.ts +5 -0
  104. package/dist-server/service/manager/index.js +9 -0
  105. package/dist-server/service/manager/index.js.map +1 -0
  106. package/dist-server/service/manager/manager-mutation.d.ts +5 -0
  107. package/dist-server/service/manager/manager-mutation.js +39 -0
  108. package/dist-server/service/manager/manager-mutation.js.map +1 -0
  109. package/dist-server/service/manager/manager-query.d.ts +4 -0
  110. package/dist-server/service/manager/manager-query.js +39 -0
  111. package/dist-server/service/manager/manager-query.js.map +1 -0
  112. package/dist-server/service/manager/manager-type.d.ts +15 -0
  113. package/dist-server/service/manager/manager-type.js +62 -0
  114. package/dist-server/service/manager/manager-type.js.map +1 -0
  115. package/dist-server/service/manager/manager.d.ts +8 -0
  116. package/dist-server/service/manager/manager.js +41 -0
  117. package/dist-server/service/manager/manager.js.map +1 -0
  118. package/dist-server/service/project/index.d.ts +7 -0
  119. package/dist-server/service/project/project-mutation.d.ts +9 -0
  120. package/dist-server/service/project/project-mutation.js +61 -55
  121. package/dist-server/service/project/project-mutation.js.map +1 -1
  122. package/dist-server/service/project/project-query.d.ts +16 -0
  123. package/dist-server/service/project/project-query.js +3 -3
  124. package/dist-server/service/project/project-query.js.map +1 -1
  125. package/dist-server/service/project/project-type.d.ts +29 -0
  126. package/dist-server/service/project/project-type.js +1 -2
  127. package/dist-server/service/project/project-type.js.map +1 -1
  128. package/dist-server/service/project/project.d.ts +35 -0
  129. package/dist-server/service/project/project.js +1 -2
  130. package/dist-server/service/project/project.js.map +1 -1
  131. package/dist-server/service/task/index.d.ts +5 -0
  132. package/dist-server/service/task/task-mutation.d.ts +10 -0
  133. package/dist-server/service/task/task-query.d.ts +11 -0
  134. package/dist-server/service/task/task-type.d.ts +18 -0
  135. package/dist-server/service/task/task.d.ts +25 -0
  136. package/dist-server/service/worker-type/index.d.ts +5 -0
  137. package/dist-server/service/worker-type/index.js +9 -0
  138. package/dist-server/service/worker-type/index.js.map +1 -0
  139. package/dist-server/service/worker-type/worker-type-mutation.d.ts +6 -0
  140. package/dist-server/service/worker-type/worker-type-mutation.js +64 -0
  141. package/dist-server/service/worker-type/worker-type-mutation.js.map +1 -0
  142. package/dist-server/service/worker-type/worker-type-query.d.ts +11 -0
  143. package/dist-server/service/{resource/resource-query.js → worker-type/worker-type-query.js} +31 -39
  144. package/dist-server/service/worker-type/worker-type-query.js.map +1 -0
  145. package/dist-server/service/worker-type/worker-type-type.d.ts +11 -0
  146. package/dist-server/service/worker-type/worker-type-type.js +43 -0
  147. package/dist-server/service/worker-type/worker-type-type.js.map +1 -0
  148. package/dist-server/service/worker-type/worker-type.d.ts +16 -0
  149. package/dist-server/service/{resource/resource.js → worker-type/worker-type.js} +35 -20
  150. package/dist-server/service/worker-type/worker-type.js.map +1 -0
  151. package/dist-server/tsconfig.tsbuildinfo +1 -1
  152. package/package.json +3 -3
  153. package/server/service/construction-type/construction-type-mutation.ts +66 -0
  154. package/server/service/construction-type/construction-type-query.ts +47 -0
  155. package/server/service/construction-type/construction-type-type.ts +26 -0
  156. package/server/service/{resource/resource.ts → construction-type/construction-type.ts} +18 -6
  157. package/server/service/construction-type/index.ts +6 -0
  158. package/server/service/index.ts +12 -4
  159. package/server/service/manager/index.ts +6 -0
  160. package/server/service/manager/manager-mutation.ts +42 -0
  161. package/server/service/manager/manager-query.ts +28 -0
  162. package/server/service/manager/manager-type.ts +40 -0
  163. package/server/service/manager/manager.ts +29 -0
  164. package/server/service/project/project-mutation.ts +101 -79
  165. package/server/service/project/project-query.ts +4 -4
  166. package/server/service/worker-type/index.ts +6 -0
  167. package/server/service/worker-type/worker-type-mutation.ts +66 -0
  168. package/server/service/worker-type/worker-type-query.ts +47 -0
  169. package/server/service/worker-type/worker-type-type.ts +26 -0
  170. package/server/service/worker-type/worker-type.ts +68 -0
  171. package/things-factory.config.js +3 -0
  172. package/client/pages/project/ox-progress-circle.ts +0 -133
  173. package/client/pages/resource/resource-importer.ts +0 -96
  174. package/client/pages/resource/resource-list-page.ts +0 -355
  175. package/dist-client/pages/project/ox-progress-circle.d.ts +0 -41
  176. package/dist-client/pages/project/ox-progress-circle.js +0 -182
  177. package/dist-client/pages/project/ox-progress-circle.js.map +0 -1
  178. package/dist-client/pages/project/project-create-popup.js.map +0 -1
  179. package/dist-client/pages/resource/resource-importer.d.ts +0 -9
  180. package/dist-client/pages/resource/resource-importer.js +0 -100
  181. package/dist-client/pages/resource/resource-importer.js.map +0 -1
  182. package/dist-client/pages/resource/resource-list-page.d.ts +0 -62
  183. package/dist-client/pages/resource/resource-list-page.js +0 -331
  184. package/dist-client/pages/resource/resource-list-page.js.map +0 -1
  185. package/dist-server/service/resource/index.js +0 -9
  186. package/dist-server/service/resource/index.js.map +0 -1
  187. package/dist-server/service/resource/resource-mutation.js +0 -129
  188. package/dist-server/service/resource/resource-mutation.js.map +0 -1
  189. package/dist-server/service/resource/resource-query.js.map +0 -1
  190. package/dist-server/service/resource/resource-type.js +0 -69
  191. package/dist-server/service/resource/resource-type.js.map +0 -1
  192. package/dist-server/service/resource/resource.js.map +0 -1
  193. package/server/service/resource/index.ts +0 -6
  194. package/server/service/resource/resource-mutation.ts +0 -139
  195. package/server/service/resource/resource-query.ts +0 -56
  196. package/server/service/resource/resource-type.ts +0 -49
File without changes
@@ -0,0 +1,7 @@
1
+ export interface Task {
2
+ name: string;
3
+ startDate: Date;
4
+ endDate: Date;
5
+ subtasks?: Task[];
6
+ }
7
+ export declare function generateExcel(tasks: Task[]): Promise<import("exceljs").Buffer>;
@@ -0,0 +1,2 @@
1
+ export * from './service';
2
+ import './routes';
@@ -0,0 +1 @@
1
+ export declare function initMiddlewares(app: any): void;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,10 @@
1
+ import { CheckItem } from './check-item';
2
+ import { NewCheckItem, CheckItemPatch } from './check-item-type';
3
+ export declare class CheckItemMutation {
4
+ createCheckItem(checkItem: NewCheckItem, context: ResolverContext): Promise<CheckItem>;
5
+ updateCheckItem(id: string, patch: CheckItemPatch, context: ResolverContext): Promise<CheckItem>;
6
+ updateMultipleCheckItem(patches: CheckItemPatch[], context: ResolverContext): Promise<CheckItem[]>;
7
+ deleteCheckItem(id: string, context: ResolverContext): Promise<boolean>;
8
+ deleteCheckItems(ids: string[], context: ResolverContext): Promise<boolean>;
9
+ importCheckItems(checkItems: CheckItemPatch[], context: ResolverContext): Promise<boolean>;
10
+ }
@@ -0,0 +1,11 @@
1
+ import { ListParam } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ import { CheckItem } from './check-item';
4
+ import { CheckItemList } from './check-item-type';
5
+ export declare class CheckItemQuery {
6
+ checkItem(id: string, context: ResolverContext): Promise<CheckItem>;
7
+ checkItems(params: ListParam, context: ResolverContext): Promise<CheckItemList>;
8
+ thumbnail(checkItem: CheckItem): Promise<string | undefined>;
9
+ updater(checkItem: CheckItem): Promise<User>;
10
+ creator(checkItem: CheckItem): Promise<User>;
11
+ }
@@ -0,0 +1,18 @@
1
+ import { CheckItem } from './check-item';
2
+ export declare class NewCheckItem {
3
+ name: string;
4
+ description?: string;
5
+ active?: boolean;
6
+ params?: string;
7
+ }
8
+ export declare class CheckItemPatch {
9
+ id?: string;
10
+ name?: string;
11
+ description?: string;
12
+ active?: boolean;
13
+ cuFlag?: string;
14
+ }
15
+ export declare class CheckItemList {
16
+ items: CheckItem[];
17
+ total: number;
18
+ }
@@ -0,0 +1,18 @@
1
+ import { User } from '@things-factory/auth-base';
2
+ import { Checklist } from '../checklist/checklist';
3
+ export declare class CheckItem {
4
+ readonly id: string;
5
+ name?: string;
6
+ result?: boolean;
7
+ reference?: string;
8
+ measuresToBeTaken?: string;
9
+ checklist?: Checklist;
10
+ checklistId?: string;
11
+ createdAt?: Date;
12
+ updatedAt?: Date;
13
+ deletedAt?: Date;
14
+ creator?: User;
15
+ creatorId?: string;
16
+ updater?: User;
17
+ updaterId?: string;
18
+ }
@@ -0,0 +1,5 @@
1
+ import { CheckItem } from './check-item';
2
+ import { CheckItemQuery } from './check-item-query';
3
+ import { CheckItemMutation } from './check-item-mutation';
4
+ export declare const entities: (typeof CheckItem)[];
5
+ export declare const resolvers: (typeof CheckItemQuery | typeof CheckItemMutation)[];
@@ -0,0 +1,10 @@
1
+ import { Checklist } from './checklist';
2
+ import { NewChecklist, ChecklistPatch } from './checklist-type';
3
+ export declare class ChecklistMutation {
4
+ createChecklist(checklist: NewChecklist, context: ResolverContext): Promise<Checklist>;
5
+ updateChecklist(id: string, patch: ChecklistPatch, context: ResolverContext): Promise<Checklist>;
6
+ updateMultipleChecklist(patches: ChecklistPatch[], context: ResolverContext): Promise<Checklist[]>;
7
+ deleteChecklist(id: string, context: ResolverContext): Promise<boolean>;
8
+ deleteChecklists(ids: string[], context: ResolverContext): Promise<boolean>;
9
+ importChecklists(checklists: ChecklistPatch[], context: ResolverContext): Promise<boolean>;
10
+ }
@@ -0,0 +1,11 @@
1
+ import { ListParam } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ import { Checklist } from './checklist';
4
+ import { ChecklistList } from './checklist-type';
5
+ export declare class ChecklistQuery {
6
+ checklist(id: string, context: ResolverContext): Promise<Checklist>;
7
+ checklists(params: ListParam, context: ResolverContext): Promise<ChecklistList>;
8
+ thumbnail(checklist: Checklist): Promise<string | undefined>;
9
+ updater(checklist: Checklist): Promise<User>;
10
+ creator(checklist: Checklist): Promise<User>;
11
+ }
@@ -0,0 +1,18 @@
1
+ import { Checklist } from './checklist';
2
+ export declare class NewChecklist {
3
+ name: string;
4
+ description?: string;
5
+ active?: boolean;
6
+ params?: string;
7
+ }
8
+ export declare class ChecklistPatch {
9
+ id?: string;
10
+ name?: string;
11
+ description?: string;
12
+ active?: boolean;
13
+ cuFlag?: string;
14
+ }
15
+ export declare class ChecklistList {
16
+ items: Checklist[];
17
+ total: number;
18
+ }
@@ -0,0 +1,26 @@
1
+ import { User } from '@things-factory/auth-base';
2
+ import { Task } from '../task/task';
3
+ import { CheckItem } from '../check-item/check-item';
4
+ export declare class Checklist {
5
+ readonly id: string;
6
+ name?: string;
7
+ documentNo?: string;
8
+ part?: string;
9
+ location?: string;
10
+ constructionInspectorDate?: Date;
11
+ supervisorInspectorDate?: Date;
12
+ overallConstructionSignature?: string;
13
+ taskConstructionSignature?: string;
14
+ overallSupervisorySignature?: string;
15
+ taskSupervisorySignature?: string;
16
+ task?: Task;
17
+ taskId?: string;
18
+ checkItems?: CheckItem[];
19
+ createdAt?: Date;
20
+ updatedAt?: Date;
21
+ deletedAt?: Date;
22
+ creator?: User;
23
+ creatorId?: string;
24
+ updater?: User;
25
+ updaterId?: string;
26
+ }
@@ -0,0 +1,5 @@
1
+ import { Checklist } from './checklist';
2
+ import { ChecklistQuery } from './checklist-query';
3
+ import { ChecklistMutation } from './checklist-mutation';
4
+ export declare const entities: (typeof Checklist)[];
5
+ export declare const resolvers: (typeof ChecklistQuery | typeof ChecklistMutation)[];
@@ -0,0 +1,6 @@
1
+ import { ConstructionType } from './construction-type';
2
+ import { ConstructionTypePatch } from './construction-type-type';
3
+ export declare class ConstructionTypeMutation {
4
+ updateMultipleConstructionType(patches: ConstructionTypePatch[], context: ResolverContext): Promise<ConstructionType[]>;
5
+ deleteConstructionTypes(ids: string[], context: ResolverContext): Promise<boolean>;
6
+ }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConstructionTypeMutation = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const type_graphql_1 = require("type-graphql");
6
+ const typeorm_1 = require("typeorm");
7
+ const construction_type_1 = require("./construction-type");
8
+ const construction_type_type_1 = require("./construction-type-type");
9
+ let ConstructionTypeMutation = class ConstructionTypeMutation {
10
+ async updateMultipleConstructionType(patches, context) {
11
+ const { domain, user, tx } = context.state;
12
+ let results = [];
13
+ const _createRecords = patches.filter((patch) => patch.cuFlag.toUpperCase() === '+');
14
+ const _updateRecords = patches.filter((patch) => patch.cuFlag.toUpperCase() === 'M');
15
+ const constructionTypeRepo = tx.getRepository(construction_type_1.ConstructionType);
16
+ if (_createRecords.length > 0) {
17
+ for (let i = 0; i < _createRecords.length; i++) {
18
+ const newRecord = _createRecords[i];
19
+ const result = await constructionTypeRepo.save(Object.assign(Object.assign({}, newRecord), { domain, creator: user, updater: user }));
20
+ results.push(Object.assign(Object.assign({}, result), { cuFlag: '+' }));
21
+ }
22
+ }
23
+ if (_updateRecords.length > 0) {
24
+ for (let i = 0; i < _updateRecords.length; i++) {
25
+ const updateRecord = _updateRecords[i];
26
+ const constructionType = await constructionTypeRepo.findOneBy({ id: updateRecord.id });
27
+ const result = await constructionTypeRepo.save(Object.assign(Object.assign(Object.assign({}, constructionType), updateRecord), { updater: user }));
28
+ results.push(Object.assign(Object.assign({}, result), { cuFlag: 'M' }));
29
+ }
30
+ }
31
+ return results;
32
+ }
33
+ async deleteConstructionTypes(ids, context) {
34
+ const { domain, tx } = context.state;
35
+ await tx.getRepository(construction_type_1.ConstructionType).softDelete({
36
+ domain: { id: domain.id },
37
+ id: (0, typeorm_1.In)(ids)
38
+ });
39
+ return true;
40
+ }
41
+ };
42
+ tslib_1.__decorate([
43
+ (0, type_graphql_1.Directive)('@transaction'),
44
+ (0, type_graphql_1.Mutation)(returns => [construction_type_1.ConstructionType], { description: "To modify multiple ConstructionTypes' information" }),
45
+ tslib_1.__param(0, (0, type_graphql_1.Arg)('patches', type => [construction_type_type_1.ConstructionTypePatch])),
46
+ tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
47
+ tslib_1.__metadata("design:type", Function),
48
+ tslib_1.__metadata("design:paramtypes", [Array, Object]),
49
+ tslib_1.__metadata("design:returntype", Promise)
50
+ ], ConstructionTypeMutation.prototype, "updateMultipleConstructionType", null);
51
+ tslib_1.__decorate([
52
+ (0, type_graphql_1.Directive)('@transaction'),
53
+ (0, type_graphql_1.Mutation)(returns => Boolean, { description: 'To delete multiple ConstructionTypes' }),
54
+ tslib_1.__param(0, (0, type_graphql_1.Arg)('ids', type => [String])),
55
+ tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
56
+ tslib_1.__metadata("design:type", Function),
57
+ tslib_1.__metadata("design:paramtypes", [Array, Object]),
58
+ tslib_1.__metadata("design:returntype", Promise)
59
+ ], ConstructionTypeMutation.prototype, "deleteConstructionTypes", null);
60
+ ConstructionTypeMutation = tslib_1.__decorate([
61
+ (0, type_graphql_1.Resolver)(construction_type_1.ConstructionType)
62
+ ], ConstructionTypeMutation);
63
+ exports.ConstructionTypeMutation = ConstructionTypeMutation;
64
+ //# sourceMappingURL=construction-type-mutation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"construction-type-mutation.js","sourceRoot":"","sources":["../../../server/service/construction-type/construction-type-mutation.ts"],"names":[],"mappings":";;;;AAAA,+CAAsE;AACtE,qCAA4B;AAC5B,2DAAsD;AACtD,qEAAgE;AAGzD,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAG7B,AAAN,KAAK,CAAC,8BAA8B,CACe,OAAgC,EAC1E,OAAwB;QAE/B,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAE1C,IAAI,OAAO,GAAG,EAAE,CAAA;QAChB,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAA;QACzF,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,CAAA;QACzF,MAAM,oBAAoB,GAAG,EAAE,CAAC,aAAa,CAAC,oCAAgB,CAAC,CAAA;QAE/D,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;YAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,SAAS,GAAG,cAAc,CAAC,CAAC,CAAC,CAAA;gBAEnC,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,IAAI,iCACzC,SAAS,KACZ,MAAM,EACN,OAAO,EAAE,IAAI,EACb,OAAO,EAAE,IAAI,IACb,CAAA;gBAEF,OAAO,CAAC,IAAI,iCAAM,MAAM,KAAE,MAAM,EAAE,GAAG,IAAG,CAAA;aACzC;SACF;QAED,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;YAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,CAAA;gBACtC,MAAM,gBAAgB,GAAG,MAAM,oBAAoB,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,YAAY,CAAC,EAAE,EAAE,CAAC,CAAA;gBAEtF,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,IAAI,+CACzC,gBAAgB,GAChB,YAAY,KACf,OAAO,EAAE,IAAI,IACb,CAAA;gBAEF,OAAO,CAAC,IAAI,iCAAM,MAAM,KAAE,MAAM,EAAE,GAAG,IAAG,CAAA;aACzC;SACF;QAED,OAAO,OAAO,CAAA;IAChB,CAAC;IAIK,AAAN,KAAK,CAAC,uBAAuB,CAA+B,GAAa,EAAS,OAAwB;QACxG,MAAM,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEpC,MAAM,EAAE,CAAC,aAAa,CAAC,oCAAgB,CAAC,CAAC,UAAU,CAAC;YAClD,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE;YACzB,EAAE,EAAE,IAAA,YAAE,EAAC,GAAG,CAAC;SACZ,CAAC,CAAA;QAEF,OAAO,IAAI,CAAA;IACb,CAAC;CACF,CAAA;AAxDO;IAFL,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,CAAC,oCAAgB,CAAC,EAAE,EAAE,WAAW,EAAE,mDAAmD,EAAE,CAAC;IAE3G,mBAAA,IAAA,kBAAG,EAAC,SAAS,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,8CAAqB,CAAC,CAAC,CAAA;IAC/C,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;8EAwCP;AAIK;IAFL,IAAA,wBAAS,EAAC,cAAc,CAAC;IACzB,IAAA,uBAAQ,EAAC,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,WAAW,EAAE,sCAAsC,EAAE,CAAC;IACvD,mBAAA,IAAA,kBAAG,EAAC,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;IAAiB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;uEAShF;AA1DU,wBAAwB;IADpC,IAAA,uBAAQ,EAAC,oCAAgB,CAAC;GACd,wBAAwB,CA2DpC;AA3DY,4DAAwB","sourcesContent":["import { Resolver, Mutation, Arg, Ctx, Directive } from 'type-graphql'\nimport { In } from 'typeorm'\nimport { ConstructionType } from './construction-type'\nimport { ConstructionTypePatch } from './construction-type-type'\n\n@Resolver(ConstructionType)\nexport class ConstructionTypeMutation {\n @Directive('@transaction')\n @Mutation(returns => [ConstructionType], { description: \"To modify multiple ConstructionTypes' information\" })\n async updateMultipleConstructionType(\n @Arg('patches', type => [ConstructionTypePatch]) patches: ConstructionTypePatch[],\n @Ctx() context: ResolverContext\n ): Promise<ConstructionType[]> {\n const { domain, user, tx } = context.state\n\n let results = []\n const _createRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === '+')\n const _updateRecords = patches.filter((patch: any) => patch.cuFlag.toUpperCase() === 'M')\n const constructionTypeRepo = tx.getRepository(ConstructionType)\n\n if (_createRecords.length > 0) {\n for (let i = 0; i < _createRecords.length; i++) {\n const newRecord = _createRecords[i]\n\n const result = await constructionTypeRepo.save({\n ...newRecord,\n domain,\n creator: user,\n updater: user\n })\n\n results.push({ ...result, cuFlag: '+' })\n }\n }\n\n if (_updateRecords.length > 0) {\n for (let i = 0; i < _updateRecords.length; i++) {\n const updateRecord = _updateRecords[i]\n const constructionType = await constructionTypeRepo.findOneBy({ id: updateRecord.id })\n\n const result = await constructionTypeRepo.save({\n ...constructionType,\n ...updateRecord,\n updater: user\n })\n\n results.push({ ...result, cuFlag: 'M' })\n }\n }\n\n return results\n }\n\n @Directive('@transaction')\n @Mutation(returns => Boolean, { description: 'To delete multiple ConstructionTypes' })\n async deleteConstructionTypes(@Arg('ids', type => [String]) ids: string[], @Ctx() context: ResolverContext): Promise<boolean> {\n const { domain, tx } = context.state\n\n await tx.getRepository(ConstructionType).softDelete({\n domain: { id: domain.id },\n id: In(ids)\n })\n\n return true\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import { Domain, ListParam } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ import { ConstructionType } from './construction-type';
4
+ import { ConstructionTypeList } from './construction-type-type';
5
+ export declare class ConstructionTypeQuery {
6
+ constructionType(id: string, context: ResolverContext): Promise<ConstructionType>;
7
+ constructionTypes(params: ListParam, context: ResolverContext): Promise<ConstructionTypeList>;
8
+ domain(constructionType: ConstructionType): Promise<Domain>;
9
+ updater(constructionType: ConstructionType): Promise<User>;
10
+ creator(constructionType: ConstructionType): Promise<User>;
11
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConstructionTypeQuery = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const type_graphql_1 = require("type-graphql");
6
+ const shell_1 = require("@things-factory/shell");
7
+ const auth_base_1 = require("@things-factory/auth-base");
8
+ const construction_type_1 = require("./construction-type");
9
+ const construction_type_type_1 = require("./construction-type-type");
10
+ let ConstructionTypeQuery = class ConstructionTypeQuery {
11
+ async constructionType(id, context) {
12
+ const { domain } = context.state;
13
+ return await (0, shell_1.getRepository)(construction_type_1.ConstructionType).findOne({
14
+ where: { domain: { id: domain.id }, id }
15
+ });
16
+ }
17
+ async constructionTypes(params, context) {
18
+ const { domain } = context.state;
19
+ const queryBuilder = (0, shell_1.getQueryBuilderFromListParams)({
20
+ domain,
21
+ params,
22
+ repository: await (0, shell_1.getRepository)(construction_type_1.ConstructionType)
23
+ });
24
+ const [items, total] = await queryBuilder.getManyAndCount();
25
+ return { items, total };
26
+ }
27
+ async domain(constructionType) {
28
+ return await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: constructionType.domainId });
29
+ }
30
+ async updater(constructionType) {
31
+ return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: constructionType.updaterId });
32
+ }
33
+ async creator(constructionType) {
34
+ return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: constructionType.creatorId });
35
+ }
36
+ };
37
+ tslib_1.__decorate([
38
+ (0, type_graphql_1.Query)(returns => construction_type_1.ConstructionType, { nullable: true, description: 'To fetch a ConstructionType' }),
39
+ tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
40
+ tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
41
+ tslib_1.__metadata("design:type", Function),
42
+ tslib_1.__metadata("design:paramtypes", [String, Object]),
43
+ tslib_1.__metadata("design:returntype", Promise)
44
+ ], ConstructionTypeQuery.prototype, "constructionType", null);
45
+ tslib_1.__decorate([
46
+ (0, type_graphql_1.Query)(returns => construction_type_type_1.ConstructionTypeList, { description: 'To fetch multiple ConstructionTypes' }),
47
+ tslib_1.__param(0, (0, type_graphql_1.Args)()),
48
+ tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
49
+ tslib_1.__metadata("design:type", Function),
50
+ tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
51
+ tslib_1.__metadata("design:returntype", Promise)
52
+ ], ConstructionTypeQuery.prototype, "constructionTypes", null);
53
+ tslib_1.__decorate([
54
+ (0, type_graphql_1.FieldResolver)(type => shell_1.Domain),
55
+ tslib_1.__param(0, (0, type_graphql_1.Root)()),
56
+ tslib_1.__metadata("design:type", Function),
57
+ tslib_1.__metadata("design:paramtypes", [construction_type_1.ConstructionType]),
58
+ tslib_1.__metadata("design:returntype", Promise)
59
+ ], ConstructionTypeQuery.prototype, "domain", null);
60
+ tslib_1.__decorate([
61
+ (0, type_graphql_1.FieldResolver)(type => auth_base_1.User),
62
+ tslib_1.__param(0, (0, type_graphql_1.Root)()),
63
+ tslib_1.__metadata("design:type", Function),
64
+ tslib_1.__metadata("design:paramtypes", [construction_type_1.ConstructionType]),
65
+ tslib_1.__metadata("design:returntype", Promise)
66
+ ], ConstructionTypeQuery.prototype, "updater", null);
67
+ tslib_1.__decorate([
68
+ (0, type_graphql_1.FieldResolver)(type => auth_base_1.User),
69
+ tslib_1.__param(0, (0, type_graphql_1.Root)()),
70
+ tslib_1.__metadata("design:type", Function),
71
+ tslib_1.__metadata("design:paramtypes", [construction_type_1.ConstructionType]),
72
+ tslib_1.__metadata("design:returntype", Promise)
73
+ ], ConstructionTypeQuery.prototype, "creator", null);
74
+ ConstructionTypeQuery = tslib_1.__decorate([
75
+ (0, type_graphql_1.Resolver)(construction_type_1.ConstructionType)
76
+ ], ConstructionTypeQuery);
77
+ exports.ConstructionTypeQuery = ConstructionTypeQuery;
78
+ //# sourceMappingURL=construction-type-query.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"construction-type-query.js","sourceRoot":"","sources":["../../../server/service/construction-type/construction-type-query.ts"],"names":[],"mappings":";;;;AAAA,+CAAmF;AACnF,iDAAuG;AACvG,yDAAgD;AAChD,2DAAsD;AACtD,qEAA+D;AAGxD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAE1B,AAAN,KAAK,CAAC,gBAAgB,CAAY,EAAU,EAAS,OAAwB;QAC3E,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEhC,OAAO,MAAM,IAAA,qBAAa,EAAC,oCAAgB,CAAC,CAAC,OAAO,CAAC;YACnD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;SACzC,CAAC,CAAA;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,iBAAiB,CAAS,MAAiB,EAAS,OAAwB;QAChF,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEhC,MAAM,YAAY,GAAG,IAAA,qCAA6B,EAAC;YACjD,MAAM;YACN,MAAM;YACN,UAAU,EAAE,MAAM,IAAA,qBAAa,EAAC,oCAAgB,CAAC;SAClD,CAAC,CAAA;QAEF,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,YAAY,CAAC,eAAe,EAAE,CAAA;QAE3D,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAA;IACzB,CAAC;IAGK,AAAN,KAAK,CAAC,MAAM,CAAS,gBAAkC;QACrD,OAAO,MAAM,IAAA,qBAAa,EAAC,cAAM,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,gBAAgB,CAAC,QAAQ,EAAE,CAAC,CAAA;IACjF,CAAC;IAGK,AAAN,KAAK,CAAC,OAAO,CAAS,gBAAkC;QACtD,OAAO,MAAM,IAAA,qBAAa,EAAC,gBAAI,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAA;IAChF,CAAC;IAGK,AAAN,KAAK,CAAC,OAAO,CAAS,gBAAkC;QACtD,OAAO,MAAM,IAAA,qBAAa,EAAC,gBAAI,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAA;IAChF,CAAC;CACF,CAAA;AArCO;IADL,IAAA,oBAAK,EAAC,OAAO,CAAC,EAAE,CAAC,oCAAiB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,6BAA6B,EAAE,CAAC;IAC5E,mBAAA,IAAA,kBAAG,EAAC,IAAI,CAAC,CAAA;IAAc,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;6DAMnD;AAGK;IADL,IAAA,oBAAK,EAAC,OAAO,CAAC,EAAE,CAAC,6CAAoB,EAAE,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;IACtE,mBAAA,IAAA,mBAAI,GAAE,CAAA;IAAqB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;6CAAjB,iBAAS;;8DAYhD;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IAChB,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAmB,oCAAgB;;mDAEtD;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,CAAC;IACb,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAmB,oCAAgB;;oDAEvD;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,CAAC;IACb,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAmB,oCAAgB;;oDAEvD;AAtCU,qBAAqB;IADjC,IAAA,uBAAQ,EAAC,oCAAgB,CAAC;GACd,qBAAqB,CAuCjC;AAvCY,sDAAqB","sourcesContent":["import { Resolver, Query, FieldResolver, Root, Args, Arg, Ctx } from 'type-graphql'\nimport { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { ConstructionType } from './construction-type'\nimport { ConstructionTypeList } from './construction-type-type'\n\n@Resolver(ConstructionType)\nexport class ConstructionTypeQuery {\n @Query(returns => ConstructionType!, { nullable: true, description: 'To fetch a ConstructionType' })\n async constructionType(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<ConstructionType> {\n const { domain } = context.state\n\n return await getRepository(ConstructionType).findOne({\n where: { domain: { id: domain.id }, id }\n })\n }\n\n @Query(returns => ConstructionTypeList, { description: 'To fetch multiple ConstructionTypes' })\n async constructionTypes(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<ConstructionTypeList> {\n const { domain } = context.state\n\n const queryBuilder = getQueryBuilderFromListParams({\n domain,\n params,\n repository: await getRepository(ConstructionType)\n })\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() constructionType: ConstructionType): Promise<Domain> {\n return await getRepository(Domain).findOneBy({ id: constructionType.domainId })\n }\n\n @FieldResolver(type => User)\n async updater(@Root() constructionType: ConstructionType): Promise<User> {\n return await getRepository(User).findOneBy({ id: constructionType.updaterId })\n }\n\n @FieldResolver(type => User)\n async creator(@Root() constructionType: ConstructionType): Promise<User> {\n return await getRepository(User).findOneBy({ id: constructionType.creatorId })\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import { ConstructionType } from './construction-type';
2
+ export declare class ConstructionTypePatch {
3
+ id?: string;
4
+ name?: string;
5
+ description?: string;
6
+ cuFlag?: string;
7
+ }
8
+ export declare class ConstructionTypeList {
9
+ items: ConstructionType[];
10
+ total: number;
11
+ }
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConstructionTypeList = exports.ConstructionTypePatch = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const type_graphql_1 = require("type-graphql");
6
+ const construction_type_1 = require("./construction-type");
7
+ let ConstructionTypePatch = class ConstructionTypePatch {
8
+ };
9
+ tslib_1.__decorate([
10
+ (0, type_graphql_1.Field)(type => type_graphql_1.ID, { nullable: true }),
11
+ tslib_1.__metadata("design:type", String)
12
+ ], ConstructionTypePatch.prototype, "id", void 0);
13
+ tslib_1.__decorate([
14
+ (0, type_graphql_1.Field)({ nullable: true }),
15
+ tslib_1.__metadata("design:type", String)
16
+ ], ConstructionTypePatch.prototype, "name", void 0);
17
+ tslib_1.__decorate([
18
+ (0, type_graphql_1.Field)({ nullable: true }),
19
+ tslib_1.__metadata("design:type", String)
20
+ ], ConstructionTypePatch.prototype, "description", void 0);
21
+ tslib_1.__decorate([
22
+ (0, type_graphql_1.Field)({ nullable: true }),
23
+ tslib_1.__metadata("design:type", String)
24
+ ], ConstructionTypePatch.prototype, "cuFlag", void 0);
25
+ ConstructionTypePatch = tslib_1.__decorate([
26
+ (0, type_graphql_1.InputType)()
27
+ ], ConstructionTypePatch);
28
+ exports.ConstructionTypePatch = ConstructionTypePatch;
29
+ let ConstructionTypeList = class ConstructionTypeList {
30
+ };
31
+ tslib_1.__decorate([
32
+ (0, type_graphql_1.Field)(type => [construction_type_1.ConstructionType]),
33
+ tslib_1.__metadata("design:type", Array)
34
+ ], ConstructionTypeList.prototype, "items", void 0);
35
+ tslib_1.__decorate([
36
+ (0, type_graphql_1.Field)(type => type_graphql_1.Int),
37
+ tslib_1.__metadata("design:type", Number)
38
+ ], ConstructionTypeList.prototype, "total", void 0);
39
+ ConstructionTypeList = tslib_1.__decorate([
40
+ (0, type_graphql_1.ObjectType)()
41
+ ], ConstructionTypeList);
42
+ exports.ConstructionTypeList = ConstructionTypeList;
43
+ //# sourceMappingURL=construction-type-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"construction-type-type.js","sourceRoot":"","sources":["../../../server/service/construction-type/construction-type-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAoE;AACpE,2DAAsD;AAG/C,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;CAYjC,CAAA;AAXC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDAC3B;AAEX;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;mDACb;AAEb;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0DACN;AAEpB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qDACX;AAXJ,qBAAqB;IADjC,IAAA,wBAAS,GAAE;GACC,qBAAqB,CAYjC;AAZY,sDAAqB;AAe3B,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;CAMhC,CAAA;AALC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,oCAAgB,CAAC,CAAC;;mDACT;AAEzB;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,CAAC;;mDACN;AALF,oBAAoB;IADhC,IAAA,yBAAU,GAAE;GACA,oBAAoB,CAMhC;AANY,oDAAoB","sourcesContent":["import { ObjectType, Field, InputType, Int, ID } from 'type-graphql'\nimport { ConstructionType } from './construction-type'\n\n@InputType()\nexport class ConstructionTypePatch {\n @Field(type => ID, { nullable: true })\n id?: string\n\n @Field({ nullable: true })\n name?: string\n\n @Field({ nullable: true })\n description?: string\n\n @Field({ nullable: true })\n cuFlag?: string\n}\n\n@ObjectType()\nexport class ConstructionTypeList {\n @Field(type => [ConstructionType])\n items: ConstructionType[]\n\n @Field(type => Int)\n total: number\n}\n"]}
@@ -0,0 +1,16 @@
1
+ import { Domain } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ export declare class ConstructionType {
4
+ readonly id: string;
5
+ domain?: Domain;
6
+ domainId?: string;
7
+ name?: string;
8
+ description?: string;
9
+ createdAt?: Date;
10
+ updatedAt?: Date;
11
+ deletedAt?: Date;
12
+ creator?: User;
13
+ creatorId?: string;
14
+ updater?: User;
15
+ updaterId?: string;
16
+ }
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConstructionType = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const typeorm_1 = require("typeorm");
6
+ const type_graphql_1 = require("type-graphql");
7
+ const shell_1 = require("@things-factory/shell");
8
+ const auth_base_1 = require("@things-factory/auth-base");
9
+ let ConstructionType = class ConstructionType {
10
+ };
11
+ tslib_1.__decorate([
12
+ (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
13
+ (0, type_graphql_1.Field)(type => type_graphql_1.ID),
14
+ tslib_1.__metadata("design:type", String)
15
+ ], ConstructionType.prototype, "id", void 0);
16
+ tslib_1.__decorate([
17
+ (0, typeorm_1.ManyToOne)(type => shell_1.Domain),
18
+ (0, type_graphql_1.Field)({ nullable: true }),
19
+ tslib_1.__metadata("design:type", shell_1.Domain)
20
+ ], ConstructionType.prototype, "domain", void 0);
21
+ tslib_1.__decorate([
22
+ (0, typeorm_1.RelationId)((constructionType) => constructionType.domain),
23
+ tslib_1.__metadata("design:type", String)
24
+ ], ConstructionType.prototype, "domainId", void 0);
25
+ tslib_1.__decorate([
26
+ (0, typeorm_1.Column)(),
27
+ (0, type_graphql_1.Field)({ nullable: true }),
28
+ tslib_1.__metadata("design:type", String)
29
+ ], ConstructionType.prototype, "name", void 0);
30
+ tslib_1.__decorate([
31
+ (0, typeorm_1.Column)({ nullable: true }),
32
+ (0, type_graphql_1.Field)({ nullable: true }),
33
+ tslib_1.__metadata("design:type", String)
34
+ ], ConstructionType.prototype, "description", void 0);
35
+ tslib_1.__decorate([
36
+ (0, typeorm_1.CreateDateColumn)(),
37
+ (0, type_graphql_1.Field)({ nullable: true }),
38
+ tslib_1.__metadata("design:type", Date)
39
+ ], ConstructionType.prototype, "createdAt", void 0);
40
+ tslib_1.__decorate([
41
+ (0, typeorm_1.UpdateDateColumn)(),
42
+ (0, type_graphql_1.Field)({ nullable: true }),
43
+ tslib_1.__metadata("design:type", Date)
44
+ ], ConstructionType.prototype, "updatedAt", void 0);
45
+ tslib_1.__decorate([
46
+ (0, typeorm_1.DeleteDateColumn)(),
47
+ (0, type_graphql_1.Field)({ nullable: true }),
48
+ tslib_1.__metadata("design:type", Date)
49
+ ], ConstructionType.prototype, "deletedAt", void 0);
50
+ tslib_1.__decorate([
51
+ (0, typeorm_1.ManyToOne)(type => auth_base_1.User, { nullable: true }),
52
+ (0, type_graphql_1.Field)(type => auth_base_1.User, { nullable: true }),
53
+ tslib_1.__metadata("design:type", auth_base_1.User)
54
+ ], ConstructionType.prototype, "creator", void 0);
55
+ tslib_1.__decorate([
56
+ (0, typeorm_1.RelationId)((constructionType) => constructionType.creator),
57
+ tslib_1.__metadata("design:type", String)
58
+ ], ConstructionType.prototype, "creatorId", void 0);
59
+ tslib_1.__decorate([
60
+ (0, typeorm_1.ManyToOne)(type => auth_base_1.User, { nullable: true }),
61
+ (0, type_graphql_1.Field)(type => auth_base_1.User, { nullable: true }),
62
+ tslib_1.__metadata("design:type", auth_base_1.User)
63
+ ], ConstructionType.prototype, "updater", void 0);
64
+ tslib_1.__decorate([
65
+ (0, typeorm_1.RelationId)((constructionType) => constructionType.updater),
66
+ tslib_1.__metadata("design:type", String)
67
+ ], ConstructionType.prototype, "updaterId", void 0);
68
+ ConstructionType = tslib_1.__decorate([
69
+ (0, typeorm_1.Entity)(),
70
+ (0, typeorm_1.Index)('ix_construction_type_0', (constructionType) => [constructionType.domain, constructionType.name], {
71
+ unique: true,
72
+ where: '"deleted_at" IS NULL'
73
+ }),
74
+ (0, type_graphql_1.ObjectType)({ description: '공종 타입' })
75
+ ], ConstructionType);
76
+ exports.ConstructionType = ConstructionType;
77
+ //# sourceMappingURL=construction-type.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"construction-type.js","sourceRoot":"","sources":["../../../server/service/construction-type/construction-type.ts"],"names":[],"mappings":";;;;AAAA,qCAUgB;AAChB,+CAAoD;AAEpD,iDAA8C;AAC9C,yDAAgD;AAQzC,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;CA6C5B,CAAA;AA5CC;IAAC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;4CACC;AAEnB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACjB,cAAM;gDAAA;AAEf;IAAC,IAAA,oBAAU,EAAC,CAAC,gBAAkC,EAAE,EAAE,CAAC,gBAAgB,CAAC,MAAM,CAAC;;kDAC3D;AAEjB;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CACb;AAEb;IAAC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC1B,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qDACN;AAEpB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;mDAAA;AAEhB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;mDAAA;AAEhB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;mDAAA;AAEhB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC3C,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCAC9B,gBAAI;iDAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,gBAAkC,EAAE,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC;;mDAC3D;AAElB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC3C,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCAC9B,gBAAI;iDAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,gBAAkC,EAAE,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC;;mDAC3D;AA5CP,gBAAgB;IAN5B,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,wBAAwB,EAAE,CAAC,gBAAkC,EAAE,EAAE,CAAC,CAAC,gBAAgB,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,EAAE;QACzH,MAAM,EAAE,IAAI;QACZ,KAAK,EAAE,sBAAsB;KAC9B,CAAC;IACD,IAAA,yBAAU,EAAC,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;GACxB,gBAAgB,CA6C5B;AA7CY,4CAAgB","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n DeleteDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, ID } from 'type-graphql'\n\nimport { Domain } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\n\n@Entity()\n@Index('ix_construction_type_0', (constructionType: ConstructionType) => [constructionType.domain, constructionType.name], {\n unique: true,\n where: '\"deleted_at\" IS NULL'\n})\n@ObjectType({ description: '공종 타입' })\nexport class ConstructionType {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field({ nullable: true })\n domain?: Domain\n\n @RelationId((constructionType: ConstructionType) => constructionType.domain)\n domainId?: string\n\n @Column()\n @Field({ nullable: true })\n name?: string\n\n @Column({ nullable: true })\n @Field({ nullable: true })\n description?: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @DeleteDateColumn()\n @Field({ nullable: true })\n deletedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n creator?: User\n\n @RelationId((constructionType: ConstructionType) => constructionType.creator)\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n updater?: User\n\n @RelationId((constructionType: ConstructionType) => constructionType.updater)\n updaterId?: string\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { ConstructionType } from './construction-type';
2
+ import { ConstructionTypeQuery } from './construction-type-query';
3
+ import { ConstructionTypeMutation } from './construction-type-mutation';
4
+ export declare const entities: (typeof ConstructionType)[];
5
+ export declare const resolvers: (typeof ConstructionTypeQuery | typeof ConstructionTypeMutation)[];
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolvers = exports.entities = void 0;
4
+ const construction_type_1 = require("./construction-type");
5
+ const construction_type_query_1 = require("./construction-type-query");
6
+ const construction_type_mutation_1 = require("./construction-type-mutation");
7
+ exports.entities = [construction_type_1.ConstructionType];
8
+ exports.resolvers = [construction_type_query_1.ConstructionTypeQuery, construction_type_mutation_1.ConstructionTypeMutation];
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/service/construction-type/index.ts"],"names":[],"mappings":";;;AAAA,2DAAsD;AACtD,uEAAiE;AACjE,6EAAuE;AAE1D,QAAA,QAAQ,GAAG,CAAC,oCAAgB,CAAC,CAAA;AAC7B,QAAA,SAAS,GAAG,CAAC,+CAAqB,EAAE,qDAAwB,CAAC,CAAA","sourcesContent":["import { ConstructionType } from './construction-type'\nimport { ConstructionTypeQuery } from './construction-type-query'\nimport { ConstructionTypeMutation } from './construction-type-mutation'\n\nexport const entities = [ConstructionType]\nexport const resolvers = [ConstructionTypeQuery, ConstructionTypeMutation]\n"]}
@@ -0,0 +1,12 @@
1
+ export * from './construction-type/construction-type';
2
+ export * from './worker-type/worker-type';
3
+ export * from './manager/manager';
4
+ export * from './check-item/check-item';
5
+ export * from './checklist/checklist';
6
+ export * from './task/task';
7
+ export * from './project/project';
8
+ export declare const entities: (typeof import("./construction-type/construction-type").ConstructionType | typeof import("./manager/manager").Manager | typeof import("./project/project").Project | typeof import("./task/task").Task | typeof import("./checklist/checklist").Checklist | typeof import("./check-item/check-item").CheckItem)[];
9
+ export declare const schema: {
10
+ resolverClasses: (typeof import("./construction-type/construction-type-query").ConstructionTypeQuery | typeof import("./construction-type/construction-type-mutation").ConstructionTypeMutation | typeof import("./worker-type/worker-type-query").WorkerTypeQuery | typeof import("./worker-type/worker-type-mutation").WorkerTypeMutation | typeof import("./manager/manager-query").ManagerQuery | typeof import("./manager/manager-mutation").ManagerMutation | typeof import("./check-item/check-item-query").CheckItemQuery | typeof import("./check-item/check-item-mutation").CheckItemMutation | typeof import("./checklist/checklist-query").ChecklistQuery | typeof import("./checklist/checklist-mutation").ChecklistMutation | typeof import("./task/task-query").TaskQuery | typeof import("./task/task-mutation").TaskMutation | typeof import("./project/project-query").ProjectQuery | typeof import("./project/project-mutation").ProjectMutation)[];
11
+ };
12
+ export declare const types: typeof import("./project/project-type").InspectionSummary[];
@@ -3,20 +3,26 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.types = exports.schema = exports.entities = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  /* EXPORT ENTITY TYPES */
6
- tslib_1.__exportStar(require("./resource/resource"), exports);
6
+ tslib_1.__exportStar(require("./construction-type/construction-type"), exports);
7
+ tslib_1.__exportStar(require("./worker-type/worker-type"), exports);
8
+ tslib_1.__exportStar(require("./manager/manager"), exports);
7
9
  tslib_1.__exportStar(require("./check-item/check-item"), exports);
8
10
  tslib_1.__exportStar(require("./checklist/checklist"), exports);
9
11
  tslib_1.__exportStar(require("./task/task"), exports);
10
12
  tslib_1.__exportStar(require("./project/project"), exports);
11
13
  /* IMPORT ENTITIES AND RESOLVERS */
12
- const resource_1 = require("./resource");
14
+ const construction_type_1 = require("./construction-type");
15
+ const worker_type_1 = require("./worker-type");
16
+ const manager_1 = require("./manager");
13
17
  const check_item_1 = require("./check-item");
14
18
  const checklist_1 = require("./checklist");
15
19
  const task_1 = require("./task");
16
20
  const project_1 = require("./project");
17
21
  exports.entities = [
18
22
  /* ENTITIES */
19
- ...resource_1.entities,
23
+ ...construction_type_1.entities,
24
+ ...worker_type_1.entities,
25
+ ...manager_1.entities,
20
26
  ...check_item_1.entities,
21
27
  ...checklist_1.entities,
22
28
  ...task_1.entities,
@@ -25,7 +31,9 @@ exports.entities = [
25
31
  exports.schema = {
26
32
  resolverClasses: [
27
33
  /* RESOLVER CLASSES */
28
- ...resource_1.resolvers,
34
+ ...construction_type_1.resolvers,
35
+ ...worker_type_1.resolvers,
36
+ ...manager_1.resolvers,
29
37
  ...check_item_1.resolvers,
30
38
  ...checklist_1.resolvers,
31
39
  ...task_1.resolvers,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/service/index.ts"],"names":[],"mappings":";;;;AAAA,yBAAyB;AACzB,8DAAmC;AACnC,kEAAuC;AACvC,gEAAqC;AACrC,sDAA2B;AAC3B,4DAAiC;AAEjC,mCAAmC;AACnC,yCAAyF;AACzF,6CAA6F;AAC7F,2CAA4F;AAC5F,iCAA6E;AAC7E,uCAA6G;AAEhG,QAAA,QAAQ,GAAG;IACtB,cAAc;IACd,GAAG,mBAAgB;IACnB,GAAG,qBAAiB;IACpB,GAAG,oBAAiB;IACpB,GAAG,eAAY;IACf,GAAG,kBAAe;CACnB,CAAA;AAEY,QAAA,MAAM,GAAG;IACpB,eAAe,EAAE;QACf,sBAAsB;QACtB,GAAG,oBAAiB;QACpB,GAAG,sBAAkB;QACrB,GAAG,qBAAkB;QACrB,GAAG,gBAAa;QAChB,GAAG,mBAAgB;KACpB;CACF,CAAA;AAEY,QAAA,KAAK,GAAG,CAAC,GAAG,eAAY,CAAC,CAAA","sourcesContent":["/* EXPORT ENTITY TYPES */\nexport * from './resource/resource'\nexport * from './check-item/check-item'\nexport * from './checklist/checklist'\nexport * from './task/task'\nexport * from './project/project'\n\n/* IMPORT ENTITIES AND RESOLVERS */\nimport { entities as ResourceEntities, resolvers as ResourceResolvers } from './resource'\nimport { entities as CheckItemEntities, resolvers as CheckItemResolvers } from './check-item'\nimport { entities as ChecklistEntities, resolvers as ChecklistResolvers } from './checklist'\nimport { entities as TaskEntities, resolvers as TaskResolvers } from './task'\nimport { entities as ProjectEntities, resolvers as ProjectResolvers, types as ProjectTypes } from './project'\n\nexport const entities = [\n /* ENTITIES */\n ...ResourceEntities,\n ...CheckItemEntities,\n ...ChecklistEntities,\n ...TaskEntities,\n ...ProjectEntities\n]\n\nexport const schema = {\n resolverClasses: [\n /* RESOLVER CLASSES */\n ...ResourceResolvers,\n ...CheckItemResolvers,\n ...ChecklistResolvers,\n ...TaskResolvers,\n ...ProjectResolvers\n ]\n}\n\nexport const types = [...ProjectTypes]\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/service/index.ts"],"names":[],"mappings":";;;;AAAA,yBAAyB;AACzB,gFAAqD;AACrD,oEAAyC;AACzC,4DAAiC;AACjC,kEAAuC;AACvC,gEAAqC;AACrC,sDAA2B;AAC3B,4DAAiC;AAEjC,mCAAmC;AACnC,2DAAkH;AAClH,+CAAgG;AAChG,uCAAsF;AACtF,6CAA6F;AAC7F,2CAA4F;AAC5F,iCAA6E;AAC7E,uCAA6G;AAEhG,QAAA,QAAQ,GAAG;IACtB,cAAc;IACd,GAAG,4BAAwB;IAC3B,GAAG,sBAAkB;IACrB,GAAG,kBAAe;IAClB,GAAG,qBAAiB;IACpB,GAAG,oBAAiB;IACpB,GAAG,eAAY;IACf,GAAG,kBAAe;CACnB,CAAA;AAEY,QAAA,MAAM,GAAG;IACpB,eAAe,EAAE;QACf,sBAAsB;QACtB,GAAG,6BAAyB;QAC5B,GAAG,uBAAmB;QACtB,GAAG,mBAAgB;QACnB,GAAG,sBAAkB;QACrB,GAAG,qBAAkB;QACrB,GAAG,gBAAa;QAChB,GAAG,mBAAgB;KACpB;CACF,CAAA;AAEY,QAAA,KAAK,GAAG,CAAC,GAAG,eAAY,CAAC,CAAA","sourcesContent":["/* EXPORT ENTITY TYPES */\nexport * from './construction-type/construction-type'\nexport * from './worker-type/worker-type'\nexport * from './manager/manager'\nexport * from './check-item/check-item'\nexport * from './checklist/checklist'\nexport * from './task/task'\nexport * from './project/project'\n\n/* IMPORT ENTITIES AND RESOLVERS */\nimport { entities as ConstructionTypeEntities, resolvers as ConstructionTypeResolvers } from './construction-type'\nimport { entities as WorkerTypeEntities, resolvers as WorkerTypeResolvers } from './worker-type'\nimport { entities as ManagerEntities, resolvers as ManagerResolvers } from './manager'\nimport { entities as CheckItemEntities, resolvers as CheckItemResolvers } from './check-item'\nimport { entities as ChecklistEntities, resolvers as ChecklistResolvers } from './checklist'\nimport { entities as TaskEntities, resolvers as TaskResolvers } from './task'\nimport { entities as ProjectEntities, resolvers as ProjectResolvers, types as ProjectTypes } from './project'\n\nexport const entities = [\n /* ENTITIES */\n ...ConstructionTypeEntities,\n ...WorkerTypeEntities,\n ...ManagerEntities,\n ...CheckItemEntities,\n ...ChecklistEntities,\n ...TaskEntities,\n ...ProjectEntities\n]\n\nexport const schema = {\n resolverClasses: [\n /* RESOLVER CLASSES */\n ...ConstructionTypeResolvers,\n ...WorkerTypeResolvers,\n ...ManagerResolvers,\n ...CheckItemResolvers,\n ...ChecklistResolvers,\n ...TaskResolvers,\n ...ProjectResolvers\n ]\n}\n\nexport const types = [...ProjectTypes]\n"]}
@@ -0,0 +1,5 @@
1
+ import { Manager } from './manager';
2
+ import { ManagerQuery } from './manager-query';
3
+ import { ManagerMutation } from './manager-mutation';
4
+ export declare const entities: (typeof Manager)[];
5
+ export declare const resolvers: (typeof ManagerQuery | typeof ManagerMutation)[];