@archi-code/domain 1.0.0-alpha.1
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/cjs/aggregate/aggregate-root.d.ts +6 -0
- package/dist/cjs/aggregate/aggregate-root.js +18 -0
- package/dist/cjs/aggregate/aggregate-root.js.map +1 -0
- package/dist/cjs/aggregate/aggregate-types.d.ts +9 -0
- package/dist/cjs/aggregate/aggregate-types.js +27 -0
- package/dist/cjs/aggregate/aggregate-types.js.map +1 -0
- package/dist/cjs/builder/builder.d.ts +8 -0
- package/dist/cjs/builder/builder.js +28 -0
- package/dist/cjs/builder/builder.js.map +1 -0
- package/dist/cjs/event/event-base.d.ts +3 -0
- package/dist/cjs/event/event-base.js +7 -0
- package/dist/cjs/event/event-base.js.map +1 -0
- package/dist/cjs/exceptions/abstract.exception.d.ts +17 -0
- package/dist/cjs/exceptions/abstract.exception.js +46 -0
- package/dist/cjs/exceptions/abstract.exception.js.map +1 -0
- package/dist/cjs/exceptions/application/application.exception.d.ts +5 -0
- package/dist/cjs/exceptions/application/application.exception.js +12 -0
- package/dist/cjs/exceptions/application/application.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.js +12 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/domain.exception.d.ts +5 -0
- package/dist/cjs/exceptions/domain/domain.exception.js +12 -0
- package/dist/cjs/exceptions/domain/domain.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.js +16 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/validation.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/validation.exception.js +12 -0
- package/dist/cjs/exceptions/domain/validation.exception.js.map +1 -0
- package/dist/cjs/exceptions/exception-code.d.ts +10 -0
- package/dist/cjs/exceptions/exception-code.js +15 -0
- package/dist/cjs/exceptions/exception-code.js.map +1 -0
- package/dist/cjs/exceptions/index.d.ts +7 -0
- package/dist/cjs/exceptions/index.js +24 -0
- package/dist/cjs/exceptions/index.js.map +1 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.d.ts +5 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.js +12 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.js.map +1 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.d.ts +4 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.js +12 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.js.map +1 -0
- package/dist/cjs/index.d.ts +10 -0
- package/dist/cjs/index.js +27 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/level/level.decorator.d.ts +4 -0
- package/dist/cjs/level/level.decorator.js +36 -0
- package/dist/cjs/level/level.decorator.js.map +1 -0
- package/dist/cjs/primitive/primitive-type.d.ts +14 -0
- package/dist/cjs/primitive/primitive-type.js +3 -0
- package/dist/cjs/primitive/primitive-type.js.map +1 -0
- package/dist/cjs/primitive/primitive-types.d.ts +19 -0
- package/dist/cjs/primitive/primitive-types.js +3 -0
- package/dist/cjs/primitive/primitive-types.js.map +1 -0
- package/dist/cjs/type/abstract-array-type.d.ts +14 -0
- package/dist/cjs/type/abstract-array-type.js +88 -0
- package/dist/cjs/type/abstract-array-type.js.map +1 -0
- package/dist/cjs/type/abstract-boolean-type.d.ts +4 -0
- package/dist/cjs/type/abstract-boolean-type.js +34 -0
- package/dist/cjs/type/abstract-boolean-type.js.map +1 -0
- package/dist/cjs/type/abstract-date-type.d.ts +5 -0
- package/dist/cjs/type/abstract-date-type.js +33 -0
- package/dist/cjs/type/abstract-date-type.js.map +1 -0
- package/dist/cjs/type/abstract-enum-type.d.ts +5 -0
- package/dist/cjs/type/abstract-enum-type.js +19 -0
- package/dist/cjs/type/abstract-enum-type.js.map +1 -0
- package/dist/cjs/type/abstract-json-type.d.ts +5 -0
- package/dist/cjs/type/abstract-json-type.js +30 -0
- package/dist/cjs/type/abstract-json-type.js.map +1 -0
- package/dist/cjs/type/abstract-number-type.d.ts +4 -0
- package/dist/cjs/type/abstract-number-type.js +31 -0
- package/dist/cjs/type/abstract-number-type.js.map +1 -0
- package/dist/cjs/type/abstract-string-type.d.ts +4 -0
- package/dist/cjs/type/abstract-string-type.js +33 -0
- package/dist/cjs/type/abstract-string-type.js.map +1 -0
- package/dist/cjs/type/abstract-type.d.ts +13 -0
- package/dist/cjs/type/abstract-type.js +46 -0
- package/dist/cjs/type/abstract-type.js.map +1 -0
- package/dist/cjs/type/abstract-uuid-type.d.ts +6 -0
- package/dist/cjs/type/abstract-uuid-type.js +37 -0
- package/dist/cjs/type/abstract-uuid-type.js.map +1 -0
- package/dist/cjs/type/index.d.ts +48 -0
- package/dist/cjs/type/index.js +138 -0
- package/dist/cjs/type/index.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.js +52 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.js.map +1 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.d.ts +7 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.js +8 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.js.map +1 -0
- package/dist/cjs/validator/decorator/type-validator.d.ts +6 -0
- package/dist/cjs/validator/decorator/type-validator.js +81 -0
- package/dist/cjs/validator/decorator/type-validator.js.map +1 -0
- package/dist/cjs/validator/decorator/validation-storage.d.ts +14 -0
- package/dist/cjs/validator/decorator/validation-storage.js +56 -0
- package/dist/cjs/validator/decorator/validation-storage.js.map +1 -0
- package/dist/cjs/validator/decorator/validators-doc.d.ts +25 -0
- package/dist/cjs/validator/decorator/validators-doc.js +479 -0
- package/dist/cjs/validator/decorator/validators-doc.js.map +1 -0
- package/dist/cjs/validator/decorator/validators-map.d.ts +114 -0
- package/dist/cjs/validator/decorator/validators-map.js +113 -0
- package/dist/cjs/validator/decorator/validators-map.js.map +1 -0
- package/dist/cjs/validator/domain-validator/domain-validator.d.ts +7 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.d.ts +3 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.js +26 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.js.map +1 -0
- package/dist/cjs/validator/domain-validator/domain-validator.js +59 -0
- package/dist/cjs/validator/domain-validator/domain-validator.js.map +1 -0
- package/dist/cjs/validator/index.d.ts +10 -0
- package/dist/cjs/validator/index.js +27 -0
- package/dist/cjs/validator/index.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.js +24 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/date.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/date.validator.js +21 -0
- package/dist/cjs/validator/primitive-validator/date.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/json.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/json.validator.js +37 -0
- package/dist/cjs/validator/primitive-validator/json.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/number.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/number.validator.js +21 -0
- package/dist/cjs/validator/primitive-validator/number.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/string.validator.d.ts +4 -0
- package/dist/cjs/validator/primitive-validator/string.validator.js +22 -0
- package/dist/cjs/validator/primitive-validator/string.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.d.ts +5 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.js +3 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.js.map +1 -0
- package/dist/esm/aggregate/aggregate-root.d.ts +6 -0
- package/dist/esm/aggregate/aggregate-root.js +14 -0
- package/dist/esm/aggregate/aggregate-root.js.map +1 -0
- package/dist/esm/aggregate/aggregate-types.d.ts +9 -0
- package/dist/esm/aggregate/aggregate-types.js +23 -0
- package/dist/esm/aggregate/aggregate-types.js.map +1 -0
- package/dist/esm/builder/builder.d.ts +8 -0
- package/dist/esm/builder/builder.js +25 -0
- package/dist/esm/builder/builder.js.map +1 -0
- package/dist/esm/event/event-base.d.ts +3 -0
- package/dist/esm/event/event-base.js +3 -0
- package/dist/esm/event/event-base.js.map +1 -0
- package/dist/esm/exceptions/abstract.exception.d.ts +17 -0
- package/dist/esm/exceptions/abstract.exception.js +42 -0
- package/dist/esm/exceptions/abstract.exception.js.map +1 -0
- package/dist/esm/exceptions/application/application.exception.d.ts +5 -0
- package/dist/esm/exceptions/application/application.exception.js +8 -0
- package/dist/esm/exceptions/application/application.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.js +8 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/domain.exception.d.ts +5 -0
- package/dist/esm/exceptions/domain/domain.exception.js +8 -0
- package/dist/esm/exceptions/domain/domain.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.js +12 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/validation.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/validation.exception.js +8 -0
- package/dist/esm/exceptions/domain/validation.exception.js.map +1 -0
- package/dist/esm/exceptions/exception-code.d.ts +10 -0
- package/dist/esm/exceptions/exception-code.js +12 -0
- package/dist/esm/exceptions/exception-code.js.map +1 -0
- package/dist/esm/exceptions/index.d.ts +7 -0
- package/dist/esm/exceptions/index.js +8 -0
- package/dist/esm/exceptions/index.js.map +1 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.d.ts +5 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.js +8 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.js.map +1 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.d.ts +4 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.js +8 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.js.map +1 -0
- package/dist/esm/index.d.ts +10 -0
- package/dist/esm/index.js +11 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/level/level.decorator.d.ts +4 -0
- package/dist/esm/level/level.decorator.js +31 -0
- package/dist/esm/level/level.decorator.js.map +1 -0
- package/dist/esm/primitive/primitive-type.d.ts +14 -0
- package/dist/esm/primitive/primitive-type.js +2 -0
- package/dist/esm/primitive/primitive-type.js.map +1 -0
- package/dist/esm/primitive/primitive-types.d.ts +19 -0
- package/dist/esm/primitive/primitive-types.js +2 -0
- package/dist/esm/primitive/primitive-types.js.map +1 -0
- package/dist/esm/type/abstract-array-type.d.ts +14 -0
- package/dist/esm/type/abstract-array-type.js +85 -0
- package/dist/esm/type/abstract-array-type.js.map +1 -0
- package/dist/esm/type/abstract-boolean-type.d.ts +4 -0
- package/dist/esm/type/abstract-boolean-type.js +31 -0
- package/dist/esm/type/abstract-boolean-type.js.map +1 -0
- package/dist/esm/type/abstract-date-type.d.ts +5 -0
- package/dist/esm/type/abstract-date-type.js +30 -0
- package/dist/esm/type/abstract-date-type.js.map +1 -0
- package/dist/esm/type/abstract-enum-type.d.ts +5 -0
- package/dist/esm/type/abstract-enum-type.js +15 -0
- package/dist/esm/type/abstract-enum-type.js.map +1 -0
- package/dist/esm/type/abstract-json-type.d.ts +5 -0
- package/dist/esm/type/abstract-json-type.js +27 -0
- package/dist/esm/type/abstract-json-type.js.map +1 -0
- package/dist/esm/type/abstract-number-type.d.ts +4 -0
- package/dist/esm/type/abstract-number-type.js +28 -0
- package/dist/esm/type/abstract-number-type.js.map +1 -0
- package/dist/esm/type/abstract-string-type.d.ts +4 -0
- package/dist/esm/type/abstract-string-type.js +30 -0
- package/dist/esm/type/abstract-string-type.js.map +1 -0
- package/dist/esm/type/abstract-type.d.ts +13 -0
- package/dist/esm/type/abstract-type.js +42 -0
- package/dist/esm/type/abstract-type.js.map +1 -0
- package/dist/esm/type/abstract-uuid-type.d.ts +6 -0
- package/dist/esm/type/abstract-uuid-type.js +34 -0
- package/dist/esm/type/abstract-uuid-type.js.map +1 -0
- package/dist/esm/type/index.d.ts +48 -0
- package/dist/esm/type/index.js +124 -0
- package/dist/esm/type/index.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-date.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-date.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-date.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-json.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-json.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-json.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-number.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-number.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-number.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-string.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-string.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-string.js.map +1 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.js +49 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.js.map +1 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.d.ts +7 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.js +5 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.js.map +1 -0
- package/dist/esm/validator/decorator/type-validator.d.ts +6 -0
- package/dist/esm/validator/decorator/type-validator.js +77 -0
- package/dist/esm/validator/decorator/type-validator.js.map +1 -0
- package/dist/esm/validator/decorator/validation-storage.d.ts +14 -0
- package/dist/esm/validator/decorator/validation-storage.js +52 -0
- package/dist/esm/validator/decorator/validation-storage.js.map +1 -0
- package/dist/esm/validator/decorator/validators-doc.d.ts +25 -0
- package/dist/esm/validator/decorator/validators-doc.js +475 -0
- package/dist/esm/validator/decorator/validators-doc.js.map +1 -0
- package/dist/esm/validator/decorator/validators-map.d.ts +114 -0
- package/dist/esm/validator/decorator/validators-map.js +110 -0
- package/dist/esm/validator/decorator/validators-map.js.map +1 -0
- package/dist/esm/validator/domain-validator/domain-validator.d.ts +7 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.d.ts +3 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.js +22 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.js.map +1 -0
- package/dist/esm/validator/domain-validator/domain-validator.js +56 -0
- package/dist/esm/validator/domain-validator/domain-validator.js.map +1 -0
- package/dist/esm/validator/index.d.ts +10 -0
- package/dist/esm/validator/index.js +11 -0
- package/dist/esm/validator/index.js.map +1 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.js +20 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/date.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/date.validator.js +17 -0
- package/dist/esm/validator/primitive-validator/date.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/json.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/json.validator.js +33 -0
- package/dist/esm/validator/primitive-validator/json.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/number.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/number.validator.js +17 -0
- package/dist/esm/validator/primitive-validator/number.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/string.validator.d.ts +4 -0
- package/dist/esm/validator/primitive-validator/string.validator.js +18 -0
- package/dist/esm/validator/primitive-validator/string.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.d.ts +5 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.js +2 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.js.map +1 -0
- package/dist/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -0
- package/package.json +83 -0
|
@@ -0,0 +1,88 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractArrayType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
12
|
+
const exceptions_1 = require("../exceptions");
|
|
13
|
+
let AbstractArrayType = class AbstractArrayType extends abstract_type_1.AbstractType {
|
|
14
|
+
filter(value) {
|
|
15
|
+
if (value === null) {
|
|
16
|
+
return null;
|
|
17
|
+
}
|
|
18
|
+
if (!Array.isArray(value)) {
|
|
19
|
+
throw new exceptions_1.DomainException(`value ${value} is not a Array.`);
|
|
20
|
+
}
|
|
21
|
+
return value.map((item) => this.getItemClass(item)).map((item) => item.value);
|
|
22
|
+
}
|
|
23
|
+
isValid() {
|
|
24
|
+
if (this.isNull) {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
return (super.isValid() &&
|
|
28
|
+
Array.isArray(this.value) &&
|
|
29
|
+
this.value.every((item) => this.getItemClass(item).isValid()));
|
|
30
|
+
}
|
|
31
|
+
validatorMessageStr(separator = ',', customReplacement = '') {
|
|
32
|
+
if (this.isNull) {
|
|
33
|
+
return 'Value must be an array';
|
|
34
|
+
}
|
|
35
|
+
let str = super.validatorMessageStr(separator, customReplacement);
|
|
36
|
+
const strItems = this.value?.map((item, index) => {
|
|
37
|
+
const txtItemMsg = this.getItemClass(item).validatorMessageStr(separator, customReplacement);
|
|
38
|
+
return txtItemMsg === '' ? '' : `Item ${index + 1}: ${txtItemMsg}`;
|
|
39
|
+
});
|
|
40
|
+
const filters = strItems?.filter((item) => item !== '');
|
|
41
|
+
if (filters && filters.length > 0) {
|
|
42
|
+
if (str === '') {
|
|
43
|
+
str = filters.join(`${separator} `);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
str += separator + filters.join(`${separator} `);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return str;
|
|
50
|
+
}
|
|
51
|
+
get toString() {
|
|
52
|
+
return !this.value ? '' : this.value.map((item) => this.getItemClass(item).toString).join(', ');
|
|
53
|
+
}
|
|
54
|
+
get items() {
|
|
55
|
+
if (this.value === null) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
return this.value?.map((item) => this.getItemClass(item));
|
|
59
|
+
}
|
|
60
|
+
addItem(value) {
|
|
61
|
+
if (this.value === null) {
|
|
62
|
+
this._value = [];
|
|
63
|
+
}
|
|
64
|
+
this.value?.push(this.getItemClass(value).value);
|
|
65
|
+
}
|
|
66
|
+
hasItem(value) {
|
|
67
|
+
const item = this.getItemClass(value);
|
|
68
|
+
return this.value?.some((itemValue) => itemValue === item.value) ?? false;
|
|
69
|
+
}
|
|
70
|
+
removeItem(value) {
|
|
71
|
+
if (this.value === null) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const item = this.getItemClass(value);
|
|
75
|
+
this._value = this.value?.filter((itemValue) => itemValue !== item.value) ?? [];
|
|
76
|
+
}
|
|
77
|
+
setItem(value) {
|
|
78
|
+
if (this.hasItem(value)) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
this.addItem(value);
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
exports.AbstractArrayType = AbstractArrayType;
|
|
85
|
+
exports.AbstractArrayType = AbstractArrayType = __decorate([
|
|
86
|
+
(0, type_validator_1.AddValidate)([{ validator: 'IsArray' }])
|
|
87
|
+
], AbstractArrayType);
|
|
88
|
+
//# sourceMappingURL=abstract-array-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-array-type.js","sourceRoot":"","sources":["../../../src/type/abstract-array-type.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractBooleanType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
12
|
+
const can_be_boolean_1 = require("../validator/decorator/custom/can-be-boolean");
|
|
13
|
+
const validator_1 = require("../validator");
|
|
14
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
15
|
+
let AbstractBooleanType = class AbstractBooleanType extends abstract_type_1.AbstractType {
|
|
16
|
+
filter(value) {
|
|
17
|
+
if (value === null) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
if (!validator_1.BooleanValidator.canBeBoolean(value)) {
|
|
21
|
+
throw new type_primitive_exception_1.TypePrimitiveException('Boolean', value);
|
|
22
|
+
}
|
|
23
|
+
if (typeof value === 'string') {
|
|
24
|
+
value = value.toLowerCase().trim();
|
|
25
|
+
return value === 'true' || value === '1';
|
|
26
|
+
}
|
|
27
|
+
return !!value;
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
exports.AbstractBooleanType = AbstractBooleanType;
|
|
31
|
+
exports.AbstractBooleanType = AbstractBooleanType = __decorate([
|
|
32
|
+
(0, type_validator_1.AddValidate)([{ validator: can_be_boolean_1.CanBeBooleanValidator }])
|
|
33
|
+
], AbstractBooleanType);
|
|
34
|
+
//# sourceMappingURL=abstract-boolean-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-boolean-type.js","sourceRoot":"","sources":["../../../src/type/abstract-boolean-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAA+C;AAC/C,0EAAoE;AACpE,iFAAqF;AACrF,4CAAgD;AAChD,4FAAuF;AAGhF,IAAM,mBAAmB,GAAzB,MAAM,mBAA4D,SAAQ,4BAGhF;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,4BAAgB,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1C,MAAM,IAAI,iDAAsB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;YACnC,OAAO,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,GAAG,CAAC;QAC3C,CAAC;QACD,OAAO,CAAC,CAAC,KAAK,CAAC;IACjB,CAAC;CACF,CAAA;AAjBY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,sCAAqB,EAAE,CAAC,CAAC;GACvC,mBAAmB,CAiB/B"}
|
|
@@ -0,0 +1,33 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractDateType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
12
|
+
const can_be_date_1 = require("../validator/decorator/custom/can-be-date");
|
|
13
|
+
const validator_1 = require("../validator");
|
|
14
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
15
|
+
let AbstractDateType = class AbstractDateType extends abstract_type_1.AbstractType {
|
|
16
|
+
filter(value) {
|
|
17
|
+
if (value === null) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
if (!validator_1.DateValidator.canBeDate(value)) {
|
|
21
|
+
throw new type_primitive_exception_1.TypePrimitiveException('Date', value);
|
|
22
|
+
}
|
|
23
|
+
return typeof value === 'string' ? new Date(value) : value;
|
|
24
|
+
}
|
|
25
|
+
get toString() {
|
|
26
|
+
return this.value instanceof Date ? this.value.toISOString() : super.toString;
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
exports.AbstractDateType = AbstractDateType;
|
|
30
|
+
exports.AbstractDateType = AbstractDateType = __decorate([
|
|
31
|
+
(0, type_validator_1.AddValidate)([{ validator: can_be_date_1.CanBeDate }])
|
|
32
|
+
], AbstractDateType);
|
|
33
|
+
//# sourceMappingURL=abstract-date-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-date-type.js","sourceRoot":"","sources":["../../../src/type/abstract-date-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAA+C;AAC/C,0EAAoE;AACpE,2EAAsE;AACtE,4CAA6C;AAC7C,4FAAuF;AAGhF,IAAM,gBAAgB,GAAtB,MAAM,gBAAyD,SAAQ,4BAG7E;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,yBAAa,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACpC,MAAM,IAAI,iDAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAClD,CAAC;QACD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC7D,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,KAAK,YAAY,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;IAChF,CAAC;CACF,CAAA;AAjBY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,uBAAS,EAAE,CAAC,CAAC;GAC3B,gBAAgB,CAiB5B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AbstractEnumType = void 0;
|
|
4
|
+
const abstract_type_1 = require("./abstract-type");
|
|
5
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
6
|
+
class AbstractEnumType extends abstract_type_1.AbstractType {
|
|
7
|
+
filter(value) {
|
|
8
|
+
if (value === null) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
const enumValues = Object.values(this.getEnum());
|
|
12
|
+
if (!enumValues.includes(value)) {
|
|
13
|
+
throw new type_primitive_exception_1.TypePrimitiveException(`Expected one of [${enumValues.join(', ')}]`, value, '');
|
|
14
|
+
}
|
|
15
|
+
return value;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.AbstractEnumType = AbstractEnumType;
|
|
19
|
+
//# sourceMappingURL=abstract-enum-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-enum-type.js","sourceRoot":"","sources":["../../../src/type/abstract-enum-type.ts"],"names":[],"mappings":";;;AAAA,mDAA+C;AAC/C,4FAAuF;AAEvF,MAAsB,gBAGpB,SAAQ,4BAAkB;IAGhB,MAAM,CAAC,KAAe;QAC9B,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,iDAAsB,CAAC,oBAAoB,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QAC5F,CAAC;QAED,OAAO,KAAU,CAAC;IACpB,CAAC;CACF;AAjBD,4CAiBC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { AbstractType } from './abstract-type';
|
|
2
|
+
export type JsonTypeValue = Record<string, any>;
|
|
3
|
+
export declare class AbstractJsonType<T extends JsonTypeValue, R extends null | undefined = undefined> extends AbstractType<T, R> {
|
|
4
|
+
protected filter(value: any): any;
|
|
5
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractJsonType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
12
|
+
const validator_1 = require("../validator");
|
|
13
|
+
const can_be_json_1 = require("../validator/decorator/custom/can-be-json");
|
|
14
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
15
|
+
let AbstractJsonType = class AbstractJsonType extends abstract_type_1.AbstractType {
|
|
16
|
+
filter(value) {
|
|
17
|
+
if (value === null) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
if (!validator_1.JsonValidator.canBeJson(value)) {
|
|
21
|
+
throw new type_primitive_exception_1.TypePrimitiveException('Json', value);
|
|
22
|
+
}
|
|
23
|
+
return typeof value === 'string' ? JSON.parse(value) : value;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.AbstractJsonType = AbstractJsonType;
|
|
27
|
+
exports.AbstractJsonType = AbstractJsonType = __decorate([
|
|
28
|
+
(0, type_validator_1.AddValidate)([{ validator: can_be_json_1.CanBeJson }])
|
|
29
|
+
], AbstractJsonType);
|
|
30
|
+
//# sourceMappingURL=abstract-json-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-json-type.js","sourceRoot":"","sources":["../../../src/type/abstract-json-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAA+C;AAC/C,0EAAoE;AACpE,4CAA6C;AAC7C,2EAAsE;AACtE,4FAAuF;AAKhF,IAAM,gBAAgB,GAAtB,MAAM,gBAGX,SAAQ,4BAAkB;IAChB,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,yBAAa,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACpC,MAAM,IAAI,iDAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAClD,CAAC;QACD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC/D,CAAC;CACF,CAAA;AAbY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,uBAAS,EAAE,CAAC,CAAC;GAC3B,gBAAgB,CAa5B"}
|
|
@@ -0,0 +1,31 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractNumberType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const validator_1 = require("../validator");
|
|
12
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
13
|
+
const can_be_number_1 = require("../validator/decorator/custom/can-be-number");
|
|
14
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
15
|
+
let AbstractNumberType = class AbstractNumberType extends abstract_type_1.AbstractType {
|
|
16
|
+
filter(value) {
|
|
17
|
+
if (value === null) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
if (!validator_1.NumberValidator.canBeNumber(value)) {
|
|
21
|
+
throw new type_primitive_exception_1.TypePrimitiveException('Number', value);
|
|
22
|
+
}
|
|
23
|
+
const number = Number(value);
|
|
24
|
+
return isNaN(number) ? NaN : number.valueOf();
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
exports.AbstractNumberType = AbstractNumberType;
|
|
28
|
+
exports.AbstractNumberType = AbstractNumberType = __decorate([
|
|
29
|
+
(0, type_validator_1.AddValidate)([{ validator: can_be_number_1.CanBeNumberValidator }])
|
|
30
|
+
], AbstractNumberType);
|
|
31
|
+
//# sourceMappingURL=abstract-number-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-number-type.js","sourceRoot":"","sources":["../../../src/type/abstract-number-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAA+C;AAC/C,4CAA+C;AAC/C,0EAAoE;AACpE,+EAAmF;AACnF,4FAAuF;AAGhF,IAAM,kBAAkB,GAAxB,MAAM,kBAA2D,SAAQ,4BAG/E;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC,2BAAe,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YACxC,MAAM,IAAI,iDAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QACpD,CAAC;QACD,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC7B,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IAChD,CAAC;CACF,CAAA;AAfY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,oCAAoB,EAAE,CAAC,CAAC;GACtC,kBAAkB,CAe9B"}
|
|
@@ -0,0 +1,33 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractStringType = void 0;
|
|
10
|
+
const abstract_type_1 = require("./abstract-type");
|
|
11
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
12
|
+
const can_be_string_1 = require("../validator/decorator/custom/can-be-string");
|
|
13
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
14
|
+
const validator_1 = require("../validator");
|
|
15
|
+
let AbstractStringType = class AbstractStringType extends abstract_type_1.AbstractType {
|
|
16
|
+
filter(value) {
|
|
17
|
+
if (value === null) {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
if (!validator_1.StringValidator.canBeString(value)) {
|
|
21
|
+
throw new type_primitive_exception_1.TypePrimitiveException('String', value);
|
|
22
|
+
}
|
|
23
|
+
if (typeof value === 'boolean') {
|
|
24
|
+
return value ? 'true' : 'false';
|
|
25
|
+
}
|
|
26
|
+
return `${value}`;
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
exports.AbstractStringType = AbstractStringType;
|
|
30
|
+
exports.AbstractStringType = AbstractStringType = __decorate([
|
|
31
|
+
(0, type_validator_1.AddValidate)([{ validator: can_be_string_1.CanBeStringValidator }])
|
|
32
|
+
], AbstractStringType);
|
|
33
|
+
//# sourceMappingURL=abstract-string-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-string-type.js","sourceRoot":"","sources":["../../../src/type/abstract-string-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAA+C;AAC/C,0EAAoE;AACpE,+EAAmF;AAEnF,4FAAuF;AACvF,4CAA+C;AAGxC,IAAM,kBAAkB,GAAxB,MAAM,kBAA2D,SAAQ,4BAG/E;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC,2BAAe,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YACxC,MAAM,IAAI,iDAAsB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QACpD,CAAC;QACD,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;QAClC,CAAC;QACD,OAAO,GAAG,KAAK,EAAE,CAAC;IACpB,CAAC;CACF,CAAA;AAjBY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,oCAAoB,EAAE,CAAC,CAAC;GACtC,kBAAkB,CAiB9B"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { TypeValidatorInterface } from '../validator';
|
|
2
|
+
export declare abstract class AbstractType<T, R extends null | undefined = undefined> implements TypeValidatorInterface {
|
|
3
|
+
protected _value: R extends null ? T | null : T;
|
|
4
|
+
constructor(value: R extends null ? T | null : T);
|
|
5
|
+
get value(): R extends null ? T | null : T;
|
|
6
|
+
get isNull(): boolean;
|
|
7
|
+
get isNotNull(): boolean;
|
|
8
|
+
isValid(): boolean;
|
|
9
|
+
validatorMessageObj(customReplacement?: string): object;
|
|
10
|
+
validatorMessageStr(separator?: string, customReplacement?: string): string;
|
|
11
|
+
get toString(): string;
|
|
12
|
+
protected abstract filter(value: any | null): any | null;
|
|
13
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AbstractType = void 0;
|
|
4
|
+
const common_1 = require("@archi-code/common");
|
|
5
|
+
const class_validator_1 = require("class-validator");
|
|
6
|
+
class AbstractType {
|
|
7
|
+
constructor(value) {
|
|
8
|
+
this._value = this.filter(value ?? null);
|
|
9
|
+
}
|
|
10
|
+
get value() {
|
|
11
|
+
return this._value;
|
|
12
|
+
}
|
|
13
|
+
get isNull() {
|
|
14
|
+
return this._value === null;
|
|
15
|
+
}
|
|
16
|
+
get isNotNull() {
|
|
17
|
+
return !this.isNull;
|
|
18
|
+
}
|
|
19
|
+
isValid() {
|
|
20
|
+
return (0, class_validator_1.validateSync)(this).length === 0;
|
|
21
|
+
}
|
|
22
|
+
validatorMessageObj(customReplacement = '') {
|
|
23
|
+
const errors = (0, class_validator_1.validateSync)(this);
|
|
24
|
+
const data = errors.map((error) => {
|
|
25
|
+
if (error.constraints) {
|
|
26
|
+
return Object.entries(error.constraints)
|
|
27
|
+
.map(([key, message]) => {
|
|
28
|
+
return {
|
|
29
|
+
[key]: message.replace('_value ', customReplacement ? `${customReplacement} ` : ''),
|
|
30
|
+
};
|
|
31
|
+
})
|
|
32
|
+
.reduce((acc, curr) => ({ ...acc, ...curr }), {});
|
|
33
|
+
}
|
|
34
|
+
return {};
|
|
35
|
+
});
|
|
36
|
+
return data.length > 0 ? data[0] : {};
|
|
37
|
+
}
|
|
38
|
+
validatorMessageStr(separator = ',', customReplacement = '') {
|
|
39
|
+
return Object.values(this.validatorMessageObj(customReplacement)).join(`${separator} `);
|
|
40
|
+
}
|
|
41
|
+
get toString() {
|
|
42
|
+
return this.isNull ? '' : (0, common_1.universalToString)(this._value);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.AbstractType = AbstractType;
|
|
46
|
+
//# sourceMappingURL=abstract-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-type.js","sourceRoot":"","sources":["../../../src/type/abstract-type.ts"],"names":[],"mappings":";;;AAAA,+CAAuD;AAEvD,qDAA+C;AAE/C,MAAsB,YAAY;IAMhC,YAAY,KAAoC;QAC9C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC;IAC9B,CAAC;IAED,IAAI,SAAS;QACX,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC;IACtB,CAAC;IAED,OAAO;QACL,OAAO,IAAA,8BAAY,EAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,mBAAmB,CAAC,iBAAiB,GAAG,EAAE;QACxC,MAAM,MAAM,GAAG,IAAA,8BAAY,EAAC,IAAI,CAAC,CAAC;QAClC,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YAChC,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;gBACtB,OAAO,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC;qBACrC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,EAAE,EAAE;oBACtB,OAAO;wBACL,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,iBAAiB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;qBACpF,CAAC;gBACJ,CAAC,CAAC;qBACD,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;YACtD,CAAC;YACD,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACxC,CAAC;IAED,mBAAmB,CAAC,SAAS,GAAG,GAAG,EAAE,iBAAiB,GAAG,EAAE;QACzD,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC;IAC1F,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAA,0BAAiB,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3D,CAAC;CAGF;AApDD,oCAoDC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { AbstractType } from './abstract-type';
|
|
2
|
+
export declare class AbstractUuidType<R extends null | undefined = undefined> extends AbstractType<string, R> {
|
|
3
|
+
static random(): string;
|
|
4
|
+
static fromValue(value: string, namespace?: string): string;
|
|
5
|
+
protected filter(value: any): any;
|
|
6
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AbstractUuidType = void 0;
|
|
10
|
+
const uuid_1 = require("uuid");
|
|
11
|
+
const abstract_type_1 = require("./abstract-type");
|
|
12
|
+
const type_validator_1 = require("../validator/decorator/type-validator");
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const type_primitive_exception_1 = require("../exceptions/domain/type-primitive.exception");
|
|
15
|
+
const DNS_NAMESPACE = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';
|
|
16
|
+
let AbstractUuidType = class AbstractUuidType extends abstract_type_1.AbstractType {
|
|
17
|
+
static random() {
|
|
18
|
+
return (0, uuid_1.v4)();
|
|
19
|
+
}
|
|
20
|
+
static fromValue(value, namespace = DNS_NAMESPACE) {
|
|
21
|
+
return (0, uuid_1.v5)(value, namespace);
|
|
22
|
+
}
|
|
23
|
+
filter(value) {
|
|
24
|
+
if (value === null) {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
if (!(0, class_validator_1.isUUID)(value)) {
|
|
28
|
+
throw new type_primitive_exception_1.TypePrimitiveException('UUID', value);
|
|
29
|
+
}
|
|
30
|
+
return value;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
exports.AbstractUuidType = AbstractUuidType;
|
|
34
|
+
exports.AbstractUuidType = AbstractUuidType = __decorate([
|
|
35
|
+
(0, type_validator_1.AddValidate)([{ validator: 'IsUUID' }])
|
|
36
|
+
], AbstractUuidType);
|
|
37
|
+
//# sourceMappingURL=abstract-uuid-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-uuid-type.js","sourceRoot":"","sources":["../../../src/type/abstract-uuid-type.ts"],"names":[],"mappings":";;;;;;;;;AAAA,+BAAkD;AAClD,mDAA+C;AAC/C,0EAAoE;AACpE,qDAAyC;AACzC,4FAAuF;AAEvF,MAAM,aAAa,GAAG,sCAAsC,CAAC;AAGtD,IAAM,gBAAgB,GAAtB,MAAM,gBAAyD,SAAQ,4BAG7E;IACC,MAAM,CAAC,MAAM;QACX,OAAO,IAAA,SAAM,GAAE,CAAC;IAClB,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,KAAa,EAAE,YAAoB,aAAa;QAC/D,OAAO,IAAA,SAAM,EAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAClC,CAAC;IAES,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC,IAAA,wBAAM,EAAC,KAAK,CAAC,EAAE,CAAC;YACnB,MAAM,IAAI,iDAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAClD,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;CACF,CAAA;AAvBY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,4BAAW,EAAC,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC,CAAC;GAC1B,gBAAgB,CAuB5B"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { AbstractBooleanType } from './abstract-boolean-type';
|
|
2
|
+
import { AbstractDateType } from './abstract-date-type';
|
|
3
|
+
import { AbstractNumberType } from './abstract-number-type';
|
|
4
|
+
import { AbstractStringType } from './abstract-string-type';
|
|
5
|
+
import { AbstractUuidType } from './abstract-uuid-type';
|
|
6
|
+
export { AbstractArrayType } from './abstract-array-type';
|
|
7
|
+
export { AbstractBooleanType } from './abstract-boolean-type';
|
|
8
|
+
export { AbstractDateType } from './abstract-date-type';
|
|
9
|
+
export { AbstractEnumType } from './abstract-enum-type';
|
|
10
|
+
export { AbstractJsonType } from './abstract-json-type';
|
|
11
|
+
export { AbstractNumberType } from './abstract-number-type';
|
|
12
|
+
export { AbstractStringType } from './abstract-string-type';
|
|
13
|
+
export { AbstractUuidType } from './abstract-uuid-type';
|
|
14
|
+
export { AddValidate } from '../validator/decorator/type-validator';
|
|
15
|
+
export declare class BooleanTypeOptional extends AbstractBooleanType<null> {
|
|
16
|
+
constructor(value?: boolean | null);
|
|
17
|
+
}
|
|
18
|
+
export declare class BooleanTypeRequired extends AbstractBooleanType {
|
|
19
|
+
}
|
|
20
|
+
export declare class DateTypeOptional extends AbstractDateType<null> {
|
|
21
|
+
constructor(value?: Date | null);
|
|
22
|
+
}
|
|
23
|
+
export declare class DateTypeRequired extends AbstractDateType {
|
|
24
|
+
}
|
|
25
|
+
export declare class CreatedAt extends DateTypeRequired {
|
|
26
|
+
static now(): CreatedAt;
|
|
27
|
+
}
|
|
28
|
+
export declare class UpdatedAt extends DateTypeRequired {
|
|
29
|
+
static now(): UpdatedAt;
|
|
30
|
+
setNow(): void;
|
|
31
|
+
}
|
|
32
|
+
export declare class UuidTypeOptional extends AbstractUuidType<null> {
|
|
33
|
+
constructor(value?: string | null);
|
|
34
|
+
}
|
|
35
|
+
export declare class UuidTypeRequired extends AbstractUuidType {
|
|
36
|
+
}
|
|
37
|
+
export declare class IdType extends AbstractUuidType {
|
|
38
|
+
}
|
|
39
|
+
export declare class NumberTypeOptional extends AbstractNumberType<null> {
|
|
40
|
+
constructor(value?: number | null);
|
|
41
|
+
}
|
|
42
|
+
export declare class NumberTypeRequired extends AbstractNumberType {
|
|
43
|
+
}
|
|
44
|
+
export declare class StringTypeOptional extends AbstractStringType<null> {
|
|
45
|
+
constructor(value?: string | null);
|
|
46
|
+
}
|
|
47
|
+
export declare class StringTypeRequired extends AbstractStringType {
|
|
48
|
+
}
|