ngx-material-entity 18.0.1 → 18.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/components/custom-table/custom-table-configuration.model.d.ts +65 -0
  2. package/components/custom-table/custom-table.component.d.ts +111 -0
  3. package/components/edit-page/edit-page.component.d.ts +5 -1
  4. package/components/input/array/array-date-input/array-date-input.component.d.ts +2 -2
  5. package/components/input/array/array-date-range-input/array-date-range-input.component.d.ts +3 -3
  6. package/components/input/array/array-date-time-input/array-date-time-input.component.d.ts +3 -3
  7. package/components/input/array/array-table.class.d.ts +25 -19
  8. package/components/input/input.component.d.ts +99 -80
  9. package/components/input/relations/references-many-input/references-many-input.component.d.ts +12 -17
  10. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +5 -5
  11. package/components/table/table-data.d.ts +9 -4
  12. package/components/table/table.component.d.ts +15 -37
  13. package/decorators/array/array-decorator-internal.data.d.ts +5 -1
  14. package/decorators/array/array-decorator.data.d.ts +38 -82
  15. package/decorators/references-many/references-many-decorator-internal.data.d.ts +3 -1
  16. package/decorators/references-many/references-many-decorator.data.d.ts +13 -1
  17. package/directives/dynamic-style-class.directive.d.ts +4 -5
  18. package/esm2022/components/confirm-dialog/confirm-dialog.component.mjs +5 -6
  19. package/esm2022/components/create-page/create-page.component.mjs +6 -7
  20. package/esm2022/components/custom-table/custom-table-configuration.model.mjs +37 -0
  21. package/esm2022/components/custom-table/custom-table.component.mjs +213 -0
  22. package/esm2022/components/edit-page/edit-page.component.mjs +19 -9
  23. package/esm2022/components/form/form.component.mjs +5 -6
  24. package/esm2022/components/input/array/array-date-input/array-date-input.component.mjs +16 -20
  25. package/esm2022/components/input/array/array-date-range-input/array-date-range-input.component.mjs +27 -26
  26. package/esm2022/components/input/array/array-date-time-input/array-date-time-input.component.mjs +17 -21
  27. package/esm2022/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.mjs +4 -4
  28. package/esm2022/components/input/array/array-string-chips-input/array-string-chips-input.component.mjs +4 -4
  29. package/esm2022/components/input/array/array-table.class.mjs +51 -43
  30. package/esm2022/components/input/date/date-range-input/date-range-input.component.mjs +5 -6
  31. package/esm2022/components/input/date/date-time-input/date-time-input.component.mjs +4 -4
  32. package/esm2022/components/input/file/file-image-input/file-image-input.component.mjs +4 -7
  33. package/esm2022/components/input/file/file-input/file-input.component.mjs +4 -5
  34. package/esm2022/components/input/input.component.mjs +143 -106
  35. package/esm2022/components/input/number/number-dropdown-input/number-dropdown-input.component.mjs +4 -5
  36. package/esm2022/components/input/relations/references-many-input/references-many-input.component.mjs +40 -55
  37. package/esm2022/components/input/string/string-autocomplete-input/string-autocomplete-input.component.mjs +4 -5
  38. package/esm2022/components/input/string/string-dropdown-input/string-dropdown-input.component.mjs +4 -5
  39. package/esm2022/components/input/string/string-password-input/string-password-input.component.mjs +4 -4
  40. package/esm2022/components/table/create-dialog/create-entity-dialog.component.mjs +7 -8
  41. package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +19 -14
  42. package/esm2022/components/table/table-data.mjs +1 -1
  43. package/esm2022/components/table/table.component.mjs +40 -107
  44. package/esm2022/components/tooltip/tooltip.component.mjs +3 -3
  45. package/esm2022/decorators/array/array-decorator-internal.data.mjs +14 -1
  46. package/esm2022/decorators/array/array-decorator.data.mjs +33 -2
  47. package/esm2022/decorators/has-many/has-many-decorator-internal.data.mjs +1 -1
  48. package/esm2022/decorators/references-many/references-many-decorator-internal.data.mjs +8 -1
  49. package/esm2022/decorators/references-many/references-many-decorator.data.mjs +1 -1
  50. package/esm2022/directives/dynamic-style-class.directive.mjs +5 -5
  51. package/esm2022/directives/tooltip.directive.mjs +4 -1
  52. package/esm2022/functions/get-changes-tooltip-content.function.mjs +23 -0
  53. package/esm2022/functions/get-validation-errors-tooltip-content.function.mjs +23 -0
  54. package/esm2022/functions/table-column-value-to-sort-value.function.mjs +29 -0
  55. package/esm2022/public-api.mjs +3 -2
  56. package/esm2022/utilities/date.utilities.mjs +7 -6
  57. package/esm2022/utilities/entity.utilities.mjs +23 -7
  58. package/esm2022/utilities/validation.utilities.mjs +2 -2
  59. package/fesm2022/ngx-material-entity.mjs +2545 -2224
  60. package/fesm2022/ngx-material-entity.mjs.map +1 -1
  61. package/functions/get-changes-tooltip-content.function.d.ts +13 -0
  62. package/functions/table-column-value-to-sort-value.function.d.ts +9 -0
  63. package/package.json +1 -1
  64. package/public-api.d.ts +2 -1
  65. package/utilities/entity.utilities.d.ts +7 -3
  66. package/esm2022/functions/get-validation-errors-tooltip-content.function.ts.mjs +0 -23
  67. /package/functions/{get-validation-errors-tooltip-content.function.ts.d.ts → get-validation-errors-tooltip-content.function.d.ts} +0 -0
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable jsdoc/require-jsdoc */
2
- import { NgFor } from '@angular/common';
2
+ import { CommonModule } from '@angular/common';
3
3
  import { Component } from '@angular/core';
4
4
  import { FormsModule } from '@angular/forms';
5
5
  import { MatChipsModule } from '@angular/material/chips';
@@ -57,7 +57,7 @@ export class ArrayStringChipsInputComponent extends NgxMatEntityBaseInputCompone
57
57
  }
58
58
  }
