@things-factory/board-service 7.0.1-beta.9 → 7.0.1-rc.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.
Files changed (147) hide show
  1. package/dist-server/constants/error-code.d.ts +2 -0
  2. package/dist-server/controllers/analyzer/analyze-integration.d.ts +5 -0
  3. package/dist-server/controllers/analyzer/analyze-integration.js +1 -2
  4. package/dist-server/controllers/analyzer/analyze-integration.js.map +1 -1
  5. package/dist-server/controllers/fonts.d.ts +9 -0
  6. package/dist-server/controllers/fonts.js.map +1 -1
  7. package/dist-server/controllers/headless-model.d.ts +6 -0
  8. package/dist-server/controllers/headless-model.js.map +1 -1
  9. package/dist-server/controllers/headless-playlist.d.ts +5 -0
  10. package/dist-server/controllers/headless-playlist.js.map +1 -1
  11. package/dist-server/controllers/headless-pool-for-board.d.ts +1 -0
  12. package/dist-server/controllers/headless-pool-for-board.js +1 -2
  13. package/dist-server/controllers/headless-pool-for-board.js.map +1 -1
  14. package/dist-server/controllers/headless-pool-for-label.d.ts +1 -0
  15. package/dist-server/controllers/headless-pool-for-label.js +4 -10
  16. package/dist-server/controllers/headless-pool-for-label.js.map +1 -1
  17. package/dist-server/controllers/index.d.ts +26 -0
  18. package/dist-server/controllers/label-command.d.ts +19 -0
  19. package/dist-server/controllers/label-command.js.map +1 -1
  20. package/dist-server/controllers/pdf.d.ts +9 -0
  21. package/dist-server/controllers/pdf.js.map +1 -1
  22. package/dist-server/controllers/print.d.ts +21 -0
  23. package/dist-server/controllers/print.js +5 -6
  24. package/dist-server/controllers/print.js.map +1 -1
  25. package/dist-server/controllers/screenshot.d.ts +11 -0
  26. package/dist-server/controllers/screenshot.js.map +1 -1
  27. package/dist-server/controllers/thumbnail.d.ts +7 -0
  28. package/dist-server/errors/index.d.ts +1 -0
  29. package/dist-server/errors/license-error.d.ts +11 -0
  30. package/dist-server/index.d.ts +5 -0
  31. package/dist-server/index.js +1 -2
  32. package/dist-server/index.js.map +1 -1
  33. package/dist-server/migrations/1556862253000-SeedGroup.d.ts +5 -0
  34. package/dist-server/migrations/1556862253000-SeedGroup.js.map +1 -1
  35. package/dist-server/migrations/index.d.ts +1 -0
  36. package/dist-server/routers/board-print-router.d.ts +1 -0
  37. package/dist-server/routers/internal-board-view-router.d.ts +1 -0
  38. package/dist-server/routers/internal-board-view-router.js.map +1 -1
  39. package/dist-server/routers/standalone-board-service-router.d.ts +1 -0
  40. package/dist-server/routers/standalone-board-service-router.js.map +1 -1
  41. package/dist-server/routes.d.ts +1 -0
  42. package/dist-server/routes.js.map +1 -1
  43. package/dist-server/service/analysis/analysis-query.d.ts +3 -0
  44. package/dist-server/service/analysis/analysis-query.js +2 -2
  45. package/dist-server/service/analysis/analysis-query.js.map +1 -1
  46. package/dist-server/service/analysis/index.d.ts +2 -0
  47. package/dist-server/service/board/board-history.d.ts +28 -0
  48. package/dist-server/service/board/board-history.js +2 -2
  49. package/dist-server/service/board/board-history.js.map +1 -1
  50. package/dist-server/service/board/board-mutation.d.ts +12 -0
  51. package/dist-server/service/board/board-mutation.js +2 -2
  52. package/dist-server/service/board/board-mutation.js.map +1 -1
  53. package/dist-server/service/board/board-query.d.ts +20 -0
  54. package/dist-server/service/board/board-query.js +4 -4
  55. package/dist-server/service/board/board-query.js.map +1 -1
  56. package/dist-server/service/board/board-subscription.d.ts +6 -0
  57. package/dist-server/service/board/board-subscription.js +2 -2
  58. package/dist-server/service/board/board-subscription.js.map +1 -1
  59. package/dist-server/service/board/board-type.d.ts +24 -0
  60. package/dist-server/service/board/board-type.js +8 -8
  61. package/dist-server/service/board/board-type.js.map +1 -1
  62. package/dist-server/service/board/board.d.ts +25 -0
  63. package/dist-server/service/board/board.js +2 -2
  64. package/dist-server/service/board/board.js.map +1 -1
  65. package/dist-server/service/board/event-subscriber.d.ts +15 -0
  66. package/dist-server/service/board/event-subscriber.js +4 -4
  67. package/dist-server/service/board/event-subscriber.js.map +1 -1
  68. package/dist-server/service/board/index.d.ts +9 -0
  69. package/dist-server/service/board-favorite/board-favorite-query.d.ts +5 -0
  70. package/dist-server/service/board-favorite/board-favorite-query.js +3 -3
  71. package/dist-server/service/board-favorite/board-favorite-query.js.map +1 -1
  72. package/dist-server/service/board-favorite/board-favorite-type.d.ts +8 -0
  73. package/dist-server/service/board-favorite/board-favorite-type.js +4 -4
  74. package/dist-server/service/board-favorite/board-favorite-type.js.map +1 -1
  75. package/dist-server/service/board-favorite/index.d.ts +3 -0
  76. package/dist-server/service/board-template/board-template-mutation.d.ts +8 -0
  77. package/dist-server/service/board-template/board-template-mutation.js +2 -2
  78. package/dist-server/service/board-template/board-template-mutation.js.map +1 -1
  79. package/dist-server/service/board-template/board-template-query.d.ts +13 -0
  80. package/dist-server/service/board-template/board-template-query.js +4 -4
  81. package/dist-server/service/board-template/board-template-query.js.map +1 -1
  82. package/dist-server/service/board-template/board-template-type.d.ts +21 -0
  83. package/dist-server/service/board-template/board-template-type.js +6 -6
  84. package/dist-server/service/board-template/board-template-type.js.map +1 -1
  85. package/dist-server/service/board-template/board-template.d.ts +23 -0
  86. package/dist-server/service/board-template/board-template.js +3 -3
  87. package/dist-server/service/board-template/board-template.js.map +1 -1
  88. package/dist-server/service/board-template/index.d.ts +6 -0
  89. package/dist-server/service/group/group-mutation.d.ts +8 -0
  90. package/dist-server/service/group/group-mutation.js +2 -2
  91. package/dist-server/service/group/group-mutation.js.map +1 -1
  92. package/dist-server/service/group/group-query.d.ts +13 -0
  93. package/dist-server/service/group/group-query.js +3 -3
  94. package/dist-server/service/group/group-query.js.map +1 -1
  95. package/dist-server/service/group/group-type.d.ts +13 -0
  96. package/dist-server/service/group/group-type.js +6 -6
  97. package/dist-server/service/group/group-type.js.map +1 -1
  98. package/dist-server/service/group/group.d.ts +17 -0
  99. package/dist-server/service/group/group.js +2 -2
  100. package/dist-server/service/group/group.js.map +1 -1
  101. package/dist-server/service/group/index.d.ts +5 -0
  102. package/dist-server/service/index.d.ts +10 -0
  103. package/dist-server/service/permission/domain-permission-subscriber.d.ts +9 -0
  104. package/dist-server/service/permission/domain-permission-subscriber.js +2 -2
  105. package/dist-server/service/permission/domain-permission-subscriber.js.map +1 -1
  106. package/dist-server/service/permission/index.d.ts +2 -0
  107. package/dist-server/service/play-group/event-subscriber.d.ts +6 -0
  108. package/dist-server/service/play-group/event-subscriber.js +2 -2
  109. package/dist-server/service/play-group/event-subscriber.js.map +1 -1
  110. package/dist-server/service/play-group/index.d.ts +8 -0
  111. package/dist-server/service/play-group/play-group-mutation.d.ts +10 -0
  112. package/dist-server/service/play-group/play-group-mutation.js +2 -2
  113. package/dist-server/service/play-group/play-group-mutation.js.map +1 -1
  114. package/dist-server/service/play-group/play-group-query.d.ts +14 -0
  115. package/dist-server/service/play-group/play-group-query.js +3 -3
  116. package/dist-server/service/play-group/play-group-query.js.map +1 -1
  117. package/dist-server/service/play-group/play-group-subscription.d.ts +6 -0
  118. package/dist-server/service/play-group/play-group-subscription.js +2 -2
  119. package/dist-server/service/play-group/play-group-subscription.js.map +1 -1
  120. package/dist-server/service/play-group/play-group-type.d.ts +13 -0
  121. package/dist-server/service/play-group/play-group-type.js +6 -6
  122. package/dist-server/service/play-group/play-group-type.js.map +1 -1
  123. package/dist-server/service/play-group/play-group.d.ts +18 -0
  124. package/dist-server/service/play-group/play-group.js +2 -2
  125. package/dist-server/service/play-group/play-group.js.map +1 -1
  126. package/dist-server/service/theme/index.d.ts +6 -0
  127. package/dist-server/service/theme/theme-mutation.d.ts +10 -0
  128. package/dist-server/service/theme/theme-mutation.js +2 -2
  129. package/dist-server/service/theme/theme-mutation.js.map +1 -1
  130. package/dist-server/service/theme/theme-query.d.ts +11 -0
  131. package/dist-server/service/theme/theme-query.js +3 -3
  132. package/dist-server/service/theme/theme-query.js.map +1 -1
  133. package/dist-server/service/theme/theme-type.d.ts +21 -0
  134. package/dist-server/service/theme/theme-type.js +6 -6
  135. package/dist-server/service/theme/theme-type.js.map +1 -1
  136. package/dist-server/service/theme/theme.d.ts +25 -0
  137. package/dist-server/service/theme/theme.js +2 -2
  138. package/dist-server/service/theme/theme.js.map +1 -1
  139. package/dist-server/tsconfig.tsbuildinfo +1 -1
  140. package/package.json +7 -7
  141. package/server/controllers/fonts.ts +1 -1
  142. package/server/service/board/board-query.ts +5 -2
  143. package/server/service/board-favorite/board-favorite-query.ts +4 -1
  144. package/server/service/board-template/board-template-query.ts +5 -2
  145. package/server/service/group/group-query.ts +1 -1
  146. package/server/service/play-group/play-group-query.ts +4 -1
  147. package/server/service/theme/theme-query.ts +1 -1
