ngx-material-entity 15.1.1 → 15.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.
Files changed (47) hide show
  1. package/classes/date.utilities.d.ts +1 -1
  2. package/classes/entity.utilities.d.ts +36 -0
  3. package/components/input/date/date-range-input/date-range-input.component.d.ts +6 -3
  4. package/components/input/date/date-time-input/date-time-input.component.d.ts +3 -2
  5. package/components/input/file/file-image-input/file-image-input.component.d.ts +4 -2
  6. package/components/input/file/file-input/file-input.component.d.ts +5 -2
  7. package/components/input/string/string-password-input/string-password-input.component.d.ts +2 -1
  8. package/decorators/base/base-property.decorator.d.ts +2 -1
  9. package/decorators/boolean/boolean-decorator.data.d.ts +6 -2
  10. package/decorators/custom/custom.decorator.d.ts +2 -1
  11. package/decorators/date/date-decorator-internal.data.d.ts +1 -1
  12. package/decorators/date/date-decorator.data.d.ts +1 -1
  13. package/decorators/number/number-decorator-internal.data.d.ts +1 -1
  14. package/decorators/number/number-decorator.data.d.ts +1 -1
  15. package/decorators/string/string-decorator-internal.data.d.ts +1 -1
  16. package/decorators/string/string-decorator.data.d.ts +1 -1
  17. package/encapsulation/reflect.utilities.d.ts +9 -0
  18. package/esm2020/classes/date.utilities.mjs +1 -1
  19. package/esm2020/classes/entity.utilities.mjs +51 -4
  20. package/esm2020/components/input/boolean/boolean-dropdown-input/boolean-dropdown-input.component.mjs +3 -3
  21. package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +21 -1
  22. package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +11 -3
  23. package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +3 -3
  24. package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +17 -3
  25. package/esm2020/components/input/file/file-input/file-input.component.mjs +14 -2
  26. package/esm2020/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +3 -3
  27. package/esm2020/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +3 -3
  28. package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +8 -3
  29. package/esm2020/decorators/base/base-property.decorator.mjs +6 -2
  30. package/esm2020/decorators/boolean/boolean-decorator-internal.data.mjs +3 -3
  31. package/esm2020/decorators/boolean/boolean-decorator.data.mjs +1 -1
  32. package/esm2020/decorators/custom/custom.decorator.mjs +4 -3
  33. package/esm2020/decorators/date/date-decorator-internal.data.mjs +1 -1
  34. package/esm2020/decorators/date/date-decorator.data.mjs +1 -1
  35. package/esm2020/decorators/date/date.decorator.mjs +4 -3
  36. package/esm2020/decorators/file/file.decorator.mjs +4 -3
  37. package/esm2020/decorators/number/number-decorator-internal.data.mjs +1 -1
  38. package/esm2020/decorators/number/number-decorator.data.mjs +1 -1
  39. package/esm2020/decorators/string/string-decorator-internal.data.mjs +1 -1
  40. package/esm2020/decorators/string/string-decorator.data.mjs +1 -1
  41. package/esm2020/decorators/string/string.decorator.mjs +3 -2
  42. package/esm2020/encapsulation/reflect.utilities.mjs +12 -1
  43. package/fesm2015/ngx-material-entity.mjs +351 -238
  44. package/fesm2015/ngx-material-entity.mjs.map +1 -1
  45. package/fesm2020/ngx-material-entity.mjs +347 -235
  46. package/fesm2020/ngx-material-entity.mjs.map +1 -1
  47. package/package.json +1 -1
