nicot 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintignore +4 -0
- package/.eslintrc.js +24 -0
- package/.prettierrc +4 -0
- package/LICENSE +22 -0
- package/README.md +3 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +22 -0
- package/dist/index.js.map +1 -0
- package/dist/src/bases/id-base.d.ts +46 -0
- package/dist/src/bases/id-base.js +57 -0
- package/dist/src/bases/id-base.js.map +1 -0
- package/dist/src/bases/index.d.ts +2 -0
- package/dist/src/bases/index.js +19 -0
- package/dist/src/bases/index.js.map +1 -0
- package/dist/src/bases/time-base.d.ts +19 -0
- package/dist/src/bases/time-base.js +47 -0
- package/dist/src/bases/time-base.js.map +1 -0
- package/dist/src/crud-base.d.ts +103 -0
- package/dist/src/crud-base.js +262 -0
- package/dist/src/crud-base.js.map +1 -0
- package/dist/src/decorators/access.d.ts +2 -0
- package/dist/src/decorators/access.js +11 -0
- package/dist/src/decorators/access.js.map +1 -0
- package/dist/src/decorators/index.d.ts +5 -0
- package/dist/src/decorators/index.js +22 -0
- package/dist/src/decorators/index.js.map +1 -0
- package/dist/src/decorators/merge.d.ts +4 -0
- package/dist/src/decorators/merge.js +36 -0
- package/dist/src/decorators/merge.js.map +1 -0
- package/dist/src/decorators/pipes.d.ts +4 -0
- package/dist/src/decorators/pipes.js +23 -0
- package/dist/src/decorators/pipes.js.map +1 -0
- package/dist/src/decorators/property.d.ts +25 -0
- package/dist/src/decorators/property.js +110 -0
- package/dist/src/decorators/property.js.map +1 -0
- package/dist/src/decorators/restful.d.ts +28 -0
- package/dist/src/decorators/restful.js +86 -0
- package/dist/src/decorators/restful.js.map +1 -0
- package/dist/src/dto/import-entry.d.ts +11 -0
- package/dist/src/dto/import-entry.js +28 -0
- package/dist/src/dto/import-entry.js.map +1 -0
- package/dist/src/dto/index.d.ts +2 -0
- package/dist/src/dto/index.js +19 -0
- package/dist/src/dto/index.js.map +1 -0
- package/dist/src/dto/page-settings.d.ts +20 -0
- package/dist/src/dto/page-settings.js +61 -0
- package/dist/src/dto/page-settings.js.map +1 -0
- package/dist/src/dto/return-message.d.ts +42 -0
- package/dist/src/dto/return-message.js +110 -0
- package/dist/src/dto/return-message.js.map +1 -0
- package/dist/src/utility/bigint.d.ts +5 -0
- package/dist/src/utility/bigint.js +16 -0
- package/dist/src/utility/bigint.js.map +1 -0
- package/dist/src/utility/index.d.ts +1 -0
- package/dist/src/utility/index.js +18 -0
- package/dist/src/utility/index.js.map +1 -0
- package/dist/src/utility/insert-field.d.ts +17 -0
- package/dist/src/utility/insert-field.js +24 -0
- package/dist/src/utility/insert-field.js.map +1 -0
- package/dist/src/utility/query.d.ts +5 -0
- package/dist/src/utility/query.js +35 -0
- package/dist/src/utility/query.js.map +1 -0
- package/index.ts +5 -0
- package/package.json +66 -0
- package/tsconfig.json +20 -0
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RestfulFactory = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const dto_1 = require("../dto");
|
|
6
|
+
const merge_1 = require("./merge");
|
|
7
|
+
const bases_1 = require("../bases");
|
|
8
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
9
|
+
const pipes_1 = require("./pipes");
|
|
10
|
+
class RestfulFactory {
|
|
11
|
+
constructor(entityClass, options = {}) {
|
|
12
|
+
this.entityClass = entityClass;
|
|
13
|
+
this.options = options;
|
|
14
|
+
this.entityReturnMessageDto = (0, dto_1.ReturnMessageDto)(this.entityClass);
|
|
15
|
+
this.entityArrayReturnMessageDto = (0, dto_1.PaginatedReturnMessageDto)(this.entityClass);
|
|
16
|
+
this.createDto = (0, swagger_1.OmitType)(this.entityClass, [
|
|
17
|
+
...bases_1.TimeBaseFields,
|
|
18
|
+
...(options.fieldsToOmit || []),
|
|
19
|
+
]);
|
|
20
|
+
this.updateDto = (0, swagger_1.PartialType)(this.createDto);
|
|
21
|
+
this.idType = Reflect.getMetadata('design:type', this.entityClass.prototype, 'id');
|
|
22
|
+
}
|
|
23
|
+
create(extras = {}) {
|
|
24
|
+
return (0, merge_1.MergeMethodDecorators)([
|
|
25
|
+
(0, common_1.Post)(),
|
|
26
|
+
(0, swagger_1.ApiOperation)({
|
|
27
|
+
summary: `Create a new ${this.entityClass.name}`,
|
|
28
|
+
...extras,
|
|
29
|
+
}),
|
|
30
|
+
(0, swagger_1.ApiBody)({ type: this.createDto }),
|
|
31
|
+
(0, swagger_1.ApiCreatedResponse)({ type: this.entityReturnMessageDto }),
|
|
32
|
+
]);
|
|
33
|
+
}
|
|
34
|
+
createParam() {
|
|
35
|
+
return (0, common_1.Body)(pipes_1.CreatePipe);
|
|
36
|
+
}
|
|
37
|
+
findOne(extras = {}) {
|
|
38
|
+
return (0, merge_1.MergeMethodDecorators)([
|
|
39
|
+
(0, common_1.Get)(':id'),
|
|
40
|
+
(0, swagger_1.ApiOperation)({
|
|
41
|
+
summary: `Find a ${this.entityClass.name} by id`,
|
|
42
|
+
...extras,
|
|
43
|
+
}),
|
|
44
|
+
(0, swagger_1.ApiParam)({ name: 'id', type: this.idType, required: true }),
|
|
45
|
+
(0, swagger_1.ApiOkResponse)({ type: this.entityReturnMessageDto }),
|
|
46
|
+
]);
|
|
47
|
+
}
|
|
48
|
+
findAll(extras = {}) {
|
|
49
|
+
return (0, merge_1.MergeMethodDecorators)([
|
|
50
|
+
(0, common_1.Get)(),
|
|
51
|
+
(0, swagger_1.ApiOperation)({ summary: `Find all ${this.entityClass.name}`, ...extras }),
|
|
52
|
+
(0, swagger_1.ApiOkResponse)({ type: this.entityArrayReturnMessageDto }),
|
|
53
|
+
]);
|
|
54
|
+
}
|
|
55
|
+
findAllParam() {
|
|
56
|
+
return (0, common_1.Query)(pipes_1.GetPipe);
|
|
57
|
+
}
|
|
58
|
+
update(extras = {}) {
|
|
59
|
+
return (0, merge_1.MergeMethodDecorators)([
|
|
60
|
+
(0, common_1.Patch)(':id'),
|
|
61
|
+
(0, swagger_1.ApiOperation)({
|
|
62
|
+
summary: `Update a ${this.entityClass.name} by id`,
|
|
63
|
+
...extras,
|
|
64
|
+
}),
|
|
65
|
+
(0, swagger_1.ApiParam)({ name: 'id', type: this.idType, required: true }),
|
|
66
|
+
(0, swagger_1.ApiBody)({ type: this.updateDto }),
|
|
67
|
+
(0, swagger_1.ApiOkResponse)({ type: dto_1.BlankReturnMessageDto }),
|
|
68
|
+
]);
|
|
69
|
+
}
|
|
70
|
+
updateParam() {
|
|
71
|
+
return (0, common_1.Body)(pipes_1.UpdatePipe);
|
|
72
|
+
}
|
|
73
|
+
delete(extras = {}) {
|
|
74
|
+
return (0, merge_1.MergeMethodDecorators)([
|
|
75
|
+
(0, common_1.Delete)(':id'),
|
|
76
|
+
(0, swagger_1.ApiOperation)({
|
|
77
|
+
summary: `Delete a ${this.entityClass.name} by id`,
|
|
78
|
+
...extras,
|
|
79
|
+
}),
|
|
80
|
+
(0, swagger_1.ApiParam)({ name: 'id', type: this.idType, required: true }),
|
|
81
|
+
(0, swagger_1.ApiNoContentResponse)({ type: dto_1.BlankReturnMessageDto }),
|
|
82
|
+
]);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.RestfulFactory = RestfulFactory;
|
|
86
|
+
//# sourceMappingURL=restful.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"restful.js","sourceRoot":"","sources":["../../../src/decorators/restful.ts"],"names":[],"mappings":";;;AAAA,2CAAuE;AACvE,gCAIgB;AAChB,mCAAgD;AAEhD,oCAAoD;AACpD,6CASyB;AACzB,mCAA0D;AAO1D,MAAa,cAAc;IAUzB,YACkB,WAAyB,EACjC,UAAiC,EAAE;QAD3B,gBAAW,GAAX,WAAW,CAAc;QACjC,YAAO,GAAP,OAAO,CAA4B;QATpC,2BAAsB,GAAG,IAAA,sBAAgB,EAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC5D,gCAA2B,GAAG,IAAA,+BAAyB,EAC9D,IAAI,CAAC,WAAW,CACjB,CAAC;QAQA,IAAI,CAAC,SAAS,GAAG,IAAA,kBAAQ,EAAC,IAAI,CAAC,WAAW,EAAE;YAC1C,GAAG,sBAAc;YACjB,GAAG,CAAC,OAAO,CAAC,YAAY,IAAI,EAAE,CAAC;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,IAAA,qBAAW,EAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7C,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,WAAW,CAC/B,aAAa,EACb,IAAI,CAAC,WAAW,CAAC,SAAS,EAC1B,IAAI,CACL,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,SAAmC,EAAE;QAC1C,OAAO,IAAA,6BAAqB,EAAC;YAC3B,IAAA,aAAI,GAAE;YACN,IAAA,sBAAY,EAAC;gBACX,OAAO,EAAE,gBAAgB,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE;gBAChD,GAAG,MAAM;aACV,CAAC;YACF,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC;YACjC,IAAA,4BAAkB,EAAC,EAAE,IAAI,EAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;SAC1D,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,OAAO,IAAA,aAAI,EAAC,kBAAU,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO,CAAC,SAAmC,EAAE;QAC3C,OAAO,IAAA,6BAAqB,EAAC;YAC3B,IAAA,YAAG,EAAC,KAAK,CAAC;YACV,IAAA,sBAAY,EAAC;gBACX,OAAO,EAAE,UAAU,IAAI,CAAC,WAAW,CAAC,IAAI,QAAQ;gBAChD,GAAG,MAAM;aACV,CAAC;YACF,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC3D,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACrD,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,SAAmC,EAAE;QAC3C,OAAO,IAAA,6BAAqB,EAAC;YAC3B,IAAA,YAAG,GAAE;YACL,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,YAAY,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC;YACzE,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,IAAI,CAAC,2BAA2B,EAAE,CAAC;SAC1D,CAAC,CAAC;IACL,CAAC;IAED,YAAY;QACV,OAAO,IAAA,cAAK,EAAC,eAAO,CAAC,CAAC;IACxB,CAAC;IAED,MAAM,CAAC,SAAmC,EAAE;QAC1C,OAAO,IAAA,6BAAqB,EAAC;YAC3B,IAAA,cAAK,EAAC,KAAK,CAAC;YACZ,IAAA,sBAAY,EAAC;gBACX,OAAO,EAAE,YAAY,IAAI,CAAC,WAAW,CAAC,IAAI,QAAQ;gBAClD,GAAG,MAAM;aACV,CAAC;YACF,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC3D,IAAA,iBAAO,EAAC,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC;YACjC,IAAA,uBAAa,EAAC,EAAE,IAAI,EAAE,2BAAqB,EAAE,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,OAAO,IAAA,aAAI,EAAC,kBAAU,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,SAAmC,EAAE;QAC1C,OAAO,IAAA,6BAAqB,EAAC;YAC3B,IAAA,eAAM,EAAC,KAAK,CAAC;YACb,IAAA,sBAAY,EAAC;gBACX,OAAO,EAAE,YAAY,IAAI,CAAC,WAAW,CAAC,IAAI,QAAQ;gBAClD,GAAG,MAAM;aACV,CAAC;YACF,IAAA,kBAAQ,EAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAC3D,IAAA,8BAAoB,EAAC,EAAE,IAAI,EAAE,2BAAqB,EAAE,CAAC;SACtD,CAAC,CAAC;IACL,CAAC;CACF;AA9FD,wCA8FC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ClassOrArray } from '../utility/insert-field';
|
|
2
|
+
export declare class ImportEntryBaseDto {
|
|
3
|
+
result: string;
|
|
4
|
+
}
|
|
5
|
+
export interface ImportEntry<T> {
|
|
6
|
+
entry: T;
|
|
7
|
+
result: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function ImportEntryDto<C extends ClassOrArray>(type: C): new () => ImportEntryBaseDto & {
|
|
10
|
+
entry: import("../utility/insert-field").ParseType<C>;
|
|
11
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ImportEntryDto = exports.ImportEntryBaseDto = void 0;
|
|
13
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
14
|
+
const insert_field_1 = require("../utility/insert-field");
|
|
15
|
+
class ImportEntryBaseDto {
|
|
16
|
+
}
|
|
17
|
+
__decorate([
|
|
18
|
+
(0, swagger_1.ApiProperty)({ description: 'Import result', type: String }),
|
|
19
|
+
__metadata("design:type", String)
|
|
20
|
+
], ImportEntryBaseDto.prototype, "result", void 0);
|
|
21
|
+
exports.ImportEntryBaseDto = ImportEntryBaseDto;
|
|
22
|
+
function ImportEntryDto(type) {
|
|
23
|
+
return (0, insert_field_1.InsertField)(ImportEntryBaseDto, {
|
|
24
|
+
entry: { type, options: { description: 'Import entry' } },
|
|
25
|
+
}, `${(0, insert_field_1.getClassFromClassOrArray)(type).name}ImportEntry`);
|
|
26
|
+
}
|
|
27
|
+
exports.ImportEntryDto = ImportEntryDto;
|
|
28
|
+
//# sourceMappingURL=import-entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"import-entry.js","sourceRoot":"","sources":["../../../src/dto/import-entry.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAA8C;AAC9C,0DAIiC;AAEjC,MAAa,kBAAkB;CAG9B;AADC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;;kDAC7C;AAFjB,gDAGC;AAOD,SAAgB,cAAc,CAAyB,IAAO;IAC5D,OAAO,IAAA,0BAAW,EAChB,kBAAkB,EAClB;QACE,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,WAAW,EAAE,cAAc,EAAE,EAAE;KAC1D,EACD,GAAG,IAAA,uCAAwB,EAAC,IAAI,CAAC,CAAC,IAAI,aAAa,CACpD,CAAC;AACJ,CAAC;AARD,wCAQC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./page-settings"), exports);
|
|
18
|
+
__exportStar(require("./return-message"), exports);
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/dto/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,mDAAiC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { SelectQueryBuilder } from 'typeorm';
|
|
2
|
+
export interface PageSettingsWise {
|
|
3
|
+
pageCount: number;
|
|
4
|
+
recordsPerPage: number;
|
|
5
|
+
}
|
|
6
|
+
export interface PageSettingsFactory {
|
|
7
|
+
getActualPageSettings(): PageSettingsWise;
|
|
8
|
+
}
|
|
9
|
+
export interface QueryWise<T> {
|
|
10
|
+
applyQuery(qb: SelectQueryBuilder<T>, entityName: string): void;
|
|
11
|
+
}
|
|
12
|
+
export declare class PageSettingsDto implements PageSettingsWise, PageSettingsFactory, QueryWise<PageSettingsDto> {
|
|
13
|
+
pageCount: number;
|
|
14
|
+
recordsPerPage: number;
|
|
15
|
+
getActualPageSettings(): PageSettingsWise;
|
|
16
|
+
getPageCount(): number;
|
|
17
|
+
getRecordsPerPage(): number;
|
|
18
|
+
getStartingFrom(): number;
|
|
19
|
+
applyQuery(qb: SelectQueryBuilder<PageSettingsDto>, entityName: string): void;
|
|
20
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.PageSettingsDto = void 0;
|
|
13
|
+
const decorators_1 = require("../decorators");
|
|
14
|
+
const class_validator_1 = require("class-validator");
|
|
15
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
16
|
+
class PageSettingsDto {
|
|
17
|
+
getActualPageSettings() {
|
|
18
|
+
return {
|
|
19
|
+
pageCount: this.getPageCount(),
|
|
20
|
+
recordsPerPage: this.getRecordsPerPage(),
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
getPageCount() {
|
|
24
|
+
return this.pageCount || 1;
|
|
25
|
+
}
|
|
26
|
+
getRecordsPerPage() {
|
|
27
|
+
return this.recordsPerPage || 25;
|
|
28
|
+
}
|
|
29
|
+
getStartingFrom() {
|
|
30
|
+
return (this.getPageCount() - 1) * this.getRecordsPerPage();
|
|
31
|
+
}
|
|
32
|
+
applyQuery(qb, entityName) {
|
|
33
|
+
qb.take(this.getRecordsPerPage()).skip(this.getStartingFrom());
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, decorators_1.NotWritable)(),
|
|
38
|
+
(0, class_validator_1.IsPositive)(),
|
|
39
|
+
(0, class_validator_1.IsInt)(),
|
|
40
|
+
(0, swagger_1.ApiProperty)({
|
|
41
|
+
description: 'The nth page, starting with 1.',
|
|
42
|
+
required: false,
|
|
43
|
+
type: Number,
|
|
44
|
+
minimum: 1,
|
|
45
|
+
}),
|
|
46
|
+
__metadata("design:type", Number)
|
|
47
|
+
], PageSettingsDto.prototype, "pageCount", void 0);
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, decorators_1.NotWritable)(),
|
|
50
|
+
(0, class_validator_1.IsPositive)(),
|
|
51
|
+
(0, class_validator_1.IsInt)(),
|
|
52
|
+
(0, swagger_1.ApiProperty)({
|
|
53
|
+
description: 'Records per page.',
|
|
54
|
+
required: false,
|
|
55
|
+
type: Number,
|
|
56
|
+
minimum: 1,
|
|
57
|
+
}),
|
|
58
|
+
__metadata("design:type", Number)
|
|
59
|
+
], PageSettingsDto.prototype, "recordsPerPage", void 0);
|
|
60
|
+
exports.PageSettingsDto = PageSettingsDto;
|
|
61
|
+
//# sourceMappingURL=page-settings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-settings.js","sourceRoot":"","sources":["../../../src/dto/page-settings.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,8CAA4C;AAE5C,qDAAoD;AACpD,6CAA8C;AAe9C,MAAa,eAAe;IAyB1B,qBAAqB;QACnB,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE;YAC9B,cAAc,EAAE,IAAI,CAAC,iBAAiB,EAAE;SACzC,CAAC;IACJ,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,eAAe;QACb,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC9D,CAAC;IAED,UAAU,CAAC,EAAuC,EAAE,UAAkB;QACpE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;IACjE,CAAC;CACF;AAnCC;IATC,IAAA,wBAAW,GAAE;IACb,IAAA,4BAAU,GAAE;IACZ,IAAA,uBAAK,GAAE;IACP,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,gCAAgC;QAC7C,QAAQ,EAAE,KAAK;QACf,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,CAAC;KACX,CAAC;;kDACgB;AAWlB;IATC,IAAA,wBAAW,GAAE;IACb,IAAA,4BAAU,GAAE;IACZ,IAAA,uBAAK,GAAE;IACP,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mBAAmB;QAChC,QAAQ,EAAE,KAAK;QACf,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,CAAC;KACX,CAAC;;uDACqB;AAvBzB,0CA+CC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { HttpException } from '@nestjs/common';
|
|
2
|
+
import { PageSettingsWise } from './page-settings';
|
|
3
|
+
import { AnyClass, ClassOrArray } from '../utility/insert-field';
|
|
4
|
+
export interface BlankReturnMessage {
|
|
5
|
+
statusCode: number;
|
|
6
|
+
message: string;
|
|
7
|
+
success: boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface ReturnMessage<T> extends BlankReturnMessage {
|
|
10
|
+
data?: T;
|
|
11
|
+
}
|
|
12
|
+
export declare class BlankReturnMessageDto implements BlankReturnMessage {
|
|
13
|
+
statusCode: number;
|
|
14
|
+
message: string;
|
|
15
|
+
success: boolean;
|
|
16
|
+
constructor(statusCode: number, message?: string);
|
|
17
|
+
toException(): HttpException;
|
|
18
|
+
}
|
|
19
|
+
export declare class BlankPaginatedReturnMessageDto extends BlankReturnMessageDto implements PageSettingsWise {
|
|
20
|
+
total: number;
|
|
21
|
+
totalPages: number;
|
|
22
|
+
pageCount: number;
|
|
23
|
+
recordsPerPage: number;
|
|
24
|
+
constructor(statusCode: number, message: string, total: number, pageSettings: PageSettingsWise);
|
|
25
|
+
}
|
|
26
|
+
export declare class GenericReturnMessageDto<T> extends BlankReturnMessageDto implements ReturnMessage<T> {
|
|
27
|
+
data?: T;
|
|
28
|
+
constructor(statusCode: number, message?: string, data?: T);
|
|
29
|
+
}
|
|
30
|
+
export declare function ReturnMessageDto<T extends ClassOrArray>(type: T): new (statusCode: number, message?: string, data?: unknown) => GenericReturnMessageDto<unknown> & {
|
|
31
|
+
data: import("../utility/insert-field").ParseType<T>;
|
|
32
|
+
};
|
|
33
|
+
export declare class GenericPaginatedReturnMessageDto<T> extends BlankPaginatedReturnMessageDto implements PageSettingsWise, ReturnMessage<T[]> {
|
|
34
|
+
data: T[];
|
|
35
|
+
constructor(statusCode: number, message: string, data: T[], total: number, pageSettings: PageSettingsWise);
|
|
36
|
+
}
|
|
37
|
+
export declare function PaginatedReturnMessageDto<T extends AnyClass>(type: T): new (statusCode: number, message: string, data: unknown[], total: number, pageSettings: PageSettingsWise) => GenericPaginatedReturnMessageDto<unknown> & {
|
|
38
|
+
data: import("../utility/insert-field").TypeFromClass<T>[];
|
|
39
|
+
};
|
|
40
|
+
export declare class StringReturnMessageDto extends GenericReturnMessageDto<string> {
|
|
41
|
+
data?: string;
|
|
42
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.StringReturnMessageDto = exports.PaginatedReturnMessageDto = exports.GenericPaginatedReturnMessageDto = exports.ReturnMessageDto = exports.GenericReturnMessageDto = exports.BlankPaginatedReturnMessageDto = exports.BlankReturnMessageDto = void 0;
|
|
13
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const insert_field_1 = require("../utility/insert-field");
|
|
16
|
+
class BlankReturnMessageDto {
|
|
17
|
+
constructor(statusCode, message) {
|
|
18
|
+
this.statusCode = statusCode;
|
|
19
|
+
this.message = message || 'success';
|
|
20
|
+
this.success = statusCode < 400;
|
|
21
|
+
}
|
|
22
|
+
toException() {
|
|
23
|
+
return new common_1.HttpException(this, this.statusCode);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, swagger_1.ApiProperty)({ description: 'Return code', type: Number }),
|
|
28
|
+
__metadata("design:type", Number)
|
|
29
|
+
], BlankReturnMessageDto.prototype, "statusCode", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, swagger_1.ApiProperty)({ description: 'Return message', type: String }),
|
|
32
|
+
__metadata("design:type", String)
|
|
33
|
+
], BlankReturnMessageDto.prototype, "message", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, swagger_1.ApiProperty)({ description: 'Whether success.', type: Boolean }),
|
|
36
|
+
__metadata("design:type", Boolean)
|
|
37
|
+
], BlankReturnMessageDto.prototype, "success", void 0);
|
|
38
|
+
exports.BlankReturnMessageDto = BlankReturnMessageDto;
|
|
39
|
+
class BlankPaginatedReturnMessageDto extends BlankReturnMessageDto {
|
|
40
|
+
constructor(statusCode, message, total, pageSettings) {
|
|
41
|
+
super(statusCode, message);
|
|
42
|
+
this.total = total;
|
|
43
|
+
this.pageCount = pageSettings.pageCount;
|
|
44
|
+
this.recordsPerPage = pageSettings.recordsPerPage;
|
|
45
|
+
this.totalPages = Math.ceil(total / pageSettings.recordsPerPage);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, swagger_1.ApiProperty)({ description: 'Total record count.', type: Number }),
|
|
50
|
+
__metadata("design:type", Number)
|
|
51
|
+
], BlankPaginatedReturnMessageDto.prototype, "total", void 0);
|
|
52
|
+
__decorate([
|
|
53
|
+
(0, swagger_1.ApiProperty)({ description: 'Total page count.', type: Number }),
|
|
54
|
+
__metadata("design:type", Number)
|
|
55
|
+
], BlankPaginatedReturnMessageDto.prototype, "totalPages", void 0);
|
|
56
|
+
__decorate([
|
|
57
|
+
(0, swagger_1.ApiProperty)({ description: 'Current page.', type: Number }),
|
|
58
|
+
__metadata("design:type", Number)
|
|
59
|
+
], BlankPaginatedReturnMessageDto.prototype, "pageCount", void 0);
|
|
60
|
+
__decorate([
|
|
61
|
+
(0, swagger_1.ApiProperty)({ description: 'Records per page.', type: Number }),
|
|
62
|
+
__metadata("design:type", Number)
|
|
63
|
+
], BlankPaginatedReturnMessageDto.prototype, "recordsPerPage", void 0);
|
|
64
|
+
exports.BlankPaginatedReturnMessageDto = BlankPaginatedReturnMessageDto;
|
|
65
|
+
class GenericReturnMessageDto extends BlankReturnMessageDto {
|
|
66
|
+
constructor(statusCode, message, data) {
|
|
67
|
+
super(statusCode, message);
|
|
68
|
+
this.data = data;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
exports.GenericReturnMessageDto = GenericReturnMessageDto;
|
|
72
|
+
function ReturnMessageDto(type) {
|
|
73
|
+
return (0, insert_field_1.InsertField)(GenericReturnMessageDto, {
|
|
74
|
+
data: {
|
|
75
|
+
type,
|
|
76
|
+
options: {
|
|
77
|
+
required: false,
|
|
78
|
+
description: 'Return data.',
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
}, `${(0, insert_field_1.getClassFromClassOrArray)(type).name}ReturnMessageDto`);
|
|
82
|
+
}
|
|
83
|
+
exports.ReturnMessageDto = ReturnMessageDto;
|
|
84
|
+
class GenericPaginatedReturnMessageDto extends BlankPaginatedReturnMessageDto {
|
|
85
|
+
constructor(statusCode, message, data, total, pageSettings) {
|
|
86
|
+
super(statusCode, message, total, pageSettings);
|
|
87
|
+
this.data = data;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.GenericPaginatedReturnMessageDto = GenericPaginatedReturnMessageDto;
|
|
91
|
+
function PaginatedReturnMessageDto(type) {
|
|
92
|
+
return (0, insert_field_1.InsertField)(GenericPaginatedReturnMessageDto, {
|
|
93
|
+
data: {
|
|
94
|
+
type: [type],
|
|
95
|
+
options: {
|
|
96
|
+
required: false,
|
|
97
|
+
description: 'Return data.',
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
}, `${(0, insert_field_1.getClassFromClassOrArray)(type).name}PaginatedReturnMessageDto`);
|
|
101
|
+
}
|
|
102
|
+
exports.PaginatedReturnMessageDto = PaginatedReturnMessageDto;
|
|
103
|
+
class StringReturnMessageDto extends GenericReturnMessageDto {
|
|
104
|
+
}
|
|
105
|
+
__decorate([
|
|
106
|
+
(0, swagger_1.ApiProperty)({ description: 'Return data.', type: String, required: false }),
|
|
107
|
+
__metadata("design:type", String)
|
|
108
|
+
], StringReturnMessageDto.prototype, "data", void 0);
|
|
109
|
+
exports.StringReturnMessageDto = StringReturnMessageDto;
|
|
110
|
+
//# sourceMappingURL=return-message.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"return-message.js","sourceRoot":"","sources":["../../../src/dto/return-message.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BigintTransformer = void 0;
|
|
4
|
+
class BigintTransformer {
|
|
5
|
+
from(dbValue) {
|
|
6
|
+
if (dbValue == null) {
|
|
7
|
+
return dbValue;
|
|
8
|
+
}
|
|
9
|
+
return parseInt(dbValue);
|
|
10
|
+
}
|
|
11
|
+
to(entValue) {
|
|
12
|
+
return entValue;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.BigintTransformer = BigintTransformer;
|
|
16
|
+
//# sourceMappingURL=bigint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bigint.js","sourceRoot":"","sources":["../../../src/utility/bigint.ts"],"names":[],"mappings":";;;AAEA,MAAa,iBAAiB;IAC5B,IAAI,CAAC,OAAO;QACV,IAAI,OAAO,IAAI,IAAI,EAAE;YACnB,OAAO,OAAO,CAAC;SAChB;QACD,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC3B,CAAC;IACD,EAAE,CAAC,QAAQ;QACT,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAVD,8CAUC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './query';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./query"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utility/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAwB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ApiPropertyOptions } from '@nestjs/swagger';
|
|
2
|
+
export declare type AnyClass = new (...args: any[]) => any;
|
|
3
|
+
export declare type ClassOrArray = AnyClass | [AnyClass];
|
|
4
|
+
export declare type ClassType<T> = new (...args: any[]) => T;
|
|
5
|
+
export declare type TypeFromClass<T> = T extends new (...args: any[]) => infer U ? U : never;
|
|
6
|
+
export declare type ParamsFromClass<T> = T extends new (...args: infer U) => any ? U : never;
|
|
7
|
+
export declare type ParseType<IC extends ClassOrArray> = IC extends [infer U] ? TypeFromClass<U>[] : TypeFromClass<IC>;
|
|
8
|
+
export declare function getClassFromClassOrArray(o: ClassOrArray): AnyClass;
|
|
9
|
+
export interface InsertOptions<C extends ClassOrArray = ClassOrArray> {
|
|
10
|
+
type: C;
|
|
11
|
+
options?: ApiPropertyOptions;
|
|
12
|
+
}
|
|
13
|
+
declare type TypeFromInsertOptions<O extends InsertOptions> = O extends InsertOptions<infer C> ? ParseType<C> : never;
|
|
14
|
+
export declare function InsertField<C extends AnyClass, M extends Record<string, InsertOptions>>(cl: C, map: M, newName?: string): new (...args: ParamsFromClass<C>) => TypeFromClass<C> & {
|
|
15
|
+
[F in keyof M]: TypeFromInsertOptions<M[F]>;
|
|
16
|
+
};
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InsertField = exports.getClassFromClassOrArray = void 0;
|
|
4
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
5
|
+
function getClassFromClassOrArray(o) {
|
|
6
|
+
return o instanceof Array ? o[0] : o;
|
|
7
|
+
}
|
|
8
|
+
exports.getClassFromClassOrArray = getClassFromClassOrArray;
|
|
9
|
+
function InsertField(cl, map, newName) {
|
|
10
|
+
const extendedCl = class extends cl {
|
|
11
|
+
};
|
|
12
|
+
for (const key in map) {
|
|
13
|
+
(0, swagger_1.ApiProperty)({
|
|
14
|
+
type: map[key].type,
|
|
15
|
+
...(map[key].options || {}),
|
|
16
|
+
})(extendedCl.prototype, key);
|
|
17
|
+
}
|
|
18
|
+
Object.defineProperty(cl, 'name', {
|
|
19
|
+
value: newName || cl.name,
|
|
20
|
+
});
|
|
21
|
+
return extendedCl;
|
|
22
|
+
}
|
|
23
|
+
exports.InsertField = InsertField;
|
|
24
|
+
//# sourceMappingURL=insert-field.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insert-field.js","sourceRoot":"","sources":["../../../src/utility/insert-field.ts"],"names":[],"mappings":";;;AAAA,6CAAkE;AAelE,SAAgB,wBAAwB,CAAC,CAAe;IACtD,OAAO,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACvC,CAAC;AAFD,4DAEC;AAaD,SAAgB,WAAW,CAIzB,EAAK,EACL,GAAM,EACN,OAAgB;IAIhB,MAAM,UAAU,GAAG,KAAM,SAAQ,EAAE;KAAG,CAAC;IACvC,KAAK,MAAM,GAAG,IAAI,GAAG,EAAE;QACrB,IAAA,qBAAW,EAAC;YACV,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI;YACnB,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;SAC5B,CAAC,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;KAC/B;IACD,MAAM,CAAC,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE;QAChC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC,IAAI;KAC1B,CAAC,CAAC;IACH,OAAO,UAAU,CAAC;AACpB,CAAC;AArBD,kCAqBC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { SelectQueryBuilder } from 'typeorm';
|
|
2
|
+
import { TimeBase } from '../bases/time-base';
|
|
3
|
+
export declare function applyQueryProperty<T extends TimeBase>(obj: T, qb: SelectQueryBuilder<T>, entityName: string, ...fields: (keyof T & string)[]): void;
|
|
4
|
+
export declare function applyQueryPropertyLike<T extends TimeBase>(obj: T, qb: SelectQueryBuilder<T>, entityName: string, ...fields: (keyof T & string)[]): void;
|
|
5
|
+
export declare function applyQueryPropertySearch<T extends TimeBase>(obj: T, qb: SelectQueryBuilder<T>, entityName: string, ...fields: (keyof T & string)[]): void;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.applyQueryPropertySearch = exports.applyQueryPropertyLike = exports.applyQueryProperty = void 0;
|
|
4
|
+
function applyQueryProperty(obj, qb, entityName, ...fields) {
|
|
5
|
+
for (const field of fields) {
|
|
6
|
+
if (obj[field] == null) {
|
|
7
|
+
continue;
|
|
8
|
+
}
|
|
9
|
+
qb.andWhere(`${entityName}.${field} = :${field}`, { [field]: obj[field] });
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.applyQueryProperty = applyQueryProperty;
|
|
13
|
+
function applyQueryPropertyLike(obj, qb, entityName, ...fields) {
|
|
14
|
+
for (const field of fields) {
|
|
15
|
+
if (obj[field] == null) {
|
|
16
|
+
continue;
|
|
17
|
+
}
|
|
18
|
+
qb.andWhere(`${entityName}.${field} like (:${field} || '%')`, {
|
|
19
|
+
[field]: obj[field],
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.applyQueryPropertyLike = applyQueryPropertyLike;
|
|
24
|
+
function applyQueryPropertySearch(obj, qb, entityName, ...fields) {
|
|
25
|
+
for (const field of fields) {
|
|
26
|
+
if (obj[field] == null) {
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
qb.andWhere(`${entityName}.${field} like ('%' || :${field} || '%')`, {
|
|
30
|
+
[field]: obj[field],
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.applyQueryPropertySearch = applyQueryPropertySearch;
|
|
35
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/utility/query.ts"],"names":[],"mappings":";;;AAGA,SAAgB,kBAAkB,CAChC,GAAM,EACN,EAAyB,EACzB,UAAkB,EAClB,GAAG,MAA4B;IAE/B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;YACtB,SAAS;SACV;QACD,EAAE,CAAC,QAAQ,CAAC,GAAG,UAAU,IAAI,KAAK,OAAO,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;KAC5E;AACH,CAAC;AAZD,gDAYC;AACD,SAAgB,sBAAsB,CACpC,GAAM,EACN,EAAyB,EACzB,UAAkB,EAClB,GAAG,MAA4B;IAE/B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;YACtB,SAAS;SACV;QACD,EAAE,CAAC,QAAQ,CAAC,GAAG,UAAU,IAAI,KAAK,WAAW,KAAK,UAAU,EAAE;YAC5D,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC;SACpB,CAAC,CAAC;KACJ;AACH,CAAC;AAdD,wDAcC;AAED,SAAgB,wBAAwB,CACtC,GAAM,EACN,EAAyB,EACzB,UAAkB,EAClB,GAAG,MAA4B;IAE/B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;QAC1B,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;YACtB,SAAS;SACV;QACD,EAAE,CAAC,QAAQ,CAAC,GAAG,UAAU,IAAI,KAAK,kBAAkB,KAAK,UAAU,EAAE;YACnE,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC;SACpB,CAAC,CAAC;KACJ;AACH,CAAC;AAdD,4DAcC"}
|
package/index.ts
ADDED
package/package.json
ADDED
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "nicot",
|
|
3
|
+
"description": "Nest.js interacting with class-validator + OpenAPI + TypeORM for Nest.js Restful API development.",
|
|
4
|
+
"version": "1.0.0",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"lint": "eslint --fix .",
|
|
9
|
+
"build": "rimraf dist && tsc",
|
|
10
|
+
"test": "jest --passWithNoTests",
|
|
11
|
+
"start": "node dist/index.js"
|
|
12
|
+
},
|
|
13
|
+
"repository": {
|
|
14
|
+
"type": "git",
|
|
15
|
+
"url": "https://code.mycard.moe/3rdeye/nicot.git"
|
|
16
|
+
},
|
|
17
|
+
"author": "Nanahira <nanahira@momobako.com>",
|
|
18
|
+
"license": "MIT",
|
|
19
|
+
"keywords": [],
|
|
20
|
+
"bugs": {
|
|
21
|
+
"url": "https://code.mycard.moe/3rdeye/nicot/issues"
|
|
22
|
+
},
|
|
23
|
+
"homepage": "https://code.mycard.moe/3rdeye/nicot",
|
|
24
|
+
"jest": {
|
|
25
|
+
"moduleFileExtensions": [
|
|
26
|
+
"js",
|
|
27
|
+
"json",
|
|
28
|
+
"ts"
|
|
29
|
+
],
|
|
30
|
+
"rootDir": "tests",
|
|
31
|
+
"testRegex": ".*\\.spec\\.ts$",
|
|
32
|
+
"transform": {
|
|
33
|
+
"^.+\\.(t|j)s$": "ts-jest"
|
|
34
|
+
},
|
|
35
|
+
"collectCoverageFrom": [
|
|
36
|
+
"**/*.(t|j)s"
|
|
37
|
+
],
|
|
38
|
+
"coverageDirectory": "../coverage",
|
|
39
|
+
"testEnvironment": "node"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@types/jest": "^28.1.5",
|
|
43
|
+
"@types/lodash": "^4.14.182",
|
|
44
|
+
"@types/node": "^18.0.4",
|
|
45
|
+
"@typescript-eslint/eslint-plugin": "^4.33.0",
|
|
46
|
+
"@typescript-eslint/parser": "^4.33.0",
|
|
47
|
+
"eslint": "^7.32.0",
|
|
48
|
+
"eslint-config-prettier": "^8.5.0",
|
|
49
|
+
"eslint-plugin-prettier": "^3.4.1",
|
|
50
|
+
"jest": "^28.1.3",
|
|
51
|
+
"prettier": "^2.7.1",
|
|
52
|
+
"rimraf": "^3.0.2",
|
|
53
|
+
"ts-jest": "^28.0.6",
|
|
54
|
+
"typescript": "^4.7.4"
|
|
55
|
+
},
|
|
56
|
+
"peerDependencies": {
|
|
57
|
+
"@nestjs/common": "^9.0.3",
|
|
58
|
+
"@nestjs/swagger": "^6.0.4",
|
|
59
|
+
"class-transformer": "^0.5.1",
|
|
60
|
+
"class-validator": "^0.13.2",
|
|
61
|
+
"typeorm": "^0.3.7"
|
|
62
|
+
},
|
|
63
|
+
"dependencies": {
|
|
64
|
+
"lodash": "^4.17.21"
|
|
65
|
+
}
|
|
66
|
+
}
|