59
59
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayStringChipsInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
60
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayStringChipsInputComponent, isStandalone: true, selector: "array-string-chips-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\" [required]=\"metadata.required(entity)\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"setValidationErrors(model, chipsModel)\"\n >\n @for (value of propertyValue; track $index) {\n <mat-chip-row (removed)=\"removeStringChipArrayValue(value)\">\n {{value}}\n <button type=\"button\" matChipRemove>\n <i [class]=\"metadata.deleteIcon\"></i>\n </button>\n </mat-chip-row>\n }\n <input #chipsModel=\"ngModel\"\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [(ngModel)]=\"chipsInput\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i2.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i2.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i2.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i2.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
60
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayStringChipsInputComponent, isStandalone: true, selector: "array-string-chips-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\" [required]=\"metadata.required(entity)\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"setValidationErrors(model, chipsModel)\"\n >\n @for (value of propertyValue; track $index) {\n <mat-chip-row (removed)=\"removeStringChipArrayValue(value)\">\n {{value}}\n <button type=\"button\" matChipRemove>\n <i [class]=\"metadata.deleteIcon\"></i>\n </button>\n </mat-chip-row>\n }\n <input #chipsModel=\"ngModel\"\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [(ngModel)]=\"chipsInput\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatChipsModule }, { kind: "component", type: i2.MatChipGrid, selector: "mat-chip-grid", inputs: ["disabled", "placeholder", "required", "value", "errorStateMatcher"], outputs: ["change", "valueChange"] }, { kind: "directive", type: i2.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i2.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i2.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["editable"], outputs: ["edited"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: CommonModule }] });
61
61
  }