@@ -57,7 +57,7 @@ export declare abstract class DateUtilities {
57
57
  * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.
58
58
  * @returns All valid dropdown values for the datetime property.
59
59
  */
60
- static getValidTimesForDropdown(times: DropdownValue<Time>[], date?: Date, min?: (date?: Date) => Time, max?: (date?: Date) => Time, filter?: ((time: Time) => boolean) | (() => boolean)): DropdownValue<Time>[];
60
+ static getValidTimesForDropdown(times: DropdownValue<Time | undefined>[], date?: Date, min?: (date?: Date) => Time, max?: (date?: Date) => Time, filter?: ((time: Time) => boolean) | (() => boolean)): DropdownValue<Time | undefined>[];
61
61
  /**
62
62
  * Checks if the time object has processable hours and minutes properties.
63
63
  * Doesn't check custom validators like min/max from the metadata configuration.
@@ -5,6 +5,42 @@ import { BaseEntityType } from './entity.model';
5
5
  * Contains HelperMethods around handling Entities and their property-metadata.
6
6
  */
7
7
  export declare abstract class EntityUtilities {
8
+ /**
9
+ * The key for all keys of metadata that should be set to undefined when the entity gets reset.
10
+ */
11
+ static readonly METADATA_KEYS_TO_RESET_KEY: string;
12
+ /**
13
+ * The key for the metadata that saves the single preview image value on image properties.
14
+ */
15
+ static readonly SINGLE_PREVIEW_IMAGE_KEY: string;
16
+ /**
17
+ * The key for the metadata that saves the multi preview images value on image properties.
18
+ */
19
+ static readonly MULTI_PREVIEW_IMAGES_KEY: string;
20
+ /**
21
+ * The key for the metadata that saves the filenames value on file properties.
22
+ */
23
+ static readonly FILENAMES_KEY: string;
24
+ /**
25
+ * The key for the metadata that saves the confirm password value on password properties.
26
+ */
27
+ static readonly CONFIRM_PASSWORD_KEY: string;
28
+ /**
29
+ * The key for the metadata that saves the time value on date time properties.
30
+ */
31
+ static readonly TIME_KEY: string;
32
+ /**
33
+ * The key for the metadata that saves the date range value on date range properties.
34
+ */
35
+ static readonly DATE_RANGE_KEY: string;
36
+ /**
37
+ * The key for the metadata that saves the date range start value on date range properties.
38
+ */
39
+ static readonly DATE_RANGE_START_KEY: string;
40
+ /**
41
+ * The key for the metadata that saves the date range end value on date range properties.
42
+ */
43
+ static readonly DATE_RANGE_END_KEY: string;
8
44
  /**
9
45
  * Gets the properties to omit when updating the entity.
10
46
  *
@@ -6,9 +6,12 @@ import { DateRange } from '../../../../decorators/date/date-decorator.data';
6
6
  import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class DateRangeInputComponent<EntityType extends BaseEntityType<EntityType>> extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_RANGE, DateRange> implements OnInit {
9
- dateRange: DateRange;
10
- dateRangeStart?: Date;
11
- dateRangeEnd?: Date;
9
+ get dateRange(): DateRange;
10
+ set dateRange(value: DateRange);
11
+ get dateRangeStart(): Date | undefined;
12
+ set dateRangeStart(value: Date | undefined);
13
+ get dateRangeEnd(): Date | undefined;
14
+ set dateRangeEnd(value: Date | undefined);
12
15
  defaultDateFilter: DateFilterFn<Date | null | undefined>;
13
16
  ngOnInit(): void;
14
17
  /**
@@ -9,8 +9,9 @@ import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
9
9
  import * as i0 from "@angular/core";
10
10
  export declare class DateTimeInputComponent<EntityType extends BaseEntityType<EntityType>> extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_TIME, Date> implements OnInit {
11
11
  DateUtilities: typeof DateUtilities;
12
- time?: Time;
13
- timeDropdownValues: DropdownValue<Time>[];
12
+ timeDropdownValues: DropdownValue<Time | undefined>[];
13
+ get time(): Time | undefined;
14
+ set time(value: Time | undefined);
14
15
  defaultDateFilter: DateFilterFn<Date | null | undefined>;
15
16
  ngOnInit(): void;
16
17
  /**
@@ -7,8 +7,10 @@ import { NgxMatEntityBaseInputComponent } from '../../base-input.component';
7
7
  import * as i0 from "@angular/core";
8
8
  export declare class FileImageInputComponent<EntityType extends BaseEntityType<EntityType>> extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.FILE_IMAGE, FileData | FileData[]> implements OnInit {
9
9
  FileUtilities: typeof FileUtilities;
10
- singlePreviewImage?: string;
11
- multiPreviewImages?: string[];
10
+ get multiPreviewImages(): string[] | undefined;
11
+ set multiPreviewImages(value: string[] | undefined);
12
+ get singlePreviewImage(): string | undefined;
13
+ set singlePreviewImage(value: string | undefined);
12
14
  imageIndex: number;
13
15
  placeHolder: string;
14
16
  private setSinglePreviewImage;
@@ -8,9 +8,12 @@ import { BaseEntityType } from '../../../../classes/entity.model';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class FileInputComponent<EntityType extends BaseEntityType<EntityType>> implements OnInit {
10
10
  private readonly dialog;
11
- filenames?: string[];
11
+ get filenames(): string[] | undefined;
12
+ set filenames(value: string[] | undefined);
12
13
  FileUtilities: typeof FileUtilities;
13
14
  propertyValue: FileData | FileData[] | undefined;
15
+ entity: EntityType;
16
+ key: keyof EntityType;
14
17
  metadata: DefaultFileDecoratorConfigInternal | ImageFileDecoratorConfigInternal;
15
18
  getValidationErrorMessage: (model: NgModel) => string;
16
19
  isReadOnly: boolean;
@@ -29,5 +32,5 @@ export declare class FileInputComponent<EntityType extends BaseEntityType<Entity
29
32
  downloadAllEnabled(): boolean;
30
33
  downloadAll(): Promise<void>;
31
34
  static ɵfac: i0.ɵɵFactoryDeclaration<FileInputComponent<any>, never>;
32
- static ɵcmp: i0.ɵɵComponentDeclaration<FileInputComponent<any>, "file-input", never, { "propertyValue": "propertyValue"; "metadata": "metadata"; "getValidationErrorMessage": "getValidationErrorMessage"; "isReadOnly": "isReadOnly"; }, { "fileDataChangeEvent": "fileDataChangeEvent"; }, never, never, false, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<FileInputComponent<any>, "file-input", never, { "propertyValue": "propertyValue"; "entity": "entity"; "key": "key"; "metadata": "metadata"; "getValidationErrorMessage": "getValidationErrorMessage"; "isReadOnly": "isReadOnly"; }, { "fileDataChangeEvent": "fileDataChangeEvent"; }, never, never, false, never>;
33
36
  }
@@ -7,7 +7,8 @@ export declare class StringPasswordInputComponent<EntityType extends BaseEntityT
7
7
  hide: boolean;
8
8
  hideConfirm: boolean;
9
9
  confirmRequired: boolean;
10
- confirmPassword?: string;
10
+ get confirmPassword(): string | undefined;
11
+ set confirmPassword(value: string | undefined);
11
12
  ngOnInit(): void;
12
13
  passwordInput(): void;
13
14
  static ɵfac: i0.ɵɵFactoryDeclaration<StringPasswordInputComponent<any>, never>;
@@ -4,6 +4,7 @@ import { DecoratorType, DecoratorTypes } from './decorator-types.enum';
4
4
  *
5
5
  * @param metadata - The metadata to define.
6
6
  * @param type - The type of metadata.
7
+ * @param metadataKeysToReset - Any metadata keys which values should be set to undefined on reset.
7
8
  * @returns The method that sets the metadata.
8
9
  */
9
- export declare function baseProperty<T extends DecoratorTypes, CustomMetadataType extends Record<string, unknown>>(metadata: DecoratorType<T, CustomMetadataType>, type: T): (target: object, propertyKey: string) => void;
10
+ export declare function baseProperty<T extends DecoratorTypes, CustomMetadataType extends Record<string, unknown>>(metadata: DecoratorType<T, CustomMetadataType>, type: T, metadataKeysToReset?: string[]): (target: object, propertyKey: string) => void;
@@ -15,12 +15,16 @@ export interface DropdownBooleanDecoratorConfig extends BooleanDecoratorConfig {
15
15
  displayStyle: 'dropdown';
16
16
  /**
17
17
  * The name of the true value if displayStyle dropdown is used.
18
+ *
19
+ * @default 'Yes'
18
20
  */
19
- dropdownTrue: string;
21
+ dropdownTrue?: string;
20
22
  /**
21
23
  * The name of the false value if displayStyle dropdown is used.
24
+ *
25
+ * @default 'No'
22
26
  */
23
- dropdownFalse: string;
27
+ dropdownFalse?: string;
24
28
  }
25
29
  /**
26
30
  * The configuration options for a boolean property displayed as a checkbox.
@@ -4,6 +4,7 @@ import { CustomDecoratorConfig } from './custom-decorator.data';
4
4
  * Decorator for setting and getting custom property metadata.
5
5
  *
6
6
  * @param metadata - The metadata of the custom property.
7
+ * @param metadataKeysToReset - Any metadata keys which values should be set to undefined on reset.
7
8
  * @returns The method that defines the metadata.
8
9
  */
9
- export declare function custom<ValueType, CustomMetadataType extends BaseEntityType<CustomMetadataType>, EntityType extends BaseEntityType<EntityType>>(metadata: CustomDecoratorConfig<EntityType, ValueType, CustomMetadataType, any>): (target: object, propertyKey: string) => void;
10
+ export declare function custom<ValueType, CustomMetadataType extends BaseEntityType<CustomMetadataType>, EntityType extends BaseEntityType<EntityType>>(metadata: CustomDecoratorConfig<EntityType, ValueType, CustomMetadataType, any>, metadataKeysToReset?: string[]): (target: object, propertyKey: string) => void;
@@ -32,7 +32,7 @@ export declare class DateRangeDateDecoratorConfigInternal extends PropertyDecora
32
32
  */
33
33
  export declare class DateTimeDateDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DateTimeDateDecoratorConfig {
34
34
  displayStyle: 'datetime';
35
- times: DropdownValue<Time>[];
35
+ times: DropdownValue<Time | undefined>[];
36
36
  timeDisplayName: string;
37
37
  minDate?: (date?: Date) => Date;
38
38
  maxDate?: (date?: Date) => Date;
@@ -94,7 +94,7 @@ export interface DateTimeDateDecoratorConfig extends DateDecoratorConfig {
94
94
  /**
95
95
  * The selectable times.
96
96
  */
97
- times?: DropdownValue<Time>[];
97
+ times?: DropdownValue<Time | undefined>[];
98
98
  /**
99
99
  * The name to use as a label for the time form field.
100
100
  *
@@ -15,7 +15,7 @@ export declare class DefaultNumberDecoratorConfigInternal extends PropertyDecora
15
15
  */
16
16
  export declare class DropdownNumberDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DropdownNumberDecoratorConfig {
17
17
  displayStyle: 'dropdown';
18
- dropdownValues: DropdownValue<number>[];
18
+ dropdownValues: DropdownValue<number | undefined>[];
19
19
  constructor(data: DropdownNumberDecoratorConfig);
20
20
  }
21
21
  /**
@@ -31,7 +31,7 @@ export interface DropdownNumberDecoratorConfig extends NumberDecoratorConfig {
31
31
  /**
32
32
  * The values of the dropdown, consisting of a name to display and the actual value.
33
33
  */
34
- dropdownValues: DropdownValue<number>[];
34
+ dropdownValues: DropdownValue<number | undefined>[];
35
35
  }
36
36
  /**
37
37
  * The configuration options for a number property displayed as a slider input.
@@ -6,7 +6,7 @@ import { AutocompleteStringDecoratorConfig, DefaultStringDecoratorConfig, Dropdo
6
6
  */
7
7
  export declare class DropdownStringDecoratorConfigInternal extends PropertyDecoratorConfigInternal implements DropdownStringDecoratorConfig {
8
8
  displayStyle: 'dropdown';
9
- dropdownValues: DropdownValue<string>[];
9
+ dropdownValues: DropdownValue<string | undefined>[];
10
10
  constructor(data: DropdownStringDecoratorConfig);
11
11
  }
12
12
  /**
@@ -18,7 +18,7 @@ export interface DropdownStringDecoratorConfig extends StringDecoratorConfig {
18
18
  * The values of the dropdown, consisting of a name to display and the actual value
19
19
  * Can also receive a function to determine the values.
20
20
  */
21
- dropdownValues: DropdownValue<string>[];
21
+ dropdownValues: DropdownValue<string | undefined>[];
22
22
  }
23
23
  /**
24
24
  * The configuration options for a string property displayed in a default text input.
@@ -44,6 +44,15 @@ export declare abstract class ReflectUtilities {
44
44
  * @returns Whether or not the given target has the key.
45
45
  */
46
46
  static has<T extends object>(target: T, propertyKey: keyof T): boolean;
47
+ /**
48
+ * Checks if the targets key entry has a metadata value for the given metadata key.
49
+ *
50
+ * @returns Whether the metadata is null or not.
51
+ * @param metadataKey - The key of the metadata on the property.
52
+ * @param target - Object that contains the property on itself or in its prototype chain.
53
+ * @param propertyKey - The key of the target.
54
+ */
55
+ static hasMetadata<T extends object>(metadataKey: string, target: T, propertyKey: keyof T): boolean;
47
56
  /**
48
57
  * Define a unique metadata entry on the target.
49
58
  *
@@ -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 '../encapsulation/lodash.utilities';\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\n\nconst DAY_IN_MS: number = 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: number = 0; hour < 24; hour++) {\n            for (let minute: number = 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: string = `${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}"]}
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 '../encapsulation/lodash.utilities';\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\n\nconst DAY_IN_MS: number = 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: number = 0; hour < 24; hour++) {\n            for (let minute: number = 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: string = `${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 | undefined>[],\n        date?: Date,\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time | undefined>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t =>\n                !t.value\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\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 || 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}"]}