ngx-material-entity 18.0.0 → 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 +9 -8
  41. package/esm2022/components/table/edit-dialog/edit-entity-dialog.component.mjs +22 -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 +2550 -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,18 +1,17 @@
1
1
  /* eslint-disable jsdoc/require-jsdoc */
2
- import { NgFor, NgIf } from '@angular/common';
2
+ import { CommonModule } from '@angular/common';
3
3
  import { HttpClient } from '@angular/common/http';
4
- import { Component, EnvironmentInjector, Inject } from '@angular/core';
4
+ import { Component, Inject } from '@angular/core';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import { MatButtonModule } from '@angular/material/button';
7
- import { MatCheckboxModule } from '@angular/material/checkbox';
8
7
  import { MatDatepickerModule } from '@angular/material/datepicker';
9
8
  import { MatDialog } from '@angular/material/dialog';
10
9
  import { MatFormFieldModule } from '@angular/material/form-field';
11
- import { MatTableModule } from '@angular/material/table';
12
10
  import { DateRangeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';
13
11
  import { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';
14
12
  import { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES } from '../../../../global-configuration-values';
15
13
  import { DateUtilities } from '../../../../utilities/date.utilities';
14
+ import { CustomTableComponent } from '../../../custom-table/custom-table.component';
16
15
  import { ArrayTableComponent } from '../array-table.class';
17
16
  import * as i0 from "@angular/core";
18
17
  import * as i1 from "@angular/material/dialog";
@@ -20,16 +19,14 @@ import * as i2 from "@angular/common/http";
20
19
  import * as i3 from "@angular/material/form-field";
21
20
  import * as i4 from "@angular/material/datepicker";
22
21
  import * as i5 from "@angular/forms";
23
- import * as i6 from "@angular/material/table";
24
- import * as i7 from "@angular/material/checkbox";
25
- import * as i8 from "@angular/material/button";
22
+ import * as i6 from "@angular/material/button";
26
23
  export class ArrayDateRangeInputComponent extends ArrayTableComponent {
27
24
  globalConfig;
28
25
  DateUtilities = DateUtilities;
29
26
  dateRangeStart;
30
27
  dateRangeEnd;
31
- constructor(matDialog, injector, http, globalConfig) {
32
- super(matDialog, injector, http);
28
+ constructor(dialog, http, globalConfig) {
29
+ super(dialog, http);
33
30
  this.globalConfig = globalConfig;
34
31
  }
35
32
  ngOnInit() {
@@ -41,41 +38,45 @@ export class ArrayDateRangeInputComponent extends ArrayTableComponent {
41
38
  end: undefined,
42
39
  values: undefined
43
40
  };
41
+ this.setTableConfig();
44
42
  }
45
43
  /**
46
44
  * Adds a DateRange to the array.
47
45
  */
48
- addDateRange() {
49
- if (this.input && this.dateRangeStart && this.dateRangeEnd) {
50
- this.input.start = new Date(this.dateRangeStart);
51
- this.input.end = new Date(this.dateRangeEnd);
52
- const values = DateUtilities.getDatesBetween(this.input.start, this.input.end, this.metadata.filter);
53
- this.input.values = values.length ? values : undefined;
54
- this.add();
46
+ async add() {
47
+ if (!this.input || !this.dateRangeStart || !this.dateRangeEnd) {
48
+ return;
55
49
  }
50
+ this.input.start = new Date(this.dateRangeStart);
51
+ this.input.end = new Date(this.dateRangeEnd);
52
+ const values = DateUtilities.getDatesBetween(this.input.start, this.input.end, this.metadata.filter);
53
+ this.input.values = values.length ? values : undefined;
54
+ await super.add();
56
55
  }
57
56
  resetInput() {
58
- this.input = undefined;
57
+ this.input = {
58
+ start: undefined,
59
+ end: undefined,
60
+ values: undefined
61
+ };
59
62
  this.dateRangeStart = undefined;
60
63
  this.dateRangeEnd = undefined;
61
64
  }
62
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateRangeInputComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.HttpClient }, { token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
63
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayDateRangeInputComponent, isStandalone: true, selector: "array-date-range-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\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>\n \n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"startModel.errors || endModel.errors\"\n (click)=\"addDateRange()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadata.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n {{getDisplayColumnValue(entity, dCol)}}\n </mat-cell>\n </ng-container>\n }\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n @if (metadata.required(entity) && !dataSource.data.length) {\n <div class=\"array-error\">\n {{metadata.missingErrorMessage}}\n </div>\n }\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i4.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i4.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i4.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i4.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i6.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i6.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i6.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i6.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i6.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i6.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i6.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i6.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i6.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i6.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] });
65
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateRangeInputComponent, deps: [{ token: i1.MatDialog }, { token: i2.HttpClient }, { token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
66
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayDateRangeInputComponent, isStandalone: true, selector: "array-date-range-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\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>\n \n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"startModel.errors || endModel.errors\"\n (click)=\"add()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <custom-table\n [configuration]=\"tableConfig\"\n [data]=\"propertyValue\"\n [required]=\"metadata.required(entity)\"\n (selectionChanged)=\"selected = $any($event)\"\n >\n </custom-table>\n</div>", styles: ["mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i4.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i4.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i4.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i4.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: CustomTableComponent, selector: "custom-table", inputs: ["data", "searchString", "required", "isLoading", "configuration"], outputs: ["cellClicked", "selectionChanged"] }] });
64
67
  }
65
68
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateRangeInputComponent, decorators: [{
66
69
  type: Component,
67
70
  args: [{ selector: 'array-date-range-input', standalone: true, imports: [
68
- NgIf,
71
+ CommonModule,
69
72
  MatFormFieldModule,
70
73
  MatDatepickerModule,
71
74
  FormsModule,
72
- MatTableModule,
73
- MatCheckboxModule,
74
75
  MatButtonModule,
75
- NgFor
76
- ], template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\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>\n \n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"startModel.errors || endModel.errors\"\n (click)=\"addDateRange()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadata.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n {{getDisplayColumnValue(entity, dCol)}}\n </mat-cell>\n </ng-container>\n }\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n @if (metadata.required(entity) && !dataSource.data.length) {\n <div class=\"array-error\">\n {{metadata.missingErrorMessage}}\n </div>\n }\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}\n"] }]
77
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.HttpClient }, { type: undefined, decorators: [{
76
+ CustomTableComponent
77
+ ], template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n <input #startModel=\"ngModel\"\n matStartDate\n [name]=\"name + 'start'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n [placeholder]=\"metadata.placeholderStart\"\n [(ngModel)]=\"dateRangeStart\"\n >\n <input #endModel=\"ngModel\"\n matEndDate\n [name]=\"name + 'end'\"\n [required]=\"metadata.required(entity)\"\n [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n [placeholder]=\"metadata.placeholderEnd\"\n [(ngModel)]=\"dateRangeEnd\"\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>\n \n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"startModel.errors || endModel.errors\"\n (click)=\"add()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <custom-table\n [configuration]=\"tableConfig\"\n [data]=\"propertyValue\"\n [required]=\"metadata.required(entity)\"\n (selectionChanged)=\"selected = $any($event)\"\n >\n </custom-table>\n</div>", styles: ["mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}\n"] }]
78
+ }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.HttpClient }, { type: undefined, decorators: [{
78
79
  type: Inject,
79
80
  args: [NGX_COMPLETE_GLOBAL_DEFAULT_VALUES]
80
81
  }] }] });
81
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-date-range-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-range-input/array-date-range-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-range-input/array-date-range-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor, NgIf } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EnvironmentInjector, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatTableModule } from '@angular/material/table';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DateRangeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\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 { ArrayTableComponent } from '../array-table.class';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-date-range-input',\n    templateUrl: './array-date-range-input.component.html',\n    styleUrls: ['./array-date-range-input.component.scss'],\n    standalone: true,\n    imports: [\n        NgIf,\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule,\n        MatTableModule,\n        MatCheckboxModule,\n        MatButtonModule,\n        NgFor\n    ]\n})\nexport class ArrayDateRangeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayTableComponent<DateRange, EntityType, DecoratorTypes.ARRAY_DATE_RANGE> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    dateRangeStart?: Date;\n    dateRangeEnd?: Date;\n\n    constructor(\n        matDialog: MatDialog,\n        injector: EnvironmentInjector,\n        http: HttpClient,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super(matDialog, injector, http);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateRangeArrayDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        this.input = {\n            start: undefined as unknown as Date,\n            end: undefined as unknown as Date,\n            values: undefined as unknown as Date[]\n        };\n    }\n\n    /**\n     * Adds a DateRange to the array.\n     */\n    addDateRange(): void {\n        if (this.input && this.dateRangeStart && this.dateRangeEnd) {\n            this.input.start = new Date(this.dateRangeStart);\n            this.input.end = new Date(this.dateRangeEnd);\n            const values: Date[] = DateUtilities.getDatesBetween(\n                this.input.start,\n                this.input.end,\n                this.metadata.filter\n            );\n            this.input.values = values.length ? values : undefined as unknown as Date[];\n            this.add();\n        }\n    }\n\n    protected override resetInput(): void {\n        this.input = undefined;\n        this.dateRangeStart = undefined;\n        this.dateRangeEnd = undefined;\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n    <div class=\"array-headline\">\n        <b>{{metadata.displayName}}</b>\n    </div>\n    @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n                <input #startModel=\"ngModel\"\n                    matStartDate\n                    [name]=\"name + 'start'\"\n                    [required]=\"metadata.required(entity)\"\n                    [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n                    [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n                    [placeholder]=\"metadata.placeholderStart\"\n                    [(ngModel)]=\"dateRangeStart\"\n                >\n                <input #endModel=\"ngModel\"\n                    matEndDate\n                    [name]=\"name + 'end'\"\n                    [required]=\"metadata.required(entity)\"\n                    [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n                    [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n                    [placeholder]=\"metadata.placeholderEnd\"\n                    [(ngModel)]=\"dateRangeEnd\"\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>\n        \n        <div class=\"buttons\">\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"startModel.errors || endModel.errors\"\n                (click)=\"addDateRange()\">\n                {{metadata.addButtonLabel}}\n            </button>\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"!selection.selected.length\"\n                (click)=\"remove()\">\n                {{metadata.removeButtonLabel}}\n            </button>\n        </div>\n    }\n\n    <mat-table [dataSource]=\"dataSource\">\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let entity\">\n                <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n            </mat-cell>\n        </ng-container>\n        \n        @for (dCol of metadata.displayColumns; track $index) {\n            <ng-container [matColumnDef]=\"dCol.displayName\">\n                <mat-header-cell *matHeaderCellDef>\n                    {{dCol.displayName}}\n                </mat-header-cell>\n                <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n                    {{getDisplayColumnValue(entity, dCol)}}\n                </mat-cell>\n            </ng-container>\n        }\n    \n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    @if (metadata.required(entity) && !dataSource.data.length) {\n        <div class=\"array-error\">\n            {{metadata.missingErrorMessage}}\n        </div>\n    }\n</div>"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-date-range-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-range-input/array-date-range-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-range-input/array-date-range-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DateRangeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\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 { CustomTableComponent } from '../../../custom-table/custom-table.component';\nimport { ArrayTableComponent } from '../array-table.class';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-date-range-input',\n    templateUrl: './array-date-range-input.component.html',\n    styleUrls: ['./array-date-range-input.component.scss'],\n    standalone: true,\n    imports: [\n        CommonModule,\n        MatFormFieldModule,\n        MatDatepickerModule,\n        FormsModule,\n        MatButtonModule,\n        CustomTableComponent\n    ]\n})\nexport class ArrayDateRangeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayTableComponent<DateRange, EntityType, DecoratorTypes.ARRAY_DATE_RANGE> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    dateRangeStart?: Date;\n    dateRangeEnd?: Date;\n\n    constructor(\n        dialog: MatDialog,\n        http: HttpClient,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super(dialog, http);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateRangeArrayDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        this.input = {\n            start: undefined as unknown as Date,\n            end: undefined as unknown as Date,\n            values: undefined as unknown as Date[]\n        };\n        this.setTableConfig();\n    }\n\n    /**\n     * Adds a DateRange to the array.\n     */\n    override async add(): Promise<void> {\n        if (!this.input || !this.dateRangeStart || !this.dateRangeEnd) {\n            return;\n        }\n        this.input.start = new Date(this.dateRangeStart);\n        this.input.end = new Date(this.dateRangeEnd);\n        const values: Date[] = DateUtilities.getDatesBetween(\n            this.input.start,\n            this.input.end,\n            this.metadata.filter\n        );\n        this.input.values = values.length ? values : undefined as unknown as Date[];\n        await super.add();\n    }\n\n    protected override resetInput(): void {\n        this.input = {\n            start: undefined as unknown as Date,\n            end: undefined as unknown as Date,\n            values: undefined as unknown as Date[]\n        };\n        this.dateRangeStart = undefined;\n        this.dateRangeEnd = undefined;\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n    <div class=\"array-headline\">\n        <b>{{metadata.displayName}}</b>\n    </div>\n    @if (!isReadOnly) {\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 ? metadata.filter : DateUtilities.defaultDateFilter\">\n                <input #startModel=\"ngModel\"\n                    matStartDate\n                    [name]=\"name + 'start'\"\n                    [required]=\"metadata.required(entity)\"\n                    [min]=\"metadata.minStart ? metadata.minStart(input?.start) : undefined\"\n                    [max]=\"metadata.maxStart ? metadata.maxStart(input?.start) : undefined\"\n                    [placeholder]=\"metadata.placeholderStart\"\n                    [(ngModel)]=\"dateRangeStart\"\n                >\n                <input #endModel=\"ngModel\"\n                    matEndDate\n                    [name]=\"name + 'end'\"\n                    [required]=\"metadata.required(entity)\"\n                    [min]=\"metadata.minEnd ? metadata.minEnd(input?.end) : undefined\"\n                    [max]=\"metadata.maxEnd ? metadata.maxEnd(input?.end) : undefined\"\n                    [placeholder]=\"metadata.placeholderEnd\"\n                    [(ngModel)]=\"dateRangeEnd\"\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>\n        \n        <div class=\"buttons\">\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"startModel.errors || endModel.errors\"\n                (click)=\"add()\">\n                {{metadata.addButtonLabel}}\n            </button>\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"!selected.length\"\n                (click)=\"remove()\">\n                {{metadata.removeButtonLabel}}\n            </button>\n        </div>\n    }\n\n    <custom-table\n        [configuration]=\"tableConfig\"\n        [data]=\"propertyValue\"\n        [required]=\"metadata.required(entity)\"\n        (selectionChanged)=\"selected = $any($event)\"\n    >\n    </custom-table>\n</div>"]}
@@ -1,20 +1,19 @@
1
1
  /* eslint-disable jsdoc/require-jsdoc */
