ngx-material-entity 1.0.0 → 1.0.5
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/README.md +11 -5
- package/capsulation/reflect.utilities.d.ts +1 -1
- package/classes/date.utilities.d.ts +3 -3
- package/classes/entity.model.d.ts +1 -1
- package/classes/entity.utilities.d.ts +2 -1
- package/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.d.ts +1 -2
- package/components/input/array/array-string-chips-input/array-string-chips-input.component.d.ts +1 -3
- package/components/input/array/array-table.class.d.ts +4 -5
- package/components/input/base-input.component.d.ts +29 -3
- package/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.d.ts +1 -1
- package/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.d.ts +1 -1
- package/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.d.ts +1 -1
- package/components/input/custom/custom.component.d.ts +3 -3
- package/components/input/date/date-input/date-input.component.d.ts +1 -3
- package/components/input/date/date-range-input/date-range-input.component.d.ts +2 -3
- package/components/input/date/date-time-input/date-time-input.component.d.ts +2 -3
- package/components/input/file/file-default-input/file-default-input.component.d.ts +1 -1
- package/components/input/file/file-image-input/file-image-input.component.d.ts +1 -1
- package/components/input/file/file-input/file-input.component.d.ts +2 -1
- package/components/input/input.component.d.ts +13 -1
- package/components/input/input.module.d.ts +37 -34
- package/components/input/number/number-dropdown-input/number-dropdown-input.component.d.ts +1 -1
- package/components/input/number/number-input/number-input.component.d.ts +1 -1
- package/components/input/number/number-slider-input/number-slider-input.component.d.ts +9 -0
- package/components/input/string/string-autocomplete-input/string-autocomplete-input.component.d.ts +2 -2
- package/components/input/string/string-dropdown-input/string-dropdown-input.component.d.ts +1 -1
- package/components/input/string/string-input/string-input.component.d.ts +1 -1
- package/components/input/string/string-password-input/string-password-input.component.d.ts +15 -0
- package/components/input/string/string-textbox-input/string-textbox-input.component.d.ts +1 -1
- package/components/table/edit-dialog/edit-entity-dialog-data.d.ts +4 -0
- package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +2 -1
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +1 -0
- package/components/table/table-data.builder.d.ts +4 -3
- package/components/table/table-data.d.ts +12 -4
- package/decorators/base/decorator-types.enum.d.ts +5 -3
- package/decorators/custom/custom-decorator.data.d.ts +4 -0
- package/decorators/number/number-decorator-internal.data.d.ts +20 -1
- package/decorators/number/number-decorator.data.d.ts +27 -1
- package/decorators/number/number.decorator.d.ts +2 -2
- package/decorators/string/string-decorator-internal.data.d.ts +14 -1
- package/decorators/string/string-decorator.data.d.ts +37 -1
- package/decorators/string/string.decorator.d.ts +2 -2
- package/esm2020/capsulation/reflect.utilities.mjs +1 -1
- package/esm2020/classes/date.utilities.mjs +3 -3
- package/esm2020/classes/entity.model.mjs +1 -1
- package/esm2020/classes/entity.utilities.mjs +28 -6
- package/esm2020/classes/file.utilities.mjs +3 -2
- package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +6 -6
- package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +5 -5
- package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +6 -6
- package/esm2020/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +9 -25
- package/esm2020/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +9 -28
- package/esm2020/components/input/array/array-table.class.mjs +9 -12
- package/esm2020/components/input/base-input.component.mjs +28 -2
- package/esm2020/components/input/boolean/boolean-checkbox-input/boolean-checkbox-input.component.mjs +4 -6
- package/esm2020/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +3 -3
- package/esm2020/components/input/boolean/boolean-toggle-input/boolean-toggle-input.component.mjs +4 -6
- package/esm2020/components/input/custom/custom.component.mjs +2 -1
- package/esm2020/components/input/date/date-input/date-input.component.mjs +3 -4
- package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +6 -6
- package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +13 -13
- package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +4 -5
- package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +21 -16
- package/esm2020/components/input/file/file-input/file-input.component.mjs +7 -5
- package/esm2020/components/input/input.component.mjs +32 -27
- package/esm2020/components/input/input.module.mjs +14 -4
- package/esm2020/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +3 -3
- package/esm2020/components/input/number/number-input/number-input.component.mjs +3 -3
- package/esm2020/components/input/number/number-slider-input/number-slider-input.component.mjs +17 -0
- package/esm2020/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +5 -7
- package/esm2020/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +3 -3
- package/esm2020/components/input/string/string-input/string-input.component.mjs +3 -3
- package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +36 -0
- package/esm2020/components/input/string/string-textbox-input/string-textbox-input.component.mjs +3 -3
- package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +1 -1
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +4 -3
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +5 -4
- package/esm2020/components/table/table-data.builder.mjs +13 -10
- package/esm2020/components/table/table-data.mjs +1 -1
- package/esm2020/components/table/table.component.mjs +16 -14
- package/esm2020/decorators/base/base-property.decorator.mjs +1 -1
- package/esm2020/decorators/base/decorator-types.enum.mjs +3 -1
- package/esm2020/decorators/custom/custom-decorator.data.mjs +1 -1
- package/esm2020/decorators/number/number-decorator-internal.data.mjs +24 -1
- package/esm2020/decorators/number/number-decorator.data.mjs +1 -1
- package/esm2020/decorators/number/number.decorator.mjs +9 -7
- package/esm2020/decorators/string/string-decorator-internal.data.mjs +16 -1
- package/esm2020/decorators/string/string-decorator.data.mjs +1 -1
- package/esm2020/decorators/string/string.decorator.mjs +13 -13
- package/fesm2015/ngx-material-entity.mjs +330 -214
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +314 -206
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -31,15 +31,16 @@ export declare class BaseDataInternal<EntityType extends BaseEntityType<EntityTy
|
|
|
31
31
|
searchLabel: string;
|
|
32
32
|
createButtonLabel: string;
|
|
33
33
|
searchString: (entity: EntityType) => string;
|
|
34
|
-
allowCreate: boolean;
|
|
35
|
-
|
|
34
|
+
allowCreate: () => boolean;
|
|
35
|
+
allowRead: (entity: EntityType) => boolean;
|
|
36
|
+
allowUpdate: (entity: EntityType) => boolean;
|
|
36
37
|
allowDelete: (entity: EntityType) => boolean;
|
|
37
38
|
multiSelectActions: MultiSelectAction<EntityType>[];
|
|
38
39
|
multiSelectLabel: string;
|
|
39
40
|
EntityClass?: EntityClassNewable<EntityType>;
|
|
40
41
|
edit?: (entity: EntityType) => unknown;
|
|
41
42
|
create?: (entity: EntityType) => unknown;
|
|
42
|
-
constructor(title: string, displayColumns: DisplayColumn<EntityType>[], EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>, searchLabel: string, createButtonLabel: string, searchString: (entity: EntityType) => string, allowCreate: boolean,
|
|
43
|
+
constructor(title: string, displayColumns: DisplayColumn<EntityType>[], EntityServiceClass: new (httpClient: HttpClient) => EntityService<EntityType>, searchLabel: string, createButtonLabel: string, searchString: (entity: EntityType) => string, allowCreate: () => boolean, allowRead: (entity: EntityType) => boolean, allowUpdate: (entity: EntityType) => boolean, allowDelete: (entity: EntityType) => boolean, multiSelectActions: MultiSelectAction<EntityType>[], multiSelectLabel: string, EntityClass?: EntityClassNewable<EntityType>, edit?: (entity: EntityType) => unknown, create?: (entity: EntityType) => unknown);
|
|
43
44
|
}
|
|
44
45
|
/**
|
|
45
46
|
* The Builder for the complete TableData. Sets default values and validates user input.
|
|
@@ -93,17 +93,25 @@ export interface BaseData<EntityType extends BaseEntityType<EntityType>> {
|
|
|
93
93
|
/**
|
|
94
94
|
* Defines whether or not the user can add new entities.
|
|
95
95
|
*
|
|
96
|
-
* @default true
|
|
96
|
+
* @default () => true
|
|
97
|
+
*/
|
|
98
|
+
allowCreate?: () => boolean;
|
|
99
|
+
/**
|
|
100
|
+
* Defines whether or not the user can view the specific entity.
|
|
101
|
+
*
|
|
102
|
+
* @default () => true
|
|
97
103
|
*/
|
|
98
|
-
|
|
104
|
+
allowRead?: (entity: EntityType) => boolean;
|
|
99
105
|
/**
|
|
100
|
-
* Defines whether or not the user can edit
|
|
106
|
+
* Defines whether or not the user can edit the specific entity.
|
|
101
107
|
*
|
|
102
108
|
* @default () => true
|
|
103
109
|
*/
|
|
104
|
-
|
|
110
|
+
allowUpdate?: (entity: EntityType) => boolean;
|
|
105
111
|
/**
|
|
106
112
|
* Whether or not the user can delete this specific entity.
|
|
113
|
+
*
|
|
114
|
+
* @default () => true
|
|
107
115
|
*/
|
|
108
116
|
allowDelete?: (entity: EntityType) => boolean;
|
|
109
117
|
/**
|
|
@@ -3,9 +3,9 @@ import { CheckboxBooleanDecoratorConfigInternal, DropdownBooleanDecoratorConfigI
|
|
|
3
3
|
import { CustomDecoratorConfigInternal } from '../custom/custom-decorator-internal.data';
|
|
4
4
|
import { DateRangeDateDecoratorConfigInternal, DateTimeDateDecoratorConfigInternal, DefaultDateDecoratorConfigInternal } from '../date/date-decorator-internal.data';
|
|
5
5
|
import { DefaultFileDecoratorConfigInternal, ImageFileDecoratorConfigInternal } from '../file/file-decorator-internal.data';
|
|
6
|
-
import { DefaultNumberDecoratorConfigInternal, DropdownNumberDecoratorConfigInternal } from '../number/number-decorator-internal.data';
|
|
6
|
+
import { DefaultNumberDecoratorConfigInternal, DropdownNumberDecoratorConfigInternal, SliderNumberDecoratorConfigInternal } from '../number/number-decorator-internal.data';
|
|
7
7
|
import { DefaultObjectDecoratorConfigInternal } from '../object/object-decorator-internal.data';
|
|
8
|
-
import { AutocompleteStringDecoratorConfigInternal, DefaultStringDecoratorConfigInternal, DropdownStringDecoratorConfigInternal, TextboxStringDecoratorConfigInternal } from '../string/string-decorator-internal.data';
|
|
8
|
+
import { AutocompleteStringDecoratorConfigInternal, DefaultStringDecoratorConfigInternal, DropdownStringDecoratorConfigInternal, PasswordStringDecoratorConfigInternal, TextboxStringDecoratorConfigInternal } from '../string/string-decorator-internal.data';
|
|
9
9
|
/**
|
|
10
10
|
* The enum Values for all the different DecoratorTypes.
|
|
11
11
|
*/
|
|
@@ -14,8 +14,10 @@ export declare enum DecoratorTypes {
|
|
|
14
14
|
STRING_DROPDOWN = "stringDropdown",
|
|
15
15
|
STRING_AUTOCOMPLETE = "stringAutocomplete",
|
|
16
16
|
STRING_TEXTBOX = "stringTextbox",
|
|
17
|
+
STRING_PASSWORD = "stringPassword",
|
|
17
18
|
NUMBER = "number",
|
|
18
19
|
NUMBER_DROPDOWN = "numberDropdown",
|
|
20
|
+
NUMBER_SLIDER = "numberSlider",
|
|
19
21
|
BOOLEAN_CHECKBOX = "boolean",
|
|
20
22
|
BOOLEAN_TOGGLE = "booleanToggle",
|
|
21
23
|
BOOLEAN_DROPDOWN = "booleanDropdown",
|
|
@@ -36,4 +38,4 @@ export declare enum DecoratorTypes {
|
|
|
36
38
|
/**
|
|
37
39
|
* Gives the metadata-config Type based on the DecoratorTypes enum.
|
|
38
40
|
*/
|
|
39
|
-
export declare type DecoratorType<T, CustomMetadataType extends Record<string, unknown>> = T extends DecoratorTypes.STRING ? DefaultStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_TEXTBOX ? TextboxStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_DROPDOWN ? DropdownStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_AUTOCOMPLETE ? AutocompleteStringDecoratorConfigInternal : T extends DecoratorTypes.NUMBER ? DefaultNumberDecoratorConfigInternal : T extends DecoratorTypes.NUMBER_DROPDOWN ? DropdownNumberDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_CHECKBOX ? CheckboxBooleanDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_TOGGLE ? ToggleBooleanDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_DROPDOWN ? DropdownBooleanDecoratorConfigInternal : T extends DecoratorTypes.OBJECT ? DefaultObjectDecoratorConfigInternal<any> : T extends DecoratorTypes.ARRAY ? EntityArrayDecoratorConfigInternal<any> : T extends DecoratorTypes.ARRAY_DATE ? DateArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_DATE_TIME ? DateTimeArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_DATE_RANGE ? DateRangeArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_STRING_CHIPS ? StringChipsArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS ? AutocompleteStringChipsArrayDecoratorConfigInternal : T extends DecoratorTypes.DATE ? DefaultDateDecoratorConfigInternal : T extends DecoratorTypes.DATE_RANGE ? DateRangeDateDecoratorConfigInternal : T extends DecoratorTypes.DATE_TIME ? DateTimeDateDecoratorConfigInternal : T extends DecoratorTypes.FILE_DEFAULT ? DefaultFileDecoratorConfigInternal : T extends DecoratorTypes.FILE_IMAGE ? ImageFileDecoratorConfigInternal : T extends DecoratorTypes.CUSTOM ? CustomDecoratorConfigInternal<any, any, CustomMetadataType, any> : never;
|
|
41
|
+
export declare type DecoratorType<T, CustomMetadataType extends Record<string, unknown>> = T extends DecoratorTypes.STRING ? DefaultStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_TEXTBOX ? TextboxStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_DROPDOWN ? DropdownStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_AUTOCOMPLETE ? AutocompleteStringDecoratorConfigInternal : T extends DecoratorTypes.STRING_PASSWORD ? PasswordStringDecoratorConfigInternal : T extends DecoratorTypes.NUMBER ? DefaultNumberDecoratorConfigInternal : T extends DecoratorTypes.NUMBER_DROPDOWN ? DropdownNumberDecoratorConfigInternal : T extends DecoratorTypes.NUMBER_SLIDER ? SliderNumberDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_CHECKBOX ? CheckboxBooleanDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_TOGGLE ? ToggleBooleanDecoratorConfigInternal : T extends DecoratorTypes.BOOLEAN_DROPDOWN ? DropdownBooleanDecoratorConfigInternal : T extends DecoratorTypes.OBJECT ? DefaultObjectDecoratorConfigInternal<any> : T extends DecoratorTypes.ARRAY ? EntityArrayDecoratorConfigInternal<any> : T extends DecoratorTypes.ARRAY_DATE ? DateArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_DATE_TIME ? DateTimeArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_DATE_RANGE ? DateRangeArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_STRING_CHIPS ? StringChipsArrayDecoratorConfigInternal : T extends DecoratorTypes.ARRAY_STRING_AUTOCOMPLETE_CHIPS ? AutocompleteStringChipsArrayDecoratorConfigInternal : T extends DecoratorTypes.DATE ? DefaultDateDecoratorConfigInternal : T extends DecoratorTypes.DATE_RANGE ? DateRangeDateDecoratorConfigInternal : T extends DecoratorTypes.DATE_TIME ? DateTimeDateDecoratorConfigInternal : T extends DecoratorTypes.FILE_DEFAULT ? DefaultFileDecoratorConfigInternal : T extends DecoratorTypes.FILE_IMAGE ? ImageFileDecoratorConfigInternal : T extends DecoratorTypes.CUSTOM ? CustomDecoratorConfigInternal<any, any, CustomMetadataType, any> : never;
|
|
@@ -16,6 +16,8 @@ export interface CustomDecoratorConfig<EntityType extends BaseEntityType<EntityT
|
|
|
16
16
|
* Used in addition to default checks like required etc.
|
|
17
17
|
* Needed for the edit and create dialogs.
|
|
18
18
|
*
|
|
19
|
+
* TIP: If you need additional data for checking if the value is valid, you can define them as metadata directly on the value.
|
|
20
|
+
*
|
|
19
21
|
* @default () => true
|
|
20
22
|
*/
|
|
21
23
|
isValid?: (value: ValueType, omit: 'create' | 'update') => boolean;
|
|
@@ -23,6 +25,8 @@ export interface CustomDecoratorConfig<EntityType extends BaseEntityType<EntityT
|
|
|
23
25
|
* The function that defines whether or not two of your custom values are equal.
|
|
24
26
|
* Needed for the edit and create dialogs.
|
|
25
27
|
*
|
|
28
|
+
* TIP: If you need additional data for checking if the value is valid, you can define them as metadata directly on the values.
|
|
29
|
+
*
|
|
26
30
|
* @default (value: ValueType, valuePriorChanges: ValueType) => LodashUtilities.isEqual(value, valuePriorChanges)
|
|
27
31
|
*/
|
|
28
32
|
isEqual?: (value: ValueType, valuePriorChanges: ValueType, metadata: CustomDecoratorConfig<EntityType, ValueType, MetadataType, ComponentType>) => boolean;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DropdownValue } from '../base/dropdown-value.interface';
|
|
2
2
|
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
3
|
-
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig } from './number-decorator.data';
|
|
3
|
+
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig, SliderNumberDecoratorConfig } from './number-decorator.data';
|
|
4
4
|
/**
|
|
5
5
|
* The internal DefaultNumberDecoratorConfig. Sets default values.
|
|
6
6
|
*/
|
|
@@ -18,3 +18,22 @@ export declare class DropdownNumberDecoratorConfigInternal extends PropertyDecor
|
|
|
18
18
|
dropdownValues: DropdownValue<number>[];
|
|
19
19
|
constructor(data: DropdownNumberDecoratorConfig);
|
|
20
20
|
}
|
|
21
|
+
/**
|
|
22
|
+
* The internal SliderNumberDecoratorConfig. Sets default values.
|
|
23
|
+
*/
|
|
24
|
+
export declare class SliderNumberDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements SliderNumberDecoratorConfig {
|
|
25
|
+
displayStyle: 'slider';
|
|
26
|
+
min?: number;
|
|
27
|
+
max?: number;
|
|
28
|
+
step?: number;
|
|
29
|
+
formatThumbLabelValue: (value: number) => string | number;
|
|
30
|
+
tickInterval?: number | 'auto';
|
|
31
|
+
constructor(data: SliderNumberDecoratorConfig);
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* The default function to format values for the number slider thumb label.
|
|
35
|
+
*
|
|
36
|
+
* @param value - The value of the slider.
|
|
37
|
+
* @returns Just the value without any formatting done.
|
|
38
|
+
*/
|
|
39
|
+
export declare function defaultFormatThumbLabelValue(value: number): number;
|
|
@@ -7,7 +7,7 @@ declare abstract class NumberDecoratorConfig extends PropertyDecoratorConfig {
|
|
|
7
7
|
/**
|
|
8
8
|
* Whether to display the number in a single line or as a dropdown.
|
|
9
9
|
*/
|
|
10
|
-
displayStyle: 'line' | 'dropdown';
|
|
10
|
+
displayStyle: 'line' | 'dropdown' | 'slider';
|
|
11
11
|
}
|
|
12
12
|
/**
|
|
13
13
|
* The configuration options for a number property displayed in a default number input.
|
|
@@ -33,4 +33,30 @@ export interface DropdownNumberDecoratorConfig extends NumberDecoratorConfig {
|
|
|
33
33
|
*/
|
|
34
34
|
dropdownValues: DropdownValue<number>[];
|
|
35
35
|
}
|
|
36
|
+
/**
|
|
37
|
+
* The configuration options for a number property displayed as a slider input.
|
|
38
|
+
*/
|
|
39
|
+
export interface SliderNumberDecoratorConfig extends NumberDecoratorConfig {
|
|
40
|
+
displayStyle: 'slider';
|
|
41
|
+
/**
|
|
42
|
+
* The minimum value of the number.
|
|
43
|
+
*/
|
|
44
|
+
min?: number;
|
|
45
|
+
/**
|
|
46
|
+
* The maximum value of the number.
|
|
47
|
+
*/
|
|
48
|
+
max?: number;
|
|
49
|
+
/**
|
|
50
|
+
* How big a single step is at which the thumb label will snap.
|
|
51
|
+
*/
|
|
52
|
+
step?: number;
|
|
53
|
+
/**
|
|
54
|
+
* Function that transforms the value to display inside the thumb label.
|
|
55
|
+
*/
|
|
56
|
+
formatThumbLabelValue?: (value: number) => string | number;
|
|
57
|
+
/**
|
|
58
|
+
* How often ticks should be displayed.
|
|
59
|
+
*/
|
|
60
|
+
tickInterval?: 'auto' | number;
|
|
61
|
+
}
|
|
36
62
|
export {};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig } from './number-decorator.data';
|
|
1
|
+
import { DefaultNumberDecoratorConfig, DropdownNumberDecoratorConfig, SliderNumberDecoratorConfig } from './number-decorator.data';
|
|
2
2
|
/**
|
|
3
3
|
* Decorator for setting and getting number property metadata.
|
|
4
4
|
*
|
|
5
5
|
* @param metadata - The metadata of the number property.
|
|
6
6
|
* @returns The method that defines the metadata.
|
|
7
7
|
*/
|
|
8
|
-
export declare function number(metadata: DefaultNumberDecoratorConfig | DropdownNumberDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
8
|
+
export declare function number(metadata: DefaultNumberDecoratorConfig | DropdownNumberDecoratorConfig | SliderNumberDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DropdownValue } from '../base/dropdown-value.interface';
|
|
2
2
|
import { PropertyDecoratorConfigInternal } from '../base/property-decorator-internal.data';
|
|
3
|
-
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
3
|
+
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, PasswordStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
4
4
|
/**
|
|
5
5
|
* The internal DropdownStringDecoratorConfig. Sets default values.
|
|
6
6
|
*/
|
|
@@ -39,3 +39,16 @@ export declare class AutocompleteStringDecoratorConfigInternal extends PropertyD
|
|
|
39
39
|
regex?: RegExp;
|
|
40
40
|
constructor(data: AutocompleteStringDecoratorConfig);
|
|
41
41
|
}
|
|
42
|
+
/**
|
|
43
|
+
* The internal PasswordStringDecoratorConfig. Sets default values.
|
|
44
|
+
*/
|
|
45
|
+
export declare class PasswordStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements PasswordStringDecoratorConfig {
|
|
46
|
+
displayStyle: 'password';
|
|
47
|
+
minLength?: number;
|
|
48
|
+
maxLength?: number;
|
|
49
|
+
regex?: RegExp;
|
|
50
|
+
needsConfirmation: boolean;
|
|
51
|
+
confirmationDisplayName: string;
|
|
52
|
+
passwordsDontMatchErrorMessage: string;
|
|
53
|
+
constructor(data: PasswordStringDecoratorConfig);
|
|
54
|
+
}
|
|
@@ -7,7 +7,7 @@ declare abstract class StringDecoratorConfig extends PropertyDecoratorConfig {
|
|
|
7
7
|
/**
|
|
8
8
|
* How to display the string.
|
|
9
9
|
*/
|
|
10
|
-
displayStyle: 'line' | 'textbox' | 'autocomplete' | 'dropdown';
|
|
10
|
+
displayStyle: 'line' | 'textbox' | 'autocomplete' | 'dropdown' | 'password';
|
|
11
11
|
}
|
|
12
12
|
/**
|
|
13
13
|
* The configuration options for a string property displayed as a dropdown.
|
|
@@ -74,4 +74,40 @@ export interface AutocompleteStringDecoratorConfig extends StringDecoratorConfig
|
|
|
74
74
|
*/
|
|
75
75
|
regex?: RegExp;
|
|
76
76
|
}
|
|
77
|
+
/**
|
|
78
|
+
* The configuration options for a string property displayed in a password input.
|
|
79
|
+
*/
|
|
80
|
+
export interface PasswordStringDecoratorConfig extends StringDecoratorConfig {
|
|
81
|
+
displayStyle: 'password';
|
|
82
|
+
/**
|
|
83
|
+
* The minimum required length of the password.
|
|
84
|
+
*/
|
|
85
|
+
minLength?: number;
|
|
86
|
+
/**
|
|
87
|
+
* The maximum required length of the password.
|
|
88
|
+
*/
|
|
89
|
+
maxLength?: number;
|
|
90
|
+
/**
|
|
91
|
+
* A regex used for validation.
|
|
92
|
+
*/
|
|
93
|
+
regex?: RegExp;
|
|
94
|
+
/**
|
|
95
|
+
* Whether or not the password needs to be retyped.
|
|
96
|
+
*
|
|
97
|
+
* @default true
|
|
98
|
+
*/
|
|
99
|
+
needsConfirmation?: boolean;
|
|
100
|
+
/**
|
|
101
|
+
* The display name of the confirmation password input.
|
|
102
|
+
*
|
|
103
|
+
* @default 'Confirm Password'
|
|
104
|
+
*/
|
|
105
|
+
confirmationDisplayName?: string;
|
|
106
|
+
/**
|
|
107
|
+
* The error message to display when the password and the confirm password don't match.
|
|
108
|
+
*
|
|
109
|
+
* @default 'Passwords need to match!'
|
|
110
|
+
*/
|
|
111
|
+
passwordsDontMatchErrorMessage?: string;
|
|
112
|
+
}
|
|
77
113
|
export {};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
1
|
+
import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, DropdownStringDecoratorConfig, PasswordStringDecoratorConfig, TextboxStringDecoratorConfig } from './string-decorator.data';
|
|
2
2
|
/**
|
|
3
3
|
* Decorator for setting and getting string Property metadata.
|
|
4
4
|
*
|
|
5
5
|
* @param metadata - The metadata of the string property.
|
|
6
6
|
* @returns The method that defines the metadata.
|
|
7
7
|
*/
|
|
8
|
-
export declare function string(metadata: DropdownStringDecoratorConfig | AutocompleteStringDecoratorConfig | DefaultStringDecoratorConfig | TextboxStringDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
8
|
+
export declare function string(metadata: DropdownStringDecoratorConfig | AutocompleteStringDecoratorConfig | DefaultStringDecoratorConfig | TextboxStringDecoratorConfig | PasswordStringDecoratorConfig): (target: object, propertyKey: string) => void;
|
|
@@ -66,4 +66,4 @@ export class ReflectUtilities {
|
|
|
66
66
|
Reflect.defineMetadata(metadataKey, metadataValue, target, propertyKey);
|
|
67
67
|
}
|
|
68
68
|
}
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVmbGVjdC51dGlsaXRpZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtbWF0ZXJpYWwtZW50aXR5L3NyYy9jYXBzdWxhdGlvbi9yZWZsZWN0LnV0aWxpdGllcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQTs7R0FFRztBQUNILE1BQU0sT0FBZ0IsZ0JBQWdCO0lBQ2xDOzs7Ozs7O09BT0c7SUFDSCxNQUFNLENBQUMsV0FBVyxDQUFtQixXQUFtQixFQUFFLE1BQVMsRUFBRSxXQUFvQjtRQUNyRixPQUFPLE9BQU8sQ0FBQyxXQUFXLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxXQUFxQixDQUFDLENBQUM7SUFDM0UsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILE1BQU0sQ0FBQyxPQUFPLENBQW1CLE1BQVM7UUFDdEMsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBZ0IsQ0FBQztJQUNsRCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsTUFBTSxDQUFDLEdBQUcsQ0FBbUIsTUFBUyxFQUFFLFdBQW9CO1FBQ3hELE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxNQUFNLENBQUMsR0FBRyxDQUFtQixNQUFTLEVBQUUsV0FBb0IsRUFBRSxLQUFjO1FBQ3hFLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRDs7Ozs7O09BTUc7SUFDSCxNQUFNLENBQUMsR0FBRyxDQUFtQixNQUFTLEVBQUUsV0FBb0I7UUFDeEQsT0FBTyxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQ7Ozs7Ozs7T0FPRztJQUNILE1BQU0sQ0FBQyxjQUFjLENBQ2pCLFdBQW9CLEVBQ3BCLGFBQXNCLEVBQ3RCLE1BQVMsRUFDVCxXQUFvQjtRQUVwQixPQUFPLENBQUMsY0FBYyxDQUFDLFdBQVcsRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLFdBQXFCLENBQUMsQ0FBQztJQUN0RixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8qKlxuICogRW5jYXBzdWxhdGVzIGFsbCBmdW5jdGlvbmFsaXR5IG9mIFJlZmxlY3QuXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBSZWZsZWN0VXRpbGl0aWVzIHtcbiAgICAvKipcbiAgICAgKiBHZXRzIHRoZSBtZXRhZGF0YSB2YWx1ZSBmb3IgdGhlIHByb3ZpZGVkIG1ldGFkYXRhIGtleSBvbiB0aGUgdGFyZ2V0IG9iamVjdCBvciBpdHMgcHJvdG90eXBlIGNoYWluLlxuICAgICAqXG4gICAgICogQHBhcmFtIG1ldGFkYXRhS2V5IC0gQSBrZXkgdXNlZCB0byBzdG9yZSBhbmQgcmV0cmlldmUgbWV0YWRhdGEuXG4gICAgICogQHBhcmFtIHRhcmdldCAtIFRoZSB0YXJnZXQgb2JqZWN0IG9uIHdoaWNoIHRoZSBtZXRhZGF0YSBpcyBkZWZpbmVkLlxuICAgICAqIEBwYXJhbSBwcm9wZXJ0eUtleSAtIFRoZSBwcm9wZXJ0eSBrZXkgZm9yIHRoZSB0YXJnZXQuXG4gICAgICogQHJldHVybnMgVGhlIG1ldGFkYXRhIHZhbHVlIGZvciB0aGUgbWV0YWRhdGEga2V5IGlmIGZvdW5kOyBvdGhlcndpc2UsIHVuZGVmaW5lZC5cbiAgICAgKi9cbiAgICBzdGF0aWMgZ2V0TWV0YWRhdGE8VCBleHRlbmRzIG9iamVjdD4obWV0YWRhdGFLZXk6IHN0cmluZywgdGFyZ2V0OiBULCBwcm9wZXJ0eUtleToga2V5b2YgVCk6IHVua25vd24ge1xuICAgICAgICByZXR1cm4gUmVmbGVjdC5nZXRNZXRhZGF0YShtZXRhZGF0YUtleSwgdGFyZ2V0LCBwcm9wZXJ0eUtleSBhcyBzdHJpbmcpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgdGhlIHN0cmluZyBhbmQgc3ltYm9sIGtleXMgb2YgdGhlIG93biBwcm9wZXJ0aWVzIG9mIGFuIG9iamVjdC4gVGhlIG93biBwcm9wZXJ0aWVzIG9mIGFuIG9iamVjdFxuICAgICAqIGFyZSB0aG9zZSB0aGF0IGFyZSBkZWZpbmVkIGRpcmVjdGx5IG9uIHRoYXQgb2JqZWN0LCBhbmQgYXJlIG5vdCBpbmhlcml0ZWQgZnJvbSB0aGUgb2JqZWN0J3MgcHJvdG90eXBlLlxuICAgICAqXG4gICAgICogQHBhcmFtIHRhcmdldCAtIE9iamVjdCB0aGF0IGNvbnRhaW5zIHRoZSBvd24gcHJvcGVydGllcy5cbiAgICAgKiBAcmV0dXJucyBUaGUga2V5cyBvZiB0aGUgZ2l2ZW4gb2JqZWN0LlxuICAgICAqL1xuICAgIHN0YXRpYyBvd25LZXlzPFQgZXh0ZW5kcyBvYmplY3Q+KHRhcmdldDogVCk6IChrZXlvZiBUKVtdIHtcbiAgICAgICAgcmV0dXJuIFJlZmxlY3Qub3duS2V5cyh0YXJnZXQpIGFzIChrZXlvZiBUKVtdO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldHMgdGhlIHByb3BlcnR5IG9mIHRhcmdldCwgZXF1aXZhbGVudCB0byBgdGFyZ2V0W3Byb3BlcnR5S2V5XWAuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gdGFyZ2V0IC0gT2JqZWN0IHRoYXQgY29udGFpbnMgdGhlIHByb3BlcnR5IG9uIGl0c2VsZiBvciBpbiBpdHMgcHJvdG90eXBlIGNoYWluLlxuICAgICAqIEBwYXJhbSBwcm9wZXJ0eUtleSAtIFRoZSBwcm9wZXJ0eSBuYW1lLlxuICAgICAqIEByZXR1cm5zIFRoZSBwcm9wZXJ0eSBvZiB0aGUgdGFyZ2V0IG9mIHRoZSBnaXZlbiBrZXkuXG4gICAgICovXG4gICAgc3RhdGljIGdldDxUIGV4dGVuZHMgb2JqZWN0Pih0YXJnZXQ6IFQsIHByb3BlcnR5S2V5OiBrZXlvZiBUKTogdW5rbm93biB7XG4gICAgICAgIHJldHVybiBSZWZsZWN0LmdldCh0YXJnZXQsIHByb3BlcnR5S2V5KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBTZXRzIHRoZSBwcm9wZXJ0eSBvZiB0YXJnZXQsIGVxdWl2YWxlbnQgdG8gYHRhcmdldFtwcm9wZXJ0eUtleV0gPSB2YWx1ZWAuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gdGFyZ2V0IC0gT2JqZWN0IHRoYXQgY29udGFpbnMgdGhlIHByb3BlcnR5IG9uIGl0c2VsZiBvciBpbiBpdHMgcHJvdG90eXBlIGNoYWluLlxuICAgICAqIEBwYXJhbSBwcm9wZXJ0eUtleSAtIFRoZSBwcm9wZXJ0eSBuYW1lLlxuICAgICAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBzZXQgdGhlIHByb3BlcnR5IHRvLlxuICAgICAqIEByZXR1cm5zIElmIHNldHRpbmcgdGhlIHZhbHVlIHdhcyBzdWNjZXNzZnVsLlxuICAgICAqL1xuICAgIHN0YXRpYyBzZXQ8VCBleHRlbmRzIG9iamVjdD4odGFyZ2V0OiBULCBwcm9wZXJ0eUtleToga2V5b2YgVCwgdmFsdWU6IHVua25vd24pOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIFJlZmxlY3Quc2V0KHRhcmdldCwgcHJvcGVydHlLZXksIHZhbHVlKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBFcXVpdmFsZW50IHRvIGBwcm9wZXJ0eUtleSBpbiB0YXJnZXRgLlxuICAgICAqXG4gICAgICogQHBhcmFtIHRhcmdldCAtIE9iamVjdCB0aGF0IGNvbnRhaW5zIHRoZSBwcm9wZXJ0eSBvbiBpdHNlbGYgb3IgaW4gaXRzIHByb3RvdHlwZSBjaGFpbi5cbiAgICAgKiBAcGFyYW0gcHJvcGVydHlLZXkgLSBOYW1lIG9mIHRoZSBwcm9wZXJ0eS5cbiAgICAgKiBAcmV0dXJucyBXaGV0aGVyIG9yIG5vdCB0aGUgZ2l2ZW4gdGFyZ2V0IGhhcyB0aGUga2V5LlxuICAgICAqL1xuICAgIHN0YXRpYyBoYXM8VCBleHRlbmRzIG9iamVjdD4odGFyZ2V0OiBULCBwcm9wZXJ0eUtleToga2V5b2YgVCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gUmVmbGVjdC5oYXModGFyZ2V0LCBwcm9wZXJ0eUtleSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogRGVmaW5lIGEgdW5pcXVlIG1ldGFkYXRhIGVudHJ5IG9uIHRoZSB0YXJnZXQuXG4gICAgICpcbiAgICAgKiBAcGFyYW0gbWV0YWRhdGFLZXkgLSBBIGtleSB1c2VkIHRvIHN0b3JlIGFuZCByZXRyaWV2ZSBtZXRhZGF0YS5cbiAgICAgKiBAcGFyYW0gbWV0YWRhdGFWYWx1ZSAtIEEgdmFsdWUgdGhhdCBjb250YWlucyBhdHRhY2hlZCBtZXRhZGF0YS5cbiAgICAgKiBAcGFyYW0gdGFyZ2V0IC0gVGhlIHRhcmdldCBvYmplY3Qgb24gd2hpY2ggdG8gZGVmaW5lIG1ldGFkYXRhLlxuICAgICAqIEBwYXJhbSBwcm9wZXJ0eUtleSAtIFRoZSBwcm9wZXJ0eSBrZXkgZm9yIHRoZSB0YXJnZXQuXG4gICAgICovXG4gICAgc3RhdGljIGRlZmluZU1ldGFkYXRhPFQgZXh0ZW5kcyBvYmplY3Q+KFxuICAgICAgICBtZXRhZGF0YUtleTogdW5rbm93bixcbiAgICAgICAgbWV0YWRhdGFWYWx1ZTogdW5rbm93bixcbiAgICAgICAgdGFyZ2V0OiBULFxuICAgICAgICBwcm9wZXJ0eUtleToga2V5b2YgVFxuICAgICk6IHZvaWQge1xuICAgICAgICBSZWZsZWN0LmRlZmluZU1ldGFkYXRhKG1ldGFkYXRhS2V5LCBtZXRhZGF0YVZhbHVlLCB0YXJnZXQsIHByb3BlcnR5S2V5IGFzIHN0cmluZyk7XG4gICAgfVxufSJdfQ==
|
|
@@ -104,14 +104,14 @@ export class DateUtilities {
|
|
|
104
104
|
/**
|
|
105
105
|
* Get all valid times for the dropdown of a datetime property.
|
|
106
106
|
*
|
|
107
|
-
* @param date - The date of the datetime.
|
|
108
107
|
* @param times - All given times to filter.
|
|
108
|
+
* @param date - The date of the datetime.
|
|
109
109
|
* @param min - The function that defines the minimum time.
|
|
110
110
|
* @param max - The function that defines the maximum time.
|
|
111
111
|
* @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.
|
|
112
112
|
* @returns All valid dropdown values for the datetime property.
|
|
113
113
|
*/
|
|
114
|
-
static getValidTimesForDropdown(
|
|
114
|
+
static getValidTimesForDropdown(times, date, min, max, filter) {
|
|
115
115
|
if (min) {
|
|
116
116
|
const minTime = min(date);
|
|
117
117
|
times = times.filter(t => !t.value
|
|
@@ -155,4 +155,4 @@ export class DateUtilities {
|
|
|
155
155
|
* The default filter function to user when none was provided by the user.
|
|
156
156
|
*/
|
|
157
157
|
DateUtilities.defaultDateFilter = () => true;
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/classes/date.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { Time } from '@angular/common';\nimport { DateFilterFn } from '@angular/material/datepicker';\nimport { LodashUtilities } from '../capsulation/lodash.utilities';\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\n\nconst DAY_IN_MS = 1000 * 60 * 60 * 24;\n\n/**\n * Valid steps from one time value to the next. Needs to be able to divide 60 minutes without remainder.\n */\ntype MinuteSteps = 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30 | 60;\n\n/**\n * Contains Helper Functions for handling date properties.\n */\nexport abstract class DateUtilities {\n\n    /**\n     * The default filter function to user when none was provided by the user.\n     */\n    static defaultDateFilter: DateFilterFn<Date | null | undefined> = (): boolean => true;\n\n    /**\n     * Gets the given value as a date value.\n     *\n     * @param value - The value to get as a date.\n     * @returns The given value as a date.\n     */\n    static asDate(value: unknown): Date {\n        return value as Date;\n    }\n\n    /**\n     * Gets the default times used by the DateTime picker when nothing is specified by the user.\n     *\n     * @param format - The time format. Defaults to 24.\n     * @param minuteSteps - The steps from one time value to the next. Defaults to 30.\n     * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.\n     */\n    static getDefaultTimes(format: 12 | 24 = 24, minuteSteps: MinuteSteps = 30): DropdownValue<Time>[] {\n        const res: DropdownValue<Time>[] = [{ displayName: '-', value: undefined as unknown as Time}];\n        for (let hour = 0; hour < 24; hour++) {\n            for (let minute = 0; minute < 60; minute += minuteSteps) {\n                res.push(DateUtilities.getTimeDropdownValue(format, hour, minute));\n            }\n        }\n        return res;\n    }\n\n    private static getTimeDropdownValue(format: 12 | 24, hour: number, minute: number): DropdownValue<Time> {\n        const displayHour: number = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));\n        const displayMinute: string = DateUtilities.getFormattedMinute(format, hour, minute);\n        return {\n            displayName: `${displayHour}:${displayMinute}`,\n            value: {\n                hours: hour,\n                minutes: minute\n            }\n        };\n    }\n\n    private static getFormattedHour(format: 12 | 24, hour: number): number {\n        if (format === 12 && hour > 12) {\n            hour -= 12;\n        }\n        return hour;\n    }\n\n    private static getFormattedMinute(format: 12 | 24, hour: number, minute: number): string {\n        let res = `${minute}`;\n        if (format === 12) {\n            if (hour > 12) {\n                res = `${minute} PM`;\n            }\n            else {\n                res = `${minute} AM`;\n            }\n        }\n        if (minute.toString().length === 1) {\n            res = '0'.concat(res);\n        }\n        return res;\n    }\n\n    /**\n     * Gets the Time object from the given date.\n     *\n     * @param value - The date to get the time object from.\n     * @returns The Time object build from the date value.\n     */\n    static getTimeFromDate(value: Date): Time | undefined {\n        if (!(value as Date | undefined)) {\n            return undefined;\n        }\n        else {\n            return {\n                hours: new Date(value).getHours(),\n                minutes: new Date(value).getMinutes()\n            };\n        }\n    }\n\n    /**\n     * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.\n     *\n     * @param startDate - The start date.\n     * @param endDate - The end date.\n     * @param filter - The custom filter from the metadata.\n     * @returns All dates between the two provided dates. Includes start and end date.\n     */\n    static getDatesBetween(\n        startDate: Date,\n        endDate: Date,\n        filter?: DateFilterFn<Date>\n    ): Date[] {\n        const res: Date[] = [];\n        while (\n            startDate.getFullYear() < endDate.getFullYear()\n            || startDate.getMonth() < endDate.getMonth()\n            || startDate.getDate() <= endDate.getDate()\n        ) {\n            res.push(new Date(startDate));\n            startDate.setTime(startDate.getTime() + DAY_IN_MS);\n        }\n        if (filter) {\n            return res.filter(d => filter(d));\n        }\n        else {\n            return res;\n        }\n    }\n\n    /**\n     * Get all valid times for the dropdown of a datetime property.\n     *\n     * @param date - The date of the datetime.\n     * @param times - All given times to filter.\n     * @param min - The function that defines the minimum time.\n     * @param max - The function that defines the maximum time.\n     * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.\n     * @returns All valid dropdown values for the datetime property.\n     */\n    static getValidTimesForDropdown(\n        date: Date,\n        times: DropdownValue<Time>[],\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t =>\n                !(t.value as Time | undefined)\n                || t.value.hours > minTime.hours\n                || (\n                    t.value.hours === minTime.hours\n                    && t.value.minutes >= minTime.minutes\n                )\n            );\n        }\n        if (max) {\n            const maxTime: Time = max(date);\n            times = times.filter(t =>\n                !(t.value as Time | undefined)\n                || t.value.hours < maxTime.hours\n                || (\n                    t.value.hours === maxTime.hours\n                    && t.value.minutes <= maxTime.minutes\n                )\n            );\n        }\n        if (filter) {\n            times = times.filter(t => !(t.value as Time | undefined) || filter(t.value));\n        }\n\n        return times;\n    }\n\n    /**\n     * Checks if the time object has processable hours and minutes properties.\n     * Doesn't check custom validators like min/max from the metadata configuration.\n     *\n     * @param time - The time to check.\n     * @returns Whether or not the time object is unprocessable.\n     */\n    static timeIsUnprocessable(time?: Time): boolean {\n        if (\n            !time\n            || time.hours == null\n            || typeof time.hours !== 'number'\n            || Number.isNaN(time.hours)\n            || time.minutes == null\n            || typeof time.minutes !== 'number'\n            || Number.isNaN(time.minutes)\n        ) {\n            return true;\n        }\n        return false;\n    }\n}"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/classes/date.utilities.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAGlE,MAAM,SAAS,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAOtC;;GAEG;AACH,MAAM,OAAgB,aAAa;IAO/B;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAc;QACxB,OAAO,KAAa,CAAC;IACzB,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,eAAe,CAAC,SAAkB,EAAE,EAAE,cAA2B,EAAE;QACtE,MAAM,GAAG,GAA0B,CAAC,EAAE,WAAW,EAAE,GAAG,EAAE,KAAK,EAAE,SAA4B,EAAC,CAAC,CAAC;QAC9F,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,EAAE,EAAE,IAAI,EAAE,EAAE;YAClC,KAAK,IAAI,MAAM,GAAG,CAAC,EAAE,MAAM,GAAG,EAAE,EAAE,MAAM,IAAI,WAAW,EAAE;gBACrD,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;aACtE;SACJ;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAEO,MAAM,CAAC,oBAAoB,CAAC,MAAe,EAAE,IAAY,EAAE,MAAc;QAC7E,MAAM,WAAW,GAAW,aAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QACpG,MAAM,aAAa,GAAW,aAAa,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QACrF,OAAO;YACH,WAAW,EAAE,GAAG,WAAW,IAAI,aAAa,EAAE;YAC9C,KAAK,EAAE;gBACH,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE,MAAM;aAClB;SACJ,CAAC;IACN,CAAC;IAEO,MAAM,CAAC,gBAAgB,CAAC,MAAe,EAAE,IAAY;QACzD,IAAI,MAAM,KAAK,EAAE,IAAI,IAAI,GAAG,EAAE,EAAE;YAC5B,IAAI,IAAI,EAAE,CAAC;SACd;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,MAAM,CAAC,kBAAkB,CAAC,MAAe,EAAE,IAAY,EAAE,MAAc;QAC3E,IAAI,GAAG,GAAG,GAAG,MAAM,EAAE,CAAC;QACtB,IAAI,MAAM,KAAK,EAAE,EAAE;YACf,IAAI,IAAI,GAAG,EAAE,EAAE;gBACX,GAAG,GAAG,GAAG,MAAM,KAAK,CAAC;aACxB;iBACI;gBACD,GAAG,GAAG,GAAG,MAAM,KAAK,CAAC;aACxB;SACJ;QACD,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;YAChC,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SACzB;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,eAAe,CAAC,KAAY;QAC/B,IAAI,CAAC,KAAK,EAAE;YACR,OAAO,SAAS,CAAC;SACpB;aACI;YACD,OAAO;gBACH,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE;gBACjC,OAAO,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,UAAU,EAAE;aACxC,CAAC;SACL;IACL,CAAC;IAED;;;;;;;OAOG;IACH,MAAM,CAAC,eAAe,CAClB,SAAe,EACf,OAAa,EACb,MAA2B;QAE3B,MAAM,GAAG,GAAW,EAAE,CAAC;QACvB,OACI,SAAS,CAAC,WAAW,EAAE,GAAG,OAAO,CAAC,WAAW,EAAE;eAC5C,SAAS,CAAC,QAAQ,EAAE,GAAG,OAAO,CAAC,QAAQ,EAAE;eACzC,SAAS,CAAC,OAAO,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE,EAC7C;YACE,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;YAC9B,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC,CAAC;SACtD;QACD,IAAI,MAAM,EAAE;YACR,OAAO,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;SACrC;aACI;YACD,OAAO,GAAG,CAAC;SACd;IACL,CAAC;IAED;;;;;;;;;OASG;IACH,MAAM,CAAC,wBAAwB,CAC3B,KAA4B,EAC5B,IAAW,EACX,GAA2B,EAC3B,GAA2B,EAC3B,MAAoD;QAEpD,IAAI,GAAG,EAAE;YACL,MAAM,OAAO,GAAS,GAAG,CAAC,IAAI,CAAC,CAAC;YAChC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACrB,CAAE,CAAC,CAAC,KAA0B;mBAC3B,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK;mBAC7B,CACC,CAAC,CAAC,KAAK,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK;uBAC5B,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CACxC,CACJ,CAAC;SACL;QACD,IAAI,GAAG,EAAE;YACL,MAAM,OAAO,GAAS,GAAG,CAAC,IAAI,CAAC,CAAC;YAChC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACrB,CAAE,CAAC,CAAC,KAA0B;mBAC3B,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK;mBAC7B,CACC,CAAC,CAAC,KAAK,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK;uBAC5B,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,CACxC,CACJ,CAAC;SACL;QACD,IAAI,MAAM,EAAE;YACR,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAE,CAAC,CAAC,KAA0B,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SAChF;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,mBAAmB,CAAC,IAAW;QAClC,IACI,CAAC,IAAI;eACF,IAAI,CAAC,KAAK,IAAI,IAAI;eAClB,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ;eAC9B,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;eACxB,IAAI,CAAC,OAAO,IAAI,IAAI;eACpB,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ;eAChC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAC/B;YACE,OAAO,IAAI,CAAC;SACf;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;;AArLD;;GAEG;AACI,+BAAiB,GAA0C,GAAG,EAAE,CAAC,IAAI,CAAC","sourcesContent":["import { Time } from '@angular/common';\nimport { DateFilterFn } from '@angular/material/datepicker';\nimport { LodashUtilities } from '../capsulation/lodash.utilities';\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\n\nconst DAY_IN_MS = 1000 * 60 * 60 * 24;\n\n/**\n * Valid steps from one time value to the next. Needs to be able to divide 60 minutes without remainder.\n */\ntype MinuteSteps = 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30 | 60;\n\n/**\n * Contains Helper Functions for handling date properties.\n */\nexport abstract class DateUtilities {\n\n    /**\n     * The default filter function to user when none was provided by the user.\n     */\n    static defaultDateFilter: DateFilterFn<Date | null | undefined> = () => true;\n\n    /**\n     * Gets the given value as a date value.\n     *\n     * @param value - The value to get as a date.\n     * @returns The given value as a date.\n     */\n    static asDate(value: unknown): Date {\n        return value as Date;\n    }\n\n    /**\n     * Gets the default times used by the DateTime picker when nothing is specified by the user.\n     *\n     * @param format - The time format. Defaults to 24.\n     * @param minuteSteps - The steps from one time value to the next. Defaults to 30.\n     * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.\n     */\n    static getDefaultTimes(format: 12 | 24 = 24, minuteSteps: MinuteSteps = 30): DropdownValue<Time>[] {\n        const res: DropdownValue<Time>[] = [{ displayName: '-', value: undefined as unknown as Time}];\n        for (let hour = 0; hour < 24; hour++) {\n            for (let minute = 0; minute < 60; minute += minuteSteps) {\n                res.push(DateUtilities.getTimeDropdownValue(format, hour, minute));\n            }\n        }\n        return res;\n    }\n\n    private static getTimeDropdownValue(format: 12 | 24, hour: number, minute: number): DropdownValue<Time> {\n        const displayHour: number = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));\n        const displayMinute: string = DateUtilities.getFormattedMinute(format, hour, minute);\n        return {\n            displayName: `${displayHour}:${displayMinute}`,\n            value: {\n                hours: hour,\n                minutes: minute\n            }\n        };\n    }\n\n    private static getFormattedHour(format: 12 | 24, hour: number): number {\n        if (format === 12 && hour > 12) {\n            hour -= 12;\n        }\n        return hour;\n    }\n\n    private static getFormattedMinute(format: 12 | 24, hour: number, minute: number): string {\n        let res = `${minute}`;\n        if (format === 12) {\n            if (hour > 12) {\n                res = `${minute} PM`;\n            }\n            else {\n                res = `${minute} AM`;\n            }\n        }\n        if (minute.toString().length === 1) {\n            res = '0'.concat(res);\n        }\n        return res;\n    }\n\n    /**\n     * Gets the Time object from the given date.\n     *\n     * @param value - The date to get the time object from.\n     * @returns The Time object build from the date value.\n     */\n    static getTimeFromDate(value?: Date): Time | undefined {\n        if (!value) {\n            return undefined;\n        }\n        else {\n            return {\n                hours: new Date(value).getHours(),\n                minutes: new Date(value).getMinutes()\n            };\n        }\n    }\n\n    /**\n     * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.\n     *\n     * @param startDate - The start date.\n     * @param endDate - The end date.\n     * @param filter - The custom filter from the metadata.\n     * @returns All dates between the two provided dates. Includes start and end date.\n     */\n    static getDatesBetween(\n        startDate: Date,\n        endDate: Date,\n        filter?: DateFilterFn<Date>\n    ): Date[] {\n        const res: Date[] = [];\n        while (\n            startDate.getFullYear() < endDate.getFullYear()\n            || startDate.getMonth() < endDate.getMonth()\n            || startDate.getDate() <= endDate.getDate()\n        ) {\n            res.push(new Date(startDate));\n            startDate.setTime(startDate.getTime() + DAY_IN_MS);\n        }\n        if (filter) {\n            return res.filter(d => filter(d));\n        }\n        else {\n            return res;\n        }\n    }\n\n    /**\n     * Get all valid times for the dropdown of a datetime property.\n     *\n     * @param times - All given times to filter.\n     * @param date - The date of the datetime.\n     * @param min - The function that defines the minimum time.\n     * @param max - The function that defines the maximum time.\n     * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.\n     * @returns All valid dropdown values for the datetime property.\n     */\n    static getValidTimesForDropdown(\n        times: DropdownValue<Time>[],\n        date?: Date,\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t =>\n                !(t.value as Time | undefined)\n                || t.value.hours > minTime.hours\n                || (\n                    t.value.hours === minTime.hours\n                    && t.value.minutes >= minTime.minutes\n                )\n            );\n        }\n        if (max) {\n            const maxTime: Time = max(date);\n            times = times.filter(t =>\n                !(t.value as Time | undefined)\n                || t.value.hours < maxTime.hours\n                || (\n                    t.value.hours === maxTime.hours\n                    && t.value.minutes <= maxTime.minutes\n                )\n            );\n        }\n        if (filter) {\n            times = times.filter(t => !(t.value as Time | undefined) || filter(t.value));\n        }\n\n        return times;\n    }\n\n    /**\n     * Checks if the time object has processable hours and minutes properties.\n     * Doesn't check custom validators like min/max from the metadata configuration.\n     *\n     * @param time - The time to check.\n     * @returns Whether or not the time object is unprocessable.\n     */\n    static timeIsUnprocessable(time?: Time): boolean {\n        if (\n            !time\n            || time.hours == null\n            || typeof time.hours !== 'number'\n            || Number.isNaN(time.hours)\n            || time.minutes == null\n            || typeof time.minutes !== 'number'\n            || Number.isNaN(time.minutes)\n        ) {\n            return true;\n        }\n        return false;\n    }\n}"]}
|
|
@@ -20,4 +20,4 @@ __decorate([
|
|
|
20
20
|
}),
|
|
21
21
|
__metadata("design:type", String)
|
|
22
22
|
], Entity.prototype, "id", void 0);
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50aXR5Lm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvY2xhc3Nlcy9lbnRpdHkubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFZckQ7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLE1BQU07SUFjeEIsWUFBWSxNQUFlO1FBQ3ZCLGVBQWUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7Q0FDSjtBQUxHO0lBUkMsTUFBTSxDQUFDO1FBQ0osYUFBYSxFQUFFLElBQUk7UUFDbkIsYUFBYSxFQUFFLElBQUk7UUFDbkIsT0FBTyxFQUFFLEtBQUs7UUFDZCxZQUFZLEVBQUUsTUFBTTtRQUNwQixXQUFXLEVBQUUsSUFBSTtRQUNqQixRQUFRLEVBQUUsSUFBSTtLQUNqQixDQUFDOztrQ0FDbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzdHJpbmcgfSBmcm9tICcuLi9kZWNvcmF0b3JzL3N0cmluZy9zdHJpbmcuZGVjb3JhdG9yJztcbmltcG9ydCB7IEVudGl0eVV0aWxpdGllcyB9IGZyb20gJy4vZW50aXR5LnV0aWxpdGllcyc7XG5cbi8qKlxuICogVGhlIG5ld2FibGUgdHlwZSB1c2VkIHdoZW5ldmVyIGFuIGVudGl0eSBjbGFzcyBpcyBwYXNzZWQgdG8gY3JlYXRlIGFuIGVudGl0eSBhbmQgaW5pdGlhbGl6ZSBpdHMgbWV0YWRhdGEuXG4gKi9cbmV4cG9ydCB0eXBlIEVudGl0eUNsYXNzTmV3YWJsZTxFbnRpdHlUeXBlIGV4dGVuZHMgQmFzZUVudGl0eVR5cGU8RW50aXR5VHlwZT4+ID0gbmV3KGRhdGE/OiBFbnRpdHlUeXBlKSA9PiBFbnRpdHlUeXBlO1xuXG4vKipcbiAqIFRoZSBHZW5lcmljIEJhc2UgRW50aXR5VHlwZS5cbiAqL1xuZXhwb3J0IHR5cGUgQmFzZUVudGl0eVR5cGU8VD4gPSB7IFtLIGluIGtleW9mIFRdOiB1bmtub3duIH07XG5cbi8qKlxuICogQSBiYXNlIEVudGl0eSBjbGFzcyB3aXRoIGEgYnVpbHRpbiBpZC5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEVudGl0eSB7XG4gICAgLyoqXG4gICAgICogQSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIEVudGl0eS5cbiAgICAgKi9cbiAgICBAc3RyaW5nKHtcbiAgICAgICAgb21pdEZvckNyZWF0ZTogdHJ1ZSxcbiAgICAgICAgb21pdEZvclVwZGF0ZTogdHJ1ZSxcbiAgICAgICAgZGlzcGxheTogZmFsc2UsXG4gICAgICAgIGRpc3BsYXlTdHlsZTogJ2xpbmUnLFxuICAgICAgICBkaXNwbGF5TmFtZTogJ0lEJyxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWVcbiAgICB9KVxuICAgIHJlYWRvbmx5IGlkITogc3RyaW5nO1xuXG4gICAgY29uc3RydWN0b3IoZW50aXR5PzogRW50aXR5KSB7XG4gICAgICAgIEVudGl0eVV0aWxpdGllcy5uZXcodGhpcywgZW50aXR5KTtcbiAgICB9XG59Il19
|