@@ -6,6 +6,7 @@ const type_graphql_1 = require("type-graphql");
6
6
  const board_template_1 = require("./board-template");
7
7
  let NewBoardTemplate = class NewBoardTemplate {
8
8
  };
9
+ exports.NewBoardTemplate = NewBoardTemplate;
9
10
  tslib_1.__decorate([
10
11
  (0, type_graphql_1.Field)(),
11
12
  tslib_1.__metadata("design:type", String)
@@ -26,12 +27,12 @@ tslib_1.__decorate([
26
27
  (0, type_graphql_1.Field)({ nullable: true }),
27
28
  tslib_1.__metadata("design:type", String)
28
29
  ], NewBoardTemplate.prototype, "thumbnail", void 0);
29
- NewBoardTemplate = tslib_1.__decorate([
30
+ exports.NewBoardTemplate = NewBoardTemplate = tslib_1.__decorate([
30
31
  (0, type_graphql_1.InputType)()
31
32
  ], NewBoardTemplate);
32
- exports.NewBoardTemplate = NewBoardTemplate;
33
33
  let BoardTemplatePatch = class BoardTemplatePatch {
34
34
  };
35
+ exports.BoardTemplatePatch = BoardTemplatePatch;
35
36
  tslib_1.__decorate([
36
37
  (0, type_graphql_1.Field)(type => type_graphql_1.ID, { nullable: true }),
37
38
  tslib_1.__metadata("design:type", String)
@@ -60,12 +61,12 @@ tslib_1.__decorate([
60
61
  (0, type_graphql_1.Field)({ nullable: true }),
61
62
  tslib_1.__metadata("design:type", String)
62
63
  ], BoardTemplatePatch.prototype, "cuFlag", void 0);
63
- BoardTemplatePatch = tslib_1.__decorate([
64
+ exports.BoardTemplatePatch = BoardTemplatePatch = tslib_1.__decorate([
64
65
  (0, type_graphql_1.InputType)()
65
66
  ], BoardTemplatePatch);
66
- exports.BoardTemplatePatch = BoardTemplatePatch;
67
67
  let BoardTemplateList = class BoardTemplateList {
68
68
  };
69
+ exports.BoardTemplateList = BoardTemplateList;
69
70
  tslib_1.__decorate([
70
71
  (0, type_graphql_1.Field)(type => [board_template_1.BoardTemplate]),
71
72
  tslib_1.__metadata("design:type", Array)
@@ -74,8 +75,7 @@ tslib_1.__decorate([
74
75
  (0, type_graphql_1.Field)(type => type_graphql_1.Int),
75
76
  tslib_1.__metadata("design:type", Number)
76
77
  ], BoardTemplateList.prototype, "total", void 0);
77
- BoardTemplateList = tslib_1.__decorate([
78
+ exports.BoardTemplateList = BoardTemplateList = tslib_1.__decorate([
78
79
  (0, type_graphql_1.ObjectType)()
79
80
  ], BoardTemplateList);
80
- exports.BoardTemplateList = BoardTemplateList;
81
81
  //# sourceMappingURL=board-template-type.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"board-template-type.js","sourceRoot":"","sources":["../../../server/service/board-template/board-template-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAoE;AACpE,qDAAgD;AAGzC,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;CAe5B,CAAA;AAdC;IAAC,IAAA,oBAAK,GAAE;;8CACI;AAEZ;IAAC,IAAA,oBAAK,GAAE;;qDACW;AAEnB;IAAC,IAAA,oBAAK,GAAE;;+CACK;AAEb;IAAC,IAAA,oBAAK,GAAE;;oDACwB;AAEhC;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;mDACT;AAdN,gBAAgB;IAD5B,IAAA,wBAAS,GAAE;GACC,gBAAgB,CAe5B;AAfY,4CAAgB;AAkBtB,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;CAqB9B,CAAA;AApBC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CAC3B;AAEX;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACb;AAEb;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uDACN;AAEpB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACb;AAEb;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;sDACO;AAEjC;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qDACR;AAElB;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;kDACX;AApBJ,kBAAkB;IAD9B,IAAA,wBAAS,GAAE;GACC,kBAAkB,CAqB9B;AArBY,gDAAkB;AAwBxB,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAM7B,CAAA;AALC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,8BAAa,CAAC,CAAC;;gDACT;AAEtB;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,CAAC;;gDACN;AALF,iBAAiB;IAD7B,IAAA,yBAAU,GAAE;GACA,iBAAiB,CAM7B;AANY,8CAAiB","sourcesContent":["import { ObjectType, Field, InputType, Int, ID } from 'type-graphql'\nimport { BoardTemplate } from './board-template'\n\n@InputType()\nexport class NewBoardTemplate {\n @Field()\n name: string\n\n @Field()\n description: string\n\n @Field()\n model: string\n\n @Field()\n visibility: 'private' | 'public'\n\n @Field({ nullable: true })\n thumbnail: string\n}\n\n@InputType()\nexport class BoardTemplatePatch {\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 model: string\n\n @Field({ nullable: true })\n visibility?: 'private' | 'public'\n\n @Field({ nullable: true })\n thumbnail?: string\n\n @Field({ nullable: true })\n cuFlag?: string\n}\n\n@ObjectType()\nexport class BoardTemplateList {\n @Field(type => [BoardTemplate])\n items: BoardTemplate[]\n\n @Field(type => Int)\n total: number\n}\n"]}
1
+ {"version":3,"file":"board-template-type.js","sourceRoot":"","sources":["../../../server/service/board-template/board-template-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAoE;AACpE,qDAAgD;AAGzC,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;CAe5B,CAAA;AAfY,4CAAgB;AAE3B;IADC,IAAA,oBAAK,GAAE;;8CACI;AAGZ;IADC,IAAA,oBAAK,GAAE;;qDACW;AAGnB;IADC,IAAA,oBAAK,GAAE;;+CACK;AAGb;IADC,IAAA,oBAAK,GAAE;;oDACwB;AAGhC;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;mDACT;2BAdN,gBAAgB;IAD5B,IAAA,wBAAS,GAAE;GACC,gBAAgB,CAe5B;AAGM,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;CAqB9B,CAAA;AArBY,gDAAkB;AAE7B;IADC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;8CAC3B;AAGX;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACb;AAGb;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uDACN;AAGpB;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACb;AAGb;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;sDACO;AAGjC;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qDACR;AAGlB;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;kDACX;6BApBJ,kBAAkB;IAD9B,IAAA,wBAAS,GAAE;GACC,kBAAkB,CAqB9B;AAGM,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAM7B,CAAA;AANY,8CAAiB;AAE5B;IADC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,8BAAa,CAAC,CAAC;;gDACT;AAGtB;IADC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,CAAC;;gDACN;4BALF,iBAAiB;IAD7B,IAAA,yBAAU,GAAE;GACA,iBAAiB,CAM7B","sourcesContent":["import { ObjectType, Field, InputType, Int, ID } from 'type-graphql'\nimport { BoardTemplate } from './board-template'\n\n@InputType()\nexport class NewBoardTemplate {\n @Field()\n name: string\n\n @Field()\n description: string\n\n @Field()\n model: string\n\n @Field()\n visibility: 'private' | 'public'\n\n @Field({ nullable: true })\n thumbnail: string\n}\n\n@InputType()\nexport class BoardTemplatePatch {\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 model: string\n\n @Field({ nullable: true })\n visibility?: 'private' | 'public'\n\n @Field({ nullable: true })\n thumbnail?: string\n\n @Field({ nullable: true })\n cuFlag?: string\n}\n\n@ObjectType()\nexport class BoardTemplateList {\n @Field(type => [BoardTemplate])\n items: BoardTemplate[]\n\n @Field(type => Int)\n total: number\n}\n"]}
@@ -0,0 +1,23 @@
1
+ import { Domain } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ export declare enum BoardTemplateStatus {
4
+ DRAFT = "DRAFT",
5
+ RELEASED = "RELEASED"
6
+ }
7
+ export declare class BoardTemplate {
8
+ readonly id: string;
9
+ domain?: Domain;
10
+ domainId?: string;
11
+ name?: string;
12
+ description?: string;
13
+ tags?: string[];
14
+ visibility?: string;
15
+ model?: string;
16
+ thumbnail?: string;
17
+ createdAt?: Date;
18
+ updatedAt?: Date;
19
+ creator?: User;
20
+ creatorId?: string;
21
+ updater?: User;
22
+ updaterId?: string;
23
+ }
@@ -13,13 +13,14 @@ var BoardTemplateStatus;
13
13
  (function (BoardTemplateStatus) {
14
14
  BoardTemplateStatus["DRAFT"] = "DRAFT";
15
15
  BoardTemplateStatus["RELEASED"] = "RELEASED";
16
- })(BoardTemplateStatus = exports.BoardTemplateStatus || (exports.BoardTemplateStatus = {}));
16
+ })(BoardTemplateStatus || (exports.BoardTemplateStatus = BoardTemplateStatus = {}));
17
17
  (0, type_graphql_1.registerEnumType)(BoardTemplateStatus, {
18
18
  name: 'BoardTemplateStatus',
19
19
  description: 'state enumeration of a boardTemplate'
20
20
  });
21
21
  let BoardTemplate = class BoardTemplate {
22
22
  };
23
+ exports.BoardTemplate = BoardTemplate;
23
24
  tslib_1.__decorate([
24
25
  (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
25
26
  (0, type_graphql_1.Field)(type => type_graphql_1.ID),
@@ -106,12 +107,11 @@ tslib_1.__decorate([
106
107
  (0, typeorm_1.RelationId)((boardTemplate) => boardTemplate.updater),
107
108
  tslib_1.__metadata("design:type", String)
108
109
  ], BoardTemplate.prototype, "updaterId", void 0);
109
- BoardTemplate = tslib_1.__decorate([
110
+ exports.BoardTemplate = BoardTemplate = tslib_1.__decorate([
110
111
  (0, typeorm_1.Entity)(),
111
112
  (0, typeorm_1.Index)('ix_board_template_0', (boardTemplate) => [boardTemplate.domain, boardTemplate.name], {
112
113
  unique: true
113
114
  }),
114
115
  (0, type_graphql_1.ObjectType)({ description: 'Entity for BoardTemplate' })
115
116
  ], BoardTemplate);
116
- exports.BoardTemplate = BoardTemplate;
117
117
  //# sourceMappingURL=board-template.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"board-template.js","sourceRoot":"","sources":["../../../server/service/board-template/board-template.ts"],"names":[],"mappings":";;;;AAAA,qCASgB;AAChB,+CAA2E;AAE3E,iDAA4D;AAC5D,yDAAgD;AAChD,6CAA4C;AAE5C,MAAM,SAAS,GAAG,YAAM,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,CAAC,CAAA;AAC7C,MAAM,aAAa,GAAG,SAAS,CAAC,IAAI,CAAA;AAEpC,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,sCAAe,CAAA;IACf,4CAAqB,CAAA;AACvB,CAAC,EAHW,mBAAmB,GAAnB,2BAAmB,KAAnB,2BAAmB,QAG9B;AAED,IAAA,+BAAgB,EAAC,mBAAmB,EAAE;IACpC,IAAI,EAAE,qBAAqB;IAC3B,WAAW,EAAE,sCAAsC;CACpD,CAAC,CAAA;AAOK,IAAM,aAAa,GAAnB,MAAM,aAAa;CAyEzB,CAAA;AAxEC;IAAC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;yCACC;AAEnB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;sCACb,cAAM;6CAAA;AAEf;IAAC,IAAA,oBAAU,EAAC,CAAC,aAA4B,EAAE,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC;;+CAClD;AAEjB;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2CACb;AAEb;IAAC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC1B,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;kDACN;AAEpB;IAAC,IAAA,gBAAM,EAAC,aAAa,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACxD,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,oBAAY,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2CACjC;AAEf;IAAC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;IAC9C,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;iDACP;AAEnB;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;QACd,IAAI,EACF,aAAa,IAAI,OAAO,IAAI,aAAa,IAAI,SAAS;YACpD,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,aAAa,IAAI,QAAQ;gBACzB,CAAC,CAAC,MAAM;gBACR,CAAC,CAAC,SAAS;KAClB,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;4CACZ;AAEd;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;QACd,IAAI,EACF,aAAa,IAAI,OAAO,IAAI,aAAa,IAAI,SAAS;YACpD,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,aAAa,IAAI,QAAQ;gBACzB,CAAC,CAAC,MAAM;gBACR,CAAC,CAAC,SAAS;KAClB,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gDACR;AAElB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;gDAAA;AAEhB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;gDAAA;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;8CAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,aAA4B,EAAE,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC;;gDAClD;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;8CAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,aAA4B,EAAE,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC;;gDAClD;AAxEP,aAAa;IALzB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,qBAAqB,EAAE,CAAC,aAA4B,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,MAAM,EAAE,aAAa,CAAC,IAAI,CAAC,EAAE;QAC1G,MAAM,EAAE,IAAI;KACb,CAAC;IACD,IAAA,yBAAU,EAAC,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;GAC3C,aAAa,CAyEzB;AAzEY,sCAAa","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Domain, ScalarObject } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { config } from '@things-factory/env'\n\nconst ORMCONFIG = config.get('ormconfig', {})\nconst DATABASE_TYPE = ORMCONFIG.type\n\nexport enum BoardTemplateStatus {\n DRAFT = 'DRAFT',\n RELEASED = 'RELEASED'\n}\n\nregisterEnumType(BoardTemplateStatus, {\n name: 'BoardTemplateStatus',\n description: 'state enumeration of a boardTemplate'\n})\n\n@Entity()\n@Index('ix_board_template_0', (boardTemplate: BoardTemplate) => [boardTemplate.domain, boardTemplate.name], {\n unique: true\n})\n@ObjectType({ description: 'Entity for BoardTemplate' })\nexport class BoardTemplate {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field(type => Domain)\n domain?: Domain\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.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 @Column('simple-json', { nullable: true, default: null })\n @Field(type => ScalarObject, { nullable: true })\n tags?: string[]\n\n @Column({ nullable: true, default: 'private' })\n @Field({ nullable: true })\n visibility?: string // 'private' | 'public' | 'domain'\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : 'varchar'\n })\n @Field({ nullable: true })\n model?: string\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : 'varchar'\n })\n @Field({ nullable: true })\n thumbnail?: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n creator?: User\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.creator)\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n updater?: User\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.updater)\n updaterId?: string\n}\n"]}
1
+ {"version":3,"file":"board-template.js","sourceRoot":"","sources":["../../../server/service/board-template/board-template.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Domain, ScalarObject } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { config } from '@things-factory/env'\n\nconst ORMCONFIG = config.get('ormconfig', {})\nconst DATABASE_TYPE = ORMCONFIG.type\n\nexport enum BoardTemplateStatus {\n DRAFT = 'DRAFT',\n RELEASED = 'RELEASED'\n}\n\nregisterEnumType(BoardTemplateStatus, {\n name: 'BoardTemplateStatus',\n description: 'state enumeration of a boardTemplate'\n})\n\n@Entity()\n@Index('ix_board_template_0', (boardTemplate: BoardTemplate) => [boardTemplate.domain, boardTemplate.name], {\n unique: true\n})\n@ObjectType({ description: 'Entity for BoardTemplate' })\nexport class BoardTemplate {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field(type => Domain)\n domain?: Domain\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.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 @Column('simple-json', { nullable: true, default: null })\n @Field(type => ScalarObject, { nullable: true })\n tags?: string[]\n\n @Column({ nullable: true, default: 'private' })\n @Field({ nullable: true })\n visibility?: string // 'private' | 'public' | 'domain'\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : 'varchar'\n })\n @Field({ nullable: true })\n model?: string\n\n @Column({\n nullable: true,\n type:\n DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'\n ? 'longtext'\n : DATABASE_TYPE == 'oracle'\n ? 'clob'\n : 'varchar'\n })\n @Field({ nullable: true })\n thumbnail?: string\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n creator?: User\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.creator)\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n updater?: User\n\n @RelationId((boardTemplate: BoardTemplate) => boardTemplate.updater)\n updaterId?: string\n}\n"]}
@@ -0,0 +1,6 @@
1
+ import { BoardTemplate } from './board-template';
2
+ import { BoardTemplateQuery } from './board-template-query';
3
+ import { BoardTemplateMutation } from './board-template-mutation';
4
+ export declare const entities: (typeof BoardTemplate)[];
5
+ export declare const resolvers: (typeof BoardTemplateQuery | typeof BoardTemplateMutation)[];
6
+ export declare const subscribers: any[];
@@ -0,0 +1,8 @@
1
+ import { Group } from './group';
2
+ import { GroupPatch, NewGroup } from './group-type';
3
+ export declare class GroupMutation {
4
+ createGroup(group: NewGroup, context: ResolverContext): Promise<Group>;
5
+ updateGroup(id: string, patch: GroupPatch, context: ResolverContext): Promise<Group>;
6
+ joinGroup(id: string, boardIds: string[], context: ResolverContext): Promise<Group>;
7
+ deleteGroup(id: string, context: ResolverContext): Promise<boolean>;
8
+ }
@@ -44,6 +44,7 @@ let GroupMutation = class GroupMutation {
44
44
  return true;
45
45
  }
46
46
  };
47
+ exports.GroupMutation = GroupMutation;
47
48
  tslib_1.__decorate([
48
49
  (0, type_graphql_1.Directive)('@transaction'),
49
50
  (0, type_graphql_1.Mutation)(returns => group_1.Group, { nullable: true, description: 'To create new Group' }),
@@ -82,8 +83,7 @@ tslib_1.__decorate([
82
83
  tslib_1.__metadata("design:paramtypes", [String, Object]),
83
84
  tslib_1.__metadata("design:returntype", Promise)
84
85
  ], GroupMutation.prototype, "deleteGroup", null);
85
- GroupMutation = tslib_1.__decorate([
86
+ exports.GroupMutation = GroupMutation = tslib_1.__decorate([
86
87
  (0, type_graphql_1.Resolver)(group_1.Group)
87
88
  ], GroupMutation);
88
- exports.GroupMutation = GroupMutation;
89
89
  //# sourceMappingURL=group-mutation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"group-mutation.js","sourceRoot":"","sources":["../../../server/service/group/group-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Mutation, Resolver, Directive } from 'type-graphql'\n\nimport { Board } from '../board/board'\nimport { Group } from './group'\nimport { GroupPatch, NewGroup } from './group-type'\n\n@Resolver(Group)\nexport class GroupMutation {\n @Directive('@transaction')\n @Mutation(returns => Group, { nullable: true, description: 'To create new Group' })\n async createGroup(@Arg('group') group: NewGroup, @Ctx() context: ResolverContext): Promise<Group> {\n const { domain, user, tx } = context.state\n\n return await tx.getRepository(Group).save({\n domain,\n ...group,\n creator: user,\n updater: user\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Group, { description: 'To modify Group information' })\n async updateGroup(\n @Arg('id') id: string,\n @Arg('patch') patch: GroupPatch,\n @Ctx() context: ResolverContext\n ): Promise<Group> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(Group)\n\n const group = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...group,\n ...patch,\n updater: user\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Group, { description: 'To make the board to join the group' })\n async joinGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { domain, tx } = context.state\n const repository = tx.getRepository(Group)\n const group = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n const boardRepository = tx.getRepository(Board)\n\n await boardIds.forEach(async boardId => {\n let board = await boardRepository.findOneBy({ domain: { id: domain.id }, id: boardId })\n board.group = group\n await boardRepository.save(board)\n })\n\n return await repository.findOne({\n where: { domain: { id: domain.id }, id },\n relations: ['boards']\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Boolean, { description: 'To delete Group' })\n async deleteGroup(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<boolean> {\n const { domain, tx } = context.state\n\n const repository = tx.getRepository(Group)\n\n /* TODO - 그룹에 소속된 보드가 있는 경우에는 그룹을 지워서는 안된다. */\n const group = await repository.findOneBy({\n domain: { id: domain.id },\n id\n })\n\n await repository.delete(id)\n return true\n }\n}\n"]}
1
+ {"version":3,"file":"group-mutation.js","sourceRoot":"","sources":["../../../server/service/group/group-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Ctx, Mutation, Resolver, Directive } from 'type-graphql'\n\nimport { Board } from '../board/board'\nimport { Group } from './group'\nimport { GroupPatch, NewGroup } from './group-type'\n\n@Resolver(Group)\nexport class GroupMutation {\n @Directive('@transaction')\n @Mutation(returns => Group, { nullable: true, description: 'To create new Group' })\n async createGroup(@Arg('group') group: NewGroup, @Ctx() context: ResolverContext): Promise<Group> {\n const { domain, user, tx } = context.state\n\n return await tx.getRepository(Group).save({\n domain,\n ...group,\n creator: user,\n updater: user\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Group, { description: 'To modify Group information' })\n async updateGroup(\n @Arg('id') id: string,\n @Arg('patch') patch: GroupPatch,\n @Ctx() context: ResolverContext\n ): Promise<Group> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(Group)\n\n const group = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...group,\n ...patch,\n updater: user\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Group, { description: 'To make the board to join the group' })\n async joinGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { domain, tx } = context.state\n const repository = tx.getRepository(Group)\n const group = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n const boardRepository = tx.getRepository(Board)\n\n await boardIds.forEach(async boardId => {\n let board = await boardRepository.findOneBy({ domain: { id: domain.id }, id: boardId })\n board.group = group\n await boardRepository.save(board)\n })\n\n return await repository.findOne({\n where: { domain: { id: domain.id }, id },\n relations: ['boards']\n })\n }\n\n @Directive('@transaction')\n @Mutation(returns => Boolean, { description: 'To delete Group' })\n async deleteGroup(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<boolean> {\n const { domain, tx } = context.state\n\n const repository = tx.getRepository(Group)\n\n /* TODO - 그룹에 소속된 보드가 있는 경우에는 그룹을 지워서는 안된다. */\n const group = await repository.findOneBy({\n domain: { id: domain.id },\n id\n })\n\n await repository.delete(id)\n return true\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { User } from '@things-factory/auth-base';
2
+ import { Domain, ListParam } from '@things-factory/shell';
3
+ import { Board } from '../board/board';
4
+ import { Group } from './group';
5
+ import { GroupList } from './group-type';
6
+ export declare class GroupQuery {
7
+ group(id: string, context: ResolverContext): Promise<Group>;
8
+ groups(params: ListParam, context: ResolverContext): Promise<GroupList>;
9
+ boards(group: Group): Promise<Board[]>;
10
+ domain(group: Group): Promise<Domain>;
11
+ updater(group: Group): Promise<User>;
12
+ creator(group: Group): Promise<User>;
13
+ }
@@ -41,6 +41,7 @@ let GroupQuery = class GroupQuery {
41
41
  return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: group.creatorId });
42
42
  }
43
43
  };
44
+ exports.GroupQuery = GroupQuery;
44
45
  tslib_1.__decorate([
45
46
  (0, type_graphql_1.Query)(returns => group_1.Group, { nullable: true, description: 'To fetch a Group' }),
46
47
  tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
@@ -51,7 +52,7 @@ tslib_1.__decorate([
51
52
  ], GroupQuery.prototype, "group", null);
52
53
  tslib_1.__decorate([
53
54
  (0, type_graphql_1.Query)(returns => group_type_1.GroupList, { description: 'To fetch multiple Groups' }),
54
- tslib_1.__param(0, (0, type_graphql_1.Args)()),
55
+ tslib_1.__param(0, (0, type_graphql_1.Args)(type => shell_1.ListParam)),
55
56
  tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
56
57
  tslib_1.__metadata("design:type", Function),
57
58
  tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
@@ -85,8 +86,7 @@ tslib_1.__decorate([
85
86
  tslib_1.__metadata("design:paramtypes", [group_1.Group]),
86
87
  tslib_1.__metadata("design:returntype", Promise)
87
88
  ], GroupQuery.prototype, "creator", null);
88
- GroupQuery = tslib_1.__decorate([
89
+ exports.GroupQuery = GroupQuery = tslib_1.__decorate([
89
90
  (0, type_graphql_1.Resolver)(group_1.Group)
90
91
  ], GroupQuery);
91
- exports.GroupQuery = GroupQuery;
92
92
  //# sourceMappingURL=group-query.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"group-query.js","sourceRoot":"","sources":["../../../server/service/group/group-query.ts"],"names":[],"mappings":";;;;AAAA,+CAAmF;AAEnF,yDAAgD;AAChD,iDAAuG;AAEvG,0CAAsC;AACtC,mCAA+B;AAC/B,6CAAwC;AAGjC,IAAM,UAAU,GAAhB,MAAM,UAAU;IAEf,AAAN,KAAK,CAAC,KAAK,CAAY,EAAU,EAAS,OAAwB;QAChE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEhC,OAAO,MAAM,IAAA,qBAAa,EAAC,aAAK,CAAC,CAAC,OAAO,CAAC;YACxC,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;SACzC,CAAC,CAAA;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,MAAM,CAAS,MAAiB,EAAS,OAAwB;QACrE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEhC,MAAM,YAAY,GAAG,IAAA,qCAA6B,EAAC;YACjD,UAAU,EAAE,IAAA,qBAAa,EAAC,aAAK,CAAC;YAChC,MAAM;YACN,MAAM;YACN,WAAW,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC;SACrC,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,KAAY;QAC/B,OAAO,MAAM,IAAA,qBAAa,EAAC,aAAK,CAAC,CAAC,MAAM,CAAC;YACvC,KAAK,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,EAAE,EAAE;SACxB,CAAC,CAAA;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,MAAM,CAAS,KAAY;QAC/B,OAAO,MAAM,IAAA,qBAAa,EAAC,cAAM,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;IACtE,CAAC;IAGK,AAAN,KAAK,CAAC,OAAO,CAAS,KAAY;QAChC,OAAO,MAAM,IAAA,qBAAa,EAAC,gBAAI,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAA;IACrE,CAAC;IAGK,AAAN,KAAK,CAAC,OAAO,CAAS,KAAY;QAChC,OAAO,MAAM,IAAA,qBAAa,EAAC,gBAAI,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAA;IACrE,CAAC;CACF,CAAA;AA7CO;IADL,IAAA,oBAAK,EAAC,OAAO,CAAC,EAAE,CAAC,aAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC;IAChE,mBAAA,IAAA,kBAAG,EAAC,IAAI,CAAC,CAAA;IAAc,mBAAA,IAAA,kBAAG,GAAE,CAAA;;;;uCAMxC;AAGK;IADL,IAAA,oBAAK,EAAC,OAAO,CAAC,EAAE,CAAC,sBAAS,EAAE,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;IAC3D,mBAAA,IAAA,mBAAI,GAAE,CAAA;IAAqB,mBAAA,IAAA,kBAAG,GAAE,CAAA;;6CAAjB,iBAAS;;wCAarC;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,aAAK,CAAC,CAAC;IACjB,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAQ,aAAK;;wCAIhC;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IAChB,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAQ,aAAK;;wCAEhC;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,CAAC;IACb,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAQ,aAAK;;yCAEjC;AAGK;IADL,IAAA,4BAAa,EAAC,IAAI,CAAC,EAAE,CAAC,gBAAI,CAAC;IACb,mBAAA,IAAA,mBAAI,GAAE,CAAA;;6CAAQ,aAAK;;yCAEjC;AA9CU,UAAU;IADtB,IAAA,uBAAQ,EAAC,aAAK,CAAC;GACH,UAAU,CA+CtB;AA/CY,gCAAU","sourcesContent":["import { Arg, Args, Ctx, FieldResolver, Query, Resolver, Root } from 'type-graphql'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'\n\nimport { Board } from '../board/board'\nimport { Group } from './group'\nimport { GroupList } from './group-type'\n\n@Resolver(Group)\nexport class GroupQuery {\n @Query(returns => Group, { nullable: true, description: 'To fetch a Group' })\n async group(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<Group> {\n const { domain } = context.state\n\n return await getRepository(Group).findOne({\n where: { domain: { id: domain.id }, id }\n })\n }\n\n @Query(returns => GroupList, { description: 'To fetch multiple Groups' })\n async groups(@Args() params: ListParam, @Ctx() context: ResolverContext): Promise<GroupList> {\n const { domain } = context.state\n\n const queryBuilder = getQueryBuilderFromListParams({\n repository: getRepository(Group),\n params,\n domain,\n searchables: ['name', 'description']\n })\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n @FieldResolver(type => [Board])\n async boards(@Root() group: Group) {\n return await getRepository(Board).findBy({\n group: { id: group.id }\n })\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() group: Group) {\n return await getRepository(Domain).findOneBy({ id: group.domainId })\n }\n\n @FieldResolver(type => User)\n async updater(@Root() group: Group): Promise<User> {\n return await getRepository(User).findOneBy({ id: group.updaterId })\n }\n\n @FieldResolver(type => User)\n async creator(@Root() group: Group): Promise<User> {\n return await getRepository(User).findOneBy({ id: group.creatorId })\n }\n}\n"]}
1
+ {"version":3,"file":"group-query.js","sourceRoot":"","sources":["../../../server/service/group/group-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Arg, Args, Ctx, FieldResolver, Query, Resolver, Root } from 'type-graphql'\n\nimport { User } from '@things-factory/auth-base'\nimport { Domain, getQueryBuilderFromListParams, getRepository, ListParam } from '@things-factory/shell'\n\nimport { Board } from '../board/board'\nimport { Group } from './group'\nimport { GroupList } from './group-type'\n\n@Resolver(Group)\nexport class GroupQuery {\n @Query(returns => Group, { nullable: true, description: 'To fetch a Group' })\n async group(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<Group> {\n const { domain } = context.state\n\n return await getRepository(Group).findOne({\n where: { domain: { id: domain.id }, id }\n })\n }\n\n @Query(returns => GroupList, { description: 'To fetch multiple Groups' })\n async groups(@Args(type => ListParam) params: ListParam, @Ctx() context: ResolverContext): Promise<GroupList> {\n const { domain } = context.state\n\n const queryBuilder = getQueryBuilderFromListParams({\n repository: getRepository(Group),\n params,\n domain,\n searchables: ['name', 'description']\n })\n\n const [items, total] = await queryBuilder.getManyAndCount()\n\n return { items, total }\n }\n\n @FieldResolver(type => [Board])\n async boards(@Root() group: Group) {\n return await getRepository(Board).findBy({\n group: { id: group.id }\n })\n }\n\n @FieldResolver(type => Domain)\n async domain(@Root() group: Group) {\n return await getRepository(Domain).findOneBy({ id: group.domainId })\n }\n\n @FieldResolver(type => User)\n async updater(@Root() group: Group): Promise<User> {\n return await getRepository(User).findOneBy({ id: group.updaterId })\n }\n\n @FieldResolver(type => User)\n async creator(@Root() group: Group): Promise<User> {\n return await getRepository(User).findOneBy({ id: group.creatorId })\n }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import { Group } from './group';
2
+ export declare class NewGroup {
3
+ name: string;
4
+ description?: string;
5
+ }
6
+ export declare class GroupPatch {
7
+ name: string;
8
+ description?: string;
9
+ }
10
+ export declare class GroupList {
11
+ items: Group[];
12
+ total: number;
13
+ }
@@ -6,6 +6,7 @@ const type_graphql_1 = require("type-graphql");
6
6
  const group_1 = require("./group");
7
7
  let NewGroup = class NewGroup {
8
8
  };
9
+ exports.NewGroup = NewGroup;
9
10
  tslib_1.__decorate([
10
11
  (0, type_graphql_1.Field)(),
11
12
  tslib_1.__metadata("design:type", String)
@@ -14,12 +15,12 @@ tslib_1.__decorate([
14
15
  (0, type_graphql_1.Field)({ nullable: true }),
15
16
  tslib_1.__metadata("design:type", String)
16
17
  ], NewGroup.prototype, "description", void 0);
17
- NewGroup = tslib_1.__decorate([
18
+ exports.NewGroup = NewGroup = tslib_1.__decorate([
18
19
  (0, type_graphql_1.InputType)()
19
20
  ], NewGroup);
20
- exports.NewGroup = NewGroup;
21
21
  let GroupPatch = class GroupPatch {
22
22
  };
23
+ exports.GroupPatch = GroupPatch;
23
24
  tslib_1.__decorate([
24
25
  (0, type_graphql_1.Field)({ nullable: true }),
25
26
  tslib_1.__metadata("design:type", String)
@@ -28,12 +29,12 @@ tslib_1.__decorate([
28
29
  (0, type_graphql_1.Field)({ nullable: true }),
29
30
  tslib_1.__metadata("design:type", String)
30
31
  ], GroupPatch.prototype, "description", void 0);
31
- GroupPatch = tslib_1.__decorate([
32
+ exports.GroupPatch = GroupPatch = tslib_1.__decorate([
32
33
  (0, type_graphql_1.InputType)()
33
34
  ], GroupPatch);
34
- exports.GroupPatch = GroupPatch;
35
35
  let GroupList = class GroupList {
36
36
  };
37
+ exports.GroupList = GroupList;
37
38
  tslib_1.__decorate([
38
39
  (0, type_graphql_1.Field)(type => [group_1.Group]),
39
40
  tslib_1.__metadata("design:type", Array)
@@ -42,8 +43,7 @@ tslib_1.__decorate([
42
43
  (0, type_graphql_1.Field)(type => type_graphql_1.Int),
43
44
  tslib_1.__metadata("design:type", Number)
44
45
  ], GroupList.prototype, "total", void 0);
45
- GroupList = tslib_1.__decorate([
46
+ exports.GroupList = GroupList = tslib_1.__decorate([
46
47
  (0, type_graphql_1.ObjectType)()
47
48
  ], GroupList);
48
- exports.GroupList = GroupList;
49
49
  //# sourceMappingURL=group-type.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"group-type.js","sourceRoot":"","sources":["../../../server/service/group/group-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAsF;AAEtF,mCAA+B;AAGxB,IAAM,QAAQ,GAAd,MAAM,QAAQ;CAMpB,CAAA;AALC;IAAC,IAAA,oBAAK,GAAE;;sCACI;AAEZ;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CACN;AALT,QAAQ;IADpB,IAAA,wBAAS,GAAE;GACC,QAAQ,CAMpB;AANY,4BAAQ;AASd,IAAM,UAAU,GAAhB,MAAM,UAAU;CAMtB,CAAA;AALC;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCACd;AAEZ;IAAC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;+CACN;AALT,UAAU;IADtB,IAAA,wBAAS,GAAE;GACC,UAAU,CAMtB;AANY,gCAAU;AAShB,IAAM,SAAS,GAAf,MAAM,SAAS;CAMrB,CAAA;AALC;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,aAAK,CAAC,CAAC;;wCACT;AAEd;IAAC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,CAAC;;wCACN;AALF,SAAS;IADrB,IAAA,yBAAU,GAAE;GACA,SAAS,CAMrB;AANY,8BAAS","sourcesContent":["import { ObjectType, Field, InputType, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Group } from './group'\n\n@InputType()\nexport class NewGroup {\n @Field()\n name: string\n\n @Field({ nullable: true })\n description?: string\n}\n\n@InputType()\nexport class GroupPatch {\n @Field({ nullable: true })\n name: string\n\n @Field({ nullable: true })\n description?: string\n}\n\n@ObjectType()\nexport class GroupList {\n @Field(type => [Group])\n items: Group[]\n\n @Field(type => Int)\n total: number\n}\n"]}
1
+ {"version":3,"file":"group-type.js","sourceRoot":"","sources":["../../../server/service/group/group-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAsF;AAEtF,mCAA+B;AAGxB,IAAM,QAAQ,GAAd,MAAM,QAAQ;CAMpB,CAAA;AANY,4BAAQ;AAEnB;IADC,IAAA,oBAAK,GAAE;;sCACI;AAGZ;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CACN;mBALT,QAAQ;IADpB,IAAA,wBAAS,GAAE;GACC,QAAQ,CAMpB;AAGM,IAAM,UAAU,GAAhB,MAAM,UAAU;CAMtB,CAAA;AANY,gCAAU;AAErB;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCACd;AAGZ;IADC,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;+CACN;qBALT,UAAU;IADtB,IAAA,wBAAS,GAAE;GACC,UAAU,CAMtB;AAGM,IAAM,SAAS,GAAf,MAAM,SAAS;CAMrB,CAAA;AANY,8BAAS;AAEpB;IADC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,aAAK,CAAC,CAAC;;wCACT;AAGd;IADC,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,kBAAG,CAAC;;wCACN;oBALF,SAAS;IADrB,IAAA,yBAAU,GAAE;GACA,SAAS,CAMrB","sourcesContent":["import { ObjectType, Field, InputType, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Group } from './group'\n\n@InputType()\nexport class NewGroup {\n @Field()\n name: string\n\n @Field({ nullable: true })\n description?: string\n}\n\n@InputType()\nexport class GroupPatch {\n @Field({ nullable: true })\n name: string\n\n @Field({ nullable: true })\n description?: string\n}\n\n@ObjectType()\nexport class GroupList {\n @Field(type => [Group])\n items: Group[]\n\n @Field(type => Int)\n total: number\n}\n"]}
@@ -0,0 +1,17 @@
1
+ import { Domain } from '@things-factory/shell';
2
+ import { User } from '@things-factory/auth-base';
3
+ import { Board } from '../board/board';
4
+ export declare class Group {
5
+ readonly id: string;
6
+ domain?: Domain;
7
+ domainId?: string;
8
+ name: string;
9
+ description?: string;
10
+ boards: Board[];
11
+ createdAt?: Date;
12
+ updatedAt?: Date;
13
+ creator?: User;
14
+ creatorId?: string;
15
+ updater?: User;
16
+ updaterId?: string;
17
+ }
@@ -9,6 +9,7 @@ const auth_base_1 = require("@things-factory/auth-base");
9
9
  const board_1 = require("../board/board");
10
10
  let Group = class Group {
11
11
  };
12
+ exports.Group = Group;
12
13
  tslib_1.__decorate([
13
14
  (0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
14
15
  (0, type_graphql_1.Field)(type => type_graphql_1.ID),
@@ -68,10 +69,9 @@ tslib_1.__decorate([
68
69
  (0, typeorm_1.RelationId)((group) => group.updater),
69
70
  tslib_1.__metadata("design:type", String)
70
71
  ], Group.prototype, "updaterId", void 0);
71
- Group = tslib_1.__decorate([
72
+ exports.Group = Group = tslib_1.__decorate([
72
73
  (0, typeorm_1.Entity)(),
73
74
  (0, typeorm_1.Index)('ix_group_0', (group) => [group.domain, group.name], { unique: true }),
74
75
  (0, type_graphql_1.ObjectType)({ description: 'Entity for Board Management Group' })
75
76
  ], Group);
76
- exports.Group = Group;
77
77
  //# sourceMappingURL=group.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"group.js","sourceRoot":"","sources":["../../../server/service/group/group.ts"],"names":[],"mappings":";;;;AAAA,qCAUgB;AAChB,+CAA2E;AAE3E,iDAA8C;AAC9C,yDAAgD;AAChD,0CAAsC;AAM/B,IAAM,KAAK,GAAX,MAAM,KAAK;CA+CjB,CAAA;AA9CC;IAAC,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;iCACC;AAEnB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACjC,cAAM;qCAAA;AAEf;IAAC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC;;uCAC1B;AAEjB;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,GAAE;;mCACI;AAEZ;IAAC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CACN;AAEpB;IAAC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,aAAK,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC;IAC9C,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,aAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qCAC5B;AAEf;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;wCAAA;AAEhB;IAAC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;wCAAA;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;sCAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;;wCAC1B;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;sCAAA;AAEd;IAAC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;;wCAC1B;AA9CP,KAAK;IAHjB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,YAAY,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACnF,IAAA,yBAAU,EAAC,EAAE,WAAW,EAAE,mCAAmC,EAAE,CAAC;GACpD,KAAK,CA+CjB;AA/CY,sBAAK","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n OneToMany,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Domain } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { Board } from '../board/board'\nimport { BoardHistory } from '../board/board-history'\n\n@Entity()\n@Index('ix_group_0', (group: Group) => [group.domain, group.name], { unique: true })\n@ObjectType({ description: 'Entity for Board Management Group' })\nexport class Group {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field(type => Domain, { nullable: true })\n domain?: Domain\n\n @RelationId((group: Group) => group.domain)\n domainId?: string\n\n @Column()\n @Field()\n name: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n description?: string\n\n @OneToMany(type => Board, board => board.group)\n @Field(type => [Board], { nullable: true })\n boards: Board[]\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n creator?: User\n\n @RelationId((group: Group) => group.creator)\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n updater?: User\n\n @RelationId((group: Group) => group.updater)\n updaterId?: string\n}\n"]}
1
+ {"version":3,"file":"group.js","sourceRoot":"","sources":["../../../server/service/group/group.ts"],"names":[],"mappings":";;;;AAAA,qCAUgB;AAChB,+CAA2E;AAE3E,iDAA8C;AAC9C,yDAAgD;AAChD,0CAAsC;AAM/B,IAAM,KAAK,GAAX,MAAM,KAAK;CA+CjB,CAAA;AA/CY,sBAAK;AAGP;IAFR,IAAA,gCAAsB,EAAC,MAAM,CAAC;IAC9B,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,iBAAE,CAAC;;iCACC;AAInB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,CAAC;IACzB,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,cAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACjC,cAAM;qCAAA;AAGf;IADC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC;;uCAC1B;AAIjB;IAFC,IAAA,gBAAM,GAAE;IACR,IAAA,oBAAK,GAAE;;mCACI;AAMZ;IAJC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;0CACN;AAIpB;IAFC,IAAA,mBAAS,EAAC,IAAI,CAAC,EAAE,CAAC,aAAK,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC;IAC9C,IAAA,oBAAK,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,aAAK,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;qCAC5B;AAIf;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;wCAAA;AAIhB;IAFC,IAAA,0BAAgB,GAAE;IAClB,IAAA,oBAAK,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;sCACd,IAAI;wCAAA;AAIhB;IAFC,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;sCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;;wCAC1B;AAIlB;IAFC,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;sCAAA;AAGd;IADC,IAAA,oBAAU,EAAC,CAAC,KAAY,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;;wCAC1B;gBA9CP,KAAK;IAHjB,IAAA,gBAAM,GAAE;IACR,IAAA,eAAK,EAAC,YAAY,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IACnF,IAAA,yBAAU,EAAC,EAAE,WAAW,EAAE,mCAAmC,EAAE,CAAC;GACpD,KAAK,CA+CjB","sourcesContent":["import {\n CreateDateColumn,\n UpdateDateColumn,\n Entity,\n Index,\n Column,\n RelationId,\n ManyToOne,\n OneToMany,\n PrimaryGeneratedColumn\n} from 'typeorm'\nimport { ObjectType, Field, Int, ID, registerEnumType } from 'type-graphql'\n\nimport { Domain } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { Board } from '../board/board'\nimport { BoardHistory } from '../board/board-history'\n\n@Entity()\n@Index('ix_group_0', (group: Group) => [group.domain, group.name], { unique: true })\n@ObjectType({ description: 'Entity for Board Management Group' })\nexport class Group {\n @PrimaryGeneratedColumn('uuid')\n @Field(type => ID)\n readonly id: string\n\n @ManyToOne(type => Domain)\n @Field(type => Domain, { nullable: true })\n domain?: Domain\n\n @RelationId((group: Group) => group.domain)\n domainId?: string\n\n @Column()\n @Field()\n name: string\n\n @Column({\n nullable: true\n })\n @Field({ nullable: true })\n description?: string\n\n @OneToMany(type => Board, board => board.group)\n @Field(type => [Board], { nullable: true })\n boards: Board[]\n\n @CreateDateColumn()\n @Field({ nullable: true })\n createdAt?: Date\n\n @UpdateDateColumn()\n @Field({ nullable: true })\n updatedAt?: Date\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n creator?: User\n\n @RelationId((group: Group) => group.creator)\n creatorId?: string\n\n @ManyToOne(type => User, { nullable: true })\n @Field(type => User, { nullable: true })\n updater?: User\n\n @RelationId((group: Group) => group.updater)\n updaterId?: string\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { Group } from './group';
2
+ import { GroupQuery } from './group-query';
3
+ import { GroupMutation } from './group-mutation';
4
+ export declare const entities: (typeof Group)[];
5
+ export declare const resolvers: (typeof GroupQuery | typeof GroupMutation)[];
@@ -0,0 +1,10 @@
1
+ export * from './board-template/board-template';
2
+ export * from './theme/theme';
3
+ export * from './board/board';
4
+ export * from './group/group';
5
+ export * from './play-group/play-group';
6
+ export declare const entities: any[];
7
+ export declare const subscribers: any[];
8
+ export declare const schema: {
9
+ resolverClasses: (typeof import("./board-template/board-template-query").BoardTemplateQuery | typeof import("./board-template/board-template-mutation").BoardTemplateMutation | typeof import("./theme/theme-query").ThemeQuery | typeof import("./theme/theme-mutation").ThemeMutation | typeof import("./board/board-query").BoardQuery | typeof import("./board/board-mutation").BoardMutation | typeof import("./board/board-subscription").BoardSubscription | typeof import("./group/group-query").GroupQuery | typeof import("./group/group-mutation").GroupMutation | typeof import("./play-group/play-group-query").PlayGroupQuery | typeof import("./play-group/play-group-mutation").PlayGroupMutation | typeof import("./play-group/play-group-subscription").PlayGroupSubscription | typeof import("./analysis/analysis-query").IntegrationAnalysisQuery | typeof import("./board-favorite/board-favorite-query").BoardFavoriteQuery)[];
10
+ };
@@ -0,0 +1,9 @@
1
+ import { EntitySubscriberInterface, InsertEvent } from 'typeorm';
2
+ import { Domain } from '@things-factory/shell';
3
+ export declare class DomainPermissionSubscriber implements EntitySubscriberInterface<Domain> {
4
+ listenTo(): typeof Domain;
5
+ /**
6
+ * Called before domain insertion.
7
+ */
8
+ afterInsert(event: InsertEvent<Domain>): Promise<void>;
9
+ }
@@ -23,8 +23,8 @@ let DomainPermissionSubscriber = class DomainPermissionSubscriber {
23
23
  }
24
24
  }
25
25
  };
26
- DomainPermissionSubscriber = tslib_1.__decorate([
26
+ exports.DomainPermissionSubscriber = DomainPermissionSubscriber;
27
+ exports.DomainPermissionSubscriber = DomainPermissionSubscriber = tslib_1.__decorate([
27
28
  (0, typeorm_1.EventSubscriber)()
28
29
  ], DomainPermissionSubscriber);
29
- exports.DomainPermissionSubscriber = DomainPermissionSubscriber;
30
30
  //# sourceMappingURL=domain-permission-subscriber.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"domain-permission-subscriber.js","sourceRoot":"","sources":["../../../server/service/permission/domain-permission-subscriber.ts"],"names":[],"mappings":";;;;AAAA,qCAAiF;AAEjF,qFAAqE;AACrE,iDAA8C;AAE9C,8DAAyD;AAGlD,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACrC,QAAQ;QACN,OAAO,cAAM,CAAA;IACf,CAAC;IACD;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,KAA0B;QAC1C,IAAI,aAAa,GAAG,KAAK,CAAC,OAAO,CAAA;QAEjC,IAAI,KAAK,GAAG,CAAC,MAAM,aAAa,CAAC,kBAAkB,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,cAAM,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAA;QAEzG,IAAI,CAAC,IAAA,qCAAW,EAAC,KAAK,CAAC,EAAE;YACvB,MAAM,IAAI,4BAAY,CAAC;gBACrB,SAAS,EAAE,4BAAY,CAAC,WAAW,CAAC,kBAAkB;aACvD,CAAC,CAAA;SACH;IACH,CAAC;CACF,CAAA;AAlBY,0BAA0B;IADtC,IAAA,yBAAe,GAAE;GACL,0BAA0B,CAkBtC;AAlBY,gEAA0B","sourcesContent":["import { EntitySubscriberInterface, EventSubscriber, InsertEvent } from 'typeorm'\n\nimport { checkDomain } from '@things-factory/operato-license-checker'\nimport { Domain } from '@things-factory/shell'\n\nimport { LicenseError } from '../../errors/license-error'\n\n@EventSubscriber()\nexport class DomainPermissionSubscriber implements EntitySubscriberInterface<Domain> {\n listenTo() {\n return Domain\n }\n /**\n * Called before domain insertion.\n */\n async afterInsert(event: InsertEvent<Domain>) {\n var entityManager = event.manager\n\n var count = (await entityManager.createQueryBuilder().select('id').from(Domain, 'domain').getCount()) + 1\n\n if (!checkDomain(count)) {\n throw new LicenseError({\n errorCode: LicenseError.ERROR_CODES.VERIFICATION_ERROR\n })\n }\n }\n}\n"]}
1
+ {"version":3,"file":"domain-permission-subscriber.js","sourceRoot":"","sources":["../../../server/service/permission/domain-permission-subscriber.ts"],"names":[],"mappings":";;;;AAAA,qCAAiF;AAEjF,qFAAqE;AACrE,iDAA8C;AAE9C,8DAAyD;AAGlD,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACrC,QAAQ;QACN,OAAO,cAAM,CAAA;IACf,CAAC;IACD;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,KAA0B;QAC1C,IAAI,aAAa,GAAG,KAAK,CAAC,OAAO,CAAA;QAEjC,IAAI,KAAK,GAAG,CAAC,MAAM,aAAa,CAAC,kBAAkB,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,cAAM,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAA;QAEzG,IAAI,CAAC,IAAA,qCAAW,EAAC,KAAK,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,4BAAY,CAAC;gBACrB,SAAS,EAAE,4BAAY,CAAC,WAAW,CAAC,kBAAkB;aACvD,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;CACF,CAAA;AAlBY,gEAA0B;qCAA1B,0BAA0B;IADtC,IAAA,yBAAe,GAAE;GACL,0BAA0B,CAkBtC","sourcesContent":["import { EntitySubscriberInterface, EventSubscriber, InsertEvent } from 'typeorm'\n\nimport { checkDomain } from '@things-factory/operato-license-checker'\nimport { Domain } from '@things-factory/shell'\n\nimport { LicenseError } from '../../errors/license-error'\n\n@EventSubscriber()\nexport class DomainPermissionSubscriber implements EntitySubscriberInterface<Domain> {\n listenTo() {\n return Domain\n }\n /**\n * Called before domain insertion.\n */\n async afterInsert(event: InsertEvent<Domain>) {\n var entityManager = event.manager\n\n var count = (await entityManager.createQueryBuilder().select('id').from(Domain, 'domain').getCount()) + 1\n\n if (!checkDomain(count)) {\n throw new LicenseError({\n errorCode: LicenseError.ERROR_CODES.VERIFICATION_ERROR\n })\n }\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import { DomainPermissionSubscriber } from './domain-permission-subscriber';
2
+ export declare const subscribers: (typeof DomainPermissionSubscriber)[];
@@ -0,0 +1,6 @@
1
+ import { EntitySubscriberInterface, UpdateEvent } from 'typeorm';
2
+ import { PlayGroup } from './play-group';
3
+ export declare class PlayGroupSubscriber implements EntitySubscriberInterface<PlayGroup> {
4
+ listenTo(): typeof PlayGroup;
5
+ afterUpdate(event: UpdateEvent<PlayGroup>): Promise<any>;
6
+ }
@@ -51,8 +51,8 @@ let PlayGroupSubscriber = class PlayGroupSubscriber {
51
51
  });
52
52
  }
53
53
  };
54
- PlayGroupSubscriber = tslib_1.__decorate([
54
+ exports.PlayGroupSubscriber = PlayGroupSubscriber;
55
+ exports.PlayGroupSubscriber = PlayGroupSubscriber = tslib_1.__decorate([
55
56
  (0, typeorm_1.EventSubscriber)()
56
57
  ], PlayGroupSubscriber);
57
- exports.PlayGroupSubscriber = PlayGroupSubscriber;
58
58
  //# sourceMappingURL=event-subscriber.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"event-subscriber.js","sourceRoot":"","sources":["../../../server/service/play-group/event-subscriber.ts"],"names":[],"mappings":";;;;AAAA,qCAA8F;AAE9F,iDAA6D;AAE7D,6CAAwC;AAGjC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAC9B,QAAQ;QACN,OAAO,sBAAS,CAAA;IAClB,CAAC;IAED,oEAAoE;IACpE,mCAAmC;IAEnC,kCAAkC;IAClC,gBAAgB;IAChB,OAAO;IACP,IAAI;IAEJ,KAAK,CAAC,WAAW,CAAC,KAA6B;QAC7C,IAAI,SAAS,GAAG,KAAK,CAAC,MAAM,CAAA;QAE5B,SAAS,GAAG,MAAM,IAAA,qBAAa,EAAC,sBAAS,CAAC,CAAC,OAAO,CAAC;YACjD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,EAAE;YAC/D,SAAS,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;SAChC,CAAC,CAAA;QAEF,IAAI,CAAC,SAAS,EAAE;YACd,OAAM;SACP;QAED,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAChD,4BAA4B;YAC5B,MAAM,YAAY,GAAG,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YAC1D,MAAM,aAAa,GAAG,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YAE3D,yBAAyB;YACzB,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;gBAC/C,mCAAmC;gBACnC,OAAO,CAAC,CAAA;aACT;iBAAM,IAAI,YAAY,KAAK,CAAC,CAAC,EAAE;gBAC9B,uCAAuC;gBACvC,OAAO,CAAC,CAAA;aACT;iBAAM,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;gBAC/B,uCAAuC;gBACvC,OAAO,CAAC,CAAC,CAAA;aACV;iBAAM;gBACL,8CAA8C;gBAC9C,OAAO,YAAY,GAAG,aAAa,CAAA;aACpC;QACH,CAAC,CAAC,CAAA;QAEF,cAAM,CAAC,OAAO,CAAC,YAAY,EAAE;YAC3B,SAAS;SACV,CAAC,CAAA;IACJ,CAAC;CACF,CAAA;AAlDY,mBAAmB;IAD/B,IAAA,yBAAe,GAAE;GACL,mBAAmB,CAkD/B;AAlDY,kDAAmB","sourcesContent":["import { EventSubscriber, EntitySubscriberInterface, InsertEvent, UpdateEvent } from 'typeorm'\n\nimport { pubsub, getRepository } from '@things-factory/shell'\n\nimport { PlayGroup } from './play-group'\n\n@EventSubscriber()\nexport class PlayGroupSubscriber implements EntitySubscriberInterface<PlayGroup> {\n listenTo() {\n return PlayGroup\n }\n\n // afterInsert(event: InsertEvent<PlayGroup>): Promise<any> | void {\n // const playGroup = event.entity\n\n // pubsub.publish('playGroup', {\n // playGroup\n // })\n // }\n\n async afterUpdate(event: UpdateEvent<PlayGroup>): Promise<any> {\n var playGroup = event.entity\n\n playGroup = await getRepository(PlayGroup).findOne({\n where: { domain: { id: playGroup.domainId }, id: playGroup.id },\n relations: ['domain', 'boards']\n })\n\n if (!playGroup) {\n return\n }\n\n playGroup.boards = playGroup.boards.sort((a, b) => {\n // 배열 A에 포함된 아이디의 순서를 가져옵니다.\n const indexOfOrder = (playGroup.order || []).indexOf(a.id)\n const indexOfBoards = (playGroup.order || []).indexOf(b.id)\n\n // 두 아이디의 순서를 비교하여 정렬합니다.\n if (indexOfOrder === -1 && indexOfBoards === -1) {\n // 두 아이디 모두 배열 A에 없는 경우, 그대로 유지합니다.\n return 0\n } else if (indexOfOrder === -1) {\n // 아이디 A만 배열 A에 없는 경우, 아이디 B를 먼저 정렬합니다.\n return 1\n } else if (indexOfBoards === -1) {\n // 아이디 B만 배열 A에 없는 경우, 아이디 A를 먼저 정렬합니다.\n return -1\n } else {\n // 두 아이디 모두 배열 A에 있는 경우, 배열 A의 아이디 순서대로 정렬합니다.\n return indexOfOrder - indexOfBoards\n }\n })\n\n pubsub.publish('play-group', {\n playGroup\n })\n }\n}\n"]}
1
+ {"version":3,"file":"event-subscriber.js","sourceRoot":"","sources":["../../../server/service/play-group/event-subscriber.ts"],"names":[],"mappings":";;;;AAAA,qCAA8F;AAE9F,iDAA6D;AAE7D,6CAAwC;AAGjC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAC9B,QAAQ;QACN,OAAO,sBAAS,CAAA;IAClB,CAAC;IAED,oEAAoE;IACpE,mCAAmC;IAEnC,kCAAkC;IAClC,gBAAgB;IAChB,OAAO;IACP,IAAI;IAEJ,KAAK,CAAC,WAAW,CAAC,KAA6B;QAC7C,IAAI,SAAS,GAAG,KAAK,CAAC,MAAM,CAAA;QAE5B,SAAS,GAAG,MAAM,IAAA,qBAAa,EAAC,sBAAS,CAAC,CAAC,OAAO,CAAC;YACjD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,EAAE;YAC/D,SAAS,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;SAChC,CAAC,CAAA;QAEF,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAM;QACR,CAAC;QAED,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAChD,4BAA4B;YAC5B,MAAM,YAAY,GAAG,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YAC1D,MAAM,aAAa,GAAG,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;YAE3D,yBAAyB;YACzB,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE,CAAC;gBAChD,mCAAmC;gBACnC,OAAO,CAAC,CAAA;YACV,CAAC;iBAAM,IAAI,YAAY,KAAK,CAAC,CAAC,EAAE,CAAC;gBAC/B,uCAAuC;gBACvC,OAAO,CAAC,CAAA;YACV,CAAC;iBAAM,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE,CAAC;gBAChC,uCAAuC;gBACvC,OAAO,CAAC,CAAC,CAAA;YACX,CAAC;iBAAM,CAAC;gBACN,8CAA8C;gBAC9C,OAAO,YAAY,GAAG,aAAa,CAAA;YACrC,CAAC;QACH,CAAC,CAAC,CAAA;QAEF,cAAM,CAAC,OAAO,CAAC,YAAY,EAAE;YAC3B,SAAS;SACV,CAAC,CAAA;IACJ,CAAC;CACF,CAAA;AAlDY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,yBAAe,GAAE;GACL,mBAAmB,CAkD/B","sourcesContent":["import { EventSubscriber, EntitySubscriberInterface, InsertEvent, UpdateEvent } from 'typeorm'\n\nimport { pubsub, getRepository } from '@things-factory/shell'\n\nimport { PlayGroup } from './play-group'\n\n@EventSubscriber()\nexport class PlayGroupSubscriber implements EntitySubscriberInterface<PlayGroup> {\n listenTo() {\n return PlayGroup\n }\n\n // afterInsert(event: InsertEvent<PlayGroup>): Promise<any> | void {\n // const playGroup = event.entity\n\n // pubsub.publish('playGroup', {\n // playGroup\n // })\n // }\n\n async afterUpdate(event: UpdateEvent<PlayGroup>): Promise<any> {\n var playGroup = event.entity\n\n playGroup = await getRepository(PlayGroup).findOne({\n where: { domain: { id: playGroup.domainId }, id: playGroup.id },\n relations: ['domain', 'boards']\n })\n\n if (!playGroup) {\n return\n }\n\n playGroup.boards = playGroup.boards.sort((a, b) => {\n // 배열 A에 포함된 아이디의 순서를 가져옵니다.\n const indexOfOrder = (playGroup.order || []).indexOf(a.id)\n const indexOfBoards = (playGroup.order || []).indexOf(b.id)\n\n // 두 아이디의 순서를 비교하여 정렬합니다.\n if (indexOfOrder === -1 && indexOfBoards === -1) {\n // 두 아이디 모두 배열 A에 없는 경우, 그대로 유지합니다.\n return 0\n } else if (indexOfOrder === -1) {\n // 아이디 A만 배열 A에 없는 경우, 아이디 B를 먼저 정렬합니다.\n return 1\n } else if (indexOfBoards === -1) {\n // 아이디 B만 배열 A에 없는 경우, 아이디 A를 먼저 정렬합니다.\n return -1\n } else {\n // 두 아이디 모두 배열 A에 있는 경우, 배열 A의 아이디 순서대로 정렬합니다.\n return indexOfOrder - indexOfBoards\n }\n })\n\n pubsub.publish('play-group', {\n playGroup\n })\n }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ import { PlayGroup } from './play-group';
2
+ import { PlayGroupQuery } from './play-group-query';
3
+ import { PlayGroupMutation } from './play-group-mutation';
4
+ import { PlayGroupSubscription } from './play-group-subscription';
5
+ import { PlayGroupSubscriber } from './event-subscriber';
6
+ export declare const entities: (typeof PlayGroup)[];
7
+ export declare const resolvers: (typeof PlayGroupQuery | typeof PlayGroupMutation | typeof PlayGroupSubscription)[];
8
+ export declare const subscribers: (typeof PlayGroupSubscriber)[];
@@ -0,0 +1,10 @@
1
+ import { PlayGroup } from './play-group';
2
+ import { NewPlayGroup, PlayGroupPatch } from './play-group-type';
3
+ export declare class PlayGroupMutation {
4
+ createPlayGroup(playGroup: NewPlayGroup, context: ResolverContext): Promise<PlayGroup>;
5
+ updatePlayGroup(id: string, patch: PlayGroupPatch, context: ResolverContext): Promise<PlayGroup>;
6
+ reorderPlayGroup(id: string, boardIds: string[], context: ResolverContext): Promise<PlayGroup>;
7
+ joinPlayGroup(id: string, boardIds: string[], context: ResolverContext): Promise<PlayGroup>;
8
+ leavePlayGroup(id: string, boardIds: string[], context: ResolverContext): Promise<PlayGroup>;
9
+ deletePlayGroup(id: string, context: ResolverContext): Promise<boolean>;
10
+ }
@@ -81,6 +81,7 @@ let PlayGroupMutation = class PlayGroupMutation {
81
81
  return true;
82
82
  }
83
83
  };
84
+ exports.PlayGroupMutation = PlayGroupMutation;
84
85
  tslib_1.__decorate([
85
86
  (0, type_graphql_1.Mutation)(returns => play_group_1.PlayGroup, { description: 'To create new PlayGroup' }),
86
87
  (0, type_graphql_1.Directive)('@transaction'),
@@ -139,8 +140,7 @@ tslib_1.__decorate([
139
140
  tslib_1.__metadata("design:paramtypes", [String, Object]),
140
141
  tslib_1.__metadata("design:returntype", Promise)
141
142
  ], PlayGroupMutation.prototype, "deletePlayGroup", null);
142
- PlayGroupMutation = tslib_1.__decorate([
143
+ exports.PlayGroupMutation = PlayGroupMutation = tslib_1.__decorate([
143
144
  (0, type_graphql_1.Resolver)(play_group_1.PlayGroup)
144
145
  ], PlayGroupMutation);
145
- exports.PlayGroupMutation = PlayGroupMutation;
146
146
  //# sourceMappingURL=play-group-mutation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"play-group-mutation.js","sourceRoot":"","sources":["../../../server/service/play-group/play-group-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Data } from '@things-factory/shell'\nimport { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { In } from 'typeorm'\n\nimport { Board } from '../board/board'\nimport { PlayGroup } from './play-group'\nimport { NewPlayGroup, PlayGroupPatch } from './play-group-type'\n\n@Resolver(PlayGroup)\nexport class PlayGroupMutation {\n @Mutation(returns => PlayGroup, { description: 'To create new PlayGroup' })\n @Directive('@transaction')\n async createPlayGroup(\n @Arg('playGroup') playGroup: NewPlayGroup,\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n\n return await tx.getRepository(PlayGroup).save({\n domain,\n ...playGroup,\n creator: user,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To modify PlayGroup information' })\n @Directive('@transaction')\n async updatePlayGroup(\n @Arg('id') id: string,\n @Arg('patch') patch: PlayGroupPatch,\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...playGroup,\n ...patch,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To modify board order of a PlayGroup' })\n @Directive('@transaction')\n async reorderPlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...playGroup,\n order: boardIds,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To make the board to join the play group' })\n @Directive('@transaction')\n async joinPlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { tx } = context.state\n\n const repository = tx.getRepository(PlayGroup)\n const playGroup = await repository.findOne({\n where: { id },\n relations: ['boards']\n })\n const order = playGroup.order || []\n\n const boardIdList = playGroup.boards.map(board => board.id)\n boardIds.forEach(boardId => {\n if (boardIdList.indexOf(boardId) == -1) {\n boardIdList.push(boardId)\n }\n if (order.indexOf(boardId) == -1) {\n order.push(boardId)\n }\n })\n\n const boardRepository = tx.getRepository(Board)\n playGroup.boards = await boardRepository.findBy({ id: In(boardIdList) })\n playGroup.updatedAt = new Date()\n playGroup.order = order\n\n return await repository.save(playGroup)\n }\n\n @Mutation(returns => PlayGroup, { description: 'To make the board to leave from the play group' })\n @Directive('@transaction')\n async leavePlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { tx } = context.state\n\n const repository = tx.getRepository(PlayGroup)\n const playGroup = await repository.findOne({\n where: { id },\n relations: ['boards']\n })\n const order = playGroup.order || []\n\n const boardIdList = playGroup.boards.map(board => board.id)\n boardIds.forEach(boardId => {\n let index = boardIdList.indexOf(boardId)\n if (index !== -1) {\n boardIdList.splice(index, 1)\n }\n\n index = order.indexOf(boardId)\n if (index !== -1) {\n order.splice(index, 1)\n }\n })\n\n const boardRepository = tx.getRepository(Board)\n playGroup.boards = await boardRepository.findBy({ id: In(boardIdList) })\n playGroup.updatedAt = new Date()\n playGroup.order = order\n\n return await repository.save(playGroup)\n }\n\n @Mutation(returns => Boolean, { description: 'To delete PlayGroup' })\n @Directive('@transaction')\n async deletePlayGroup(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<boolean> {\n const { domain, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n /* TODO - 플레이 그룹은 소속된 보드-플레이그룹 관계들도 제거되어야 한다. */\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n await repository.delete(id)\n return true\n }\n}\n"]}
1
+ {"version":3,"file":"play-group-mutation.js","sourceRoot":"","sources":["../../../server/service/play-group/play-group-mutation.ts"],"names":[],"mappings":"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","sourcesContent":["import { Data } from '@things-factory/shell'\nimport { Arg, Ctx, Directive, Mutation, Resolver } from 'type-graphql'\nimport { In } from 'typeorm'\n\nimport { Board } from '../board/board'\nimport { PlayGroup } from './play-group'\nimport { NewPlayGroup, PlayGroupPatch } from './play-group-type'\n\n@Resolver(PlayGroup)\nexport class PlayGroupMutation {\n @Mutation(returns => PlayGroup, { description: 'To create new PlayGroup' })\n @Directive('@transaction')\n async createPlayGroup(\n @Arg('playGroup') playGroup: NewPlayGroup,\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n\n return await tx.getRepository(PlayGroup).save({\n domain,\n ...playGroup,\n creator: user,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To modify PlayGroup information' })\n @Directive('@transaction')\n async updatePlayGroup(\n @Arg('id') id: string,\n @Arg('patch') patch: PlayGroupPatch,\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...playGroup,\n ...patch,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To modify board order of a PlayGroup' })\n @Directive('@transaction')\n async reorderPlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ): Promise<PlayGroup> {\n const { domain, user, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n return await repository.save({\n ...playGroup,\n order: boardIds,\n updater: user\n })\n }\n\n @Mutation(returns => PlayGroup, { description: 'To make the board to join the play group' })\n @Directive('@transaction')\n async joinPlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { tx } = context.state\n\n const repository = tx.getRepository(PlayGroup)\n const playGroup = await repository.findOne({\n where: { id },\n relations: ['boards']\n })\n const order = playGroup.order || []\n\n const boardIdList = playGroup.boards.map(board => board.id)\n boardIds.forEach(boardId => {\n if (boardIdList.indexOf(boardId) == -1) {\n boardIdList.push(boardId)\n }\n if (order.indexOf(boardId) == -1) {\n order.push(boardId)\n }\n })\n\n const boardRepository = tx.getRepository(Board)\n playGroup.boards = await boardRepository.findBy({ id: In(boardIdList) })\n playGroup.updatedAt = new Date()\n playGroup.order = order\n\n return await repository.save(playGroup)\n }\n\n @Mutation(returns => PlayGroup, { description: 'To make the board to leave from the play group' })\n @Directive('@transaction')\n async leavePlayGroup(\n @Arg('id') id: string,\n @Arg('boardIds', type => [String]) boardIds: string[],\n @Ctx() context: ResolverContext\n ) {\n const { tx } = context.state\n\n const repository = tx.getRepository(PlayGroup)\n const playGroup = await repository.findOne({\n where: { id },\n relations: ['boards']\n })\n const order = playGroup.order || []\n\n const boardIdList = playGroup.boards.map(board => board.id)\n boardIds.forEach(boardId => {\n let index = boardIdList.indexOf(boardId)\n if (index !== -1) {\n boardIdList.splice(index, 1)\n }\n\n index = order.indexOf(boardId)\n if (index !== -1) {\n order.splice(index, 1)\n }\n })\n\n const boardRepository = tx.getRepository(Board)\n playGroup.boards = await boardRepository.findBy({ id: In(boardIdList) })\n playGroup.updatedAt = new Date()\n playGroup.order = order\n\n return await repository.save(playGroup)\n }\n\n @Mutation(returns => Boolean, { description: 'To delete PlayGroup' })\n @Directive('@transaction')\n async deletePlayGroup(@Arg('id') id: string, @Ctx() context: ResolverContext): Promise<boolean> {\n const { domain, tx } = context.state\n const repository = tx.getRepository(PlayGroup)\n\n /* TODO - 플레이 그룹은 소속된 보드-플레이그룹 관계들도 제거되어야 한다. */\n const playGroup = await repository.findOneBy({ domain: { id: domain.id }, id })\n\n await repository.delete(id)\n return true\n }\n}\n"]}