62
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayStringChipsInputComponent, decorators: [{
63
63
  type: Component,
@@ -66,7 +66,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
66
66
  MatChipsModule,
67
67
  FormsModule,
68
68
  MatInputModule,
69
- NgFor
69
+ CommonModule
70
70
  ], template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\" [required]=\"metadata.required(entity)\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (ngModelChange)=\"setValidationErrors(model, chipsModel)\"\n >\n @for (value of propertyValue; track $index) {\n <mat-chip-row (removed)=\"removeStringChipArrayValue(value)\">\n {{value}}\n <button type=\"button\" matChipRemove>\n <i [class]=\"metadata.deleteIcon\"></i>\n </button>\n </mat-chip-row>\n }\n <input #chipsModel=\"ngModel\"\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [(ngModel)]=\"chipsInput\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
71
71
  }] });
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-string-chips-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,WAAW,EAAW,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAqB,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzD,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AACzE,OAAO,EAAE,8BAA8B,EAAE,MAAM,4BAA4B,CAAC;;;;;;AAgB5E,MAAM,OAAO,8BACT,SAAQ,8BAAuF;IAE/F,KAAK,GAAW,aAAa,CAAC,MAAM,EAAE,CAAC;IACvC,UAAU,GAAW,EAAE,CAAC;IAExB;;;;;;;;;;OAUG;IACH,uBAAuB,CAAC,KAAwB,EAAE,OAAgB;QAC9D,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAC1B,OAAO;QACX,CAAC;QAED,MAAM,KAAK,GAAW,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/B,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QAErB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED;;;;;;;;OAQG;IACH,0BAA0B,CAAC,KAAa;QACpC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QAEjF,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,mBAAmB,CAAC,KAAc,EAAE,UAAmB;QACnD,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC;YACpB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC/C,CAAC;IACL,CAAC;uGApDQ,8BAA8B;2FAA9B,8BAA8B,2GC3B3C,uzCA8BiB,qFDVT,kBAAkB,uYAClB,cAAc,4uBACd,WAAW,0yCACX,cAAc;;2FAIT,8BAA8B;kBAd1C,SAAS;+BAEI,0BAA0B,cAGxB,IAAI,WACP;wBACL,kBAAkB;wBAClB,cAAc;wBACd,WAAW;wBACX,cAAc;wBACd,KAAK;qBACR","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor } from '@angular/common';\nimport { Component, OnInit } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatChipInputEvent, MatChipsModule } from '@angular/material/chips';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { UUIDUtilities } from '../../../../encapsulation/uuid.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-string-chips-input',\n    templateUrl: './array-string-chips-input.component.html',\n    styleUrls: ['./array-string-chips-input.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatChipsModule,\n        FormsModule,\n        MatInputModule,\n        NgFor\n    ]\n})\nexport class ArrayStringChipsInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.ARRAY_STRING_CHIPS, string[]> implements OnInit {\n\n    uuid2: string = UUIDUtilities.create();\n    chipsInput: string = '';\n\n    /**\n     * Handles adding strings to the chipsArray.\n     * Checks validation and also creates a new array if it is undefined.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it contains values, we can set it to undefined when the last element is removed\n     * (removeStringChipArrayValue). That way we can use the \"required\" validator.\n     * @param event - The event that fires when a new chip is completed.\n     * @param invalid - Whether or not the input is invalid.\n     */\n    addStringChipArrayValue(event: MatChipInputEvent, invalid: boolean): void {\n        if (invalid || !event.value) {\n            return;\n        }\n\n        const value: string = event.value.trim();\n        this.propertyValue = this.propertyValue ?? [];\n        this.propertyValue.push(value);\n\n        event.chipInput?.clear();\n        this.chipsInput = '';\n\n        this.emitChange();\n    }\n\n    /**\n     * Removes the given value from the array.\n     * Sets the array to undefined if it is now empty.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it is empty, setting it to undefined here enables us to use the \"required\" validator.\n     * @param value - The string to remove from the array.\n     */\n    removeStringChipArrayValue(value: string): void {\n        this.propertyValue?.splice(this.propertyValue.indexOf(value), 1);\n        this.propertyValue = this.propertyValue?.length ? this.propertyValue : undefined;\n\n        this.emitChange();\n    }\n\n    setValidationErrors(model: NgModel, chipsModel: NgModel): void {\n        if (chipsModel.errors) {\n            model.control.setErrors(chipsModel.errors);\n        }\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        #model=\"ngModel\" [name]=\"name\" [required]=\"metadata.required(entity)\"\n        [disabled]=\"isReadOnly\"\n        [(ngModel)]=\"propertyValue\"\n        (ngModelChange)=\"setValidationErrors(model, chipsModel)\"\n    >\n        @for (value of propertyValue; track $index) {\n            <mat-chip-row (removed)=\"removeStringChipArrayValue(value)\">\n                {{value}}\n                <button type=\"button\" matChipRemove>\n                    <i [class]=\"metadata.deleteIcon\"></i>\n                </button>\n            </mat-chip-row>\n        }\n        <input #chipsModel=\"ngModel\"\n            matInput\n            [matChipInputFor]=\"chipGrid\"\n            [matChipInputAddOnBlur]=\"true\"\n            [name]=\"uuid2\"\n            [minlength]=\"metadata.minLength ?? null\"\n            [maxlength]=\"metadata.maxLength ?? null\"\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n            [(ngModel)]=\"chipsInput\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n        />\n    </mat-chip-grid>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-string-chips-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-chips-input/array-string-chips-input.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,WAAW,EAAW,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAqB,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzD,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAC;AACzE,OAAO,EAAE,8BAA8B,EAAE,MAAM,4BAA4B,CAAC;;;;;;AAgB5E,MAAM,OAAO,8BACT,SAAQ,8BAAuF;IAE/F,KAAK,GAAW,aAAa,CAAC,MAAM,EAAE,CAAC;IACvC,UAAU,GAAW,EAAE,CAAC;IAExB;;;;;;;;;;OAUG;IACH,uBAAuB,CAAC,KAAwB,EAAE,OAAgB;QAC9D,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAC1B,OAAO;QACX,CAAC;QAED,MAAM,KAAK,GAAW,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/B,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QAErB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED;;;;;;;;OAQG;IACH,0BAA0B,CAAC,KAAa;QACpC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;QAEjF,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,mBAAmB,CAAC,KAAc,EAAE,UAAmB;QACnD,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC;YACpB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC/C,CAAC;IACL,CAAC;uGApDQ,8BAA8B;2FAA9B,8BAA8B,2GC3B3C,uzCA8BiB,qFDVT,kBAAkB,uYAClB,cAAc,4uBACd,WAAW,0yCACX,cAAc,0WACd,YAAY;;2FAGP,8BAA8B;kBAd1C,SAAS;+BAEI,0BAA0B,cAGxB,IAAI,WACP;wBACL,kBAAkB;wBAClB,cAAc;wBACd,WAAW;wBACX,cAAc;wBACd,YAAY;qBACf","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { Component, OnInit } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatChipInputEvent, MatChipsModule } from '@angular/material/chips';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { UUIDUtilities } from '../../../../encapsulation/uuid.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-string-chips-input',\n    templateUrl: './array-string-chips-input.component.html',\n    styleUrls: ['./array-string-chips-input.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatChipsModule,\n        FormsModule,\n        MatInputModule,\n        CommonModule\n    ]\n})\nexport class ArrayStringChipsInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.ARRAY_STRING_CHIPS, string[]> implements OnInit {\n\n    uuid2: string = UUIDUtilities.create();\n    chipsInput: string = '';\n\n    /**\n     * Handles adding strings to the chipsArray.\n     * Checks validation and also creates a new array if it is undefined.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it contains values, we can set it to undefined when the last element is removed\n     * (removeStringChipArrayValue). That way we can use the \"required\" validator.\n     * @param event - The event that fires when a new chip is completed.\n     * @param invalid - Whether or not the input is invalid.\n     */\n    addStringChipArrayValue(event: MatChipInputEvent, invalid: boolean): void {\n        if (invalid || !event.value) {\n            return;\n        }\n\n        const value: string = event.value.trim();\n        this.propertyValue = this.propertyValue ?? [];\n        this.propertyValue.push(value);\n\n        event.chipInput?.clear();\n        this.chipsInput = '';\n\n        this.emitChange();\n    }\n\n    /**\n     * Removes the given value from the array.\n     * Sets the array to undefined if it is now empty.\n     * This is needed because two things are validated: The array itself\n     * and the contents of the array. And we need a way to display an\n     * mat-error. As the only validation for the array is whether or not\n     * it is empty, setting it to undefined here enables us to use the \"required\" validator.\n     * @param value - The string to remove from the array.\n     */\n    removeStringChipArrayValue(value: string): void {\n        this.propertyValue?.splice(this.propertyValue.indexOf(value), 1);\n        this.propertyValue = this.propertyValue?.length ? this.propertyValue : undefined;\n\n        this.emitChange();\n    }\n\n    setValidationErrors(model: NgModel, chipsModel: NgModel): void {\n        if (chipsModel.errors) {\n            model.control.setErrors(chipsModel.errors);\n        }\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        #model=\"ngModel\" [name]=\"name\" [required]=\"metadata.required(entity)\"\n        [disabled]=\"isReadOnly\"\n        [(ngModel)]=\"propertyValue\"\n        (ngModelChange)=\"setValidationErrors(model, chipsModel)\"\n    >\n        @for (value of propertyValue; track $index) {\n            <mat-chip-row (removed)=\"removeStringChipArrayValue(value)\">\n                {{value}}\n                <button type=\"button\" matChipRemove>\n                    <i [class]=\"metadata.deleteIcon\"></i>\n                </button>\n            </mat-chip-row>\n        }\n        <input #chipsModel=\"ngModel\"\n            matInput\n            [matChipInputFor]=\"chipGrid\"\n            [matChipInputAddOnBlur]=\"true\"\n            [name]=\"uuid2\"\n            [minlength]=\"metadata.minLength ?? null\"\n            [maxlength]=\"metadata.maxLength ?? null\"\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n            [(ngModel)]=\"chipsInput\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n        />\n    </mat-chip-grid>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}
@@ -1,12 +1,9 @@
1
- /* eslint-disable jsdoc/require-jsdoc */
2
- import { SelectionModel } from '@angular/cdk/collections';
3
1
  import { HttpClient } from '@angular/common/http';
4
- import { Component, EnvironmentInjector, runInInjectionContext } from '@angular/core';
2
+ import { Component } from '@angular/core';
5
3
  import { MatDialog } from '@angular/material/dialog';
6
- import { MatTableDataSource } from '@angular/material/table';
7
4
  import { LodashUtilities } from '../../../encapsulation/lodash.utilities';
5
+ import { defaultFalse } from '../../../functions/default-false.function';
8
6
  import { EntityUtilities } from '../../../utilities/entity.utilities';
9
- import { SelectionUtilities } from '../../../utilities/selection.utilities';
10
7
  import { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';
11
8
  import { NgxMatEntityBaseInputComponent } from '../base-input.component';
12
9
  import * as i0 from "@angular/core";
@@ -17,59 +14,70 @@ import * as i2 from "@angular/common/http";
17
14
  */
18
15
  // eslint-disable-next-line angular/prefer-standalone
19
16
  export class ArrayTableComponent extends NgxMatEntityBaseInputComponent {
20
- matDialog;
21
- injector;
17
+ dialog;
22
18
  http;
19
+ /**
20
+ * The input that should be added to the array.
21
+ */
23
22
  input = undefined;
24
- dataSource = new MatTableDataSource();
25
- selection = new SelectionModel(true, []);
26
- displayedColumns;
27
- SelectionUtilities = SelectionUtilities;
28
- constructor(matDialog, injector, http) {
23
+ /**
24
+ * The currently selected values.
25
+ */
26
+ selected = [];
27
+ /**
28
+ * The configuration of the table.
29
+ */
30
+ tableConfig; // TODO: Make generic type
31
+ get propertyValue() {
32
+ return this.entity[this.key];
33
+ }
34
+ set propertyValue(value) {
35
+ this.entity[this.key] = value;
36
+ this.metadata.change?.(this.entity);
37
+ }
38
+ constructor(dialog, http) {
29
39
  super();
30
- this.matDialog = matDialog;
31
- this.injector = injector;
40
+ this.dialog = dialog;
32
41
  this.http = http;
33
42
  }
34
43
  ngOnInit() {
35
44
  super.ngOnInit();
36
45
  this.propertyValue = this.propertyValue ?? [];
37
- const givenDisplayColumns = this.metadata.displayColumns.map((v) => v.displayName);
38
- if (givenDisplayColumns.find(s => s === 'select')) {
39
- throw new Error(`The name "select" for a display column is reserved.
40
- Please choose a different name.`);
41
- }
42
- this.displayedColumns = this.isReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns);
43
- this.dataSource.data = this.propertyValue;
44
46
  }
45
47
  /**
46
- * Gets the value to display in the column.
47
- * Runs in environment context to enable injection.
48
- * @param entity - The entity to get the value from.
49
- * @param displayColumn - The display column to get the value from.
50
- * @returns The value of the display column.
48
+ * Sets the table config.
49
+ * This is not included in the ngOnInit for child classes to be able to set their metadata.
50
+ * (which is used in the table config).
51
51
  */
52
- getDisplayColumnValue(entity, displayColumn) {
53
- return runInInjectionContext(this.injector, () => displayColumn.value(entity));
52
+ setTableConfig() {
53
+ this.tableConfig = {
54
+ allowClick: defaultFalse,
55
+ displayColumns: this.metadata.displayColumns,
56
+ withSelection: !this.isReadOnly,
57
+ dynamicRowStyleClasses: this.metadata.dynamicRowStyleClasses
58
+ };
54
59
  }
55
60
  /**
56
61
  * Tries to add an item to the array.
57
62
  */
58
- add() {
63
+ async add() {
59
64
  if (this.input == undefined) {
60
65
  return;
61
66
  }
62
- if (!this.metadata.allowDuplicates
63
- && this.propertyValue?.find(async (v) => await EntityUtilities.isEqual(this.input, v, this.metadata, this.metadata.itemType, this.http)) != undefined) {
64
- this.matDialog.open(NgxMatEntityConfirmDialogComponent, {
65
- data: this.metadata.duplicatesErrorDialog,
66
- autoFocus: false,
67
- restoreFocus: false
68
- });
69
- return;
67
+ if (!this.metadata.allowDuplicates) {
68
+ for (const value of this.propertyValue) {
69
+ if (await EntityUtilities.isEqual(this.input, value, this.metadata, this.metadata.itemType, this.http)) {
70
+ this.dialog.open(NgxMatEntityConfirmDialogComponent, {
71
+ data: this.metadata.duplicatesErrorDialog,
72
+ autoFocus: false,
73
+ restoreFocus: false
74
+ });
75
+ return;
76
+ }
77
+ }
70
78
  }
71
- this.propertyValue?.push(LodashUtilities.cloneDeep(this.input));
72
- this.dataSource.data = this.propertyValue ?? [];
79
+ this.propertyValue.push(LodashUtilities.cloneDeep(this.input));
80
+ this.propertyValue = [...this.propertyValue];
73
81
  this.resetInput();
74
82
  this.emitChange();
75
83
  }
@@ -83,10 +91,10 @@ export class ArrayTableComponent extends NgxMatEntityBaseInputComponent {
83
91
  * Removes all selected entries from the entity array.
84
92
  */
85
93
  remove() {
86
- SelectionUtilities.remove(this.selection, this.propertyValue, this.dataSource);
94
+ this.propertyValue = this.propertyValue.filter(v => !this.selected.includes(v));
87
95
  this.emitChange();
88
96
  }
89
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayTableComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
97
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayTableComponent, deps: [{ token: i1.MatDialog }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
90
98
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: ArrayTableComponent, selector: "ngx-mat-entity-array-table", usesInheritance: true, ngImport: i0, template: '', isInline: true });
91
99
  }
92
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayTableComponent, decorators: [{
@@ -95,5 +103,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
95
103
  selector: 'ngx-mat-entity-array-table',
96
104
  template: ''
97
105
  }]
98
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.HttpClient }] });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-table.class.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/input/array/array-table.class.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EnvironmentInjector, OnInit, runInInjectionContext } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatTableDataSource } from '@angular/material/table';\n\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../decorators/base/decorator-types.enum';\nimport { LodashUtilities } from '../../../encapsulation/lodash.utilities';\nimport { EntityUtilities } from '../../../utilities/entity.utilities';\nimport { SelectionUtilities } from '../../../utilities/selection.utilities';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { DisplayColumn } from '../../table/table-data';\nimport { NgxMatEntityBaseInputComponent } from '../base-input.component';\n\ntype ArrayTableType = DecoratorTypes.ARRAY | DecoratorTypes.ARRAY_DATE\n    | DecoratorTypes.ARRAY_DATE_RANGE | DecoratorTypes.ARRAY_DATE_TIME;\n\n/**\n * The base component needed for all arrays that are displayed as a table.\n */\n// eslint-disable-next-line angular/prefer-standalone\n@Component({\n    selector: 'ngx-mat-entity-array-table',\n    template: ''\n})\nexport abstract class ArrayTableComponent<ValueType, EntityType extends BaseEntityType<EntityType>, ArrayType extends ArrayTableType>\n    extends NgxMatEntityBaseInputComponent<EntityType, ArrayType, ValueType[]> implements OnInit {\n\n    input?: ValueType = undefined;\n    dataSource: MatTableDataSource<ValueType> = new MatTableDataSource();\n    selection: SelectionModel<ValueType> = new SelectionModel<ValueType>(true, []);\n    displayedColumns!: string[];\n\n    SelectionUtilities: typeof SelectionUtilities = SelectionUtilities;\n\n    constructor(private readonly matDialog: MatDialog, private readonly injector: EnvironmentInjector, private readonly http: HttpClient) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.propertyValue = this.propertyValue ?? [];\n        const givenDisplayColumns: string[] = this.metadata.displayColumns.map((v) => v.displayName);\n        if (givenDisplayColumns.find(s => s === 'select')) {\n            throw new Error(\n                `The name \"select\" for a display column is reserved.\n                Please choose a different name.`\n            );\n        }\n        this.displayedColumns = this.isReadOnly ? givenDisplayColumns : ['select'].concat(givenDisplayColumns);\n        this.dataSource.data = this.propertyValue;\n    }\n\n    /**\n     * Gets the value to display in the column.\n     * Runs in environment context to enable injection.\n     * @param entity - The entity to get the value from.\n     * @param displayColumn - The display column to get the value from.\n     * @returns The value of the display column.\n     */\n    getDisplayColumnValue(entity: ValueType, displayColumn: DisplayColumn<ValueType>): unknown {\n        return runInInjectionContext(this.injector, () => displayColumn.value(entity));\n    }\n\n    /**\n     * Tries to add an item to the array.\n     */\n    add(): void {\n        if (this.input == undefined) {\n            return;\n        }\n        if (\n            !this.metadata.allowDuplicates\n            && this.propertyValue?.find(\n                async v => await EntityUtilities.isEqual(this.input, v, this.metadata, this.metadata.itemType, this.http)\n            ) != undefined\n        ) {\n            this.matDialog.open(NgxMatEntityConfirmDialogComponent, {\n                data: this.metadata.duplicatesErrorDialog,\n                autoFocus: false,\n                restoreFocus: false\n            });\n            return;\n        }\n        this.propertyValue?.push(LodashUtilities.cloneDeep(this.input));\n        this.dataSource.data = this.propertyValue ?? [];\n        this.resetInput();\n        this.emitChange();\n    }\n\n    /**\n     * Is split up from the add method to override this functionality more easily.\n     */\n    protected resetInput(): void {\n        this.input = undefined;\n    }\n\n    /**\n     * Removes all selected entries from the entity array.\n     */\n    remove(): void {\n        SelectionUtilities.remove(this.selection, this.propertyValue as [], this.dataSource);\n        this.emitChange();\n    }\n}"]}
106
+ }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.HttpClient }] });
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-table.class.js","sourceRoot":"","sources":["../../../../../../projects/ngx-material-entity/src/components/input/array/array-table.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Component, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\n\nimport { BaseEntityType } from '../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../decorators/base/decorator-types.enum';\nimport { LodashUtilities } from '../../../encapsulation/lodash.utilities';\nimport { defaultFalse } from '../../../functions/default-false.function';\nimport { EntityUtilities } from '../../../utilities/entity.utilities';\nimport { NgxMatEntityConfirmDialogComponent } from '../../confirm-dialog/confirm-dialog.component';\nimport { CustomTableConfiguration } from '../../custom-table/custom-table-configuration.model';\nimport { DisplayColumn, DynamicStyleClasses } from '../../table/table-data';\nimport { NgxMatEntityBaseInputComponent } from '../base-input.component';\n\n/**\n * The Decorator Types that use the array table class.\n */\ntype ArrayTableType = DecoratorTypes.ARRAY | DecoratorTypes.ARRAY_DATE\n    | DecoratorTypes.ARRAY_DATE_RANGE | DecoratorTypes.ARRAY_DATE_TIME;\n\n/**\n * The base component needed for all arrays that are displayed as a table.\n */\n// eslint-disable-next-line angular/prefer-standalone\n@Component({\n    selector: 'ngx-mat-entity-array-table',\n    template: ''\n})\nexport abstract class ArrayTableComponent<ValueType, EntityType extends BaseEntityType<EntityType>, ArrayType extends ArrayTableType>\n    extends NgxMatEntityBaseInputComponent<EntityType, ArrayType, ValueType[]> implements OnInit {\n\n    /**\n     * The input that should be added to the array.\n     */\n    input?: ValueType = undefined;\n    /**\n     * The currently selected values.\n     */\n    selected: ValueType[] = [];\n    /**\n     * The configuration of the table.\n     */\n    tableConfig!: CustomTableConfiguration; // TODO: Make generic type\n\n    override get propertyValue(): ValueType[] {\n        return this.entity[this.key] as ValueType[];\n    }\n\n    override set propertyValue(value: ValueType[]) {\n        (this.entity[this.key] as ValueType[]) = value;\n        this.metadata.change?.(this.entity);\n    }\n\n    constructor(private readonly dialog: MatDialog, private readonly http: HttpClient) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.propertyValue = this.propertyValue ?? [];\n    }\n\n    /**\n     * Sets the table config.\n     * This is not included in the ngOnInit for child classes to be able to set their metadata.\n     * (which is used in the table config).\n     */\n    protected setTableConfig(): void {\n        this.tableConfig = {\n            allowClick: defaultFalse,\n            displayColumns: this.metadata.displayColumns as DisplayColumn<unknown>[],\n            withSelection: !this.isReadOnly,\n            dynamicRowStyleClasses: this.metadata.dynamicRowStyleClasses as DynamicStyleClasses<unknown>\n        };\n    }\n\n    /**\n     * Tries to add an item to the array.\n     */\n    async add(): Promise<void> {\n        if (this.input == undefined) {\n            return;\n        }\n        if (!this.metadata.allowDuplicates) {\n            for (const value of this.propertyValue) {\n                if (await EntityUtilities.isEqual(this.input, value, this.metadata, this.metadata.itemType, this.http)) {\n                    this.dialog.open(NgxMatEntityConfirmDialogComponent, {\n                        data: this.metadata.duplicatesErrorDialog,\n                        autoFocus: false,\n                        restoreFocus: false\n                    });\n                    return;\n                }\n            }\n        }\n        this.propertyValue.push(LodashUtilities.cloneDeep(this.input));\n        this.propertyValue = [...this.propertyValue];\n        this.resetInput();\n        this.emitChange();\n    }\n\n    /**\n     * Is split up from the add method to override this functionality more easily.\n     */\n    protected resetInput(): void {\n        this.input = undefined;\n    }\n\n    /**\n     * Removes all selected entries from the entity array.\n     */\n    remove(): void {\n        this.propertyValue = this.propertyValue.filter(v => !this.selected.includes(v));\n        this.emitChange();\n    }\n}"]}
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable jsdoc/require-jsdoc */
2
- import { NgFor, NgIf } from '@angular/common';
2
+ import { CommonModule } from '@angular/common';
3
3
  import { Component, Inject } from '@angular/core';
