ngx-material-entity 0.1.0 → 0.1.3
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/CONTRIBUTING.md +7 -1
- package/README.md +3 -2
- package/classes/base-builder.class.d.ts +35 -0
- package/classes/entity-model.class.d.ts +1 -1
- package/classes/entity-service.class.d.ts +27 -17
- package/classes/entity-utilities.class.d.ts +96 -46
- package/components/confirm-dialog/confirm-dialog-data.builder.d.ts +23 -0
- package/components/confirm-dialog/confirm-dialog-data.d.ts +18 -8
- package/components/confirm-dialog/confirm-dialog.component.d.ts +15 -5
- package/components/get-validation-error-message.function.d.ts +3 -2
- package/components/input/add-array-item-dialog-data.builder.d.ts +21 -0
- package/components/input/add-array-item-dialog-data.d.ts +20 -0
- package/components/input/input.component.d.ts +116 -26
- package/components/input/input.module.d.ts +6 -4
- package/components/table/create-dialog/create-dialog-data.builder.d.ts +21 -0
- package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +22 -0
- package/components/table/create-dialog/create-entity-dialog-data.d.ts +2 -2
- package/components/table/create-dialog/create-entity-dialog.component.d.ts +19 -5
- package/components/table/edit-dialog/edit-dialog-data.builder.d.ts +25 -0
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +5 -5
- package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +23 -0
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +23 -5
- package/components/table/table-data.builder.d.ts +51 -0
- package/components/table/table-data.d.ts +40 -24
- package/components/table/table.component.d.ts +52 -5
- package/components/table/table.module.d.ts +3 -1
- package/decorators/array/array-decorator-internal.data.d.ts +45 -0
- package/decorators/array/array-decorator.data.d.ts +129 -0
- package/decorators/array/array.decorator.d.ts +10 -0
- package/decorators/base/base-property.decorator.d.ts +7 -6
- package/decorators/base/decorator-types.enum.d.ts +7 -7
- package/decorators/base/property-decorator-internal.data.d.ts +24 -0
- package/decorators/base/property-decorator.data.d.ts +70 -0
- package/decorators/boolean/boolean-decorator-internal.data.d.ts +25 -0
- package/decorators/boolean/boolean-decorator.data.d.ts +37 -0
- package/decorators/boolean/boolean.decorator.d.ts +8 -0
- package/decorators/number/number-decorator-internal.data.d.ts +22 -0
- package/decorators/number/number-decorator.data.d.ts +38 -0
- package/decorators/number/number.decorator.d.ts +8 -0
- package/decorators/object/object-decorator-internal.data.d.ts +11 -0
- package/decorators/object/object-decorator.data.d.ts +25 -0
- package/decorators/object/object.decorator.d.ts +9 -0
- package/decorators/string/string-decorator-internal.data.d.ts +43 -0
- package/decorators/string/string-decorator.data.d.ts +79 -0
- package/decorators/string/string.decorator.d.ts +8 -0
- package/esm2020/classes/base-builder.class.mjs +43 -0
- package/esm2020/classes/entity-model.class.mjs +2 -2
- package/esm2020/classes/entity-service.class.mjs +20 -14
- package/esm2020/classes/entity-utilities.class.mjs +182 -101
- package/esm2020/components/confirm-dialog/confirm-dialog-data.builder.mjs +44 -0
- package/esm2020/components/confirm-dialog/confirm-dialog-data.mjs +1 -1
- package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +18 -22
- package/esm2020/components/get-validation-error-message.function.mjs +8 -3
- package/esm2020/components/input/add-array-item-dialog-data.builder.mjs +30 -0
- package/esm2020/components/input/add-array-item-dialog-data.mjs +2 -0
- package/esm2020/components/input/input.component.mjs +168 -32
- package/esm2020/components/input/input.module.mjs +19 -9
- package/esm2020/components/table/create-dialog/create-dialog-data.builder.mjs +32 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +26 -0
- package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +30 -30
- package/esm2020/components/table/create-dialog/create-entity-dialog.module.mjs +20 -4
- package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +41 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +27 -0
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +43 -47
- package/esm2020/components/table/table-data.builder.mjs +105 -0
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +90 -82
- package/esm2020/components/table/table.module.mjs +12 -4
- package/esm2020/decorators/array/array-decorator-internal.data.mjs +51 -0
- package/esm2020/decorators/array/array-decorator.data.mjs +7 -0
- package/esm2020/decorators/array/array.decorator.mjs +24 -0
- package/esm2020/decorators/base/base-property.decorator.mjs +6 -5
- package/esm2020/decorators/base/decorator-types.enum.mjs +1 -1
- package/esm2020/decorators/base/property-decorator-internal.data.mjs +38 -0
- package/esm2020/decorators/base/property-decorator.data.mjs +6 -0
- package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +33 -0
- package/esm2020/decorators/boolean/boolean-decorator.data.mjs +7 -0
- package/esm2020/decorators/boolean/boolean.decorator.mjs +21 -0
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +23 -0
- package/esm2020/decorators/number/number-decorator.data.mjs +7 -0
- package/esm2020/decorators/number/number.decorator.mjs +18 -0
- package/esm2020/decorators/object/object-decorator-internal.data.mjs +12 -0
- package/esm2020/decorators/object/object-decorator.data.mjs +7 -0
- package/esm2020/decorators/object/object.decorator.mjs +13 -0
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +48 -0
- package/esm2020/decorators/string/string-decorator.data.mjs +7 -0
- package/esm2020/decorators/string/string.decorator.mjs +24 -0
- package/esm2020/public-api.mjs +15 -10
- package/fesm2015/ngx-material-entity.mjs +1221 -880
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +1225 -877
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +2 -1
- package/public-api.d.ts +15 -7
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.d.ts +0 -35
- package/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.d.ts +0 -12
- package/components/input/array-table/array-table.component.d.ts +0 -34
- package/components/input/array-table/array-table.module.d.ts +0 -19
- package/components/input/internal-input/internal-input.component.d.ts +0 -57
- package/components/input/internal-input/internal-input.module.d.ts +0 -16
- package/decorators/array.decorator.d.ts +0 -125
- package/decorators/base/property-decorator-config.interface.d.ts +0 -50
- package/decorators/boolean.decorator.d.ts +0 -42
- package/decorators/number.decorator.d.ts +0 -40
- package/decorators/object.decorator.d.ts +0 -27
- package/decorators/string.decorator.d.ts +0 -76
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.component.mjs +0 -43
- package/esm2020/components/input/array-table/add-array-item-dialog/add-array-item-dialog.module.mjs +0 -22
- package/esm2020/components/input/array-table/array-table.component.mjs +0 -116
- package/esm2020/components/input/array-table/array-table.module.mjs +0 -66
- package/esm2020/components/input/internal-input/internal-input.component.mjs +0 -73
- package/esm2020/components/input/internal-input/internal-input.module.mjs +0 -54
- package/esm2020/decorators/array.decorator.mjs +0 -70
- package/esm2020/decorators/base/property-decorator-config.interface.mjs +0 -31
- package/esm2020/decorators/boolean.decorator.mjs +0 -44
- package/esm2020/decorators/number.decorator.mjs +0 -36
- package/esm2020/decorators/object.decorator.mjs +0 -23
- package/esm2020/decorators/string.decorator.mjs +0 -61
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
2
|
+
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig } from './number-decorator.data';
|
|
3
|
+
/**
|
|
4
|
+
* The internal DefaultNumberDecoratorConfig. Sets default values.
|
|
5
|
+
*/
|
|
6
|
+
export declare class DefaultNumberDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DefaultNumberDecoratorConfig {
|
|
7
|
+
displayStyle: 'line';
|
|
8
|
+
min?: number;
|
|
9
|
+
max?: number;
|
|
10
|
+
constructor(data: DefaultNumberDecoratorConfig);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* The internal DropdownNumberDecoratorConfig. Sets default values.
|
|
14
|
+
*/
|
|
15
|
+
export declare class DropdownNumberDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DropdownNumberDecoratorConfig {
|
|
16
|
+
displayStyle: 'dropdown';
|
|
17
|
+
dropdownValues: {
|
|
18
|
+
displayName: string;
|
|
19
|
+
value: number;
|
|
20
|
+
}[];
|
|
21
|
+
constructor(data: DropdownNumberDecoratorConfig);
|
|
22
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { PropertyDecoratorConfig } from '../base/property-decorator.data';
|
|
2
|
+
/**
|
|
3
|
+
* Definition for the @number metadata.
|
|
4
|
+
*/
|
|
5
|
+
declare abstract class NumberDecoratorConfig extends PropertyDecoratorConfig {
|
|
6
|
+
/**
|
|
7
|
+
* Whether to display the number in a single line or as a dropdown.
|
|
8
|
+
*/
|
|
9
|
+
displayStyle: 'line' | 'dropdown';
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* The configuration options for a number property displayed in a default number input.
|
|
13
|
+
*/
|
|
14
|
+
export interface DefaultNumberDecoratorConfig extends NumberDecoratorConfig {
|
|
15
|
+
displayStyle: 'line';
|
|
16
|
+
/**
|
|
17
|
+
* The minimum value of the number.
|
|
18
|
+
*/
|
|
19
|
+
min?: number;
|
|
20
|
+
/**
|
|
21
|
+
* The maximum value of the number.
|
|
22
|
+
*/
|
|
23
|
+
max?: number;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* The configuration options for a number property displayed in a dropdown.
|
|
27
|
+
*/
|
|
28
|
+
export interface DropdownNumberDecoratorConfig extends NumberDecoratorConfig {
|
|
29
|
+
displayStyle: 'dropdown';
|
|
30
|
+
/**
|
|
31
|
+
* The values of the dropdown, consisting of a name to display and the actual value.
|
|
32
|
+
*/
|
|
33
|
+
dropdownValues: {
|
|
34
|
+
displayName: string;
|
|
35
|
+
value: number;
|
|
36
|
+
}[];
|
|
37
|
+
}
|
|
38
|
+
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig } from './number-decorator.data';
|
|
2
|
+
/**
|
|
3
|
+
* Decorator for setting and getting string property metadata.
|
|
4
|
+
*
|
|
5
|
+
* @param metadata - The metadata of the string property.
|
|
6
|
+
* @returns The method that defines the metadata.
|
|
7
|
+
*/
|
|
8
|
+
export declare function number(metadata: DefaultNumberDecoratorConfig | DropdownNumberDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Entity } from '../../classes/entity-model.class';
|
|
2
|
+
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
3
|
+
import { DefaultObjectDecoratorConfig } from './object-decorator.data';
|
|
4
|
+
/**
|
|
5
|
+
* The internal DefaultObjectDecoratorConfig. Sets default values.
|
|
6
|
+
*/
|
|
7
|
+
export declare class DefaultObjectDecoratorConfigInternal<EntityType extends Entity> extends PropertyDecoratorConfigInternal implements DefaultObjectDecoratorConfig<EntityType> {
|
|
8
|
+
displayStyle: 'inline';
|
|
9
|
+
type: new (entity?: EntityType) => EntityType;
|
|
10
|
+
constructor(data: DefaultObjectDecoratorConfig<EntityType>);
|
|
11
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Entity } from '../../classes/entity-model.class';
|
|
2
|
+
import { PropertyDecoratorConfig } from '../base/property-decorator.data';
|
|
3
|
+
/**
|
|
4
|
+
* Definition for the @object metadata.
|
|
5
|
+
*/
|
|
6
|
+
declare abstract class ObjectDecoratorConfig<EntityType extends Entity> extends PropertyDecoratorConfig {
|
|
7
|
+
/**
|
|
8
|
+
* The entity type of the object.
|
|
9
|
+
*/
|
|
10
|
+
type: new (entity?: EntityType) => EntityType;
|
|
11
|
+
/**
|
|
12
|
+
* How to display the object.
|
|
13
|
+
*
|
|
14
|
+
* The objects properties are added as input fields in an section of the entity.
|
|
15
|
+
* Useful if the object only contains a few properties (e.g. A address on a user).
|
|
16
|
+
*/
|
|
17
|
+
displayStyle: 'inline';
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* The configuration options for a object property.
|
|
21
|
+
*/
|
|
22
|
+
export interface DefaultObjectDecoratorConfig<EntityType extends Entity> extends ObjectDecoratorConfig<EntityType> {
|
|
23
|
+
displayStyle: 'inline';
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Entity } from '../../classes/entity-model.class';
|
|
2
|
+
import { DefaultObjectDecoratorConfig } from './object-decorator.data';
|
|
3
|
+
/**
|
|
4
|
+
* Decorator for setting and getting object property metadata.
|
|
5
|
+
*
|
|
6
|
+
* @param metadata - The metadata of the object property.
|
|
7
|
+
* @returns The method that defines the metadata.
|
|
8
|
+
*/
|
|
9
|
+
export declare function object<EntityType extends Entity>(metadata: DefaultObjectDecoratorConfig<EntityType>): (target: object, propertyKey: string) => void;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
2
|
+
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
3
|
+
/**
|
|
4
|
+
* The internal DropdownStringDecoratorConfig. Sets default values.
|
|
5
|
+
*/
|
|
6
|
+
export declare class DropdownStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DropdownStringDecoratorConfig {
|
|
7
|
+
displayStyle: 'dropdown';
|
|
8
|
+
dropdownValues: {
|
|
9
|
+
displayName: string;
|
|
10
|
+
value: string;
|
|
11
|
+
}[];
|
|
12
|
+
constructor(data: DropdownStringDecoratorConfig);
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* The internal DefaultStringDecoratorConfig. Sets default values.
|
|
16
|
+
*/
|
|
17
|
+
export declare class DefaultStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DefaultStringDecoratorConfig {
|
|
18
|
+
displayStyle: 'line';
|
|
19
|
+
minLength?: number;
|
|
20
|
+
maxLength?: number;
|
|
21
|
+
regex?: RegExp;
|
|
22
|
+
constructor(data: DefaultStringDecoratorConfig);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* The internal TextboxStringDecoratorConfig. Sets default values.
|
|
26
|
+
*/
|
|
27
|
+
export declare class TextboxStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements TextboxStringDecoratorConfig {
|
|
28
|
+
displayStyle: 'textbox';
|
|
29
|
+
minLength?: number;
|
|
30
|
+
maxLength?: number;
|
|
31
|
+
constructor(data: TextboxStringDecoratorConfig);
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* The internal AutocompleteStringDecoratorConfig. Sets default values.
|
|
35
|
+
*/
|
|
36
|
+
export declare class AutocompleteStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements AutocompleteStringDecoratorConfig {
|
|
37
|
+
displayStyle: 'autocomplete';
|
|
38
|
+
autocompleteValues: string[];
|
|
39
|
+
minLength?: number;
|
|
40
|
+
maxLength?: number;
|
|
41
|
+
regex?: RegExp;
|
|
42
|
+
constructor(data: AutocompleteStringDecoratorConfig);
|
|
43
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { PropertyDecoratorConfig } from '../base/property-decorator.data';
|
|
2
|
+
/**
|
|
3
|
+
* Definition for the @string metadata.
|
|
4
|
+
*/
|
|
5
|
+
declare abstract class StringDecoratorConfig extends PropertyDecoratorConfig {
|
|
6
|
+
/**
|
|
7
|
+
* How to display the string.
|
|
8
|
+
*/
|
|
9
|
+
displayStyle: 'line' | 'textbox' | 'autocomplete' | 'dropdown';
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* The configuration options for a string property displayed as a dropdown.
|
|
13
|
+
*/
|
|
14
|
+
export interface DropdownStringDecoratorConfig extends StringDecoratorConfig {
|
|
15
|
+
displayStyle: 'dropdown';
|
|
16
|
+
/**
|
|
17
|
+
* The values of the dropdown, consisting of a name to display and the actual value
|
|
18
|
+
* Can also receive a function to determine the values.
|
|
19
|
+
*/
|
|
20
|
+
dropdownValues: {
|
|
21
|
+
displayName: string;
|
|
22
|
+
value: string;
|
|
23
|
+
}[];
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* The configuration options for a string property displayed in a default text input.
|
|
27
|
+
*/
|
|
28
|
+
export interface DefaultStringDecoratorConfig extends StringDecoratorConfig {
|
|
29
|
+
displayStyle: 'line';
|
|
30
|
+
/**
|
|
31
|
+
* The minimum required length of the string.
|
|
32
|
+
*/
|
|
33
|
+
minLength?: number;
|
|
34
|
+
/**
|
|
35
|
+
* The maximum required length of the string.
|
|
36
|
+
*/
|
|
37
|
+
maxLength?: number;
|
|
38
|
+
/**
|
|
39
|
+
* A regex used for validation.
|
|
40
|
+
*/
|
|
41
|
+
regex?: RegExp;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* The configuration options for a string property displayed in a textbox input.
|
|
45
|
+
*/
|
|
46
|
+
export interface TextboxStringDecoratorConfig extends StringDecoratorConfig {
|
|
47
|
+
displayStyle: 'textbox';
|
|
48
|
+
/**
|
|
49
|
+
* The minimum required length of the string.
|
|
50
|
+
*/
|
|
51
|
+
minLength?: number;
|
|
52
|
+
/**
|
|
53
|
+
* The maximum required length of the string.
|
|
54
|
+
*/
|
|
55
|
+
maxLength?: number;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* The configuration options for a string property displayed in a mat-autocomplete input.
|
|
59
|
+
*/
|
|
60
|
+
export interface AutocompleteStringDecoratorConfig extends StringDecoratorConfig {
|
|
61
|
+
displayStyle: 'autocomplete';
|
|
62
|
+
/**
|
|
63
|
+
* The autocomplete values.
|
|
64
|
+
*/
|
|
65
|
+
autocompleteValues: string[];
|
|
66
|
+
/**
|
|
67
|
+
* The minimum required length of the string.
|
|
68
|
+
*/
|
|
69
|
+
minLength?: number;
|
|
70
|
+
/**
|
|
71
|
+
* The maximum required length of the string.
|
|
72
|
+
*/
|
|
73
|
+
maxLength?: number;
|
|
74
|
+
/**
|
|
75
|
+
* A regex used for validation.
|
|
76
|
+
*/
|
|
77
|
+
regex?: RegExp;
|
|
78
|
+
}
|
|
79
|
+
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
2
|
+
/**
|
|
3
|
+
* Decorator for setting and getting string Property metadata.
|
|
4
|
+
*
|
|
5
|
+
* @param metadata - The metadata of the string property.
|
|
6
|
+
* @returns The method that defines the metadata.
|
|
7
|
+
*/
|
|
8
|
+
export declare function string(metadata: DropdownStringDecoratorConfig | AutocompleteStringDecoratorConfig | DefaultStringDecoratorConfig | TextboxStringDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* The abstract BaseBuilder class.
|
|
3
|
+
*/
|
|
4
|
+
export class BaseBuilder {
|
|
5
|
+
constructor(data) {
|
|
6
|
+
this.validateInput(data);
|
|
7
|
+
this.inputData = data;
|
|
8
|
+
this.data = this.generateBaseData(data);
|
|
9
|
+
return this;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Used to validate the user input in the constructor.
|
|
13
|
+
*
|
|
14
|
+
* @param data - The user input.
|
|
15
|
+
*/
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
17
|
+
validateInput(data) {
|
|
18
|
+
// By default, no validation is done
|
|
19
|
+
}
|
|
20
|
+
;
|
|
21
|
+
/**
|
|
22
|
+
* Sets the value for the given key if no user value was provided.
|
|
23
|
+
*
|
|
24
|
+
* @param key - The key to set the default value for.
|
|
25
|
+
* @param value - The value to set when nothing was provided.
|
|
26
|
+
* @returns The Builder.
|
|
27
|
+
*/
|
|
28
|
+
withDefault(key, value) {
|
|
29
|
+
if (!this.inputData || !this.inputData[key]) {
|
|
30
|
+
this.data[key] = value;
|
|
31
|
+
}
|
|
32
|
+
return this;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Method used to get the final build value after applying all chaining.
|
|
36
|
+
*
|
|
37
|
+
* @returns The build value.
|
|
38
|
+
*/
|
|
39
|
+
getResult() {
|
|
40
|
+
return this.data;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1idWlsZGVyLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY2xhc3Nlcy9iYXNlLWJ1aWxkZXIuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0E7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLFdBQVc7SUFLN0IsWUFBc0IsSUFBZ0I7UUFDbEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN4QyxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBVUQ7Ozs7T0FJRztJQUNILDZEQUE2RDtJQUNuRCxhQUFhLENBQUMsSUFBZ0I7UUFDcEMsb0NBQW9DO0lBQ3hDLENBQUM7SUFBQSxDQUFDO0lBRUY7Ozs7OztPQU1HO0lBQ0gsV0FBVyxDQUFDLEdBQW9CLEVBQUUsS0FBdUQ7UUFDckYsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3pDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBc0MsQ0FBQztTQUMzRDtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsU0FBUztRQUNMLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNyQixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8qKlxuICogVGhlIGFic3RyYWN0IEJhc2VCdWlsZGVyIGNsYXNzLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUJ1aWxkZXI8SW50ZXJuYWxUeXBlIGV4dGVuZHMgSW5wdXRUeXBlLCBJbnB1dFR5cGUgZXh0ZW5kcyBvYmplY3Q+IHtcblxuICAgIHByaXZhdGUgcmVhZG9ubHkgZGF0YTogSW50ZXJuYWxUeXBlO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgaW5wdXREYXRhPzogSW5wdXRUeXBlO1xuXG4gICAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKGRhdGE/OiBJbnB1dFR5cGUpIHtcbiAgICAgICAgdGhpcy52YWxpZGF0ZUlucHV0KGRhdGEpO1xuICAgICAgICB0aGlzLmlucHV0RGF0YSA9IGRhdGE7XG4gICAgICAgIHRoaXMuZGF0YSA9IHRoaXMuZ2VuZXJhdGVCYXNlRGF0YShkYXRhKTtcbiAgICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogR2VuZXJhdGVzIHRoZSBpbnRlcm5hbCBkYXRhIGZyb20gdGhlIGdpdmVuIHVzZXIgaW5wdXRzLlxuICAgICAqXG4gICAgICogQHBhcmFtIGRhdGEgLSBUaGUgaW5wdXQgZnJvbSB0aGUgdXNlci5cbiAgICAgKiBAcmV0dXJucyBUaGUgaW50ZXJuYWwgZGF0YS5cbiAgICAgKi9cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2VuZXJhdGVCYXNlRGF0YShkYXRhPzogSW5wdXRUeXBlKTogSW50ZXJuYWxUeXBlO1xuXG4gICAgLyoqXG4gICAgICogVXNlZCB0byB2YWxpZGF0ZSB0aGUgdXNlciBpbnB1dCBpbiB0aGUgY29uc3RydWN0b3IuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gZGF0YSAtIFRoZSB1c2VyIGlucHV0LlxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgICBwcm90ZWN0ZWQgdmFsaWRhdGVJbnB1dChkYXRhPzogSW5wdXRUeXBlKTogdm9pZCB7XG4gICAgICAgIC8vIEJ5IGRlZmF1bHQsIG5vIHZhbGlkYXRpb24gaXMgZG9uZVxuICAgIH07XG5cbiAgICAvKipcbiAgICAgKiBTZXRzIHRoZSB2YWx1ZSBmb3IgdGhlIGdpdmVuIGtleSBpZiBubyB1c2VyIHZhbHVlIHdhcyBwcm92aWRlZC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBrZXkgLSBUaGUga2V5IHRvIHNldCB0aGUgZGVmYXVsdCB2YWx1ZSBmb3IuXG4gICAgICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIHRvIHNldCB3aGVuIG5vdGhpbmcgd2FzIHByb3ZpZGVkLlxuICAgICAqIEByZXR1cm5zIFRoZSBCdWlsZGVyLlxuICAgICAqL1xuICAgIHdpdGhEZWZhdWx0KGtleToga2V5b2YgSW5wdXRUeXBlLCB2YWx1ZTogT21pdDxJbnRlcm5hbFR5cGVba2V5b2YgSW5wdXRUeXBlXSwgJ3VuZGVmaW5lZCc+KTogQmFzZUJ1aWxkZXI8SW50ZXJuYWxUeXBlLCBJbnB1dFR5cGU+IHtcbiAgICAgICAgaWYgKCF0aGlzLmlucHV0RGF0YSB8fCAhdGhpcy5pbnB1dERhdGFba2V5XSkge1xuICAgICAgICAgICAgdGhpcy5kYXRhW2tleV0gPSB2YWx1ZSBhcyBJbnRlcm5hbFR5cGVba2V5b2YgSW5wdXRUeXBlXTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBNZXRob2QgdXNlZCB0byBnZXQgdGhlIGZpbmFsIGJ1aWxkIHZhbHVlIGFmdGVyIGFwcGx5aW5nIGFsbCBjaGFpbmluZy5cbiAgICAgKlxuICAgICAqIEByZXR1cm5zIFRoZSBidWlsZCB2YWx1ZS5cbiAgICAgKi9cbiAgICBnZXRSZXN1bHQoKTogSW50ZXJuYWxUeXBlIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZGF0YTtcbiAgICB9XG59Il19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { string } from '../decorators/string.decorator';
|
|
2
|
+
import { string } from '../decorators/string/string.decorator';
|
|
3
3
|
/**
|
|
4
4
|
* The base Entity class.
|
|
5
5
|
*/
|
|
@@ -16,4 +16,4 @@ __decorate([
|
|
|
16
16
|
}),
|
|
17
17
|
__metadata("design:type", String)
|
|
18
18
|
], Entity.prototype, "id", void 0);
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5LW1vZGVsLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY2xhc3Nlcy9lbnRpdHktbW9kZWwuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUUvRDs7R0FFRztBQUNILE1BQU0sT0FBZ0IsTUFBTTtDQWEzQjtBQURHO0lBUkMsTUFBTSxDQUFDO1FBQ0osYUFBYSxFQUFFLElBQUk7UUFDbkIsYUFBYSxFQUFFLElBQUk7UUFDbkIsT0FBTyxFQUFFLEtBQUs7UUFDZCxZQUFZLEVBQUUsTUFBTTtRQUNwQixXQUFXLEVBQUUsSUFBSTtRQUNqQixRQUFRLEVBQUUsSUFBSTtLQUNqQixDQUFDOztrQ0FDVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHN0cmluZyB9IGZyb20gJy4uL2RlY29yYXRvcnMvc3RyaW5nL3N0cmluZy5kZWNvcmF0b3InO1xuXG4vKipcbiAqIFRoZSBiYXNlIEVudGl0eSBjbGFzcy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEVudGl0eSB7XG4gICAgLyoqXG4gICAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIEVudGl0eS5cbiAgICAgKi9cbiAgICBAc3RyaW5nKHtcbiAgICAgICAgb21pdEZvckNyZWF0ZTogdHJ1ZSxcbiAgICAgICAgb21pdEZvclVwZGF0ZTogdHJ1ZSxcbiAgICAgICAgZGlzcGxheTogZmFsc2UsXG4gICAgICAgIGRpc3BsYXlTdHlsZTogJ2xpbmUnLFxuICAgICAgICBkaXNwbGF5TmFtZTogJ0lEJyxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICB9KVxuICAgIGlkITogc3RyaW5nO1xufSJdfQ==
|
|
@@ -11,22 +11,25 @@ export class EntityService {
|
|
|
11
11
|
constructor(http) {
|
|
12
12
|
this.http = http;
|
|
13
13
|
/**
|
|
14
|
-
*
|
|
14
|
+
* A subject of all the entity values.
|
|
15
15
|
* Can be subscribed to when you want to do a specific thing whenever the entities change.
|
|
16
16
|
*/
|
|
17
17
|
this.entitiesSubject = new BehaviorSubject([]);
|
|
18
18
|
}
|
|
19
19
|
/**
|
|
20
|
-
*
|
|
20
|
+
* Gets the entities in an array from the internal entitiesSubject.
|
|
21
|
+
*
|
|
22
|
+
* @returns The current entities in form of an array.
|
|
21
23
|
*/
|
|
22
24
|
get entities() {
|
|
23
25
|
return this.entitiesSubject.value;
|
|
24
26
|
}
|
|
25
27
|
/**
|
|
26
|
-
* Creates a new Entity and pushes it to the entities array
|
|
27
|
-
*
|
|
28
|
+
* Creates a new Entity and pushes it to the entities array.
|
|
29
|
+
*
|
|
30
|
+
* @param entity - The data of the entity to create.
|
|
28
31
|
* All values that should be omitted will be removed from it inside this method.
|
|
29
|
-
* @returns A Promise of the created entity
|
|
32
|
+
* @returns A Promise of the created entity.
|
|
30
33
|
*/
|
|
31
34
|
async create(entity) {
|
|
32
35
|
const body = omit(entity, EntityUtilities.getOmitForCreate(entity));
|
|
@@ -36,8 +39,9 @@ export class EntityService {
|
|
|
36
39
|
return e;
|
|
37
40
|
}
|
|
38
41
|
/**
|
|
39
|
-
* Gets all existing entities and pushes them to the
|
|
40
|
-
*
|
|
42
|
+
* Gets all existing entities and pushes them to the entities array.
|
|
43
|
+
*
|
|
44
|
+
* @returns A Promise of all received Entities.
|
|
41
45
|
*/
|
|
42
46
|
async read() {
|
|
43
47
|
const e = await firstValueFrom(this.http.get(this.baseUrl));
|
|
@@ -45,11 +49,12 @@ export class EntityService {
|
|
|
45
49
|
return e;
|
|
46
50
|
}
|
|
47
51
|
/**
|
|
48
|
-
* Updates a specific Entity
|
|
49
|
-
*
|
|
52
|
+
* Updates a specific Entity.
|
|
53
|
+
*
|
|
54
|
+
* @param entity - The updated Entity
|
|
50
55
|
* All values that should be omitted will be removed from it inside this method.
|
|
51
|
-
* @param entityPriorChanges The current Entity.
|
|
52
|
-
* It Is used to get changed values and only update them instead of sending the whole entity data
|
|
56
|
+
* @param entityPriorChanges - The current Entity.
|
|
57
|
+
* It Is used to get changed values and only update them instead of sending the whole entity data.
|
|
53
58
|
*/
|
|
54
59
|
async update(entity, entityPriorChanges) {
|
|
55
60
|
const reqBody = omit(EntityUtilities.difference(entity, entityPriorChanges), EntityUtilities.getOmitForUpdate(entity));
|
|
@@ -58,8 +63,9 @@ export class EntityService {
|
|
|
58
63
|
this.entitiesSubject.next(this.entities);
|
|
59
64
|
}
|
|
60
65
|
/**
|
|
61
|
-
*
|
|
62
|
-
*
|
|
66
|
+
* Deletes a specific Entity.
|
|
67
|
+
*
|
|
68
|
+
* @param id - The id of the element to delete.
|
|
63
69
|
*/
|
|
64
70
|
async delete(id) {
|
|
65
71
|
await firstValueFrom(this.http.delete(`${this.baseUrl}/${id}`));
|
|
@@ -67,4 +73,4 @@ export class EntityService {
|
|
|
67
73
|
this.entitiesSubject.next(this.entities);
|
|
68
74
|
}
|
|
69
75
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-service.class.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/classes/entity-service.class.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAE3D;;;;;GAKG;AACH,MAAM,OAAgB,aAAa;IA8B/B,YAA6B,IAAgB;QAAhB,SAAI,GAAJ,IAAI,CAAY;QAf7C;;;WAGG;QACM,oBAAe,GAAkC,IAAI,eAAe,CAAe,EAAE,CAAC,CAAC;IAWhD,CAAC;IATjD;;;;OAIG;IACH,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC;IACtC,CAAC;IAID;;;;;;OAMG;IACH,KAAK,CAAC,MAAM,CAAC,MAAkB;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,EAAE,eAAe,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;QACpE,MAAM,CAAC,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAa,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACtB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzC,OAAO,CAAC,CAAC;IACb,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,IAAI;QACN,MAAM,CAAC,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAe,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAC1E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7B,OAAO,CAAC,CAAC;IACb,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,MAAM,CAAC,MAAkB,EAAE,kBAA8B;QAC3D,MAAM,OAAO,GAAG,IAAI,CAChB,eAAe,CAAC,UAAU,CAAC,MAAM,EAAE,kBAAkB,CAAC,EACtD,eAAe,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAC3C,CAAC;QACF,MAAM,aAAa,GAAG,MAAM,cAAc,CACtC,IAAI,CAAC,IAAI,CAAC,KAAK,CACX,GAAG,IAAI,CAAC,OAAO,IAAI,kBAAkB,CAAC,EAAE,EAAE,EAC1C,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CACzB,CACJ,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,kBAAkB,CAAC,EAAE,CAAC,CAAC,GAAG,aAAa,CAAC;QAC9F,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,EAAU;QACnB,MAAM,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAChB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CACjD,CAAC;QACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;CACJ","sourcesContent":["import { Entity } from './entity-model.class';\nimport { HttpClient } from '@angular/common/http';\nimport { BehaviorSubject, firstValueFrom } from 'rxjs';\nimport { isNil, omit, omitBy } from 'lodash';\nimport { EntityUtilities } from './entity-utilities.class';\n\n/**\n * A generic EntityService class.\n * Offers basic CRUD-functionality.\n * You should create a service for every Entity you have.\n * If you extend from this you need to make sure that the extended Service can be injected.\n */\nexport abstract class EntityService<EntityType extends Entity> {\n    /**\n     * The base url used for api requests. If u want to have more control over this,\n     * you can override the create, read, update and delete methods.\n     *\n     * Create Sends a POST-Request to baseUrl.\n     *\n     * Read Sends a GET-Request to baseUrl.\n     *\n     * Update Sends a PATCH-Request to baseUrl/{id}.\n     *\n     * Delete Sends a DEL-Request to baseUrl/{id}.\n     */\n    abstract readonly baseUrl: string;\n\n    /**\n     * A subject of all the entity values.\n     * Can be subscribed to when you want to do a specific thing whenever the entities change.\n     */\n    readonly entitiesSubject: BehaviorSubject<EntityType[]> = new BehaviorSubject<EntityType[]>([]);\n\n    /**\n     * Gets the entities in an array from the internal entitiesSubject.\n     *\n     * @returns The current entities in form of an array.\n     */\n    get entities(): EntityType[] {\n        return this.entitiesSubject.value;\n    }\n\n    constructor(private readonly http: HttpClient) {}\n\n    /**\n     * Creates a new Entity and pushes it to the entities array.\n     *\n     * @param entity - The data of the entity to create.\n     * All values that should be omitted will be removed from it inside this method.\n     * @returns A Promise of the created entity.\n     */\n    async create(entity: EntityType): Promise<EntityType> {\n        const body = omit(entity, EntityUtilities.getOmitForCreate(entity));\n        const e = await firstValueFrom(this.http.post<EntityType>(this.baseUrl, body));\n        this.entities.push(e);\n        this.entitiesSubject.next(this.entities);\n        return e;\n    }\n\n    /**\n     * Gets all existing entities and pushes them to the entities array.\n     *\n     * @returns A Promise of all received Entities.\n     */\n    async read(): Promise<EntityType[]> {\n        const e = await firstValueFrom(this.http.get<EntityType[]>(this.baseUrl));\n        this.entitiesSubject.next(e);\n        return e;\n    }\n\n    /**\n     * Updates a specific Entity.\n     *\n     * @param entity - The updated Entity\n     * All values that should be omitted will be removed from it inside this method.\n     * @param entityPriorChanges - The current Entity.\n     * It Is used to get changed values and only update them instead of sending the whole entity data.\n     */\n    async update(entity: EntityType, entityPriorChanges: EntityType): Promise<void> {\n        const reqBody = omit(\n            EntityUtilities.difference(entity, entityPriorChanges),\n            EntityUtilities.getOmitForUpdate(entity)\n        );\n        const updatedEntity = await firstValueFrom(\n            this.http.patch<EntityType>(\n                `${this.baseUrl}/${entityPriorChanges.id}`,\n                omitBy(reqBody, isNil)\n            )\n        );\n        this.entities[this.entities.findIndex((e) => e.id === entityPriorChanges.id)] = updatedEntity;\n        this.entitiesSubject.next(this.entities);\n    }\n\n    /**\n     * Deletes a specific Entity.\n     *\n     * @param id - The id of the element to delete.\n     */\n    async delete(id: string): Promise<void> {\n        await firstValueFrom(this.http.delete<void>(`${this.baseUrl}/${id}`));\n        this.entities.splice(\n            this.entities.findIndex((e) => e.id === id), 1\n        );\n        this.entitiesSubject.next(this.entities);\n    }\n}"]}
|