2
- import { NgFor, NgIf } from '@angular/common';
2
+ import { CommonModule } from '@angular/common';
3
3
  import { HttpClient } from '@angular/common/http';
4
- import { Component, EnvironmentInjector, Inject } from '@angular/core';
4
+ import { Component, Inject } from '@angular/core';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import { MatButtonModule } from '@angular/material/button';
7
- import { MatCheckboxModule } from '@angular/material/checkbox';
8
7
  import { MatDatepickerModule } from '@angular/material/datepicker';
9
8
  import { MatDialog } from '@angular/material/dialog';
10
9
  import { MatFormFieldModule } from '@angular/material/form-field';
11
10
  import { MatInputModule } from '@angular/material/input';
12
11
  import { MatSelectModule } from '@angular/material/select';
13
- import { MatTableModule } from '@angular/material/table';
14
12
  import { DateTimeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';
15
13
  import { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';
16
14
  import { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES } from '../../../../global-configuration-values';
17
15
  import { DateUtilities } from '../../../../utilities/date.utilities';
16
+ import { CustomTableComponent } from '../../../custom-table/custom-table.component';
18
17
  import { ArrayTableComponent } from '../array-table.class';
19
18
  import * as i0 from "@angular/core";
20
19
  import * as i1 from "@angular/material/dialog";
@@ -24,18 +23,16 @@ import * as i4 from "@angular/forms";
24
23
  import * as i5 from "@angular/material/datepicker";
25
24
  import * as i6 from "@angular/material/select";
26
25
  import * as i7 from "@angular/material/core";
27
- import * as i8 from "@angular/material/table";
28
- import * as i9 from "@angular/material/checkbox";
29
- import * as i10 from "@angular/material/input";
30
- import * as i11 from "@angular/material/button";
26
+ import * as i8 from "@angular/material/input";
27
+ import * as i9 from "@angular/material/button";
31
28
  export class ArrayDateTimeInputComponent extends ArrayTableComponent {
32
29
  globalConfig;
33
30
  DateUtilities = DateUtilities;
34
31
  dateTime;
35
32
  time;
36
33
  timeDropdownValues;
37
- constructor(matDialog, injector, http, globalConfig) {
38
- super(matDialog, injector, http);
34
+ constructor(matDialog, http, globalConfig) {
35
+ super(matDialog, http);
39
36
  this.globalConfig = globalConfig;
40
37
  }
41
38
  ngOnInit() {
@@ -47,6 +44,7 @@ export class ArrayDateTimeInputComponent extends ArrayTableComponent {
47
44
  if (this.entity[this.key] != undefined) {
48
45
  this.dateTime = new Date(this.entity[this.key]);
49
46
  }
47
+ this.setTableConfig();
50
48
  }
51
49
  resetInput() {
52
50
  this.input = undefined;
@@ -55,32 +53,30 @@ export class ArrayDateTimeInputComponent extends ArrayTableComponent {
55
53
  /**
56
54
  * Adds a date time to the array.
57
55
  */
58
- addDateTime() {
56
+ async addDateTime() {
59
57
  if (this.input && this.time) {
60
58
  this.input = new Date(this.input);
61
59
  this.input.setHours(this.time.hours, this.time.minutes, 0, 0);
62
- this.add();
60
+ await this.add();
63
61
  }
64
62
  }
65
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateTimeInputComponent, deps: [{ token: i1.MatDialog }, { token: i0.EnvironmentInjector }, { token: i2.HttpClient }, { token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
66
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayDateTimeInputComponent, isStandalone: true, selector: "array-date-time-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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(input) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n [(ngModel)]=\"input\"\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 [(ngModel)]=\"time\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n \n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n </div>\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n (click)=\"addDateTime()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadata.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n {{getDisplayColumnValue(entity, dCol)}}\n </mat-cell>\n </ng-container>\n }\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n @if (metadata.required(entity) && !dataSource.data.length) {\n <div class=\"array-error\">{{metadata.missingErrorMessage}}</div>\n }\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { 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: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i6.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: i7.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i8.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i8.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i8.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i8.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i8.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i8.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i8.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i8.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i8.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i8.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i9.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i10.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: MatButtonModule }, { kind: "component", type: i11.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] });
63
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateTimeInputComponent, deps: [{ token: i1.MatDialog }, { token: i2.HttpClient }, { token: NGX_COMPLETE_GLOBAL_DEFAULT_VALUES }], target: i0.ɵɵFactoryTarget.Component });
64
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayDateTimeInputComponent, isStandalone: true, selector: "array-date-time-input", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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(input) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n [(ngModel)]=\"input\"\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 [(ngModel)]=\"time\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n \n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n </div>\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n (click)=\"addDateTime()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <custom-table\n [configuration]=\"tableConfig\"\n [data]=\"propertyValue\"\n [required]=\"metadata.required(entity)\"\n (selectionChanged)=\"selected = $any($event)\"\n >\n </custom-table>\n</div>", styles: ["mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { 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: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i6.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: i7.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i8.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: MatButtonModule }, { kind: "component", type: i9.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: CustomTableComponent, selector: "custom-table", inputs: ["data", "searchString", "required", "isLoading", "configuration"], outputs: ["cellClicked", "selectionChanged"] }] });
67
65
  }
68
66
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayDateTimeInputComponent, decorators: [{
69
67
  type: Component,
70
68
  args: [{ selector: 'array-date-time-input', standalone: true, imports: [
71
- NgIf,
69
+ CommonModule,
72
70
  MatFormFieldModule,
73
71
  FormsModule,
74
72
  MatDatepickerModule,
75
73
  MatSelectModule,
76
- MatTableModule,
77
- MatCheckboxModule,
78
74
  MatInputModule,
79
75
  MatButtonModule,
80
- NgFor
81
- ], template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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(input) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n [(ngModel)]=\"input\"\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 [(ngModel)]=\"time\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n \n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n </div>\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n (click)=\"addDateTime()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selection.selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <mat-table [dataSource]=\"dataSource\">\n <!-- select Column -->\n <ng-container matColumnDef=\"select\">\n <mat-header-cell *matHeaderCellDef>\n <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\">\n <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n </mat-cell>\n </ng-container>\n \n @for (dCol of metadata.displayColumns; track $index) {\n <ng-container [matColumnDef]=\"dCol.displayName\">\n <mat-header-cell *matHeaderCellDef>\n {{dCol.displayName}}\n </mat-header-cell>\n <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n {{getDisplayColumnValue(entity, dCol)}}\n </mat-cell>\n </ng-container>\n }\n \n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n </mat-table>\n\n @if (metadata.required(entity) && !dataSource.data.length) {\n <div class=\"array-error\">{{metadata.missingErrorMessage}}</div>\n }\n</div>", styles: [".mdc-data-table__row:last-child .mdc-data-table__cell{border-bottom:1px solid rgba(0,0,0,.12)}mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}mat-table{border:1px solid #E0E0E0;border-radius:5px;padding-top:5px;padding-bottom:5px}.mat-column-select{flex:0 0 48px;padding-left:0;padding-right:0;justify-content:center}.array-error{display:flex;align-items:center;justify-content:center;margin-top:-6px;border:1px solid #E0E0E0;background-color:#f8d3d7;color:#721c24;height:fit-content;padding-left:4px;padding-right:4px;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"] }]
82
- }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i0.EnvironmentInjector }, { type: i2.HttpClient }, { type: undefined, decorators: [{
76
+ CustomTableComponent
77
+ ], template: "<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n <div class=\"array-headline\">\n <b>{{metadata.displayName}}</b>\n </div>\n @if (!isReadOnly) {\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(input) : undefined\"\n [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n [(ngModel)]=\"input\"\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 [(ngModel)]=\"time\"\n >\n @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n }\n \n </mat-select>\n <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n </mat-form-field>\n </div>\n <div class=\"buttons\">\n <button type=\"button\" mat-raised-button\n [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n (click)=\"addDateTime()\">\n {{metadata.addButtonLabel}}\n </button>\n <button type=\"button\" mat-raised-button\n [disabled]=\"!selected.length\"\n (click)=\"remove()\">\n {{metadata.removeButtonLabel}}\n </button>\n </div>\n }\n\n <custom-table\n [configuration]=\"tableConfig\"\n [data]=\"propertyValue\"\n [required]=\"metadata.required(entity)\"\n (selectionChanged)=\"selected = $any($event)\"\n >\n </custom-table>\n</div>", styles: ["mat-form-field{width:100%}.buttons{display:flex;justify-content:space-between;margin-bottom:10px;margin-top:5px;flex-wrap:wrap;gap:10px}.buttons button{flex-grow:1}.elevation-container{border-radius:5px;padding:15px 15px 0;margin-bottom:15px;margin-top:15px}.array-headline{padding-bottom:10px}.date-time{display:flex;align-items:baseline;flex-wrap:wrap;column-gap:10px}\n"] }]
78
+ }], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.HttpClient }, { type: undefined, decorators: [{
83
79
  type: Inject,
84
80
  args: [NGX_COMPLETE_GLOBAL_DEFAULT_VALUES]
85
81
  }] }] });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-date-time-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-time-input/array-date-time-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-time-input/array-date-time-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor, NgIf } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, EnvironmentInjector, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatTableModule } from '@angular/material/table';\n\nimport { BaseEntityType } from '../../../../classes/entity.model';\nimport { DateTimeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../../../decorators/base/dropdown-value.interface';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities, Time } from '../../../../utilities/date.utilities';\nimport { ArrayTableComponent } from '../array-table.class';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-date-time-input',\n    templateUrl: './array-date-time-input.component.html',\n    styleUrls: ['./array-date-time-input.component.scss'],\n    standalone: true,\n    imports: [\n        NgIf,\n        MatFormFieldModule,\n        FormsModule,\n        MatDatepickerModule,\n        MatSelectModule,\n        MatTableModule,\n        MatCheckboxModule,\n        MatInputModule,\n        MatButtonModule,\n        NgFor\n    ]\n})\nexport class ArrayDateTimeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayTableComponent<Date, EntityType, DecoratorTypes.ARRAY_DATE_TIME> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    dateTime?: Date;\n    time?: Time;\n    timeDropdownValues!: DropdownValue<Time>[];\n\n    constructor(\n        matDialog: MatDialog,\n        injector: EnvironmentInjector,\n        http: HttpClient,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super(matDialog, injector, http);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateTimeArrayDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        this.time = DateUtilities.getTimeFromDate(this.entity[this.key] as Date);\n        this.timeDropdownValues = this.metadata.times;\n        if (this.entity[this.key] != undefined) {\n            this.dateTime = new Date(this.entity[this.key] as Date);\n        }\n    }\n\n    protected override resetInput(): void {\n        this.input = undefined;\n        this.time = undefined;\n    }\n\n    /**\n     * Adds a date time to the array.\n     */\n    addDateTime(): void {\n        if (this.input && this.time) {\n            this.input = new Date(this.input);\n            this.input.setHours(this.time.hours, this.time.minutes, 0, 0);\n            this.add();\n        }\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n    <div class=\"array-headline\">\n        <b>{{metadata.displayName}}</b>\n    </div>\n    @if (!isReadOnly) {\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(input) : undefined\"\n                    [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n                    [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n                    [(ngModel)]=\"input\"\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                    [(ngModel)]=\"time\"\n                >\n                    @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n                        <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n                    }\n                    \n                </mat-select>\n                <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n            </mat-form-field>\n        </div>\n        <div class=\"buttons\">\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n                (click)=\"addDateTime()\">\n                {{metadata.addButtonLabel}}\n            </button>\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"!selection.selected.length\"\n                (click)=\"remove()\">\n                {{metadata.removeButtonLabel}}\n            </button>\n        </div>\n    }\n\n    <mat-table [dataSource]=\"dataSource\">\n        <!-- select Column -->\n        <ng-container matColumnDef=\"select\">\n            <mat-header-cell *matHeaderCellDef>\n                <mat-checkbox [disabled]=\"!dataSource.data.length\" [checked]=\"selection.hasValue() && SelectionUtilities.isAllSelected(selection, dataSource)\" [indeterminate]=\"selection.hasValue() && !SelectionUtilities.isAllSelected(selection, dataSource)\" (change)=\"$event ? SelectionUtilities.masterToggle(selection, dataSource) : null\"></mat-checkbox>\n            </mat-header-cell>\n            <mat-cell *matCellDef=\"let entity\">\n                <mat-checkbox [checked]=\"selection.isSelected(entity)\" (click)=\"$event.stopPropagation()\" (change)=\"$event ? selection.toggle(entity) : null\"></mat-checkbox>\n            </mat-cell>\n        </ng-container>\n    \n        @for (dCol of metadata.displayColumns; track $index) {\n            <ng-container [matColumnDef]=\"dCol.displayName\">\n                <mat-header-cell *matHeaderCellDef>\n                    {{dCol.displayName}}\n                </mat-header-cell>\n                <mat-cell *matCellDef=\"let entity\" class=\"entity\">\n                    {{getDisplayColumnValue(entity, dCol)}}\n                </mat-cell>\n            </ng-container>\n        }\n    \n        <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n        <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n    </mat-table>\n\n    @if (metadata.required(entity) && !dataSource.data.length) {\n        <div class=\"array-error\">{{metadata.missingErrorMessage}}</div>\n    }\n</div>"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-date-time-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-time-input/array-date-time-input.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-date-time-input/array-date-time-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { HttpClient } from '@angular/common/http';\nimport { Component, Inject, OnInit } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatDialog } from '@angular/material/dialog';\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 { DateTimeArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { DecoratorTypes } from '../../../../decorators/base/decorator-types.enum';\nimport { DropdownValue } from '../../../../decorators/base/dropdown-value.interface';\nimport { ReflectUtilities } from '../../../../encapsulation/reflect.utilities';\nimport { NGX_COMPLETE_GLOBAL_DEFAULT_VALUES, NgxGlobalDefaultValues } from '../../../../global-configuration-values';\nimport { DateUtilities, Time } from '../../../../utilities/date.utilities';\nimport { CustomTableComponent } from '../../../custom-table/custom-table.component';\nimport { ArrayTableComponent } from '../array-table.class';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-date-time-input',\n    templateUrl: './array-date-time-input.component.html',\n    styleUrls: ['./array-date-time-input.component.scss'],\n    standalone: true,\n    imports: [\n        CommonModule,\n        MatFormFieldModule,\n        FormsModule,\n        MatDatepickerModule,\n        MatSelectModule,\n        MatInputModule,\n        MatButtonModule,\n        CustomTableComponent\n    ]\n})\nexport class ArrayDateTimeInputComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayTableComponent<Date, EntityType, DecoratorTypes.ARRAY_DATE_TIME> implements OnInit {\n\n    DateUtilities: typeof DateUtilities = DateUtilities;\n\n    dateTime?: Date;\n    time?: Time;\n    timeDropdownValues!: DropdownValue<Time>[];\n\n    constructor(\n        matDialog: MatDialog,\n        http: HttpClient,\n        @Inject(NGX_COMPLETE_GLOBAL_DEFAULT_VALUES)\n        private readonly globalConfig: NgxGlobalDefaultValues\n    ) {\n        super(matDialog, http);\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.metadata = new DateTimeArrayDecoratorConfigInternal(this.metadata, this.globalConfig);\n        ReflectUtilities.defineMetadata('metadata', this.metadata, this.entity, this.key);\n        this.time = DateUtilities.getTimeFromDate(this.entity[this.key] as Date);\n        this.timeDropdownValues = this.metadata.times;\n        if (this.entity[this.key] != undefined) {\n            this.dateTime = new Date(this.entity[this.key] as Date);\n        }\n        this.setTableConfig();\n    }\n\n    protected override resetInput(): void {\n        this.input = undefined;\n        this.time = undefined;\n    }\n\n    /**\n     * Adds a date time to the array.\n     */\n    async addDateTime(): Promise<void> {\n        if (this.input && this.time) {\n            this.input = new Date(this.input);\n            this.input.setHours(this.time.hours, this.time.minutes, 0, 0);\n            await this.add();\n        }\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n<div class=\"mat-elevation-z8 elevation-container\">\n    <div class=\"array-headline\">\n        <b>{{metadata.displayName}}</b>\n    </div>\n    @if (!isReadOnly) {\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(input) : undefined\"\n                    [max]=\"metadata.maxDate ? metadata.maxDate(input) : undefined\"\n                    [matDatepickerFilter]=\"metadata.filterDate ?? DateUtilities.defaultDateFilter\"\n                    [(ngModel)]=\"input\"\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                    [(ngModel)]=\"time\"\n                >\n                    @for (validTime of DateUtilities.getValidTimesForDropdown(metadata.times, input, metadata.minTime, metadata.maxTime, metadata.filterTime); track $index) {\n                        <mat-option [value]=\"validTime.value\">{{validTime.displayName}}</mat-option>\n                    }\n                    \n                </mat-select>\n                <mat-error>{{getValidationErrorMessage(timeModel)}}</mat-error>\n            </mat-form-field>\n        </div>\n        <div class=\"buttons\">\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"model.errors || timeModel.errors || DateUtilities.timeIsUnprocessable(time)\"\n                (click)=\"addDateTime()\">\n                {{metadata.addButtonLabel}}\n            </button>\n            <button type=\"button\" mat-raised-button\n                [disabled]=\"!selected.length\"\n                (click)=\"remove()\">\n                {{metadata.removeButtonLabel}}\n            </button>\n        </div>\n    }\n\n    <custom-table\n        [configuration]=\"tableConfig\"\n        [data]=\"propertyValue\"\n        [required]=\"metadata.required(entity)\"\n        (selectionChanged)=\"selected = $any($event)\"\n    >\n    </custom-table>\n</div>"]}
@@ -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, EnvironmentInjector, runInInjectionContext } from '@angular/core';
4
4
  import { FormsModule } from '@angular/forms';