4
4
  import { FormsModule } from '@angular/forms';
5
5
  import { MatDatepickerModule } from '@angular/material/datepicker';
@@ -67,19 +67,18 @@ export class DateRangeInputComponent extends NgxMatEntityBaseInputComponent {
67
67
  this.emitChange();
68
68
  }
69
69
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: DateRangeInputComponent, deps: [{ token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
70
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: DateRangeInputComponent, isStandalone: true, selector: "date-range-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n \n <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required(entity)\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(dateRangeStart) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(dateRangeStart) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n (dateChange)=\"setDateRangeValues()\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(dateRangeEnd) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRangeEnd) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\n (dateChange)=\"setDateRangeValues()\"\n >\n </mat-date-range-input>\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-date-range-picker #picker></mat-date-range-picker>\n\n @if (startModel.errors) {\n <mat-error >{{getValidationErrorMessage(startModel)}}</mat-error>\n }\n @if (!startModel.errors && endModel.errors) {\n <mat-error >{{getValidationErrorMessage(endModel)}}</mat-error>\n }\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i2.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i2.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i2.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i2.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
70
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: DateRangeInputComponent, isStandalone: true, selector: "date-range-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n \n <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required(entity)\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(dateRangeStart) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(dateRangeStart) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n (dateChange)=\"setDateRangeValues()\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(dateRangeEnd) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRangeEnd) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\n (dateChange)=\"setDateRangeValues()\"\n >\n </mat-date-range-input>\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-date-range-picker #picker></mat-date-range-picker>\n\n @if (startModel.errors) {\n <mat-error >{{getValidationErrorMessage(startModel)}}</mat-error>\n }\n @if (!startModel.errors && endModel.errors) {\n <mat-error >{{getValidationErrorMessage(endModel)}}</mat-error>\n }\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { kind: "directive", type: i1.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i2.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i2.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i2.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i2.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
71
71
  }
72
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: DateRangeInputComponent, decorators: [{
73
73
  type: Component,
74
74
  args: [{ selector: 'date-range-input', standalone: true, imports: [
75
+ CommonModule,
75
76
  MatFormFieldModule,
76
77
  MatDatepickerModule,
77
- FormsModule,
78
- NgFor,
79
- NgIf
78
+ FormsModule
80
79
  ], template: "<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n \n <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required(entity)\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(dateRangeStart) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(dateRangeStart) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n (dateChange)=\"setDateRangeValues()\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(dateRangeEnd) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRangeEnd) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\n (dateChange)=\"setDateRangeValues()\"\n >\n </mat-date-range-input>\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-date-range-picker #picker></mat-date-range-picker>\n\n @if (startModel.errors) {\n <mat-error >{{getValidationErrorMessage(startModel)}}</mat-error>\n }\n @if (!startModel.errors && endModel.errors) {\n <mat-error >{{getValidationErrorMessage(endModel)}}</mat-error>\n }\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
81
80
  }], ctorParameters: () => [{ type: undefined, decorators: [{
82
81
  type: Inject,
83
82
  args: [NGX_COMPLETE_GLOBAL_DEFAULT_VALUES]
84
83
  }] }] });
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/date/date-range-input/date-range-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/date/date-range-input/date-range-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor, NgIf } from '@angular/common';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DateFilterFn, MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DateRangeDateDecoratorConfigInternal } from '../../../../decorators/date/date-decorator-internal.data';\nimport { DateRange } from '../../../../decorators/date/date-decorator.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities } from '../../../../utilities/date.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'date-range-input',\n    templateUrl: './date-range-input.component.html',\n    styleUrls: ['./date-range-input.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule,\n        NgFor,\n        NgIf\n    ]\n})\nexport class DateRangeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_RANGE, DateRange> implements OnInit {\n\n    dateRangeStart?: Date;\n    dateRangeEnd?: Date;\n\n    defaultDateFilter: DateFilterFn<Date | null | undefined> = DateUtilities.defaultDateFilter;\n\n    constructor(\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateRangeDateDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        // this.dateRange = LodashUtilities.cloneDeep(this.propertyValue) ?? EMPTY_DATERANGE;\n        if (this.propertyValue?.start) {\n            this.dateRangeStart = new Date(this.propertyValue.start);\n        }\n        if (this.propertyValue?.end) {\n            this.dateRangeEnd = new Date(this.propertyValue.end);\n        }\n        this.setDateRangeValues();\n    }\n\n    /**\n     * Updates the date range values based on the start and end date.\n     */\n    setDateRangeValues(): void {\n        if (this.dateRangeStart && this.dateRangeEnd) {\n            const values: Date[] = DateUtilities.getDatesBetween(\n                new Date(this.dateRangeStart),\n                new Date(this.dateRangeEnd),\n                this.metadata.filter\n            );\n            this.propertyValue = {\n                start: new Date(this.dateRangeStart),\n                end: new Date(this.dateRangeEnd),\n                values: values.length ? values : (undefined as unknown as Date[])\n            };\n        }\n        else if (!this.dateRangeStart && !this.dateRangeEnd) {\n            this.propertyValue = undefined;\n        }\n        else if (this.dateRangeStart) {\n            this.propertyValue = {\n                start: new Date(this.dateRangeStart),\n                end: undefined as unknown as Date,\n                values: undefined as unknown as Date[]\n            };\n        }\n        else if (this.dateRangeEnd) {\n            this.propertyValue = {\n                start: undefined as unknown as Date,\n                end: new Date(this.dateRangeEnd),\n                values: undefined as unknown as Date[]\n            };\n        }\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    \n    <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required(entity)\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n        <input #startModel=\"ngModel\"\n            matStartDate\n            [name]=\"name + 'start'\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minStart ? metadata.minStart(dateRangeStart) : undefined\"\n            [max]=\"metadata.maxStart ? metadata.maxStart(dateRangeStart) : undefined\"\n            [placeholder]=\"metadata.placeholderStart\"\n            [(ngModel)]=\"dateRangeStart\"\n            (dateChange)=\"setDateRangeValues()\"\n        >\n        <input #endModel=\"ngModel\"\n            matEndDate\n            [name]=\"name + 'end'\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minEnd ? metadata.minEnd(dateRangeEnd) : undefined\"\n            [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRangeEnd) : undefined\"\n            [placeholder]=\"metadata.placeholderEnd\"\n            [(ngModel)]=\"dateRangeEnd\"\n            (dateChange)=\"setDateRangeValues()\"\n        >\n    </mat-date-range-input>\n    <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n    <mat-date-range-picker #picker></mat-date-range-picker>\n\n    @if (startModel.errors) {\n        <mat-error >{{getValidationErrorMessage(startModel)}}</mat-error>\n    }\n    @if (!startModel.errors && endModel.errors) {\n        <mat-error >{{getValidationErrorMessage(endModel)}}</mat-error>\n    }\n</mat-form-field>"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/date/date-range-input/date-range-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/date/date-range-input/date-range-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DateFilterFn, MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DateRangeDateDecoratorConfigInternal } from '../../../../decorators/date/date-decorator-internal.data';\nimport { DateRange } from '../../../../decorators/date/date-decorator.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities } from '../../../../utilities/date.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'date-range-input',\n    templateUrl: './date-range-input.component.html',\n    styleUrls: ['./date-range-input.component.scss'],\n    standalone: true,\n    imports: [\n        CommonModule,\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule\n    ]\n})\nexport class DateRangeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_RANGE, DateRange> implements OnInit {\n\n    dateRangeStart?: Date;\n    dateRangeEnd?: Date;\n\n    defaultDateFilter: DateFilterFn<Date | null | undefined> = DateUtilities.defaultDateFilter;\n\n    constructor(\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateRangeDateDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        // this.dateRange = LodashUtilities.cloneDeep(this.propertyValue) ?? EMPTY_DATERANGE;\n        if (this.propertyValue?.start) {\n            this.dateRangeStart = new Date(this.propertyValue.start);\n        }\n        if (this.propertyValue?.end) {\n            this.dateRangeEnd = new Date(this.propertyValue.end);\n        }\n        this.setDateRangeValues();\n    }\n\n    /**\n     * Updates the date range values based on the start and end date.\n     */\n    setDateRangeValues(): void {\n        if (this.dateRangeStart && this.dateRangeEnd) {\n            const values: Date[] = DateUtilities.getDatesBetween(\n                new Date(this.dateRangeStart),\n                new Date(this.dateRangeEnd),\n                this.metadata.filter\n            );\n            this.propertyValue = {\n                start: new Date(this.dateRangeStart),\n                end: new Date(this.dateRangeEnd),\n                values: values.length ? values : (undefined as unknown as Date[])\n            };\n        }\n        else if (!this.dateRangeStart && !this.dateRangeEnd) {\n            this.propertyValue = undefined;\n        }\n        else if (this.dateRangeStart) {\n            this.propertyValue = {\n                start: new Date(this.dateRangeStart),\n                end: undefined as unknown as Date,\n                values: undefined as unknown as Date[]\n            };\n        }\n        else if (this.dateRangeEnd) {\n            this.propertyValue = {\n                start: undefined as unknown as Date,\n                end: new Date(this.dateRangeEnd),\n                values: undefined as unknown as Date[]\n            };\n        }\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    \n    <mat-date-range-input [rangePicker]=\"picker\" [required]=\"metadata.required(entity)\" [dateFilter]=\"metadata.filter ?? defaultDateFilter\" [disabled]=\"isReadOnly\">\n        <input #startModel=\"ngModel\"\n            matStartDate\n            [name]=\"name + 'start'\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minStart ? metadata.minStart(dateRangeStart) : undefined\"\n            [max]=\"metadata.maxStart ? metadata.maxStart(dateRangeStart) : undefined\"\n            [placeholder]=\"metadata.placeholderStart\"\n            [(ngModel)]=\"dateRangeStart\"\n            (dateChange)=\"setDateRangeValues()\"\n        >\n        <input #endModel=\"ngModel\"\n            matEndDate\n            [name]=\"name + 'end'\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minEnd ? metadata.minEnd(dateRangeEnd) : undefined\"\n            [max]=\"metadata.maxEnd ? metadata.maxEnd(dateRangeEnd) : undefined\"\n            [placeholder]=\"metadata.placeholderEnd\"\n            [(ngModel)]=\"dateRangeEnd\"\n            (dateChange)=\"setDateRangeValues()\"\n        >\n    </mat-date-range-input>\n    <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n    <mat-date-range-picker #picker></mat-date-range-picker>\n\n    @if (startModel.errors) {\n        <mat-error >{{getValidationErrorMessage(startModel)}}</mat-error>\n    }\n    @if (!startModel.errors && endModel.errors) {\n        <mat-error >{{getValidationErrorMessage(endModel)}}</mat-error>\n    }\n</mat-form-field>"]}
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable jsdoc/require-jsdoc */
2
- import { NgFor } from '@angular/common';
2
+ import { CommonModule } from '@angular/common';
3
3
  import { Component, Inject } from '@angular/core';
