@things-factory/board-service 9.0.0-beta.27 → 9.0.0-beta.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist-server/constants/error-code.d.ts +2 -0
- package/dist-server/constants/error-code.js +6 -0
- package/dist-server/constants/error-code.js.map +1 -0
- package/dist-server/controllers/analyzer/analyze-integration.d.ts +5 -0
- package/dist-server/controllers/analyzer/analyze-integration.js +117 -0
- package/dist-server/controllers/analyzer/analyze-integration.js.map +1 -0
- package/dist-server/controllers/fonts.d.ts +9 -0
- package/dist-server/controllers/fonts.js +76 -0
- package/dist-server/controllers/fonts.js.map +1 -0
- package/dist-server/controllers/headless-model.d.ts +6 -0
- package/dist-server/controllers/headless-model.js +55 -0
- package/dist-server/controllers/headless-model.js.map +1 -0
- package/dist-server/controllers/headless-pdf-to-image.d.ts +12 -0
- package/dist-server/controllers/headless-pdf-to-image.js +106 -0
- package/dist-server/controllers/headless-pdf-to-image.js.map +1 -0
- package/dist-server/controllers/headless-playlist.d.ts +5 -0
- package/dist-server/controllers/headless-playlist.js +71 -0
- package/dist-server/controllers/headless-playlist.js.map +1 -0
- package/dist-server/controllers/headless-pool-for-board.d.ts +1 -0
- package/dist-server/controllers/headless-pool-for-board.js +64 -0
- package/dist-server/controllers/headless-pool-for-board.js.map +1 -0
- package/dist-server/controllers/headless-pool-for-label.d.ts +1 -0
- package/dist-server/controllers/headless-pool-for-label.js +133 -0
- package/dist-server/controllers/headless-pool-for-label.js.map +1 -0
- package/dist-server/controllers/index.d.ts +34 -0
- package/dist-server/controllers/index.js +14 -0
- package/dist-server/controllers/index.js.map +1 -0
- package/dist-server/controllers/label-command.d.ts +19 -0
- package/dist-server/controllers/label-command.js +52 -0
- package/dist-server/controllers/label-command.js.map +1 -0
- package/dist-server/controllers/pdf.d.ts +9 -0
- package/dist-server/controllers/pdf.js +102 -0
- package/dist-server/controllers/pdf.js.map +1 -0
- package/dist-server/controllers/screenshot.d.ts +11 -0
- package/dist-server/controllers/screenshot.js +101 -0
- package/dist-server/controllers/screenshot.js.map +1 -0
- package/dist-server/controllers/thumbnail.d.ts +7 -0
- package/dist-server/controllers/thumbnail.js +16 -0
- package/dist-server/controllers/thumbnail.js.map +1 -0
- package/dist-server/errors/index.d.ts +1 -0
- package/dist-server/errors/index.js +5 -0
- package/dist-server/errors/index.js.map +1 -0
- package/dist-server/errors/license-error.d.ts +11 -0
- package/dist-server/errors/license-error.js +18 -0
- package/dist-server/errors/license-error.js.map +1 -0
- package/dist-server/index.d.ts +5 -0
- package/dist-server/index.js +35 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/migrations/1556862253000-SeedGroup.d.ts +5 -0
- package/dist-server/migrations/1556862253000-SeedGroup.js +43 -0
- package/dist-server/migrations/1556862253000-SeedGroup.js.map +1 -0
- package/dist-server/migrations/index.d.ts +1 -0
- package/dist-server/migrations/index.js +12 -0
- package/dist-server/migrations/index.js.map +1 -0
- package/dist-server/routers/internal-board-view-router.d.ts +1 -0
- package/dist-server/routers/internal-board-view-router.js +32 -0
- package/dist-server/routers/internal-board-view-router.js.map +1 -0
- package/dist-server/routers/standalone-board-service-router.d.ts +1 -0
- package/dist-server/routers/standalone-board-service-router.js +250 -0
- package/dist-server/routers/standalone-board-service-router.js.map +1 -0
- package/dist-server/routes.d.ts +1 -0
- package/dist-server/routes.js +23 -0
- package/dist-server/routes.js.map +1 -0
- package/dist-server/service/analysis/analysis-query.d.ts +3 -0
- package/dist-server/service/analysis/analysis-query.js +25 -0
- package/dist-server/service/analysis/analysis-query.js.map +1 -0
- package/dist-server/service/analysis/index.d.ts +2 -0
- package/dist-server/service/analysis/index.js +6 -0
- package/dist-server/service/analysis/index.js.map +1 -0
- package/dist-server/service/board/board-history.d.ts +28 -0
- package/dist-server/service/board/board-history.js +155 -0
- package/dist-server/service/board/board-history.js.map +1 -0
- package/dist-server/service/board/board-mutation.d.ts +12 -0
- package/dist-server/service/board/board-mutation.js +377 -0
- package/dist-server/service/board/board-mutation.js.map +1 -0
- package/dist-server/service/board/board-query.d.ts +20 -0
- package/dist-server/service/board/board-query.js +220 -0
- package/dist-server/service/board/board-query.js.map +1 -0
- package/dist-server/service/board/board-subscription.d.ts +6 -0
- package/dist-server/service/board/board-subscription.js +49 -0
- package/dist-server/service/board/board-subscription.js.map +1 -0
- package/dist-server/service/board/board-type.d.ts +24 -0
- package/dist-server/service/board/board-type.js +88 -0
- package/dist-server/service/board/board-type.js.map +1 -0
- package/dist-server/service/board/board.d.ts +25 -0
- package/dist-server/service/board/board.js +140 -0
- package/dist-server/service/board/board.js.map +1 -0
- package/dist-server/service/board/event-subscriber.d.ts +15 -0
- package/dist-server/service/board/event-subscriber.js +63 -0
- package/dist-server/service/board/event-subscriber.js.map +1 -0
- package/dist-server/service/board/index.d.ts +9 -0
- package/dist-server/service/board/index.js +13 -0
- package/dist-server/service/board/index.js.map +1 -0
- package/dist-server/service/board-favorite/board-favorite-query.d.ts +5 -0
- package/dist-server/service/board-favorite/board-favorite-query.js +56 -0
- package/dist-server/service/board-favorite/board-favorite-query.js.map +1 -0
- package/dist-server/service/board-favorite/board-favorite-type.d.ts +8 -0
- package/dist-server/service/board-favorite/board-favorite-type.js +31 -0
- package/dist-server/service/board-favorite/board-favorite-type.js.map +1 -0
- package/dist-server/service/board-favorite/index.d.ts +3 -0
- package/dist-server/service/board-favorite/index.js +7 -0
- package/dist-server/service/board-favorite/index.js.map +1 -0
- package/dist-server/service/board-template/board-template-mutation.d.ts +8 -0
- package/dist-server/service/board-template/board-template-mutation.js +146 -0
- package/dist-server/service/board-template/board-template-mutation.js.map +1 -0
- package/dist-server/service/board-template/board-template-query.d.ts +13 -0
- package/dist-server/service/board-template/board-template-query.js +147 -0
- package/dist-server/service/board-template/board-template-query.js.map +1 -0
- package/dist-server/service/board-template/board-template-type.d.ts +21 -0
- package/dist-server/service/board-template/board-template-type.js +81 -0
- package/dist-server/service/board-template/board-template-type.js.map +1 -0
- package/dist-server/service/board-template/board-template.d.ts +23 -0
- package/dist-server/service/board-template/board-template.js +123 -0
- package/dist-server/service/board-template/board-template.js.map +1 -0
- package/dist-server/service/board-template/index.d.ts +6 -0
- package/dist-server/service/board-template/index.js +10 -0
- package/dist-server/service/board-template/index.js.map +1 -0
- package/dist-server/service/group/group-mutation.d.ts +8 -0
- package/dist-server/service/group/group-mutation.js +89 -0
- package/dist-server/service/group/group-mutation.js.map +1 -0
- package/dist-server/service/group/group-query.d.ts +13 -0
- package/dist-server/service/group/group-query.js +92 -0
- package/dist-server/service/group/group-query.js.map +1 -0
- package/dist-server/service/group/group-type.d.ts +13 -0
- package/dist-server/service/group/group-type.js +49 -0
- package/dist-server/service/group/group-type.js.map +1 -0
- package/dist-server/service/group/group.d.ts +17 -0
- package/dist-server/service/group/group.js +77 -0
- package/dist-server/service/group/group.js.map +1 -0
- package/dist-server/service/group/index.d.ts +5 -0
- package/dist-server/service/group/index.js +9 -0
- package/dist-server/service/group/index.js.map +1 -0
- package/dist-server/service/index.d.ts +10 -0
- package/dist-server/service/index.js +49 -0
- package/dist-server/service/index.js.map +1 -0
- package/dist-server/service/permission/domain-permission-subscriber.d.ts +9 -0
- package/dist-server/service/permission/domain-permission-subscriber.js +30 -0
- package/dist-server/service/permission/domain-permission-subscriber.js.map +1 -0
- package/dist-server/service/permission/index.d.ts +2 -0
- package/dist-server/service/permission/index.js +6 -0
- package/dist-server/service/permission/index.js.map +1 -0
- package/dist-server/service/play-group/event-subscriber.d.ts +6 -0
- package/dist-server/service/play-group/event-subscriber.js +58 -0
- package/dist-server/service/play-group/event-subscriber.js.map +1 -0
- package/dist-server/service/play-group/index.d.ts +8 -0
- package/dist-server/service/play-group/index.js +12 -0
- package/dist-server/service/play-group/index.js.map +1 -0
- package/dist-server/service/play-group/play-group-mutation.d.ts +10 -0
- package/dist-server/service/play-group/play-group-mutation.js +146 -0
- package/dist-server/service/play-group/play-group-mutation.js.map +1 -0
- package/dist-server/service/play-group/play-group-query.d.ts +14 -0
- package/dist-server/service/play-group/play-group-query.js +129 -0
- package/dist-server/service/play-group/play-group-query.js.map +1 -0
- package/dist-server/service/play-group/play-group-subscription.d.ts +6 -0
- package/dist-server/service/play-group/play-group-subscription.js +49 -0
- package/dist-server/service/play-group/play-group-subscription.js.map +1 -0
- package/dist-server/service/play-group/play-group-type.d.ts +13 -0
- package/dist-server/service/play-group/play-group-type.js +49 -0
- package/dist-server/service/play-group/play-group-type.js.map +1 -0
- package/dist-server/service/play-group/play-group.d.ts +18 -0
- package/dist-server/service/play-group/play-group.js +82 -0
- package/dist-server/service/play-group/play-group.js.map +1 -0
- package/dist-server/service/theme/index.d.ts +6 -0
- package/dist-server/service/theme/index.js +10 -0
- package/dist-server/service/theme/index.js.map +1 -0
- package/dist-server/service/theme/theme-mutation.d.ts +10 -0
- package/dist-server/service/theme/theme-mutation.js +125 -0
- package/dist-server/service/theme/theme-mutation.js.map +1 -0
- package/dist-server/service/theme/theme-query.d.ts +11 -0
- package/dist-server/service/theme/theme-query.js +79 -0
- package/dist-server/service/theme/theme-query.js.map +1 -0
- package/dist-server/service/theme/theme-type.d.ts +21 -0
- package/dist-server/service/theme/theme-type.js +82 -0
- package/dist-server/service/theme/theme-type.js.map +1 -0
- package/dist-server/service/theme/theme.d.ts +25 -0
- package/dist-server/service/theme/theme.js +101 -0
- package/dist-server/service/theme/theme.js.map +1 -0
- package/dist-server/tsconfig.tsbuildinfo +1 -0
- package/package.json +7 -7
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { BoardTemplate } from './board-template.js';
|
|
2
|
+
export declare class NewBoardTemplate {
|
|
3
|
+
name: string;
|
|
4
|
+
description: string;
|
|
5
|
+
model: string;
|
|
6
|
+
visibility: 'private' | 'public';
|
|
7
|
+
thumbnail: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class BoardTemplatePatch {
|
|
10
|
+
id?: string;
|
|
11
|
+
name?: string;
|
|
12
|
+
description?: string;
|
|
13
|
+
model: string;
|
|
14
|
+
visibility?: 'private' | 'public';
|
|
15
|
+
thumbnail?: string;
|
|
16
|
+
cuFlag?: string;
|
|
17
|
+
}
|
|
18
|
+
export declare class BoardTemplateList {
|
|
19
|
+
items: BoardTemplate[];
|
|
20
|
+
total: number;
|
|
21
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BoardTemplateList = exports.BoardTemplatePatch = exports.NewBoardTemplate = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const type_graphql_1 = require("type-graphql");
|
|
6
|
+
const board_template_js_1 = require("./board-template.js");
|
|
7
|
+
let NewBoardTemplate = class NewBoardTemplate {
|
|
8
|
+
};
|
|
9
|
+
exports.NewBoardTemplate = NewBoardTemplate;
|
|
10
|
+
tslib_1.__decorate([
|
|
11
|
+
(0, type_graphql_1.Field)(),
|
|
12
|
+
tslib_1.__metadata("design:type", String)
|
|
13
|
+
], NewBoardTemplate.prototype, "name", void 0);
|
|
14
|
+
tslib_1.__decorate([
|
|
15
|
+
(0, type_graphql_1.Field)(),
|
|
16
|
+
tslib_1.__metadata("design:type", String)
|
|
17
|
+
], NewBoardTemplate.prototype, "description", void 0);
|
|
18
|
+
tslib_1.__decorate([
|
|
19
|
+
(0, type_graphql_1.Field)(),
|
|
20
|
+
tslib_1.__metadata("design:type", String)
|
|
21
|
+
], NewBoardTemplate.prototype, "model", void 0);
|
|
22
|
+
tslib_1.__decorate([
|
|
23
|
+
(0, type_graphql_1.Field)(),
|
|
24
|
+
tslib_1.__metadata("design:type", String)
|
|
25
|
+
], NewBoardTemplate.prototype, "visibility", void 0);
|
|
26
|
+
tslib_1.__decorate([
|
|
27
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
28
|
+
tslib_1.__metadata("design:type", String)
|
|
29
|
+
], NewBoardTemplate.prototype, "thumbnail", void 0);
|
|
30
|
+
exports.NewBoardTemplate = NewBoardTemplate = tslib_1.__decorate([
|
|
31
|
+
(0, type_graphql_1.InputType)()
|
|
32
|
+
], NewBoardTemplate);
|
|
33
|
+
let BoardTemplatePatch = class BoardTemplatePatch {
|
|
34
|
+
};
|
|
35
|
+
exports.BoardTemplatePatch = BoardTemplatePatch;
|
|
36
|
+
tslib_1.__decorate([
|
|
37
|
+
(0, type_graphql_1.Field)(type => type_graphql_1.ID, { nullable: true }),
|
|
38
|
+
tslib_1.__metadata("design:type", String)
|
|
39
|
+
], BoardTemplatePatch.prototype, "id", void 0);
|
|
40
|
+
tslib_1.__decorate([
|
|
41
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
42
|
+
tslib_1.__metadata("design:type", String)
|
|
43
|
+
], BoardTemplatePatch.prototype, "name", void 0);
|
|
44
|
+
tslib_1.__decorate([
|
|
45
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
46
|
+
tslib_1.__metadata("design:type", String)
|
|
47
|
+
], BoardTemplatePatch.prototype, "description", void 0);
|
|
48
|
+
tslib_1.__decorate([
|
|
49
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
50
|
+
tslib_1.__metadata("design:type", String)
|
|
51
|
+
], BoardTemplatePatch.prototype, "model", void 0);
|
|
52
|
+
tslib_1.__decorate([
|
|
53
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
54
|
+
tslib_1.__metadata("design:type", String)
|
|
55
|
+
], BoardTemplatePatch.prototype, "visibility", void 0);
|
|
56
|
+
tslib_1.__decorate([
|
|
57
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
58
|
+
tslib_1.__metadata("design:type", String)
|
|
59
|
+
], BoardTemplatePatch.prototype, "thumbnail", void 0);
|
|
60
|
+
tslib_1.__decorate([
|
|
61
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
62
|
+
tslib_1.__metadata("design:type", String)
|
|
63
|
+
], BoardTemplatePatch.prototype, "cuFlag", void 0);
|
|
64
|
+
exports.BoardTemplatePatch = BoardTemplatePatch = tslib_1.__decorate([
|
|
65
|
+
(0, type_graphql_1.InputType)()
|
|
66
|
+
], BoardTemplatePatch);
|
|
67
|
+
let BoardTemplateList = class BoardTemplateList {
|
|
68
|
+
};
|
|
69
|
+
exports.BoardTemplateList = BoardTemplateList;
|
|
70
|
+
tslib_1.__decorate([
|
|
71
|
+
(0, type_graphql_1.Field)(type => [board_template_js_1.BoardTemplate]),
|
|
72
|
+
tslib_1.__metadata("design:type", Array)
|
|
73
|
+
], BoardTemplateList.prototype, "items", void 0);
|
|
74
|
+
tslib_1.__decorate([
|
|
75
|
+
(0, type_graphql_1.Field)(type => type_graphql_1.Int),
|
|
76
|
+
tslib_1.__metadata("design:type", Number)
|
|
77
|
+
], BoardTemplateList.prototype, "total", void 0);
|
|
78
|
+
exports.BoardTemplateList = BoardTemplateList = tslib_1.__decorate([
|
|
79
|
+
(0, type_graphql_1.ObjectType)()
|
|
80
|
+
], BoardTemplateList);
|
|
81
|
+
//# sourceMappingURL=board-template-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"board-template-type.js","sourceRoot":"","sources":["../../../server/service/board-template/board-template-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAoE;AACpE,2DAAmD;AAG5C,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,iCAAa,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.js'\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
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BoardTemplate = exports.BoardTemplateStatus = 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
|
+
const env_1 = require("@things-factory/env");
|
|
10
|
+
const ORMCONFIG = env_1.config.get('ormconfig', {});
|
|
11
|
+
const DATABASE_TYPE = ORMCONFIG.type;
|
|
12
|
+
var BoardTemplateStatus;
|
|
13
|
+
(function (BoardTemplateStatus) {
|
|
14
|
+
BoardTemplateStatus["DRAFT"] = "DRAFT";
|
|
15
|
+
BoardTemplateStatus["RELEASED"] = "RELEASED";
|
|
16
|
+
})(BoardTemplateStatus || (exports.BoardTemplateStatus = BoardTemplateStatus = {}));
|
|
17
|
+
(0, type_graphql_1.registerEnumType)(BoardTemplateStatus, {
|
|
18
|
+
name: 'BoardTemplateStatus',
|
|
19
|
+
description: 'state enumeration of a boardTemplate'
|
|
20
|
+
});
|
|
21
|
+
let BoardTemplate = class BoardTemplate {
|
|
22
|
+
};
|
|
23
|
+
exports.BoardTemplate = BoardTemplate;
|
|
24
|
+
tslib_1.__decorate([
|
|
25
|
+
(0, typeorm_1.PrimaryGeneratedColumn)('uuid'),
|
|
26
|
+
(0, type_graphql_1.Field)(type => type_graphql_1.ID),
|
|
27
|
+
tslib_1.__metadata("design:type", String)
|
|
28
|
+
], BoardTemplate.prototype, "id", void 0);
|
|
29
|
+
tslib_1.__decorate([
|
|
30
|
+
(0, typeorm_1.ManyToOne)(type => shell_1.Domain),
|
|
31
|
+
(0, type_graphql_1.Field)(type => shell_1.Domain),
|
|
32
|
+
tslib_1.__metadata("design:type", shell_1.Domain)
|
|
33
|
+
], BoardTemplate.prototype, "domain", void 0);
|
|
34
|
+
tslib_1.__decorate([
|
|
35
|
+
(0, typeorm_1.RelationId)((boardTemplate) => boardTemplate.domain),
|
|
36
|
+
tslib_1.__metadata("design:type", String)
|
|
37
|
+
], BoardTemplate.prototype, "domainId", void 0);
|
|
38
|
+
tslib_1.__decorate([
|
|
39
|
+
(0, typeorm_1.Column)(),
|
|
40
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
41
|
+
tslib_1.__metadata("design:type", String)
|
|
42
|
+
], BoardTemplate.prototype, "name", void 0);
|
|
43
|
+
tslib_1.__decorate([
|
|
44
|
+
(0, typeorm_1.Column)({ nullable: true }),
|
|
45
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
46
|
+
tslib_1.__metadata("design:type", String)
|
|
47
|
+
], BoardTemplate.prototype, "description", void 0);
|
|
48
|
+
tslib_1.__decorate([
|
|
49
|
+
(0, typeorm_1.Column)('simple-json', { nullable: true, default: null }),
|
|
50
|
+
(0, type_graphql_1.Field)(type => shell_1.ScalarObject, { nullable: true }),
|
|
51
|
+
tslib_1.__metadata("design:type", Array)
|
|
52
|
+
], BoardTemplate.prototype, "tags", void 0);
|
|
53
|
+
tslib_1.__decorate([
|
|
54
|
+
(0, typeorm_1.Column)({ nullable: true, default: 'private' }),
|
|
55
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
56
|
+
tslib_1.__metadata("design:type", String)
|
|
57
|
+
], BoardTemplate.prototype, "visibility", void 0);
|
|
58
|
+
tslib_1.__decorate([
|
|
59
|
+
(0, typeorm_1.Column)({
|
|
60
|
+
nullable: true,
|
|
61
|
+
type: DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'
|
|
62
|
+
? 'longtext'
|
|
63
|
+
: DATABASE_TYPE == 'oracle'
|
|
64
|
+
? 'clob'
|
|
65
|
+
: DATABASE_TYPE == 'mssql'
|
|
66
|
+
? 'nvarchar'
|
|
67
|
+
: 'varchar',
|
|
68
|
+
length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined
|
|
69
|
+
}),
|
|
70
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
71
|
+
tslib_1.__metadata("design:type", String)
|
|
72
|
+
], BoardTemplate.prototype, "model", void 0);
|
|
73
|
+
tslib_1.__decorate([
|
|
74
|
+
(0, typeorm_1.Column)({
|
|
75
|
+
nullable: true,
|
|
76
|
+
type: DATABASE_TYPE == 'mysql' || DATABASE_TYPE == 'mariadb'
|
|
77
|
+
? 'longtext'
|
|
78
|
+
: DATABASE_TYPE == 'oracle'
|
|
79
|
+
? 'clob'
|
|
80
|
+
: DATABASE_TYPE == 'mssql'
|
|
81
|
+
? 'nvarchar'
|
|
82
|
+
: 'varchar',
|
|
83
|
+
length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined
|
|
84
|
+
}),
|
|
85
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
86
|
+
tslib_1.__metadata("design:type", String)
|
|
87
|
+
], BoardTemplate.prototype, "thumbnail", void 0);
|
|
88
|
+
tslib_1.__decorate([
|
|
89
|
+
(0, typeorm_1.CreateDateColumn)(),
|
|
90
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
91
|
+
tslib_1.__metadata("design:type", Date)
|
|
92
|
+
], BoardTemplate.prototype, "createdAt", void 0);
|
|
93
|
+
tslib_1.__decorate([
|
|
94
|
+
(0, typeorm_1.UpdateDateColumn)(),
|
|
95
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
96
|
+
tslib_1.__metadata("design:type", Date)
|
|
97
|
+
], BoardTemplate.prototype, "updatedAt", void 0);
|
|
98
|
+
tslib_1.__decorate([
|
|
99
|
+
(0, typeorm_1.ManyToOne)(type => auth_base_1.User, { nullable: true }),
|
|
100
|
+
(0, type_graphql_1.Field)(type => auth_base_1.User, { nullable: true }),
|
|
101
|
+
tslib_1.__metadata("design:type", auth_base_1.User)
|
|
102
|
+
], BoardTemplate.prototype, "creator", void 0);
|
|
103
|
+
tslib_1.__decorate([
|
|
104
|
+
(0, typeorm_1.RelationId)((boardTemplate) => boardTemplate.creator),
|
|
105
|
+
tslib_1.__metadata("design:type", String)
|
|
106
|
+
], BoardTemplate.prototype, "creatorId", void 0);
|
|
107
|
+
tslib_1.__decorate([
|
|
108
|
+
(0, typeorm_1.ManyToOne)(type => auth_base_1.User, { nullable: true }),
|
|
109
|
+
(0, type_graphql_1.Field)(type => auth_base_1.User, { nullable: true }),
|
|
110
|
+
tslib_1.__metadata("design:type", auth_base_1.User)
|
|
111
|
+
], BoardTemplate.prototype, "updater", void 0);
|
|
112
|
+
tslib_1.__decorate([
|
|
113
|
+
(0, typeorm_1.RelationId)((boardTemplate) => boardTemplate.updater),
|
|
114
|
+
tslib_1.__metadata("design:type", String)
|
|
115
|
+
], BoardTemplate.prototype, "updaterId", void 0);
|
|
116
|
+
exports.BoardTemplate = BoardTemplate = tslib_1.__decorate([
|
|
117
|
+
(0, typeorm_1.Entity)(),
|
|
118
|
+
(0, typeorm_1.Index)('ix_board_template_0', (boardTemplate) => [boardTemplate.domain, boardTemplate.name], {
|
|
119
|
+
unique: true
|
|
120
|
+
}),
|
|
121
|
+
(0, type_graphql_1.ObjectType)({ description: 'Entity for BoardTemplate' })
|
|
122
|
+
], BoardTemplate);
|
|
123
|
+
//# sourceMappingURL=board-template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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 : DATABASE_TYPE == 'mssql'\n ? 'nvarchar'\n : 'varchar',\n length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined\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 : DATABASE_TYPE == 'mssql'\n ? 'nvarchar'\n : 'varchar',\n length: DATABASE_TYPE == 'mssql' ? 'MAX' : undefined\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.js';
|
|
2
|
+
import { BoardTemplateQuery } from './board-template-query.js';
|
|
3
|
+
import { BoardTemplateMutation } from './board-template-mutation.js';
|
|
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,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.subscribers = exports.resolvers = exports.entities = void 0;
|
|
4
|
+
const board_template_js_1 = require("./board-template.js");
|
|
5
|
+
const board_template_query_js_1 = require("./board-template-query.js");
|
|
6
|
+
const board_template_mutation_js_1 = require("./board-template-mutation.js");
|
|
7
|
+
exports.entities = [board_template_js_1.BoardTemplate];
|
|
8
|
+
exports.resolvers = [board_template_query_js_1.BoardTemplateQuery, board_template_mutation_js_1.BoardTemplateMutation];
|
|
9
|
+
exports.subscribers = [];
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/service/board-template/index.ts"],"names":[],"mappings":";;;AAAA,2DAAmD;AACnD,uEAA8D;AAC9D,6EAAoE;AAEvD,QAAA,QAAQ,GAAG,CAAC,iCAAa,CAAC,CAAA;AAC1B,QAAA,SAAS,GAAG,CAAC,4CAAkB,EAAE,kDAAqB,CAAC,CAAA;AACvD,QAAA,WAAW,GAAG,EAAE,CAAA","sourcesContent":["import { BoardTemplate } from './board-template.js'\nimport { BoardTemplateQuery } from './board-template-query.js'\nimport { BoardTemplateMutation } from './board-template-mutation.js'\n\nexport const entities = [BoardTemplate]\nexport const resolvers = [BoardTemplateQuery, BoardTemplateMutation]\nexport const subscribers = []\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Group } from './group.js';
|
|
2
|
+
import { GroupPatch, NewGroup } from './group-type.js';
|
|
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
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GroupMutation = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const type_graphql_1 = require("type-graphql");
|
|
6
|
+
const board_js_1 = require("../board/board.js");
|
|
7
|
+
const group_js_1 = require("./group.js");
|
|
8
|
+
const group_type_js_1 = require("./group-type.js");
|
|
9
|
+
let GroupMutation = class GroupMutation {
|
|
10
|
+
async createGroup(group, context) {
|
|
11
|
+
const { domain, user, tx } = context.state;
|
|
12
|
+
return await tx.getRepository(group_js_1.Group).save(Object.assign(Object.assign({ domain }, group), { creator: user, updater: user }));
|
|
13
|
+
}
|
|
14
|
+
async updateGroup(id, patch, context) {
|
|
15
|
+
const { domain, user, tx } = context.state;
|
|
16
|
+
const repository = tx.getRepository(group_js_1.Group);
|
|
17
|
+
const group = await repository.findOneBy({ domain: { id: domain.id }, id });
|
|
18
|
+
return await repository.save(Object.assign(Object.assign(Object.assign({}, group), patch), { updater: user }));
|
|
19
|
+
}
|
|
20
|
+
async joinGroup(id, boardIds, context) {
|
|
21
|
+
const { domain, tx } = context.state;
|
|
22
|
+
const repository = tx.getRepository(group_js_1.Group);
|
|
23
|
+
const group = await repository.findOneBy({ domain: { id: domain.id }, id });
|
|
24
|
+
const boardRepository = tx.getRepository(board_js_1.Board);
|
|
25
|
+
await boardIds.forEach(async (boardId) => {
|
|
26
|
+
let board = await boardRepository.findOneBy({ domain: { id: domain.id }, id: boardId });
|
|
27
|
+
board.group = group;
|
|
28
|
+
await boardRepository.save(board);
|
|
29
|
+
});
|
|
30
|
+
return await repository.findOne({
|
|
31
|
+
where: { domain: { id: domain.id }, id },
|
|
32
|
+
relations: ['boards']
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
async deleteGroup(id, context) {
|
|
36
|
+
const { domain, tx } = context.state;
|
|
37
|
+
const repository = tx.getRepository(group_js_1.Group);
|
|
38
|
+
/* TODO - 그룹에 소속된 보드가 있는 경우에는 그룹을 지워서는 안된다. */
|
|
39
|
+
const group = await repository.findOneBy({
|
|
40
|
+
domain: { id: domain.id },
|
|
41
|
+
id
|
|
42
|
+
});
|
|
43
|
+
await repository.delete(id);
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
exports.GroupMutation = GroupMutation;
|
|
48
|
+
tslib_1.__decorate([
|
|
49
|
+
(0, type_graphql_1.Directive)('@transaction'),
|
|
50
|
+
(0, type_graphql_1.Mutation)(returns => group_js_1.Group, { nullable: true, description: 'To create new Group' }),
|
|
51
|
+
tslib_1.__param(0, (0, type_graphql_1.Arg)('group')),
|
|
52
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
53
|
+
tslib_1.__metadata("design:type", Function),
|
|
54
|
+
tslib_1.__metadata("design:paramtypes", [group_type_js_1.NewGroup, Object]),
|
|
55
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
56
|
+
], GroupMutation.prototype, "createGroup", null);
|
|
57
|
+
tslib_1.__decorate([
|
|
58
|
+
(0, type_graphql_1.Directive)('@transaction'),
|
|
59
|
+
(0, type_graphql_1.Mutation)(returns => group_js_1.Group, { description: 'To modify Group information' }),
|
|
60
|
+
tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
|
|
61
|
+
tslib_1.__param(1, (0, type_graphql_1.Arg)('patch')),
|
|
62
|
+
tslib_1.__param(2, (0, type_graphql_1.Ctx)()),
|
|
63
|
+
tslib_1.__metadata("design:type", Function),
|
|
64
|
+
tslib_1.__metadata("design:paramtypes", [String, group_type_js_1.GroupPatch, Object]),
|
|
65
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
66
|
+
], GroupMutation.prototype, "updateGroup", null);
|
|
67
|
+
tslib_1.__decorate([
|
|
68
|
+
(0, type_graphql_1.Directive)('@transaction'),
|
|
69
|
+
(0, type_graphql_1.Mutation)(returns => group_js_1.Group, { description: 'To make the board to join the group' }),
|
|
70
|
+
tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
|
|
71
|
+
tslib_1.__param(1, (0, type_graphql_1.Arg)('boardIds', type => [String])),
|
|
72
|
+
tslib_1.__param(2, (0, type_graphql_1.Ctx)()),
|
|
73
|
+
tslib_1.__metadata("design:type", Function),
|
|
74
|
+
tslib_1.__metadata("design:paramtypes", [String, Array, Object]),
|
|
75
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
76
|
+
], GroupMutation.prototype, "joinGroup", null);
|
|
77
|
+
tslib_1.__decorate([
|
|
78
|
+
(0, type_graphql_1.Directive)('@transaction'),
|
|
79
|
+
(0, type_graphql_1.Mutation)(returns => Boolean, { description: 'To delete Group' }),
|
|
80
|
+
tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
|
|
81
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
82
|
+
tslib_1.__metadata("design:type", Function),
|
|
83
|
+
tslib_1.__metadata("design:paramtypes", [String, Object]),
|
|
84
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
85
|
+
], GroupMutation.prototype, "deleteGroup", null);
|
|
86
|
+
exports.GroupMutation = GroupMutation = tslib_1.__decorate([
|
|
87
|
+
(0, type_graphql_1.Resolver)(group_js_1.Group)
|
|
88
|
+
], GroupMutation);
|
|
89
|
+
//# sourceMappingURL=group-mutation.js.map
|
|
@@ -0,0 +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.js'\nimport { Group } from './group.js'\nimport { GroupPatch, NewGroup } from './group-type.js'\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.js';
|
|
4
|
+
import { Group } from './group.js';
|
|
5
|
+
import { GroupList } from './group-type.js';
|
|
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
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GroupQuery = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const type_graphql_1 = require("type-graphql");
|
|
6
|
+
const auth_base_1 = require("@things-factory/auth-base");
|
|
7
|
+
const shell_1 = require("@things-factory/shell");
|
|
8
|
+
const board_js_1 = require("../board/board.js");
|
|
9
|
+
const group_js_1 = require("./group.js");
|
|
10
|
+
const group_type_js_1 = require("./group-type.js");
|
|
11
|
+
let GroupQuery = class GroupQuery {
|
|
12
|
+
async group(id, context) {
|
|
13
|
+
const { domain } = context.state;
|
|
14
|
+
return await (0, shell_1.getRepository)(group_js_1.Group).findOne({
|
|
15
|
+
where: { domain: { id: domain.id }, id }
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
async groups(params, context) {
|
|
19
|
+
const { domain } = context.state;
|
|
20
|
+
const queryBuilder = (0, shell_1.getQueryBuilderFromListParams)({
|
|
21
|
+
repository: (0, shell_1.getRepository)(group_js_1.Group),
|
|
22
|
+
params,
|
|
23
|
+
domain,
|
|
24
|
+
searchables: ['name', 'description']
|
|
25
|
+
});
|
|
26
|
+
const [items, total] = await queryBuilder.getManyAndCount();
|
|
27
|
+
return { items, total };
|
|
28
|
+
}
|
|
29
|
+
async boards(group) {
|
|
30
|
+
return await (0, shell_1.getRepository)(board_js_1.Board).findBy({
|
|
31
|
+
group: { id: group.id }
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
async domain(group) {
|
|
35
|
+
return await (0, shell_1.getRepository)(shell_1.Domain).findOneBy({ id: group.domainId });
|
|
36
|
+
}
|
|
37
|
+
async updater(group) {
|
|
38
|
+
return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: group.updaterId });
|
|
39
|
+
}
|
|
40
|
+
async creator(group) {
|
|
41
|
+
return await (0, shell_1.getRepository)(auth_base_1.User).findOneBy({ id: group.creatorId });
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.GroupQuery = GroupQuery;
|
|
45
|
+
tslib_1.__decorate([
|
|
46
|
+
(0, type_graphql_1.Query)(returns => group_js_1.Group, { nullable: true, description: 'To fetch a Group' }),
|
|
47
|
+
tslib_1.__param(0, (0, type_graphql_1.Arg)('id')),
|
|
48
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
49
|
+
tslib_1.__metadata("design:type", Function),
|
|
50
|
+
tslib_1.__metadata("design:paramtypes", [String, Object]),
|
|
51
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
52
|
+
], GroupQuery.prototype, "group", null);
|
|
53
|
+
tslib_1.__decorate([
|
|
54
|
+
(0, type_graphql_1.Query)(returns => group_type_js_1.GroupList, { description: 'To fetch multiple Groups' }),
|
|
55
|
+
tslib_1.__param(0, (0, type_graphql_1.Args)(type => shell_1.ListParam)),
|
|
56
|
+
tslib_1.__param(1, (0, type_graphql_1.Ctx)()),
|
|
57
|
+
tslib_1.__metadata("design:type", Function),
|
|
58
|
+
tslib_1.__metadata("design:paramtypes", [shell_1.ListParam, Object]),
|
|
59
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
60
|
+
], GroupQuery.prototype, "groups", null);
|
|
61
|
+
tslib_1.__decorate([
|
|
62
|
+
(0, type_graphql_1.FieldResolver)(type => [board_js_1.Board]),
|
|
63
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
64
|
+
tslib_1.__metadata("design:type", Function),
|
|
65
|
+
tslib_1.__metadata("design:paramtypes", [group_js_1.Group]),
|
|
66
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
67
|
+
], GroupQuery.prototype, "boards", null);
|
|
68
|
+
tslib_1.__decorate([
|
|
69
|
+
(0, type_graphql_1.FieldResolver)(type => shell_1.Domain),
|
|
70
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
71
|
+
tslib_1.__metadata("design:type", Function),
|
|
72
|
+
tslib_1.__metadata("design:paramtypes", [group_js_1.Group]),
|
|
73
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
74
|
+
], GroupQuery.prototype, "domain", null);
|
|
75
|
+
tslib_1.__decorate([
|
|
76
|
+
(0, type_graphql_1.FieldResolver)(type => auth_base_1.User),
|
|
77
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
78
|
+
tslib_1.__metadata("design:type", Function),
|
|
79
|
+
tslib_1.__metadata("design:paramtypes", [group_js_1.Group]),
|
|
80
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
81
|
+
], GroupQuery.prototype, "updater", null);
|
|
82
|
+
tslib_1.__decorate([
|
|
83
|
+
(0, type_graphql_1.FieldResolver)(type => auth_base_1.User),
|
|
84
|
+
tslib_1.__param(0, (0, type_graphql_1.Root)()),
|
|
85
|
+
tslib_1.__metadata("design:type", Function),
|
|
86
|
+
tslib_1.__metadata("design:paramtypes", [group_js_1.Group]),
|
|
87
|
+
tslib_1.__metadata("design:returntype", Promise)
|
|
88
|
+
], GroupQuery.prototype, "creator", null);
|
|
89
|
+
exports.GroupQuery = GroupQuery = tslib_1.__decorate([
|
|
90
|
+
(0, type_graphql_1.Resolver)(group_js_1.Group)
|
|
91
|
+
], GroupQuery);
|
|
92
|
+
//# sourceMappingURL=group-query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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.js'\nimport { Group } from './group.js'\nimport { GroupList } from './group-type.js'\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.js';
|
|
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
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GroupList = exports.GroupPatch = exports.NewGroup = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const type_graphql_1 = require("type-graphql");
|
|
6
|
+
const group_js_1 = require("./group.js");
|
|
7
|
+
let NewGroup = class NewGroup {
|
|
8
|
+
};
|
|
9
|
+
exports.NewGroup = NewGroup;
|
|
10
|
+
tslib_1.__decorate([
|
|
11
|
+
(0, type_graphql_1.Field)(),
|
|
12
|
+
tslib_1.__metadata("design:type", String)
|
|
13
|
+
], NewGroup.prototype, "name", void 0);
|
|
14
|
+
tslib_1.__decorate([
|
|
15
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
16
|
+
tslib_1.__metadata("design:type", String)
|
|
17
|
+
], NewGroup.prototype, "description", void 0);
|
|
18
|
+
exports.NewGroup = NewGroup = tslib_1.__decorate([
|
|
19
|
+
(0, type_graphql_1.InputType)()
|
|
20
|
+
], NewGroup);
|
|
21
|
+
let GroupPatch = class GroupPatch {
|
|
22
|
+
};
|
|
23
|
+
exports.GroupPatch = GroupPatch;
|
|
24
|
+
tslib_1.__decorate([
|
|
25
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
26
|
+
tslib_1.__metadata("design:type", String)
|
|
27
|
+
], GroupPatch.prototype, "name", void 0);
|
|
28
|
+
tslib_1.__decorate([
|
|
29
|
+
(0, type_graphql_1.Field)({ nullable: true }),
|
|
30
|
+
tslib_1.__metadata("design:type", String)
|
|
31
|
+
], GroupPatch.prototype, "description", void 0);
|
|
32
|
+
exports.GroupPatch = GroupPatch = tslib_1.__decorate([
|
|
33
|
+
(0, type_graphql_1.InputType)()
|
|
34
|
+
], GroupPatch);
|
|
35
|
+
let GroupList = class GroupList {
|
|
36
|
+
};
|
|
37
|
+
exports.GroupList = GroupList;
|
|
38
|
+
tslib_1.__decorate([
|
|
39
|
+
(0, type_graphql_1.Field)(type => [group_js_1.Group]),
|
|
40
|
+
tslib_1.__metadata("design:type", Array)
|
|
41
|
+
], GroupList.prototype, "items", void 0);
|
|
42
|
+
tslib_1.__decorate([
|
|
43
|
+
(0, type_graphql_1.Field)(type => type_graphql_1.Int),
|
|
44
|
+
tslib_1.__metadata("design:type", Number)
|
|
45
|
+
], GroupList.prototype, "total", void 0);
|
|
46
|
+
exports.GroupList = GroupList = tslib_1.__decorate([
|
|
47
|
+
(0, type_graphql_1.ObjectType)()
|
|
48
|
+
], GroupList);
|
|
49
|
+
//# sourceMappingURL=group-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"group-type.js","sourceRoot":"","sources":["../../../server/service/group/group-type.ts"],"names":[],"mappings":";;;;AAAA,+CAAsF;AAEtF,yCAAkC;AAG3B,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,gBAAK,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.js'\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.js';
|
|
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
|
+
}
|