5
5
  import { MatAutocompleteModule } from '@angular/material/autocomplete';
@@ -62,7 +62,7 @@ export class ArrayStringAutocompleteChipsComponent extends ArrayStringChipsInput
62
62
  this.filteredAutocompleteStrings = this.autocompleteStrings.filter(s => s.toLowerCase().includes(filterValue));
63
63
  }
64
64
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayStringAutocompleteChipsComponent, deps: [{ token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Component });
65
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayStringAutocompleteChipsComponent, isStandalone: true, selector: "array-string-autocomplete-chips", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\"\n [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 #chipsElement\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matAutocomplete]=\"auto\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [includedIn]=\"autocompleteMetadata.restrictToOptions ? autocompleteStrings : undefined\"\n [(ngModel)]=\"chipsInput\"\n (keyup)=\"filterAutocompleteStrings(chipsInput)\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event, chipsElement, model, chipsModel)\">\n @for (value of filteredAutocompleteStrings; track $index) {\n <mat-option [value]=\"value\">{{value}}</mat-option>\n }\n </mat-autocomplete>\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: MatAutocompleteModule }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: IncludedInValidatorDirective, selector: "[includedIn]", inputs: ["includedIn"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.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"] }] });
65
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0", type: ArrayStringAutocompleteChipsComponent, isStandalone: true, selector: "array-string-autocomplete-chips", usesInheritance: true, ngImport: i0, template: "<!-- eslint-disable angular/no-call-expression -->\n\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\"\n [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 #chipsElement\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matAutocomplete]=\"auto\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [includedIn]=\"autocompleteMetadata.restrictToOptions ? autocompleteStrings : undefined\"\n [(ngModel)]=\"chipsInput\"\n (keyup)=\"filterAutocompleteStrings(chipsInput)\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event, chipsElement, model, chipsModel)\">\n @for (value of filteredAutocompleteStrings; track $index) {\n <mat-option [value]=\"value\">{{value}}</mat-option>\n }\n </mat-autocomplete>\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: MatAutocompleteModule }, { kind: "component", type: i4.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i4.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: IncludedInValidatorDirective, selector: "[includedIn]", inputs: ["includedIn"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.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 }] });
66
66
  }
