ngx-st-tables 17.0.46 → 17.0.48

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.
@@ -1,181 +1,189 @@
1
- .st-material-table {
2
- .search-form {
3
- button {
4
- height: 40px;
5
- }
1
+ @mixin tableStyles() {
2
+ width: 100%;
3
+ box-shadow: none;
4
+
5
+ th.mat-mdc-header-cell,
6
+ td.mat-mdc-cell,
7
+ td.mat-mdc-footer-cell {
8
+ padding: 0;
9
+ }
6
10
 
7
- mat-form-field {
8
- &:first-child {
9
- padding-left: 0;
10
- }
11
+ th.mat-mdc-header-cell:first-of-type,
12
+ td.mat-mdc-cell:first-of-type,
13
+ td.mat-mdc-footer-cell:first-of-type {
14
+ padding-left: 12px;
15
+ }
11
16
 
12
- &:last-child {
13
- padding-right: 0;
14
- }
15
- }
17
+ th.mat-mdc-header-cell:last-of-type,
18
+ td.mat-mdc-cell:last-of-type,
19
+ td.mat-mdc-footer-cell:last-of-type {
20
+ padding-right: 12px;
21
+ }
16
22
 
17
- .clear {
18
- padding: 0;
23
+ thead {
24
+ tr {
25
+ background-color: #fff9c4;
26
+ height: 40px !important;
19
27
 
20
- mat-icon {
21
- height: 20px;
22
- width: 20px;
23
- font-size: 20px;
24
- cursor: pointer;
28
+ th {
29
+ border-color: #fdd835;
30
+ font-size: 0.9rem;
31
+ font-weight: 500;
32
+ color: #424242;
25
33
  }
26
34
  }
27
35
  }
28
36
 
29
- table {
30
- width: 100%;
31
- box-shadow: none;
32
-
33
- th.mat-mdc-header-cell,
34
- td.mat-mdc-cell,
35
- td.mat-mdc-footer-cell {
36
- padding: 0;
37
- }
38
-
39
- th.mat-mdc-header-cell:first-of-type,
40
- td.mat-mdc-cell:first-of-type,
41
- td.mat-mdc-footer-cell:first-of-type {
42
- padding-left: 12px;
43
- }
37
+ tbody {
38
+ background-color: transparent !important;
44
39
 
45
- th.mat-mdc-header-cell:last-of-type,
46
- td.mat-mdc-cell:last-of-type,
47
- td.mat-mdc-footer-cell:last-of-type {
48
- padding-right: 12px;
49
- }
40
+ & > tr {
41
+ cursor: pointer;
50
42
 
51
- thead {
52
- tr {
53
- background-color: #fff9c4;
54
- height: 40px !important;
43
+ &.active {
44
+ background-color: #a5d6a7;
55
45
 
56
- th {
57
- border-color: #fdd835;
58
- font-size: 0.9rem;
59
- font-weight: 500;
60
- color: #424242;
46
+ td {
47
+ border-bottom-color: #81c784 !important;
61
48
  }
62
49
  }
63
- }
64
50
 
65
- tbody {
66
- background-color: transparent !important;
51
+ &:hover {
52
+ background-color: #f5f5f5;
67
53
 
68
- & > tr {
69
- cursor: pointer;
54
+ //td {
55
+ // border-bottom-color: #81c784 !important;
56
+ //}
57
+ }
70
58
 
71
- &.active {
72
- background-color: #a5d6a7;
59
+ &.disabled {
60
+ cursor: not-allowed;
73
61
 
74
- td {
75
- border-bottom-color: #81c784 !important;
76
- }
62
+ &:hover {
63
+ background-color: inherit !important;
77
64
  }
65
+ }
78
66
 
79
- &:hover {
80
- background-color: #f5f5f5;
67
+ &.detail-row {
68
+ height: 0;
69
+ cursor: default;
81
70
 
82
- //td {
83
- // border-bottom-color: #81c784 !important;
84
- //}
71
+ &:hover {
72
+ background-color: transparent;
85
73
  }
86
74
 
87
- &.disabled {
88
- cursor: not-allowed;
75
+ .element-detail {
76
+ overflow: hidden;
77
+ display: flex;
89
78
 
90
- &:hover {
91
- background-color: inherit !important;
79
+ p {
80
+ padding: 20px 0;
81
+ margin-bottom: 0;
82
+ white-space: pre-wrap;
92
83
  }
93
84
  }
85
+ }
94
86
 
95
- &.detail-row {
96
- height: 0;
97
- cursor: default;
87
+ td {
88
+ i.active-row {
89
+ color: #1b5e20;
90
+ font-weight: bold;
91
+ font-size: 25px;
92
+ height: 25px;
93
+ width: 25px;
94
+ margin-top: 2px;
95
+ }
96
+ }
98
97
 
99
- &:hover {
100
- background-color: transparent;
98
+ td {
99
+ & > div {
100
+ max-height: 200px;
101
+ overflow: hidden;
102
+ overflow-y: auto;
103
+ }
104
+ a {
105
+ button {
106
+ color: #000;
101
107
  }
102
108
 
103
- .element-detail {
104
- overflow: hidden;
105
- display: flex;
106
-
107
- p {
108
- padding: 20px 0;
109
- margin-bottom: 0;
110
- white-space: pre-wrap;
111
- }
109
+ mat-icon {
110
+ color: #333;
112
111
  }
113
112
  }
113
+ }
114
+ }
115
+ }
114
116
 
115
- td {
116
- i.active-row {
117
- color: #1b5e20;
118
- font-weight: bold;
119
- font-size: 25px;
120
- height: 25px;
121
- width: 25px;
122
- margin-top: 2px;
117
+ .mat-column-active {
118
+ width: 48px;
119
+ }
120
+
121
+ &.no-hover {
122
+ tbody {
123
+ tr {
124
+ cursor: default;
125
+
126
+ &.active {
127
+ background-color: transparent !important;
128
+
129
+ td {
130
+ border-bottom-color: #0000001f !important;
123
131
  }
124
132
  }
125
133
 
126
- td {
127
- & > div {
128
- max-height: 200px;
129
- overflow: hidden;
130
- overflow-y: auto;
131
- }
132
- a {
133
- button {
134
- color: #000;
135
- }
136
-
137
- mat-icon {
138
- color: #333;
139
- }
134
+ &:hover {
135
+ background-color: transparent !important;
136
+
137
+ td {
138
+ border-bottom-color: #0000001f !important;
140
139
  }
141
140
  }
142
141
  }
143
142
  }
143
+ }
144
144
 
145
- .mat-column-active {
146
- width: 48px;
145
+ &.admin-table {
146
+ .actions-cell {
147
+ width: 100px;
147
148
  }
149
+ }
150
+ }
148
151
 
149
- &.no-hover {
150
- tbody {
151
- tr {
152
- cursor: default;
153
-
154
- &.active {
155
- background-color: transparent !important;
156
-
157
- td {
158
- border-bottom-color: #0000001f !important;
159
- }
160
- }
152
+ .st-material-table {
153
+ .search-form {
154
+ button {
155
+ height: 40px;
156
+ }
161
157
 
162
- &:hover {
163
- background-color: transparent !important;
158
+ mat-form-field {
159
+ &:first-child {
160
+ padding-left: 0;
161
+ }
164
162
 
165
- td {
166
- border-bottom-color: #0000001f !important;
167
- }
168
- }
169
- }
163
+ &:last-child {
164
+ padding-right: 0;
170
165
  }
171
166
  }
172
167
 
173
- &.admin-table {
174
- .actions-cell {
175
- width: 100px;
168
+ .clear {
169
+ padding: 0;
170
+
171
+ mat-icon {
172
+ height: 20px;
173
+ width: 20px;
174
+ font-size: 20px;
175
+ cursor: pointer;
176
176
  }
177
177
  }
178
178
  }
179
+
180
+ table {
181
+ @include tableStyles();
182
+ }
183
+ }
184
+
185
+ table.st-material-table {
186
+ @include tableStyles();
179
187
  }
180
188
 
181
189
  .dark-theme {
@@ -70,13 +70,13 @@ export class MaterialTableFilterDialogComponent {
70
70
  });
71
71
  }
72
72
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialTableFilterDialogComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.NonNullableFormBuilder }, { token: i0.ChangeDetectorRef }, { token: i3.StTablesTranslationsService }], target: i0.ɵɵFactoryTarget.Component }); }
73
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MaterialTableFilterDialogComponent, selector: "st-material-table-filter-dialog", ngImport: i0, template: "<h3 mat-dialog-title class=\"filters-dialog-title\">\n {{ stTableTranslations.getTranslations()().filterTitle }}\n <div class=\"filters-show-hide\">\n @if (!allVisible) {\n <button\n mat-icon-button\n (click)=\"showAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\n >\n <mat-icon>unfold_more</mat-icon>\n </button>\n }\n @if (allVisible) {\n <button\n mat-icon-button\n (click)=\"hideAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\n >\n <mat-icon>unfold_less</mat-icon>\n </button>\n }\n <button\n mat-icon-button\n (click)=\"clearAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\n >\n <mat-icon>filter_alt_off</mat-icon>\n </button>\n </div>\n</h3>\n\n<mat-dialog-content>\n <form [formGroup]=\"formGroup\">\n @for (column of filterColumns; track column.field) {\n @switch (column.filterType || column.type || 'string') {\n @case ('string') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Contains'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().searchFilter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n <button\n matSuffix\n mat-icon-button\n aria-label=\"Clear\"\n (click)=\"formGroup.controls[column.field].setValue('')\"\n >\n <mat-icon style=\"font-size: 22px\">close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('number') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Equal'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"number\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('date') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Date is'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filterChooseDate\n }}</mat-label>\n <input\n matInput\n [matDatepicker]=\"picker\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n <mat-datepicker-toggle\n matIconSuffix\n [for]=\"picker\"\n ></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('boolean') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Data is'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().booleanPickValue\n }}</mat-label>\n <mat-select>\n <mat-option value=\"\">{{\n stTableTranslations.getTranslations()().booleanNone\n }}</mat-option>\n <mat-option [value]=\"true\">{{\n stTableTranslations.getTranslations()().booleanYes\n }}</mat-option>\n <mat-option [value]=\"false\">{{\n stTableTranslations.getTranslations()().booleanNo\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('custom') {\n @if (column.customFilterOptions) {}\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Equal'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().customPickValue\n }}</mat-label>\n <mat-select>\n <mat-option value=\"\">{{\n stTableTranslations.getTranslations()().customNone\n }}</mat-option>\n @for (option of column.customFilterOptions; track option) {\n <mat-option [value]=\"option.value\">\n {{ option.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n }\n }\n </form>\n </mat-dialog-content>\n <mat-dialog-actions>\n <div class=\"row justify-content-between\" style=\"width: 100%\">\n <button mat-flat-button mat-dialog-close>\n {{ stTableTranslations.getTranslations()().cancel }}\n </button>\n <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\n {{ stTableTranslations.getTranslations()().save }}\n </button>\n </div>\n </mat-dialog-actions>\n\n <ng-template #filterHeader let-column>\n <div class=\"filter-title row justify-content-between\">\n {{ column.header }}\n\n @if (column.expanded) {\n <mat-icon (click)=\"column.expanded = !column.expanded\"\n >keyboard_arrow_up</mat-icon\n >\n } @else {\n <mat-icon (click)=\"column.expanded = !column.expanded\"\n >keyboard_arrow_down</mat-icon\n >\n }\n </div>\n </ng-template>\n", styles: [".filters-dialog-title .filters-show-hide{position:absolute;top:6px;right:15px}.filter{width:100%;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.filter .filter-title{padding:.5rem 0;color:#000c;font-size:1rem;font-weight:500}.filter .filter-title mat-icon{cursor:pointer}.filter .filter-content{margin-top:.5rem;gap:.5rem}.filter .filter-content.hide{display:none}.filter .filter-content>div.col-auto,.filter .filter-content>div.col{padding:0!important}.filter .filter-content mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { 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: "directive", type: i9.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { 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.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { 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: i10.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: i11.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i12.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i12.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i12.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
73
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MaterialTableFilterDialogComponent, selector: "st-material-table-filter-dialog", ngImport: i0, template: "<h3 mat-dialog-title class=\"filters-dialog-title\">\r\n {{ stTableTranslations.getTranslations()().filterTitle }}\r\n <div class=\"filters-show-hide\">\r\n @if (!allVisible) {\r\n <button\r\n mat-icon-button\r\n (click)=\"showAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\r\n >\r\n <mat-icon>unfold_more</mat-icon>\r\n </button>\r\n }\r\n @if (allVisible) {\r\n <button\r\n mat-icon-button\r\n (click)=\"hideAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\r\n >\r\n <mat-icon>unfold_less</mat-icon>\r\n </button>\r\n }\r\n <button\r\n mat-icon-button\r\n (click)=\"clearAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\r\n >\r\n <mat-icon>filter_alt_off</mat-icon>\r\n </button>\r\n </div>\r\n</h3>\r\n\r\n<mat-dialog-content>\r\n <form [formGroup]=\"formGroup\">\r\n @for (column of filterColumns; track column.field) {\r\n @switch (column.filterType || column.type || 'string') {\r\n @case ('string') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Contains'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().searchFilter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n <button\r\n matSuffix\r\n mat-icon-button\r\n aria-label=\"Clear\"\r\n (click)=\"formGroup.controls[column.field].setValue('')\"\r\n >\r\n <mat-icon style=\"font-size: 22px\">close</mat-icon>\r\n </button>\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('number') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Equal'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"number\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('date') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Date is'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filterChooseDate\r\n }}</mat-label>\r\n <input\r\n matInput\r\n [matDatepicker]=\"picker\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n <mat-datepicker-toggle\r\n matIconSuffix\r\n [for]=\"picker\"\r\n ></mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('boolean') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Data is'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().booleanPickValue\r\n }}</mat-label>\r\n <mat-select>\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 </div>\r\n </div>\r\n }\r\n @case ('custom') {\r\n @if (column.customFilterOptions) {}\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Equal'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().customPickValue\r\n }}</mat-label>\r\n <mat-select>\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 </div>\r\n </div>\r\n }\r\n }\r\n }\r\n </form>\r\n </mat-dialog-content>\r\n <mat-dialog-actions>\r\n <div class=\"row justify-content-between\" style=\"width: 100%\">\r\n <button mat-flat-button mat-dialog-close>\r\n {{ stTableTranslations.getTranslations()().cancel }}\r\n </button>\r\n <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\r\n {{ stTableTranslations.getTranslations()().save }}\r\n </button>\r\n </div>\r\n </mat-dialog-actions>\r\n\r\n <ng-template #filterHeader let-column>\r\n <div class=\"filter-title row justify-content-between\">\r\n {{ column.header }}\r\n\r\n @if (column.expanded) {\r\n <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n >keyboard_arrow_up</mat-icon\r\n >\r\n } @else {\r\n <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n >keyboard_arrow_down</mat-icon\r\n >\r\n }\r\n </div>\r\n </ng-template>\r\n", styles: [".filters-dialog-title .filters-show-hide{position:absolute;top:6px;right:15px}.filter{width:100%;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.filter .filter-title{padding:.5rem 0;color:#000c;font-size:1rem;font-weight:500}.filter .filter-title mat-icon{cursor:pointer}.filter .filter-content{margin-top:.5rem;gap:.5rem}.filter .filter-content.hide{display:none}.filter .filter-content>div.col-auto,.filter .filter-content>div.col{padding:0!important}.filter .filter-content mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i7.MatLabel, selector: "mat-label" }, { kind: "directive", type: i7.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { 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: "directive", type: i9.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { 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.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { 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: i10.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: i11.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i12.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i12.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i12.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
74
74
  }
75
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialTableFilterDialogComponent, decorators: [{
76
76
  type: Component,
77
- args: [{ selector: 'st-material-table-filter-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h3 mat-dialog-title class=\"filters-dialog-title\">\n {{ stTableTranslations.getTranslations()().filterTitle }}\n <div class=\"filters-show-hide\">\n @if (!allVisible) {\n <button\n mat-icon-button\n (click)=\"showAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\n >\n <mat-icon>unfold_more</mat-icon>\n </button>\n }\n @if (allVisible) {\n <button\n mat-icon-button\n (click)=\"hideAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\n >\n <mat-icon>unfold_less</mat-icon>\n </button>\n }\n <button\n mat-icon-button\n (click)=\"clearAllFilters()\"\n [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\n >\n <mat-icon>filter_alt_off</mat-icon>\n </button>\n </div>\n</h3>\n\n<mat-dialog-content>\n <form [formGroup]=\"formGroup\">\n @for (column of filterColumns; track column.field) {\n @switch (column.filterType || column.type || 'string') {\n @case ('string') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Contains'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().searchFilter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n <button\n matSuffix\n mat-icon-button\n aria-label=\"Clear\"\n (click)=\"formGroup.controls[column.field].setValue('')\"\n >\n <mat-icon style=\"font-size: 22px\">close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('number') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Equal'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"number\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('date') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Date is'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filterChooseDate\n }}</mat-label>\n <input\n matInput\n [matDatepicker]=\"picker\"\n [disabled]=\"column.visible\"\n [formControlName]=\"column.field\"\n />\n <mat-datepicker-toggle\n matIconSuffix\n [for]=\"picker\"\n ></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('boolean') {\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Data is'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().booleanPickValue\n }}</mat-label>\n <mat-select>\n <mat-option value=\"\">{{\n stTableTranslations.getTranslations()().booleanNone\n }}</mat-option>\n <mat-option [value]=\"true\">{{\n stTableTranslations.getTranslations()().booleanYes\n }}</mat-option>\n <mat-option [value]=\"false\">{{\n stTableTranslations.getTranslations()().booleanNo\n }}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n @case ('custom') {\n @if (column.customFilterOptions) {}\n <div class=\"filter\">\n <ng-container\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n ></ng-container>\n <div\n class=\"filter-content row\"\n [ngClass]=\"{ hide: !column.expanded }\"\n >\n <div class=\"col-auto\">\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n <mat-label>{{\n stTableTranslations.getTranslations()().filter\n }}</mat-label>\n <input\n matInput\n type=\"text\"\n [disabled]=\"true\"\n [value]=\"'Equal'\"\n />\n </mat-form-field>\n </div>\n\n <div class=\"col\">\n <mat-form-field appearance=\"outline\">\n <mat-label>{{\n stTableTranslations.getTranslations()().customPickValue\n }}</mat-label>\n <mat-select>\n <mat-option value=\"\">{{\n stTableTranslations.getTranslations()().customNone\n }}</mat-option>\n @for (option of column.customFilterOptions; track option) {\n <mat-option [value]=\"option.value\">\n {{ option.label }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n </div>\n </div>\n </div>\n }\n }\n }\n </form>\n </mat-dialog-content>\n <mat-dialog-actions>\n <div class=\"row justify-content-between\" style=\"width: 100%\">\n <button mat-flat-button mat-dialog-close>\n {{ stTableTranslations.getTranslations()().cancel }}\n </button>\n <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\n {{ stTableTranslations.getTranslations()().save }}\n </button>\n </div>\n </mat-dialog-actions>\n\n <ng-template #filterHeader let-column>\n <div class=\"filter-title row justify-content-between\">\n {{ column.header }}\n\n @if (column.expanded) {\n <mat-icon (click)=\"column.expanded = !column.expanded\"\n >keyboard_arrow_up</mat-icon\n >\n } @else {\n <mat-icon (click)=\"column.expanded = !column.expanded\"\n >keyboard_arrow_down</mat-icon\n >\n }\n </div>\n </ng-template>\n", styles: [".filters-dialog-title .filters-show-hide{position:absolute;top:6px;right:15px}.filter{width:100%;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.filter .filter-title{padding:.5rem 0;color:#000c;font-size:1rem;font-weight:500}.filter .filter-title mat-icon{cursor:pointer}.filter .filter-content{margin-top:.5rem;gap:.5rem}.filter .filter-content.hide{display:none}.filter .filter-content>div.col-auto,.filter .filter-content>div.col{padding:0!important}.filter .filter-content mat-form-field{width:100%}\n"] }]
77
+ args: [{ selector: 'st-material-table-filter-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h3 mat-dialog-title class=\"filters-dialog-title\">\r\n {{ stTableTranslations.getTranslations()().filterTitle }}\r\n <div class=\"filters-show-hide\">\r\n @if (!allVisible) {\r\n <button\r\n mat-icon-button\r\n (click)=\"showAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\r\n >\r\n <mat-icon>unfold_more</mat-icon>\r\n </button>\r\n }\r\n @if (allVisible) {\r\n <button\r\n mat-icon-button\r\n (click)=\"hideAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\r\n >\r\n <mat-icon>unfold_less</mat-icon>\r\n </button>\r\n }\r\n <button\r\n mat-icon-button\r\n (click)=\"clearAllFilters()\"\r\n [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\r\n >\r\n <mat-icon>filter_alt_off</mat-icon>\r\n </button>\r\n </div>\r\n</h3>\r\n\r\n<mat-dialog-content>\r\n <form [formGroup]=\"formGroup\">\r\n @for (column of filterColumns; track column.field) {\r\n @switch (column.filterType || column.type || 'string') {\r\n @case ('string') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Contains'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().searchFilter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n <button\r\n matSuffix\r\n mat-icon-button\r\n aria-label=\"Clear\"\r\n (click)=\"formGroup.controls[column.field].setValue('')\"\r\n >\r\n <mat-icon style=\"font-size: 22px\">close</mat-icon>\r\n </button>\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('number') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Equal'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"number\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('date') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Date is'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filterChooseDate\r\n }}</mat-label>\r\n <input\r\n matInput\r\n [matDatepicker]=\"picker\"\r\n [disabled]=\"column.visible\"\r\n [formControlName]=\"column.field\"\r\n />\r\n <mat-datepicker-toggle\r\n matIconSuffix\r\n [for]=\"picker\"\r\n ></mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n @case ('boolean') {\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Data is'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().booleanPickValue\r\n }}</mat-label>\r\n <mat-select>\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 </div>\r\n </div>\r\n }\r\n @case ('custom') {\r\n @if (column.customFilterOptions) {}\r\n <div class=\"filter\">\r\n <ng-container\r\n *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n ></ng-container>\r\n <div\r\n class=\"filter-content row\"\r\n [ngClass]=\"{ hide: !column.expanded }\"\r\n >\r\n <div class=\"col-auto\">\r\n <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().filter\r\n }}</mat-label>\r\n <input\r\n matInput\r\n type=\"text\"\r\n [disabled]=\"true\"\r\n [value]=\"'Equal'\"\r\n />\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{\r\n stTableTranslations.getTranslations()().customPickValue\r\n }}</mat-label>\r\n <mat-select>\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 </div>\r\n </div>\r\n }\r\n }\r\n }\r\n </form>\r\n </mat-dialog-content>\r\n <mat-dialog-actions>\r\n <div class=\"row justify-content-between\" style=\"width: 100%\">\r\n <button mat-flat-button mat-dialog-close>\r\n {{ stTableTranslations.getTranslations()().cancel }}\r\n </button>\r\n <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\r\n {{ stTableTranslations.getTranslations()().save }}\r\n </button>\r\n </div>\r\n </mat-dialog-actions>\r\n\r\n <ng-template #filterHeader let-column>\r\n <div class=\"filter-title row justify-content-between\">\r\n {{ column.header }}\r\n\r\n @if (column.expanded) {\r\n <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n >keyboard_arrow_up</mat-icon\r\n >\r\n } @else {\r\n <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n >keyboard_arrow_down</mat-icon\r\n >\r\n }\r\n </div>\r\n </ng-template>\r\n", styles: [".filters-dialog-title .filters-show-hide{position:absolute;top:6px;right:15px}.filter{width:100%;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.filter .filter-title{padding:.5rem 0;color:#000c;font-size:1rem;font-weight:500}.filter .filter-title mat-icon{cursor:pointer}.filter .filter-content{margin-top:.5rem;gap:.5rem}.filter .filter-content.hide{display:none}.filter .filter-content>div.col-auto,.filter .filter-content>div.col{padding:0!important}.filter .filter-content mat-form-field{width:100%}\n"] }]
78
78
  }], ctorParameters: () => [{ type: undefined, decorators: [{
79
79
  type: Inject,
80
80
  args: [MAT_DIALOG_DATA]
81
81
  }] }, { type: i1.MatDialogRef }, { type: i2.NonNullableFormBuilder }, { type: i0.ChangeDetectorRef }, { type: i3.StTablesTranslationsService }] });
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table-filter-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-caption/material-table-filter-dialog/material-table-filter-dialog.component.ts","../../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-caption/material-table-filter-dialog/material-table-filter-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Inject,\r\n  OnInit,\r\n} from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { ViewStMaterialTableColumnModel } from '../../../../models/view/view-st-material-table-column.model';\r\nimport { FormGroup, NonNullableFormBuilder } from '@angular/forms';\r\nimport { StTablesTranslationsService } from '../../../../services/st-tables-translations.service';\r\n\r\n@Component({\r\n  selector: 'st-material-table-filter-dialog',\r\n  templateUrl: './material-table-filter-dialog.component.html',\r\n  styleUrls: ['./material-table-filter-dialog.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class MaterialTableFilterDialogComponent implements OnInit {\r\n  filterColumns: ViewStMaterialTableColumnModel[] = [];\r\n\r\n  formGroup: FormGroup = this.fb.group({});\r\n\r\n  allVisible = true;\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA)\r\n    public dialogData: {\r\n      columns: ViewStMaterialTableColumnModel[];\r\n      initFilters: { [key: string]: string };\r\n    },\r\n    public dialogRef: MatDialogRef<\r\n      MaterialTableFilterDialogComponent,\r\n      MaterialTableFilterDialogResult\r\n    >,\r\n    private fb: NonNullableFormBuilder,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    public stTableTranslations: StTablesTranslationsService\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.filterColumns = this.dialogData.columns\r\n      .filter(column => column.filter)\r\n      .map(col => {\r\n        this.formGroup.addControl(col.field, this.fb.control(''));\r\n\r\n        return {\r\n          ...col,\r\n        };\r\n      });\r\n\r\n    if (this.dialogData.initFilters) {\r\n      const filtersKeys = Object.keys(this.dialogData.initFilters);\r\n      filtersKeys.forEach(key => {\r\n        if (this.formGroup.get(key)) {\r\n          this.formGroup.get(key)?.setValue(this.dialogData.initFilters[key]);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  clearAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      if (this.formGroup.get(column.field)) {\r\n        this.formGroup.get(column.field)?.setValue('');\r\n      }\r\n    });\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  showAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      column.expanded = true;\r\n    });\r\n    this.allVisible = true;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  hideAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      column.expanded = false;\r\n    });\r\n    this.allVisible = false;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  saveFilters() {\r\n    this.dialogRef.close({\r\n      filters: this.formGroup.getRawValue(),\r\n    });\r\n  }\r\n}\r\n\r\nexport interface MaterialTableFilterDialogResult {\r\n  filters: { [key: string]: string };\r\n}\r\n","<h3 mat-dialog-title class=\"filters-dialog-title\">\n  {{ stTableTranslations.getTranslations()().filterTitle }}\n  <div class=\"filters-show-hide\">\n    @if (!allVisible) {\n      <button\n        mat-icon-button\n        (click)=\"showAllFilters()\"\n        [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\n        >\n        <mat-icon>unfold_more</mat-icon>\n      </button>\n    }\n    @if (allVisible) {\n      <button\n        mat-icon-button\n        (click)=\"hideAllFilters()\"\n        [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\n        >\n        <mat-icon>unfold_less</mat-icon>\n      </button>\n    }\n    <button\n      mat-icon-button\n      (click)=\"clearAllFilters()\"\n      [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\n      >\n      <mat-icon>filter_alt_off</mat-icon>\n    </button>\n  </div>\n</h3>\n\n<mat-dialog-content>\n  <form [formGroup]=\"formGroup\">\n    @for (column of filterColumns; track column.field) {\n      @switch (column.filterType || column.type || 'string') {\n        @case ('string') {\n          <div class=\"filter\">\n            <ng-container\n              *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n            ></ng-container>\n            <div\n              class=\"filter-content row\"\n              [ngClass]=\"{ hide: !column.expanded }\"\n              >\n              <div class=\"col-auto\">\n                <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n                  <mat-label>{{\n                    stTableTranslations.getTranslations()().filter\n                  }}</mat-label>\n                  <input\n                    matInput\n                    type=\"text\"\n                    [disabled]=\"true\"\n                    [value]=\"'Contains'\"\n                    />\n                  </mat-form-field>\n                </div>\n\n                <div class=\"col\">\n                  <mat-form-field appearance=\"outline\">\n                    <mat-label>{{\n                      stTableTranslations.getTranslations()().searchFilter\n                    }}</mat-label>\n                    <input\n                      matInput\n                      type=\"text\"\n                      [disabled]=\"column.visible\"\n                      [formControlName]=\"column.field\"\n                      />\n                      <button\n                        matSuffix\n                        mat-icon-button\n                        aria-label=\"Clear\"\n                        (click)=\"formGroup.controls[column.field].setValue('')\"\n                        >\n                        <mat-icon style=\"font-size: 22px\">close</mat-icon>\n                      </button>\n                    </mat-form-field>\n                  </div>\n                </div>\n              </div>\n            }\n            @case ('number') {\n              <div class=\"filter\">\n                <ng-container\n                  *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n                ></ng-container>\n                <div\n                  class=\"filter-content row\"\n                  [ngClass]=\"{ hide: !column.expanded }\"\n                  >\n                  <div class=\"col-auto\">\n                    <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n                      <mat-label>{{\n                        stTableTranslations.getTranslations()().filter\n                      }}</mat-label>\n                      <input\n                        matInput\n                        type=\"text\"\n                        [disabled]=\"true\"\n                        [value]=\"'Equal'\"\n                        />\n                      </mat-form-field>\n                    </div>\n\n                    <div class=\"col\">\n                      <mat-form-field appearance=\"outline\">\n                        <mat-label>{{\n                          stTableTranslations.getTranslations()().filter\n                        }}</mat-label>\n                        <input\n                          matInput\n                          type=\"number\"\n                          [disabled]=\"column.visible\"\n                          [formControlName]=\"column.field\"\n                          />\n                        </mat-form-field>\n                      </div>\n                    </div>\n                  </div>\n                }\n                @case ('date') {\n                  <div class=\"filter\">\n                    <ng-container\n                      *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n                    ></ng-container>\n                    <div\n                      class=\"filter-content row\"\n                      [ngClass]=\"{ hide: !column.expanded }\"\n                      >\n                      <div class=\"col-auto\">\n                        <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n                          <mat-label>{{\n                            stTableTranslations.getTranslations()().filter\n                          }}</mat-label>\n                          <input\n                            matInput\n                            type=\"text\"\n                            [disabled]=\"true\"\n                            [value]=\"'Date is'\"\n                            />\n                          </mat-form-field>\n                        </div>\n\n                        <div class=\"col\">\n                          <mat-form-field appearance=\"outline\">\n                            <mat-label>{{\n                              stTableTranslations.getTranslations()().filterChooseDate\n                            }}</mat-label>\n                            <input\n                              matInput\n                              [matDatepicker]=\"picker\"\n                              [disabled]=\"column.visible\"\n                              [formControlName]=\"column.field\"\n                              />\n                              <mat-datepicker-toggle\n                                matIconSuffix\n                                [for]=\"picker\"\n                              ></mat-datepicker-toggle>\n                              <mat-datepicker #picker></mat-datepicker>\n                            </mat-form-field>\n                          </div>\n                        </div>\n                      </div>\n                    }\n                    @case ('boolean') {\n                      <div class=\"filter\">\n                        <ng-container\n                          *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n                        ></ng-container>\n                        <div\n                          class=\"filter-content row\"\n                          [ngClass]=\"{ hide: !column.expanded }\"\n                          >\n                          <div class=\"col-auto\">\n                            <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n                              <mat-label>{{\n                                stTableTranslations.getTranslations()().filter\n                              }}</mat-label>\n                              <input\n                                matInput\n                                type=\"text\"\n                                [disabled]=\"true\"\n                                [value]=\"'Data is'\"\n                                />\n                              </mat-form-field>\n                            </div>\n\n                            <div class=\"col\">\n                              <mat-form-field appearance=\"outline\">\n                                <mat-label>{{\n                                  stTableTranslations.getTranslations()().booleanPickValue\n                                }}</mat-label>\n                                <mat-select>\n                                  <mat-option value=\"\">{{\n                                    stTableTranslations.getTranslations()().booleanNone\n                                  }}</mat-option>\n                                  <mat-option [value]=\"true\">{{\n                                    stTableTranslations.getTranslations()().booleanYes\n                                  }}</mat-option>\n                                  <mat-option [value]=\"false\">{{\n                                    stTableTranslations.getTranslations()().booleanNo\n                                  }}</mat-option>\n                                </mat-select>\n                              </mat-form-field>\n                            </div>\n                          </div>\n                        </div>\n                      }\n                      @case ('custom') {\n                        @if (column.customFilterOptions) {}\n                          <div class=\"filter\">\n                            <ng-container\n                              *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\n                            ></ng-container>\n                            <div\n                              class=\"filter-content row\"\n                              [ngClass]=\"{ hide: !column.expanded }\"\n                              >\n                              <div class=\"col-auto\">\n                                <mat-form-field appearance=\"outline\" style=\"width: 100px\">\n                                  <mat-label>{{\n                                    stTableTranslations.getTranslations()().filter\n                                  }}</mat-label>\n                                  <input\n                                    matInput\n                                    type=\"text\"\n                                    [disabled]=\"true\"\n                                    [value]=\"'Equal'\"\n                                    />\n                                  </mat-form-field>\n                                </div>\n\n                                <div class=\"col\">\n                                  <mat-form-field appearance=\"outline\">\n                                    <mat-label>{{\n                                      stTableTranslations.getTranslations()().customPickValue\n                                    }}</mat-label>\n                                    <mat-select>\n                                      <mat-option value=\"\">{{\n                                        stTableTranslations.getTranslations()().customNone\n                                      }}</mat-option>\n                                      @for (option of column.customFilterOptions; track option) {\n                                        <mat-option [value]=\"option.value\">\n                                          {{ option.label }}\n                                        </mat-option>\n                                      }\n                                    </mat-select>\n                                  </mat-form-field>\n                                </div>\n                              </div>\n                            </div>\n                          }\n                        }\n                      }\n                    </form>\n                  </mat-dialog-content>\n                  <mat-dialog-actions>\n                    <div class=\"row justify-content-between\" style=\"width: 100%\">\n                      <button mat-flat-button mat-dialog-close>\n                        {{ stTableTranslations.getTranslations()().cancel }}\n                      </button>\n                      <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\n                        {{ stTableTranslations.getTranslations()().save }}\n                      </button>\n                    </div>\n                  </mat-dialog-actions>\n\n                  <ng-template #filterHeader let-column>\n                    <div class=\"filter-title row justify-content-between\">\n                      {{ column.header }}\n\n                      @if (column.expanded) {\n                        <mat-icon (click)=\"column.expanded = !column.expanded\"\n                          >keyboard_arrow_up</mat-icon\n                          >\n                        } @else {\n                          <mat-icon (click)=\"column.expanded = !column.expanded\"\n                            >keyboard_arrow_down</mat-icon\n                            >\n                          }\n                        </div>\n                      </ng-template>\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-table-filter-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-caption/material-table-filter-dialog/material-table-filter-dialog.component.ts","../../../../../../../../projects/ngx-st-tables/src/lib/components/material-table/material-table-caption/material-table-filter-dialog/material-table-filter-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  Inject,\r\n  OnInit,\r\n} from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { ViewStMaterialTableColumnModel } from '../../../../models/view/view-st-material-table-column.model';\r\nimport { FormGroup, NonNullableFormBuilder } from '@angular/forms';\r\nimport { StTablesTranslationsService } from '../../../../services/st-tables-translations.service';\r\n\r\n@Component({\r\n  selector: 'st-material-table-filter-dialog',\r\n  templateUrl: './material-table-filter-dialog.component.html',\r\n  styleUrls: ['./material-table-filter-dialog.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class MaterialTableFilterDialogComponent implements OnInit {\r\n  filterColumns: ViewStMaterialTableColumnModel[] = [];\r\n\r\n  formGroup: FormGroup = this.fb.group({});\r\n\r\n  allVisible = true;\r\n\r\n  constructor(\r\n    @Inject(MAT_DIALOG_DATA)\r\n    public dialogData: {\r\n      columns: ViewStMaterialTableColumnModel[];\r\n      initFilters: { [key: string]: string };\r\n    },\r\n    public dialogRef: MatDialogRef<\r\n      MaterialTableFilterDialogComponent,\r\n      MaterialTableFilterDialogResult\r\n    >,\r\n    private fb: NonNullableFormBuilder,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    public stTableTranslations: StTablesTranslationsService\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.filterColumns = this.dialogData.columns\r\n      .filter(column => column.filter)\r\n      .map(col => {\r\n        this.formGroup.addControl(col.field, this.fb.control(''));\r\n\r\n        return {\r\n          ...col,\r\n        };\r\n      });\r\n\r\n    if (this.dialogData.initFilters) {\r\n      const filtersKeys = Object.keys(this.dialogData.initFilters);\r\n      filtersKeys.forEach(key => {\r\n        if (this.formGroup.get(key)) {\r\n          this.formGroup.get(key)?.setValue(this.dialogData.initFilters[key]);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  clearAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      if (this.formGroup.get(column.field)) {\r\n        this.formGroup.get(column.field)?.setValue('');\r\n      }\r\n    });\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  showAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      column.expanded = true;\r\n    });\r\n    this.allVisible = true;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  hideAllFilters() {\r\n    this.filterColumns.forEach(column => {\r\n      column.expanded = false;\r\n    });\r\n    this.allVisible = false;\r\n    this.changeDetectorRef.markForCheck();\r\n  }\r\n\r\n  saveFilters() {\r\n    this.dialogRef.close({\r\n      filters: this.formGroup.getRawValue(),\r\n    });\r\n  }\r\n}\r\n\r\nexport interface MaterialTableFilterDialogResult {\r\n  filters: { [key: string]: string };\r\n}\r\n","<h3 mat-dialog-title class=\"filters-dialog-title\">\r\n  {{ stTableTranslations.getTranslations()().filterTitle }}\r\n  <div class=\"filters-show-hide\">\r\n    @if (!allVisible) {\r\n      <button\r\n        mat-icon-button\r\n        (click)=\"showAllFilters()\"\r\n        [matTooltip]=\"stTableTranslations.getTranslations()().expandAllFilters\"\r\n        >\r\n        <mat-icon>unfold_more</mat-icon>\r\n      </button>\r\n    }\r\n    @if (allVisible) {\r\n      <button\r\n        mat-icon-button\r\n        (click)=\"hideAllFilters()\"\r\n        [matTooltip]=\"stTableTranslations.getTranslations()().collapseAllFilters\"\r\n        >\r\n        <mat-icon>unfold_less</mat-icon>\r\n      </button>\r\n    }\r\n    <button\r\n      mat-icon-button\r\n      (click)=\"clearAllFilters()\"\r\n      [matTooltip]=\"stTableTranslations.getTranslations()().clearFilters\"\r\n      >\r\n      <mat-icon>filter_alt_off</mat-icon>\r\n    </button>\r\n  </div>\r\n</h3>\r\n\r\n<mat-dialog-content>\r\n  <form [formGroup]=\"formGroup\">\r\n    @for (column of filterColumns; track column.field) {\r\n      @switch (column.filterType || column.type || 'string') {\r\n        @case ('string') {\r\n          <div class=\"filter\">\r\n            <ng-container\r\n              *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n            ></ng-container>\r\n            <div\r\n              class=\"filter-content row\"\r\n              [ngClass]=\"{ hide: !column.expanded }\"\r\n              >\r\n              <div class=\"col-auto\">\r\n                <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n                  <mat-label>{{\r\n                    stTableTranslations.getTranslations()().filter\r\n                  }}</mat-label>\r\n                  <input\r\n                    matInput\r\n                    type=\"text\"\r\n                    [disabled]=\"true\"\r\n                    [value]=\"'Contains'\"\r\n                    />\r\n                  </mat-form-field>\r\n                </div>\r\n\r\n                <div class=\"col\">\r\n                  <mat-form-field appearance=\"outline\">\r\n                    <mat-label>{{\r\n                      stTableTranslations.getTranslations()().searchFilter\r\n                    }}</mat-label>\r\n                    <input\r\n                      matInput\r\n                      type=\"text\"\r\n                      [disabled]=\"column.visible\"\r\n                      [formControlName]=\"column.field\"\r\n                      />\r\n                      <button\r\n                        matSuffix\r\n                        mat-icon-button\r\n                        aria-label=\"Clear\"\r\n                        (click)=\"formGroup.controls[column.field].setValue('')\"\r\n                        >\r\n                        <mat-icon style=\"font-size: 22px\">close</mat-icon>\r\n                      </button>\r\n                    </mat-form-field>\r\n                  </div>\r\n                </div>\r\n              </div>\r\n            }\r\n            @case ('number') {\r\n              <div class=\"filter\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n                ></ng-container>\r\n                <div\r\n                  class=\"filter-content row\"\r\n                  [ngClass]=\"{ hide: !column.expanded }\"\r\n                  >\r\n                  <div class=\"col-auto\">\r\n                    <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n                      <mat-label>{{\r\n                        stTableTranslations.getTranslations()().filter\r\n                      }}</mat-label>\r\n                      <input\r\n                        matInput\r\n                        type=\"text\"\r\n                        [disabled]=\"true\"\r\n                        [value]=\"'Equal'\"\r\n                        />\r\n                      </mat-form-field>\r\n                    </div>\r\n\r\n                    <div class=\"col\">\r\n                      <mat-form-field appearance=\"outline\">\r\n                        <mat-label>{{\r\n                          stTableTranslations.getTranslations()().filter\r\n                        }}</mat-label>\r\n                        <input\r\n                          matInput\r\n                          type=\"number\"\r\n                          [disabled]=\"column.visible\"\r\n                          [formControlName]=\"column.field\"\r\n                          />\r\n                        </mat-form-field>\r\n                      </div>\r\n                    </div>\r\n                  </div>\r\n                }\r\n                @case ('date') {\r\n                  <div class=\"filter\">\r\n                    <ng-container\r\n                      *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n                    ></ng-container>\r\n                    <div\r\n                      class=\"filter-content row\"\r\n                      [ngClass]=\"{ hide: !column.expanded }\"\r\n                      >\r\n                      <div class=\"col-auto\">\r\n                        <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n                          <mat-label>{{\r\n                            stTableTranslations.getTranslations()().filter\r\n                          }}</mat-label>\r\n                          <input\r\n                            matInput\r\n                            type=\"text\"\r\n                            [disabled]=\"true\"\r\n                            [value]=\"'Date is'\"\r\n                            />\r\n                          </mat-form-field>\r\n                        </div>\r\n\r\n                        <div class=\"col\">\r\n                          <mat-form-field appearance=\"outline\">\r\n                            <mat-label>{{\r\n                              stTableTranslations.getTranslations()().filterChooseDate\r\n                            }}</mat-label>\r\n                            <input\r\n                              matInput\r\n                              [matDatepicker]=\"picker\"\r\n                              [disabled]=\"column.visible\"\r\n                              [formControlName]=\"column.field\"\r\n                              />\r\n                              <mat-datepicker-toggle\r\n                                matIconSuffix\r\n                                [for]=\"picker\"\r\n                              ></mat-datepicker-toggle>\r\n                              <mat-datepicker #picker></mat-datepicker>\r\n                            </mat-form-field>\r\n                          </div>\r\n                        </div>\r\n                      </div>\r\n                    }\r\n                    @case ('boolean') {\r\n                      <div class=\"filter\">\r\n                        <ng-container\r\n                          *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n                        ></ng-container>\r\n                        <div\r\n                          class=\"filter-content row\"\r\n                          [ngClass]=\"{ hide: !column.expanded }\"\r\n                          >\r\n                          <div class=\"col-auto\">\r\n                            <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n                              <mat-label>{{\r\n                                stTableTranslations.getTranslations()().filter\r\n                              }}</mat-label>\r\n                              <input\r\n                                matInput\r\n                                type=\"text\"\r\n                                [disabled]=\"true\"\r\n                                [value]=\"'Data is'\"\r\n                                />\r\n                              </mat-form-field>\r\n                            </div>\r\n\r\n                            <div class=\"col\">\r\n                              <mat-form-field appearance=\"outline\">\r\n                                <mat-label>{{\r\n                                  stTableTranslations.getTranslations()().booleanPickValue\r\n                                }}</mat-label>\r\n                                <mat-select>\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                          </div>\r\n                        </div>\r\n                      }\r\n                      @case ('custom') {\r\n                        @if (column.customFilterOptions) {}\r\n                          <div class=\"filter\">\r\n                            <ng-container\r\n                              *ngTemplateOutlet=\"filterHeader; context: { $implicit: column }\"\r\n                            ></ng-container>\r\n                            <div\r\n                              class=\"filter-content row\"\r\n                              [ngClass]=\"{ hide: !column.expanded }\"\r\n                              >\r\n                              <div class=\"col-auto\">\r\n                                <mat-form-field appearance=\"outline\" style=\"width: 100px\">\r\n                                  <mat-label>{{\r\n                                    stTableTranslations.getTranslations()().filter\r\n                                  }}</mat-label>\r\n                                  <input\r\n                                    matInput\r\n                                    type=\"text\"\r\n                                    [disabled]=\"true\"\r\n                                    [value]=\"'Equal'\"\r\n                                    />\r\n                                  </mat-form-field>\r\n                                </div>\r\n\r\n                                <div class=\"col\">\r\n                                  <mat-form-field appearance=\"outline\">\r\n                                    <mat-label>{{\r\n                                      stTableTranslations.getTranslations()().customPickValue\r\n                                    }}</mat-label>\r\n                                    <mat-select>\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                              </div>\r\n                            </div>\r\n                          }\r\n                        }\r\n                      }\r\n                    </form>\r\n                  </mat-dialog-content>\r\n                  <mat-dialog-actions>\r\n                    <div class=\"row justify-content-between\" style=\"width: 100%\">\r\n                      <button mat-flat-button mat-dialog-close>\r\n                        {{ stTableTranslations.getTranslations()().cancel }}\r\n                      </button>\r\n                      <button mat-flat-button color=\"accent\" (click)=\"saveFilters()\">\r\n                        {{ stTableTranslations.getTranslations()().save }}\r\n                      </button>\r\n                    </div>\r\n                  </mat-dialog-actions>\r\n\r\n                  <ng-template #filterHeader let-column>\r\n                    <div class=\"filter-title row justify-content-between\">\r\n                      {{ column.header }}\r\n\r\n                      @if (column.expanded) {\r\n                        <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n                          >keyboard_arrow_up</mat-icon\r\n                          >\r\n                        } @else {\r\n                          <mat-icon (click)=\"column.expanded = !column.expanded\"\r\n                            >keyboard_arrow_down</mat-icon\r\n                            >\r\n                          }\r\n                        </div>\r\n                      </ng-template>\r\n"]}