4
4
  import { FormsModule } from '@angular/forms';
5
5
  import { MatDatepickerModule } from '@angular/material/datepicker';
@@ -71,7 +71,7 @@ export class DateTimeInputComponent extends NgxMatEntityBaseInputComponent {
71
71
  this.emitChange();
72
72
  }
73
73
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: DateTimeInputComponent, deps: [{ token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
74
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: DateTimeInputComponent, isStandalone: true, selector: "date-time-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"date-time\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [name]=\"name\"\n [matDatepicker]=\"picker\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minDate ? metadata.minDate(propertyValue) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(propertyValue) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? defaultDateFilter\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (dateChange)=\"setTime()\"\n >\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n <mat-form-field class=\"timepicker\">\n <mat-label>{{metadata.timeDisplayName}}</mat-label>\n <mat-select\n #timeModel=\"ngModel\"\n [name]=\"name + 'time'\"\n [required]=\"metadata.required(entity)\"\n [compareWith]=\"compareTimes\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"time\"\n (selectionChange)=\"setTime()\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, propertyValue, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: ["mat-form-field{width:100%}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }] });
74
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: DateTimeInputComponent, isStandalone: true, selector: "date-time-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"date-time\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [name]=\"name\"\n [matDatepicker]=\"picker\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minDate ? metadata.minDate(propertyValue) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(propertyValue) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? defaultDateFilter\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (dateChange)=\"setTime()\"\n >\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n <mat-form-field class=\"timepicker\">\n <mat-label>{{metadata.timeDisplayName}}</mat-label>\n <mat-select\n #timeModel=\"ngModel\"\n [name]=\"name + 'time'\"\n [required]=\"metadata.required(entity)\"\n [compareWith]=\"compareTimes\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"time\"\n (selectionChange)=\"setTime()\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, propertyValue, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: ["mat-form-field{width:100%}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: CommonModule }] });
75
75
  }