67
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: ArrayStringAutocompleteChipsComponent, decorators: [{
68
68
  type: Component,
@@ -73,7 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
73
73
  MatAutocompleteModule,
74
74
  IncludedInValidatorDirective,
75
75
  MatInputModule,
76
- NgFor
76
+ CommonModule
77
77
  ], template: "<!-- eslint-disable angular/no-call-expression -->\n\n<mat-form-field>\n <mat-label>{{metadata.displayName}}</mat-label>\n <mat-chip-grid #chipGrid\n #model=\"ngModel\" [name]=\"name\"\n [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 #chipsElement\n matInput\n [matChipInputFor]=\"chipGrid\"\n [matAutocomplete]=\"auto\"\n [matChipInputAddOnBlur]=\"true\"\n [name]=\"uuid2\"\n [minlength]=\"metadata.minLength ?? null\"\n [maxlength]=\"metadata.maxLength ?? null\"\n [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n [includedIn]=\"autocompleteMetadata.restrictToOptions ? autocompleteStrings : undefined\"\n [(ngModel)]=\"chipsInput\"\n (keyup)=\"filterAutocompleteStrings(chipsInput)\"\n (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n />\n </mat-chip-grid>\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event, chipsElement, model, chipsModel)\">\n @for (value of filteredAutocompleteStrings; track $index) {\n <mat-option [value]=\"value\">{{value}}</mat-option>\n }\n </mat-autocomplete>\n <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>", styles: ["mat-form-field{width:100%}\n"] }]
