ngx-st-tables 17.0.64 → 17.0.65

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.
@@ -0,0 +1,302 @@
1
+ import { ChangeDetectionStrategy, Component, input, output, } from '@angular/core';
2
+ import { StSubscribeDestroyComponent } from 'ngx-st-base-functions';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../../../services/st-tables-translations.service";
5
+ import * as i2 from "@angular/forms";
6
+ import * as i3 from "@angular/material/form-field";
7
+ import * as i4 from "@angular/material/input";
8
+ import * as i5 from "@angular/material/select";
9
+ import * as i6 from "@angular/material/core";
10
+ import * as i7 from "@angular/material/datepicker";
11
+ export class MaterialTableFilterComponent extends StSubscribeDestroyComponent {
12
+ constructor(stTableTranslations, fb) {
13
+ super();
14
+ this.stTableTranslations = stTableTranslations;
15
+ this.fb = fb;
16
+ this.column = input.required({});
17
+ this.filterValue = input({}, {
18
+ transform: (filterValue) => {
19
+ this.setFilterValue(filterValue);
20
+ return filterValue || {};
21
+ },
22
+ });
23
+ this.filterValueChanged = output();
24
+ this.formGroup = this.fb.group({
25
+ matchMode: {
26
+ value: 'contains',
27
+ disabled: true,
28
+ },
29
+ value: '',
30
+ dateFrom: null,
31
+ dateTo: null,
32
+ });
33
+ this.isUpdatingFromOutside = false;
34
+ }
35
+ ngOnInit() {
36
+ this.formGroup.valueChanges.subscribe(() => {
37
+ if (!this.isUpdatingFromOutside) {
38
+ this.updateAfterFormValueChanged();
39
+ }
40
+ });
41
+ // this.filtersValue.subscribe(filtersValue => {
42
+ // console.log('Filters updated child');
43
+ // });
44
+ }
45
+ setFilterValue(newFilterValue) {
46
+ if (newFilterValue) {
47
+ this.formGroup.controls.matchMode.setValue(newFilterValue.matchMode, {
48
+ emitEvent: false,
49
+ });
50
+ if (this.column().filterType === 'date') {
51
+ const tmpValue = newFilterValue.value;
52
+ this.formGroup.controls.dateFrom.setValue(tmpValue[0] ? new Date(tmpValue[0]) : null, { emitEvent: false });
53
+ this.formGroup.controls.dateTo.setValue(tmpValue[1] ? new Date(tmpValue[1]) : null, { emitEvent: false });
54
+ }
55
+ else {
56
+ this.formGroup.controls.value.setValue(newFilterValue.value || '', { emitEvent: false });
57
+ }
58
+ }
59
+ }
60
+ updateAfterFormValueChanged() {
61
+ const tmpValue = this.column().filterType === 'date'
62
+ ? [
63
+ this.formGroup.controls.dateFrom.value
64
+ ? this.formGroup.controls.dateFrom.value.toISOString()
65
+ : null,
66
+ this.formGroup.controls.dateTo.value
67
+ ? this.formGroup.controls.dateTo.value.toISOString()
68
+ : null,
69
+ ]
70
+ : this.formGroup.controls.value.value;
71
+ const newFilter = {
72
+ matchMode: this.formGroup.controls.matchMode.value,
73
+ value: tmpValue,
74
+ };
75
+ this.filterValueChanged.emit(newFilter);
76
+ // const newValue = {
77
+ // ...this.filtersValue(),
78
+ // [this.column().field]: newFilter,
79
+ // };
80
+ //
81
+ // this.filtersValue.set(newValue);
82
+ }
83
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialTableFilterComponent, deps: [{ token: i1.StTablesTranslationsService }, { token: i2.NonNullableFormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
84
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MaterialTableFilterComponent, selector: "ngx-st-material-table-filter", inputs: { column: { classPropertyName: "column", publicName: "column", isSignal: true, isRequired: true, transformFunction: null }, filterValue: { classPropertyName: "filterValue", publicName: "filterValue", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filterValueChanged: "filterValueChanged" }, usesInheritance: true, ngImport: i0, template: `
85
+ <form class="row" [formGroup]="formGroup" style="width: 100%;">
86
+ <div class="col-auto">
87
+ <mat-form-field appearance="outline" style="width: 120px">
88
+ <mat-label>
89
+ {{ stTableTranslations.getTranslations()().matchMode }}</mat-label
90
+ >
91
+ <input matInput type="text" [formControlName]="'matchMode'" />
92
+ </mat-form-field>
93
+ </div>
94
+
95
+ @if (
96
+ column().filterType === 'string' || column().filterType === 'number'
97
+ ) {
98
+ <div class="col">
99
+ <mat-form-field appearance="outline" style="width: 100%">
100
+ <mat-label>{{
101
+ stTableTranslations.getTranslations()().searchFilter
102
+ }}</mat-label>
103
+ <input
104
+ matInput
105
+ [type]="column().filterType === 'string' ? 'text' : 'number'"
106
+ [formControlName]="'value'"
107
+ />
108
+ </mat-form-field>
109
+ </div>
110
+ }
111
+
112
+ @if (column().filterType === 'date') {
113
+ <div class="col">
114
+ <mat-form-field appearance="outline" style="width: 170px">
115
+ <mat-label>{{
116
+ stTableTranslations.getTranslations()().dateFrom
117
+ }}</mat-label>
118
+ <input
119
+ matInput
120
+ [matDatepicker]="picker1"
121
+ [formControlName]="'dateFrom'"
122
+ />
123
+ <mat-datepicker-toggle
124
+ matIconSuffix
125
+ [for]="picker1"
126
+ ></mat-datepicker-toggle>
127
+ <mat-datepicker #picker1></mat-datepicker>
128
+ </mat-form-field>
129
+ </div>
130
+ <div class="col">
131
+ <mat-form-field appearance="outline" style="width: 170px">
132
+ <mat-label>{{
133
+ stTableTranslations.getTranslations()().dateTo
134
+ }}</mat-label>
135
+ <input
136
+ matInput
137
+ [matDatepicker]="picker2"
138
+ [formControlName]="'dateTo'"
139
+ />
140
+ <mat-datepicker-toggle
141
+ matIconSuffix
142
+ [for]="picker2"
143
+ ></mat-datepicker-toggle>
144
+ <mat-datepicker #picker2></mat-datepicker>
145
+ </mat-form-field>
146
+ </div>
147
+ }
148
+
149
+ @if (column().filterType === 'boolean') {
150
+ <div class="col">
151
+ <mat-form-field appearance="outline" style="width: 100%">
152
+ <mat-label>{{
153
+ stTableTranslations.getTranslations()().booleanPickValue
154
+ }}</mat-label>
155
+ <mat-select [formControlName]="'value'">
156
+ <mat-option value="">{{
157
+ stTableTranslations.getTranslations()().booleanNone
158
+ }}</mat-option>
159
+ <mat-option [value]="true">{{
160
+ stTableTranslations.getTranslations()().booleanYes
161
+ }}</mat-option>
162
+ <mat-option [value]="false">{{
163
+ stTableTranslations.getTranslations()().booleanNo
164
+ }}</mat-option>
165
+ </mat-select>
166
+ </mat-form-field>
167
+ </div>
168
+ }
169
+
170
+ @if (column().filterType === 'custom') {
171
+ <div class="col">
172
+ <mat-form-field appearance="outline" style="width: 100%">
173
+ <mat-label>{{
174
+ stTableTranslations.getTranslations()().customPickValue
175
+ }}</mat-label>
176
+ <mat-select [formControlName]="'value'">
177
+ <mat-option value="">{{
178
+ stTableTranslations.getTranslations()().customNone
179
+ }}</mat-option>
180
+ @for (option of column().customFilterOptions; track option) {
181
+ <mat-option [value]="option.value">
182
+ {{ option.label }}
183
+ </mat-option>
184
+ }
185
+ </mat-select>
186
+ </mat-form-field>
187
+ </div>
188
+ }
189
+ </form>
190
+ `, isInline: true, styles: [":host{width:100%}form.row{gap:8px}form.row>:is(.col-auto,.col){padding:0}\n"], dependencies: [{ 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.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "component", type: i7.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i7.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i7.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
191
+ }
192
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialTableFilterComponent, decorators: [{
193
+ type: Component,
194
+ args: [{ selector: 'ngx-st-material-table-filter', template: `
195
+ <form class="row" [formGroup]="formGroup" style="width: 100%;">
196
+ <div class="col-auto">
197
+ <mat-form-field appearance="outline" style="width: 120px">
198
+ <mat-label>
199
+ {{ stTableTranslations.getTranslations()().matchMode }}</mat-label
200
+ >
201
+ <input matInput type="text" [formControlName]="'matchMode'" />
202
+ </mat-form-field>
203
+ </div>
204
+
205
+ @if (
206
+ column().filterType === 'string' || column().filterType === 'number'
207
+ ) {
208
+ <div class="col">
209
+ <mat-form-field appearance="outline" style="width: 100%">
210
+ <mat-label>{{
211
+ stTableTranslations.getTranslations()().searchFilter
212
+ }}</mat-label>
213
+ <input
214
+ matInput
215
+ [type]="column().filterType === 'string' ? 'text' : 'number'"
216
+ [formControlName]="'value'"
217
+ />
218
+ </mat-form-field>
219
+ </div>
220
+ }
221
+
222
+ @if (column().filterType === 'date') {
223
+ <div class="col">
224
+ <mat-form-field appearance="outline" style="width: 170px">
225
+ <mat-label>{{
226
+ stTableTranslations.getTranslations()().dateFrom
227
+ }}</mat-label>
228
+ <input
229
+ matInput
230
+ [matDatepicker]="picker1"
231
+ [formControlName]="'dateFrom'"
232
+ />
233
+ <mat-datepicker-toggle
234
+ matIconSuffix
235
+ [for]="picker1"
236
+ ></mat-datepicker-toggle>
237
+ <mat-datepicker #picker1></mat-datepicker>
238
+ </mat-form-field>
239
+ </div>
240
+ <div class="col">
241
+ <mat-form-field appearance="outline" style="width: 170px">
242
+ <mat-label>{{
243
+ stTableTranslations.getTranslations()().dateTo
244
+ }}</mat-label>
245
+ <input
246
+ matInput
247
+ [matDatepicker]="picker2"
248
+ [formControlName]="'dateTo'"
249
+ />
250
+ <mat-datepicker-toggle
251
+ matIconSuffix
252
+ [for]="picker2"
253
+ ></mat-datepicker-toggle>
254
+ <mat-datepicker #picker2></mat-datepicker>
255
+ </mat-form-field>
256
+ </div>
257
+ }
258
+
259
+ @if (column().filterType === 'boolean') {
260
+ <div class="col">
261
+ <mat-form-field appearance="outline" style="width: 100%">
262
+ <mat-label>{{
263
+ stTableTranslations.getTranslations()().booleanPickValue
264
+ }}</mat-label>
265
+ <mat-select [formControlName]="'value'">
266
+ <mat-option value="">{{
267
+ stTableTranslations.getTranslations()().booleanNone
268
+ }}</mat-option>
269
+ <mat-option [value]="true">{{
270
+ stTableTranslations.getTranslations()().booleanYes
271
+ }}</mat-option>
272
+ <mat-option [value]="false">{{
273
+ stTableTranslations.getTranslations()().booleanNo
274
+ }}</mat-option>
275
+ </mat-select>
276
+ </mat-form-field>
277
+ </div>
278
+ }
279
+
280
+ @if (column().filterType === 'custom') {
281
+ <div class="col">
282
+ <mat-form-field appearance="outline" style="width: 100%">
283
+ <mat-label>{{
284
+ stTableTranslations.getTranslations()().customPickValue
285
+ }}</mat-label>
286
+ <mat-select [formControlName]="'value'">
287
+ <mat-option value="">{{
288
+ stTableTranslations.getTranslations()().customNone
289
+ }}</mat-option>
290
+ @for (option of column().customFilterOptions; track option) {
291
+ <mat-option [value]="option.value">
292
+ {{ option.label }}
293
+ </mat-option>
294
+ }
295
+ </mat-select>
296
+ </mat-form-field>
297
+ </div>
298
+ }
299
+ </form>
300
+ `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{width:100%}form.row{gap:8px}form.row>:is(.col-auto,.col){padding:0}\n"] }]
301
+ }], ctorParameters: () => [{ type: i1.StTablesTranslationsService }, { type: i2.NonNullableFormBuilder }] });
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table-filter.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-caption/material-table-filter-dialog/material-table-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  input,\r\n  model,\r\n  OnInit,\r\n  effect,\r\n  output,\r\n} from '@angular/core';\r\nimport { StTablesTranslationsService } from '../../../../services/st-tables-translations.service';\r\nimport { ViewStMaterialTableColumnModel } from '../../../../models/view/view-st-material-table-column.model';\r\nimport { NonNullableFormBuilder } from '@angular/forms';\r\nimport { StSubscribeDestroyComponent } from 'ngx-st-base-functions';\r\nimport {\r\n  StMaterialTableFilter,\r\n  StMaterialTableFilterMatchModeType,\r\n} from '../../../../models/models';\r\n\r\n@Component({\r\n  selector: 'ngx-st-material-table-filter',\r\n  template: `\r\n    <form class=\"row\" [formGroup]=\"formGroup\" style=\"width: 100%;\">\r\n      <div class=\"col-auto\">\r\n        <mat-form-field appearance=\"outline\" style=\"width: 120px\">\r\n          <mat-label>\r\n            {{ stTableTranslations.getTranslations()().matchMode }}</mat-label\r\n          >\r\n          <input matInput type=\"text\" [formControlName]=\"'matchMode'\" />\r\n        </mat-form-field>\r\n      </div>\r\n\r\n      @if (\r\n        column().filterType === 'string' || column().filterType === 'number'\r\n      ) {\r\n        <div class=\"col\">\r\n          <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n            <mat-label>{{\r\n              stTableTranslations.getTranslations()().searchFilter\r\n            }}</mat-label>\r\n            <input\r\n              matInput\r\n              [type]=\"column().filterType === 'string' ? 'text' : 'number'\"\r\n              [formControlName]=\"'value'\"\r\n            />\r\n          </mat-form-field>\r\n        </div>\r\n      }\r\n\r\n      @if (column().filterType === 'date') {\r\n        <div class=\"col\">\r\n          <mat-form-field appearance=\"outline\" style=\"width: 170px\">\r\n            <mat-label>{{\r\n              stTableTranslations.getTranslations()().dateFrom\r\n            }}</mat-label>\r\n            <input\r\n              matInput\r\n              [matDatepicker]=\"picker1\"\r\n              [formControlName]=\"'dateFrom'\"\r\n            />\r\n            <mat-datepicker-toggle\r\n              matIconSuffix\r\n              [for]=\"picker1\"\r\n            ></mat-datepicker-toggle>\r\n            <mat-datepicker #picker1></mat-datepicker>\r\n          </mat-form-field>\r\n        </div>\r\n        <div class=\"col\">\r\n          <mat-form-field appearance=\"outline\" style=\"width: 170px\">\r\n            <mat-label>{{\r\n              stTableTranslations.getTranslations()().dateTo\r\n            }}</mat-label>\r\n            <input\r\n              matInput\r\n              [matDatepicker]=\"picker2\"\r\n              [formControlName]=\"'dateTo'\"\r\n            />\r\n            <mat-datepicker-toggle\r\n              matIconSuffix\r\n              [for]=\"picker2\"\r\n            ></mat-datepicker-toggle>\r\n            <mat-datepicker #picker2></mat-datepicker>\r\n          </mat-form-field>\r\n        </div>\r\n      }\r\n\r\n      @if (column().filterType === 'boolean') {\r\n        <div class=\"col\">\r\n          <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n            <mat-label>{{\r\n              stTableTranslations.getTranslations()().booleanPickValue\r\n            }}</mat-label>\r\n            <mat-select [formControlName]=\"'value'\">\r\n              <mat-option value=\"\">{{\r\n                stTableTranslations.getTranslations()().booleanNone\r\n              }}</mat-option>\r\n              <mat-option [value]=\"true\">{{\r\n                stTableTranslations.getTranslations()().booleanYes\r\n              }}</mat-option>\r\n              <mat-option [value]=\"false\">{{\r\n                stTableTranslations.getTranslations()().booleanNo\r\n              }}</mat-option>\r\n            </mat-select>\r\n          </mat-form-field>\r\n        </div>\r\n      }\r\n\r\n      @if (column().filterType === 'custom') {\r\n        <div class=\"col\">\r\n          <mat-form-field appearance=\"outline\" style=\"width: 100%\">\r\n            <mat-label>{{\r\n              stTableTranslations.getTranslations()().customPickValue\r\n            }}</mat-label>\r\n            <mat-select [formControlName]=\"'value'\">\r\n              <mat-option value=\"\">{{\r\n                stTableTranslations.getTranslations()().customNone\r\n              }}</mat-option>\r\n              @for (option of column().customFilterOptions; track option) {\r\n                <mat-option [value]=\"option.value\">\r\n                  {{ option.label }}\r\n                </mat-option>\r\n              }\r\n            </mat-select>\r\n          </mat-form-field>\r\n        </div>\r\n      }\r\n    </form>\r\n  `,\r\n  styles: [\r\n    `\r\n      :host {\r\n        width: 100%;\r\n      }\r\n      form.row {\r\n        gap: 8px;\r\n\r\n        & > .col-auto,\r\n        & > .col {\r\n          padding: 0;\r\n        }\r\n      }\r\n    `,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class MaterialTableFilterComponent\r\n  extends StSubscribeDestroyComponent\r\n  implements OnInit\r\n{\r\n  column = input.required<ViewStMaterialTableColumnModel>({});\r\n  filterValue = input({} as StMaterialTableFilter, {\r\n    transform: (filterValue: StMaterialTableFilter) => {\r\n      this.setFilterValue(filterValue);\r\n      return filterValue || {};\r\n    },\r\n  });\r\n\r\n  filterValueChanged = output<StMaterialTableFilter>();\r\n\r\n  formGroup = this.fb.group({\r\n    matchMode: {\r\n      value: <StMaterialTableFilterMatchModeType>'contains',\r\n      disabled: true,\r\n    },\r\n    value: <null | string | number>'',\r\n    dateFrom: <null | Date>null,\r\n    dateTo: <null | Date>null,\r\n  });\r\n\r\n  constructor(\r\n    public stTableTranslations: StTablesTranslationsService,\r\n    private fb: NonNullableFormBuilder\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.formGroup.valueChanges.subscribe(() => {\r\n      if (!this.isUpdatingFromOutside) {\r\n        this.updateAfterFormValueChanged();\r\n      }\r\n    });\r\n    // this.filtersValue.subscribe(filtersValue => {\r\n    //   console.log('Filters updated child');\r\n    // });\r\n  }\r\n\r\n  private isUpdatingFromOutside = false;\r\n\r\n  private setFilterValue(newFilterValue: StMaterialTableFilter) {\r\n    if (newFilterValue) {\r\n      this.formGroup.controls.matchMode.setValue(newFilterValue.matchMode, {\r\n        emitEvent: false,\r\n      });\r\n\r\n      if (this.column().filterType === 'date') {\r\n        const tmpValue = newFilterValue.value as [string | null, string | null];\r\n        this.formGroup.controls.dateFrom.setValue(\r\n          tmpValue[0] ? new Date(tmpValue[0]!) : null,\r\n          { emitEvent: false }\r\n        );\r\n        this.formGroup.controls.dateTo.setValue(\r\n          tmpValue[1] ? new Date(tmpValue[1]) : null,\r\n          { emitEvent: false }\r\n        );\r\n      } else {\r\n        this.formGroup.controls.value.setValue(\r\n          (newFilterValue.value as string | number | null) || '',\r\n          { emitEvent: false }\r\n        );\r\n      }\r\n    }\r\n  }\r\n\r\n  private updateAfterFormValueChanged() {\r\n    const tmpValue =\r\n      this.column().filterType === 'date'\r\n        ? ([\r\n            this.formGroup.controls.dateFrom.value\r\n              ? this.formGroup.controls.dateFrom.value.toISOString()\r\n              : null,\r\n            this.formGroup.controls.dateTo.value\r\n              ? this.formGroup.controls.dateTo.value.toISOString()\r\n              : null,\r\n          ] as [string | null, string | null])\r\n        : this.formGroup.controls.value.value;\r\n\r\n    const newFilter: StMaterialTableFilter = {\r\n      matchMode: this.formGroup.controls.matchMode.value,\r\n      value: tmpValue,\r\n    };\r\n\r\n    this.filterValueChanged.emit(newFilter);\r\n    // const newValue = {\r\n    //   ...this.filtersValue(),\r\n    //   [this.column().field]: newFilter,\r\n    // };\r\n    //\r\n    // this.filtersValue.set(newValue);\r\n  }\r\n}\r\n"]}