76
76
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: DateTimeInputComponent, decorators: [{
77
77
  type: Component,
@@ -81,10 +81,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
81
81
  MatDatepickerModule,
82
82
  FormsModule,
83
83
  MatSelectModule,
84
- NgFor
84
+ CommonModule
85
85
  ], template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"date-time\">\n <mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <input\n #model=\"ngModel\"\n matInput\n [name]=\"name\"\n [matDatepicker]=\"picker\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minDate ? metadata.minDate(propertyValue) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(propertyValue) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? defaultDateFilter\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"propertyValue\"\n (dateChange)=\"setTime()\"\n >\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n </mat-form-field>\n <mat-form-field class=\"timepicker\">\n <mat-label>{{metadata.timeDisplayName}}</mat-label>\n <mat-select\n #timeModel=\"ngModel\"\n [name]=\"name + 'time'\"\n [required]=\"metadata.required(entity)\"\n [compareWith]=\"compareTimes\"\n [disabled]=\"isReadOnly\"\n [(ngModel)]=\"time\"\n (selectionChange)=\"setTime()\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, propertyValue, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n</div>", styles: ["mat-form-field{width:100%}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"] }]
86
86
  }], ctorParameters: () => [{ type: undefined, decorators: [{
87
87
  type: Inject,
88
88
  args: [NGX_COMPLETE_GLOBAL_DEFAULT_VALUES]
89
89
  }] }] });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/date/date-time-input/date-time-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/date/date-time-input/date-time-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor } from '@angular/common';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DateFilterFn, MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../../../decorators/base/dropdown-value.interface';\nimport { DateTimeDateDecoratorConfigInternal } from '../../../../decorators/date/date-decorator-internal.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { defaultTrue } from '../../../../functions/default-true.function';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities, Time } from '../../../../utilities/date.utilities';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'date-time-input',\n    templateUrl: './date-time-input.component.html',\n    styleUrls: ['./date-time-input.component.scss'],\n    standalone: true,\n    imports: [\n        MatInputModule,\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule,\n        MatSelectModule,\n        NgFor\n    ]\n})\nexport class DateTimeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_TIME, Date> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    timeDropdownValues!: DropdownValue<Time | undefined>[];\n\n    get time(): Time | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.TIME_KEY, this.entity, this.key) as Time | undefined;\n    }\n\n    set time(value: Time | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.TIME_KEY, value, this.entity, this.key);\n    }\n\n    defaultDateFilter: DateFilterFn<Date | null | undefined> = defaultTrue;\n\n    constructor(\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateTimeDateDecoratorConfigInternal(this.metadata, this.globalConfig);\n        this.time = DateUtilities.getTimeFromDate(this.propertyValue);\n        this.timeDropdownValues = this.metadata.times;\n        if (this.propertyValue) {\n            this.propertyValue = new Date(this.propertyValue);\n        }\n    }\n\n    /**\n     * Checks if two times are equal. Is needed for the dropdown.\n     * @param time1 - The first time to compare.\n     * @param time2 - The second time to compare.\n     * @returns Whether or not the time objects are the same.\n     */\n    compareTimes(time1?: Time, time2?: Time): boolean {\n        return !!time1 && !!time2 && time1.hours === time2.hours && time1.minutes === time2.minutes;\n    }\n\n    /**\n     * Sets the time on a datetime property.\n     */\n    setTime(): void {\n        if (!this.propertyValue) {\n            this.emitChange();\n            return;\n        }\n        this.propertyValue = new Date(this.propertyValue);\n        if (this.time?.hours != undefined && this.time?.minutes != undefined) {\n            this.propertyValue.setHours(this.time.hours, this.time.minutes, 0, 0);\n        }\n        else {\n            this.propertyValue.setHours(0, 0, 0, 0);\n        }\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"date-time\">\n    <mat-form-field>\n        <mat-label>{{metadata.displayName}}</mat-label>\n        <input\n            #model=\"ngModel\"\n            matInput\n            [name]=\"name\"\n            [matDatepicker]=\"picker\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minDate ? metadata.minDate(propertyValue) : undefined\"\n            [max]=\"metadata.maxDate ? metadata.maxDate(propertyValue) : undefined\"\n            [matDatepickerFilter]=\"metadata.filterDate ?? defaultDateFilter\"\n            [disabled]=\"isReadOnly\"\n            [(ngModel)]=\"propertyValue\"\n            (dateChange)=\"setTime()\"\n        >\n        <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n        <mat-datepicker #picker></mat-datepicker>\n        <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n    </mat-form-field>\n    <mat-form-field class=\"timepicker\">\n        <mat-label>{{metadata.timeDisplayName}}</mat-label>\n        <mat-select\n            #timeModel=\"ngModel\"\n            [name]=\"name + 'time'\"\n            [required]=\"metadata.required(entity)\"\n            [compareWith]=\"compareTimes\"\n            [disabled]=\"isReadOnly\"\n            [(ngModel)]=\"time\"\n            (selectionChange)=\"setTime()\"\n        >\n            @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, propertyValue, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n                <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n            }\n        </mat-select>\n        <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n    </mat-form-field>\n</div>"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/date/date-time-input/date-time-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/date/date-time-input/date-time-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DateFilterFn, MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../../../decorators/base/dropdown-value.interface';\nimport { DateTimeDateDecoratorConfigInternal } from '../../../../decorators/date/date-decorator-internal.data';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { defaultTrue } from '../../../../functions/default-true.function';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities, Time } from '../../../../utilities/date.utilities';\nimport { EntityUtilities } from '../../../../utilities/entity.utilities';\nimport { NgxMatEntityBaseInputComponent } from '../../base-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'date-time-input',\n    templateUrl: './date-time-input.component.html',\n    styleUrls: ['./date-time-input.component.scss'],\n    standalone: true,\n    imports: [\n        MatInputModule,\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule,\n        MatSelectModule,\n        CommonModule\n    ]\n})\nexport class DateTimeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends NgxMatEntityBaseInputComponent<EntityType, DecoratorTypes.DATE_TIME, Date> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    timeDropdownValues!: DropdownValue<Time | undefined>[];\n\n    get time(): Time | undefined {\n        return ReflectUtilities.getMetadata(EntityUtilities.TIME_KEY, this.entity, this.key) as Time | undefined;\n    }\n\n    set time(value: Time | undefined) {\n        ReflectUtilities.defineMetadata(EntityUtilities.TIME_KEY, value, this.entity, this.key);\n    }\n\n    defaultDateFilter: DateFilterFn<Date | null | undefined> = defaultTrue;\n\n    constructor(\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateTimeDateDecoratorConfigInternal(this.metadata, this.globalConfig);\n        this.time = DateUtilities.getTimeFromDate(this.propertyValue);\n        this.timeDropdownValues = this.metadata.times;\n        if (this.propertyValue) {\n            this.propertyValue = new Date(this.propertyValue);\n        }\n    }\n\n    /**\n     * Checks if two times are equal. Is needed for the dropdown.\n     * @param time1 - The first time to compare.\n     * @param time2 - The second time to compare.\n     * @returns Whether or not the time objects are the same.\n     */\n    compareTimes(time1?: Time, time2?: Time): boolean {\n        return !!time1 && !!time2 && time1.hours === time2.hours && time1.minutes === time2.minutes;\n    }\n\n    /**\n     * Sets the time on a datetime property.\n     */\n    setTime(): void {\n        if (!this.propertyValue) {\n            this.emitChange();\n            return;\n        }\n        this.propertyValue = new Date(this.propertyValue);\n        if (this.time?.hours != undefined && this.time?.minutes != undefined) {\n            this.propertyValue.setHours(this.time.hours, this.time.minutes, 0, 0);\n        }\n        else {\n            this.propertyValue.setHours(0, 0, 0, 0);\n        }\n        this.emitChange();\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"date-time\">\n    <mat-form-field>\n        <mat-label>{{metadata.displayName}}</mat-label>\n        <input\n            #model=\"ngModel\"\n            matInput\n            [name]=\"name\"\n            [matDatepicker]=\"picker\"\n            [required]=\"metadata.required(entity)\"\n            [min]=\"metadata.minDate ? metadata.minDate(propertyValue) : undefined\"\n            [max]=\"metadata.maxDate ? metadata.maxDate(propertyValue) : undefined\"\n            [matDatepickerFilter]=\"metadata.filterDate ?? defaultDateFilter\"\n            [disabled]=\"isReadOnly\"\n            [(ngModel)]=\"propertyValue\"\n            (dateChange)=\"setTime()\"\n        >\n        <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n        <mat-datepicker #picker></mat-datepicker>\n        <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n    </mat-form-field>\n    <mat-form-field class=\"timepicker\">\n        <mat-label>{{metadata.timeDisplayName}}</mat-label>\n        <mat-select\n            #timeModel=\"ngModel\"\n            [name]=\"name + 'time'\"\n            [required]=\"metadata.required(entity)\"\n            [compareWith]=\"compareTimes\"\n            [disabled]=\"isReadOnly\"\n            [(ngModel)]=\"time\"\n            (selectionChange)=\"setTime()\"\n        >\n            @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, propertyValue, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n                <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n            }\n        </mat-select>\n        <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n    </mat-form-field>\n</div>"]}