78
78
  }], ctorParameters: () => [{ type: i0.EnvironmentInjector }] });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-string-autocomplete-chips.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,SAAS,EAAE,mBAAmB,EAAU,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAE,WAAW,EAAW,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,qBAAqB,EAAgC,MAAM,gCAAgC,CAAC;AACrG,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzD,OAAO,EAAE,4BAA4B,EAAE,MAAM,8CAA8C,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAC7E,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;;;;;;;;AAkBhH,MAAM,OAAO,qCACT,SAAQ,8BAA0C;IASrB;IAP7B,2BAA2B,CAAY;IACvC,mBAAmB,GAAa,EAAE,CAAC;IAEnC,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,QAA0E,CAAC;IAC3F,CAAC;IAED,YAA6B,QAA6B;QACtD,KAAK,EAAE,CAAC;QADiB,aAAQ,GAAR,QAAQ,CAAqB;IAE1D,CAAC;IAEQ,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,KAAK,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;YACjD,IAAI,CAAC,mBAAmB,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3F,IAAI,CAAC,2BAA2B,GAAG,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC3F,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;OAMG;IACH,QAAQ,CAAC,KAAmC,EAAE,UAA4B,EAAE,KAAc,EAAE,UAAmB;QAC3G,8DAA8D;QAC9D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAe,CAAC,CAAC;QACtD,UAAU,CAAC,KAAK,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,UAAU,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;QAC5C,KAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;QACvC,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAC5C,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED;;;OAGG;IACH,yBAAyB,CAAC,KAAa;QACnC,MAAM,WAAW,GAAW,KAAK,CAAC,WAAW,EAAE,CAAC;QAChD,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC;IACnH,CAAC;uGAjDQ,qCAAqC;2FAArC,qCAAqC,kHC/BlD,+0DAyCiB,qFDnBT,kBAAkB,uYAClB,cAAc,4uBACd,WAAW,0yCACX,qBAAqB,y1BACrB,4BAA4B,gFAC5B,cAAc;;2FAIT,qCAAqC;kBAhBjD,SAAS;+BAEI,iCAAiC,cAG/B,IAAI,WACP;wBACL,kBAAkB;wBAClB,cAAc;wBACd,WAAW;wBACX,qBAAqB;wBACrB,4BAA4B;wBAC5B,cAAc;wBACd,KAAK;qBACR","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { NgFor } from '@angular/common';\nimport { Component, EnvironmentInjector, OnInit, runInInjectionContext } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { 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 { AutocompleteStringChipsArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { IncludedInValidatorDirective } from '../../../../directives/included-in.directive';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { ArrayStringChipsInputComponent } from '../array-string-chips-input/array-string-chips-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-string-autocomplete-chips',\n    templateUrl: './array-string-autocomplete-chips.component.html',\n    styleUrls: ['./array-string-autocomplete-chips.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatChipsModule,\n        FormsModule,\n        MatAutocompleteModule,\n        IncludedInValidatorDirective,\n        MatInputModule,\n        NgFor\n    ]\n})\nexport class ArrayStringAutocompleteChipsComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayStringChipsInputComponent<EntityType> implements OnInit {\n\n    filteredAutocompleteStrings!: string[];\n    autocompleteStrings: string[] = [];\n\n    get autocompleteMetadata(): AutocompleteStringChipsArrayDecoratorConfigInternal {\n        return this.metadata as unknown as AutocompleteStringChipsArrayDecoratorConfigInternal;\n    }\n\n    constructor(private readonly injector: EnvironmentInjector) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        void runInInjectionContext(this.injector, async () => {\n            this.autocompleteStrings = await this.autocompleteMetadata.autocompleteValues(this.entity);\n            this.filteredAutocompleteStrings = LodashUtilities.cloneDeep(this.autocompleteStrings);\n        });\n    }\n\n    /**\n     * Handles adding a string to the array when an autocomplete value has been selected.\n     * @param event - The autocomplete selected event.\n     * @param chipsInput - The element where the user typed the value.\n     * @param model - The model of the string array.\n     * @param chipsModel - The model of the single string input.\n     */\n    selected(event: MatAutocompleteSelectedEvent, chipsInput: HTMLInputElement, model: NgModel, chipsModel: NgModel): void {\n        // validation is not needed as selected options are all valid.\n        this.propertyValue = this.propertyValue ?? [];\n        this.propertyValue.push(event.option.value as string);\n        chipsInput.value = '';\n        this.chipsInput = '';\n        this.filterAutocompleteStrings(this.chipsInput);\n        chipsModel.control.updateValueAndValidity();\n        model.control.updateValueAndValidity();\n        this.setValidationErrors(model, chipsModel);\n        this.emitChange();\n    }\n\n    /**\n     * Dynamically filters the Autocomplete options when the user inputs something.\n     * @param input - The input of the user.\n     */\n    filterAutocompleteStrings(input: string): void {\n        const filterValue: string = input.toLowerCase();\n        this.filteredAutocompleteStrings = this.autocompleteStrings.filter(s => s.toLowerCase().includes(filterValue));\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        #model=\"ngModel\" [name]=\"name\"\n        [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            #chipsElement\n            matInput\n            [matChipInputFor]=\"chipGrid\"\n            [matAutocomplete]=\"auto\"\n            [matChipInputAddOnBlur]=\"true\"\n            [name]=\"uuid2\"\n            [minlength]=\"metadata.minLength ?? null\"\n            [maxlength]=\"metadata.maxLength ?? null\"\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n            [includedIn]=\"autocompleteMetadata.restrictToOptions ? autocompleteStrings : undefined\"\n            [(ngModel)]=\"chipsInput\"\n            (keyup)=\"filterAutocompleteStrings(chipsInput)\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n        />\n    </mat-chip-grid>\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event, chipsElement, model, chipsModel)\">\n        @for (value of filteredAutocompleteStrings; track $index) {\n            <mat-option [value]=\"value\">{{value}}</mat-option>\n        }\n    </mat-autocomplete>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array-string-autocomplete-chips.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.ts","../../../../../../../projects/ngx-material-entity/src/components/input/array/array-string-autocomplete-chips/array-string-autocomplete-chips.component.html"],"names":[],"mappings":"AAAA,wCAAwC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,mBAAmB,EAAU,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAE,WAAW,EAAW,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,qBAAqB,EAAgC,MAAM,gCAAgC,CAAC;AACrG,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIzD,OAAO,EAAE,4BAA4B,EAAE,MAAM,8CAA8C,CAAC;AAC5F,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAC;AAC7E,OAAO,EAAE,8BAA8B,EAAE,MAAM,gEAAgE,CAAC;;;;;;;;AAkBhH,MAAM,OAAO,qCACT,SAAQ,8BAA0C;IASrB;IAP7B,2BAA2B,CAAY;IACvC,mBAAmB,GAAa,EAAE,CAAC;IAEnC,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,QAA0E,CAAC;IAC3F,CAAC;IAED,YAA6B,QAA6B;QACtD,KAAK,EAAE,CAAC;QADiB,aAAQ,GAAR,QAAQ,CAAqB;IAE1D,CAAC;IAEQ,QAAQ;QACb,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,KAAK,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;YACjD,IAAI,CAAC,mBAAmB,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3F,IAAI,CAAC,2BAA2B,GAAG,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC3F,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;OAMG;IACH,QAAQ,CAAC,KAAmC,EAAE,UAA4B,EAAE,KAAc,EAAE,UAAmB;QAC3G,8DAA8D;QAC9D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAe,CAAC,CAAC;QACtD,UAAU,CAAC,KAAK,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChD,UAAU,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;QAC5C,KAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;QACvC,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QAC5C,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED;;;OAGG;IACH,yBAAyB,CAAC,KAAa;QACnC,MAAM,WAAW,GAAW,KAAK,CAAC,WAAW,EAAE,CAAC;QAChD,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC;IACnH,CAAC;uGAjDQ,qCAAqC;2FAArC,qCAAqC,kHC/BlD,+0DAyCiB,qFDnBT,kBAAkB,uYAClB,cAAc,4uBACd,WAAW,0yCACX,qBAAqB,y1BACrB,4BAA4B,gFAC5B,cAAc,0WACd,YAAY;;2FAGP,qCAAqC;kBAhBjD,SAAS;+BAEI,iCAAiC,cAG/B,IAAI,WACP;wBACL,kBAAkB;wBAClB,cAAc;wBACd,WAAW;wBACX,qBAAqB;wBACrB,4BAA4B;wBAC5B,cAAc;wBACd,YAAY;qBACf","sourcesContent":["/* eslint-disable jsdoc/require-jsdoc */\nimport { CommonModule } from '@angular/common';\nimport { Component, EnvironmentInjector, OnInit, runInInjectionContext } from '@angular/core';\nimport { FormsModule, NgModel } from '@angular/forms';\nimport { MatAutocompleteModule, MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { 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 { AutocompleteStringChipsArrayDecoratorConfigInternal } from '../../../../decorators/array/array-decorator-internal.data';\nimport { IncludedInValidatorDirective } from '../../../../directives/included-in.directive';\nimport { LodashUtilities } from '../../../../encapsulation/lodash.utilities';\nimport { ArrayStringChipsInputComponent } from '../array-string-chips-input/array-string-chips-input.component';\n\n@Component({\n    // eslint-disable-next-line angular/component-selector\n    selector: 'array-string-autocomplete-chips',\n    templateUrl: './array-string-autocomplete-chips.component.html',\n    styleUrls: ['./array-string-autocomplete-chips.component.scss'],\n    standalone: true,\n    imports: [\n        MatFormFieldModule,\n        MatChipsModule,\n        FormsModule,\n        MatAutocompleteModule,\n        IncludedInValidatorDirective,\n        MatInputModule,\n        CommonModule\n    ]\n})\nexport class ArrayStringAutocompleteChipsComponent<EntityType extends BaseEntityType<EntityType>>\n    extends ArrayStringChipsInputComponent<EntityType> implements OnInit {\n\n    filteredAutocompleteStrings!: string[];\n    autocompleteStrings: string[] = [];\n\n    get autocompleteMetadata(): AutocompleteStringChipsArrayDecoratorConfigInternal {\n        return this.metadata as unknown as AutocompleteStringChipsArrayDecoratorConfigInternal;\n    }\n\n    constructor(private readonly injector: EnvironmentInjector) {\n        super();\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        void runInInjectionContext(this.injector, async () => {\n            this.autocompleteStrings = await this.autocompleteMetadata.autocompleteValues(this.entity);\n            this.filteredAutocompleteStrings = LodashUtilities.cloneDeep(this.autocompleteStrings);\n        });\n    }\n\n    /**\n     * Handles adding a string to the array when an autocomplete value has been selected.\n     * @param event - The autocomplete selected event.\n     * @param chipsInput - The element where the user typed the value.\n     * @param model - The model of the string array.\n     * @param chipsModel - The model of the single string input.\n     */\n    selected(event: MatAutocompleteSelectedEvent, chipsInput: HTMLInputElement, model: NgModel, chipsModel: NgModel): void {\n        // validation is not needed as selected options are all valid.\n        this.propertyValue = this.propertyValue ?? [];\n        this.propertyValue.push(event.option.value as string);\n        chipsInput.value = '';\n        this.chipsInput = '';\n        this.filterAutocompleteStrings(this.chipsInput);\n        chipsModel.control.updateValueAndValidity();\n        model.control.updateValueAndValidity();\n        this.setValidationErrors(model, chipsModel);\n        this.emitChange();\n    }\n\n    /**\n     * Dynamically filters the Autocomplete options when the user inputs something.\n     * @param input - The input of the user.\n     */\n    filterAutocompleteStrings(input: string): void {\n        const filterValue: string = input.toLowerCase();\n        this.filteredAutocompleteStrings = this.autocompleteStrings.filter(s => s.toLowerCase().includes(filterValue));\n    }\n}","<!-- eslint-disable angular/no-call-expression -->\n\n<mat-form-field>\n    <mat-label>{{metadata.displayName}}</mat-label>\n    <mat-chip-grid #chipGrid\n        #model=\"ngModel\" [name]=\"name\"\n        [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            #chipsElement\n            matInput\n            [matChipInputFor]=\"chipGrid\"\n            [matAutocomplete]=\"auto\"\n            [matChipInputAddOnBlur]=\"true\"\n            [name]=\"uuid2\"\n            [minlength]=\"metadata.minLength ?? null\"\n            [maxlength]=\"metadata.maxLength ?? null\"\n            [pattern]=\"metadata.regex ?? '[\\\\s\\\\S]*'\"\n            [includedIn]=\"autocompleteMetadata.restrictToOptions ? autocompleteStrings : undefined\"\n            [(ngModel)]=\"chipsInput\"\n            (keyup)=\"filterAutocompleteStrings(chipsInput)\"\n            (matChipInputTokenEnd)=\"addStringChipArrayValue($event, !!chipsModel.errors)\"\n        />\n    </mat-chip-grid>\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"selected($event, chipsElement, model, chipsModel)\">\n        @for (value of filteredAutocompleteStrings; track $index) {\n            <mat-option [value]=\"value\">{{value}}</mat-option>\n        }\n    </mat-autocomplete>\n    <mat-error>{{getValidationErrorMessage(model)}}</mat-error>\n</mat-form-field>"]}