@mediusinc/mng-commons 5.4.0 → 5.5.0-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/core/descriptors/table.descriptor.d.ts +4 -2
  2. package/core/directives/rerender.directive.d.ts +9 -0
  3. package/core/helpers/route.d.ts +25 -25
  4. package/core/index.d.ts +2 -0
  5. package/core/models/version.model.d.ts +16 -4
  6. package/core/reactivity/effect.d.ts +16 -0
  7. package/esm2022/core/components/notification/notification-wrapper.component.mjs +4 -4
  8. package/esm2022/core/components/pages/error/error.page.component.mjs +4 -4
  9. package/esm2022/core/components/pages/not-found/not-found.page.component.mjs +4 -4
  10. package/esm2022/core/data-list/data-list-params-helpers.mjs +18 -3
  11. package/esm2022/core/descriptors/table.descriptor.mjs +1 -1
  12. package/esm2022/core/directives/component.directive.mjs +4 -4
  13. package/esm2022/core/directives/rerender.directive.mjs +25 -0
  14. package/esm2022/core/directives/template.directive.mjs +4 -4
  15. package/esm2022/core/index.mjs +4 -1
  16. package/esm2022/core/models/version.model.mjs +1 -1
  17. package/esm2022/core/pipes/boolean.pipe.mjs +6 -6
  18. package/esm2022/core/pipes/class-map.pipe.mjs +4 -4
  19. package/esm2022/core/pipes/enum.pipe.mjs +4 -4
  20. package/esm2022/core/pipes/enumerate-async.pipe.mjs +4 -4
  21. package/esm2022/core/pipes/enumerate.pipe.mjs +4 -4
  22. package/esm2022/core/pipes/getter.pipe.mjs +5 -5
  23. package/esm2022/core/pipes/i18n-property.pipe.mjs +4 -4
  24. package/esm2022/core/pipes/json-path.pipe.mjs +4 -4
  25. package/esm2022/core/pipes/parametrize.pipe.mjs +4 -4
  26. package/esm2022/core/pipes/template.pipe.mjs +4 -4
  27. package/esm2022/core/reactivity/effect.mjs +22 -0
  28. package/esm2022/core/security/permission.service.mjs +4 -4
  29. package/esm2022/core/services/commons-init.service.mjs +4 -4
  30. package/esm2022/core/services/commons-router.service.mjs +4 -4
  31. package/esm2022/core/services/commons-storage.service.mjs +4 -4
  32. package/esm2022/core/services/commons.service.mjs +8 -8
  33. package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +32 -25
  34. package/esm2022/filter/descriptors/filter.descriptor.mjs +53 -1
  35. package/esm2022/form/components/autocomplete/autocomplete.component.mjs +4 -4
  36. package/esm2022/form/components/date-range/date-range.component.mjs +4 -4
  37. package/esm2022/form/components/dropdown/dropdown.component.mjs +4 -4
  38. package/esm2022/form/components/number-range/number-range.component.mjs +4 -4
  39. package/esm2022/form/directives/input-trim.directive.mjs +4 -4
  40. package/esm2022/table/api/descriptors/sort.descriptor.mjs +2 -2
  41. package/esm2022/table/api/descriptors/table.descriptor.mjs +31 -7
  42. package/esm2022/table/components/column-filter/column-filter.component.mjs +33 -40
  43. package/esm2022/table/components/column-value/column-value.component.mjs +6 -6
  44. package/esm2022/table/components/filter/filter-active-tag/filter-active-tag.component.mjs +7 -7
  45. package/esm2022/table/components/filter/filter-form/filter-form.component.mjs +28 -35
  46. package/esm2022/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.mjs +44 -45
  47. package/esm2022/table/components/table/table.component.mjs +114 -430
  48. package/esm2022/table/helpers/filters.mjs +9 -25
  49. package/esm2022/table/helpers/table.mjs +24 -0
  50. package/esm2022/table/index.mjs +2 -2
  51. package/esm2022/table/models/column-preferences.model.mjs +1 -1
  52. package/esm2022/table/models/filter.model.mjs +1 -1
  53. package/esm2022/table/pipes/filter-value.pipe.mjs +4 -4
  54. package/esm2022/table/pipes/locale-default-row-class.pipe.mjs +4 -4
  55. package/esm2022/table/pipes/table-column-filter-class.pipe.mjs +4 -4
  56. package/esm2022/table/services/table-data.service.mjs +194 -0
  57. package/esm2022/table/services/table-metadata.service.mjs +136 -0
  58. package/esm2022/table/services/table-preferences.service.mjs +142 -0
  59. package/esm2022/tableview/action/components/action/action.component.mjs +6 -7
  60. package/esm2022/tableview/action/components/editor/action-editor.component.mjs +4 -4
  61. package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +69 -46
  62. package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +4 -4
  63. package/esm2022/tableview/action/components/route/action-route.component.mjs +5 -6
  64. package/esm2022/tableview/action/components/table/action-table.component.mjs +6 -6
  65. package/esm2022/tableview/action/helpers/action-execution.mjs +25 -0
  66. package/esm2022/tableview/action/models/execution/action-instance.model.mjs +2 -3
  67. package/esm2022/tableview/action/services/action-executor.service.mjs +12 -79
  68. package/esm2022/tableview/action/services/component-action-executor.service.mjs +4 -4
  69. package/esm2022/tableview/action/services/data-provider-executor.service.mjs +4 -4
  70. package/esm2022/tableview/action/services/navigation.service.mjs +4 -4
  71. package/esm2022/tableview/action/services/root-action-executor.service.mjs +4 -4
  72. package/esm2022/tableview/action/services/view-container.service.mjs +4 -4
  73. package/esm2022/tableview/api/action/descriptors/action-confirmation.descriptor.mjs +13 -1
  74. package/esm2022/tableview/api/action/descriptors/action-editor.descriptor.mjs +67 -10
  75. package/esm2022/tableview/api/action/descriptors/action-link-descriptor.factory.mjs +2 -2
  76. package/esm2022/tableview/api/action/descriptors/action-link.descriptor.mjs +17 -1
  77. package/esm2022/tableview/api/action/descriptors/action.descriptor.mjs +32 -7
  78. package/esm2022/tableview/api/action/models/execution/action-instance-state.model.mjs +2 -2
  79. package/esm2022/tableview/api/editor/descriptors/field-many.descriptor.mjs +2 -1
  80. package/esm2022/tableview/api/editor/models/formly-custom-field.model.mjs +4 -4
  81. package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +13 -5
  82. package/esm2022/tableview/api/tableview/helpers/tableview-default-actions.mjs +3 -2
  83. package/esm2022/tableview/api/tableview/helpers/tableview-descriptor-helpers.mjs +2 -2
  84. package/esm2022/tableview/editor/components/editor/auto-save-status/auto-save-status.component.mjs +4 -4
  85. package/esm2022/tableview/editor/components/editor/form-editor.component.mjs +31 -38
  86. package/esm2022/tableview/editor/components/formly/fields/formly-field-action/formly-field-action.component.mjs +4 -4
  87. package/esm2022/tableview/editor/components/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +7 -5
  88. package/esm2022/tableview/editor/components/formly/fields/formly-field-custom/formly-field-custom.component.mjs +4 -4
  89. package/esm2022/tableview/editor/components/formly/fields/formly-field-datepicker/formly-field-datepicker.component.mjs +7 -5
  90. package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +7 -5
  91. package/esm2022/tableview/editor/components/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +4 -4
  92. package/esm2022/tableview/editor/components/formly/fields/formly-field-input/formly-field-input.component.mjs +5 -5
  93. package/esm2022/tableview/editor/components/formly/fields/formly-field-label/formly-field-label.component.mjs +4 -4
  94. package/esm2022/tableview/editor/components/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +5 -6
  95. package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +5 -6
  96. package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +6 -7
  97. package/esm2022/tableview/editor/components/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +4 -4
  98. package/esm2022/tableview/editor/components/formly/fields/formly-field-type.abstract.component.mjs +6 -5
  99. package/esm2022/tableview/editor/components/formly/pipes/formly-field-label.pipe.mjs +4 -4
  100. package/esm2022/tableview/editor/components/formly/wrappers/formly-field-no-label-wrapper/formly-field-no-label-wrapper.component.mjs +4 -4
  101. package/esm2022/tableview/editor/components/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +4 -4
  102. package/esm2022/tableview/editor/helpers/editor-autosave.mjs +2 -2
  103. package/esm2022/tableview/editor/services/form-editor.service.mjs +4 -4
  104. package/esm2022/tableview/index.mjs +1 -2
  105. package/esm2022/tableview/tableview/components/route/tableview-route.component.mjs +4 -4
  106. package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +4 -4
  107. package/fesm2022/mediusinc-mng-commons-core.mjs +130 -71
  108. package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
  109. package/fesm2022/mediusinc-mng-commons-filter.mjs +83 -24
  110. package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
  111. package/fesm2022/mediusinc-mng-commons-form-api.mjs.map +1 -1
  112. package/fesm2022/mediusinc-mng-commons-form.mjs +15 -15
  113. package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
  114. package/fesm2022/mediusinc-mng-commons-model.mjs.map +1 -1
  115. package/fesm2022/mediusinc-mng-commons-table-api.mjs +31 -7
  116. package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
  117. package/fesm2022/mediusinc-mng-commons-table.mjs +704 -606
  118. package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
  119. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +146 -26
  120. package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
  121. package/fesm2022/mediusinc-mng-commons-tableview.mjs +260 -317
  122. package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
  123. package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
  124. package/filter/descriptors/filter-lookup.descriptor.d.ts +17 -20
  125. package/filter/descriptors/filter.descriptor.d.ts +32 -2
  126. package/form/components/date-range/date-range.component.d.ts +3 -3
  127. package/form/components/number-range/number-range.component.d.ts +2 -2
  128. package/package.json +4 -4
  129. package/table/api/descriptors/column.descriptor.d.ts +1 -1
  130. package/table/api/descriptors/sort.descriptor.d.ts +2 -2
  131. package/table/api/descriptors/table.descriptor.d.ts +20 -6
  132. package/table/components/column-filter/column-filter.component.d.ts +8 -14
  133. package/table/components/filter/filter-active-tag/filter-active-tag.component.d.ts +5 -5
  134. package/table/components/filter/filter-form/filter-form.component.d.ts +10 -19
  135. package/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.d.ts +11 -13
  136. package/table/components/table/table.component.d.ts +20 -64
  137. package/table/helpers/filters.d.ts +4 -7
  138. package/table/helpers/table.d.ts +6 -0
  139. package/table/index.d.ts +1 -1
  140. package/table/models/column-preferences.model.d.ts +2 -2
  141. package/table/models/filter.model.d.ts +14 -2
  142. package/table/services/table-data.service.d.ts +36 -0
  143. package/table/services/table-metadata.service.d.ts +31 -0
  144. package/table/services/table-preferences.service.d.ts +25 -0
  145. package/tableview/action/components/editor/injector-context/action-editor-injector-context.component.d.ts +4 -7
  146. package/tableview/action/components/localization/data-language-dropdown.component.d.ts +1 -1
  147. package/tableview/action/helpers/action-execution.d.ts +7 -0
  148. package/tableview/action/models/execution/action-instance.model.d.ts +1 -2
  149. package/tableview/action/services/action-executor.service.d.ts +1 -2
  150. package/tableview/api/action/descriptors/action-confirmation.descriptor.d.ts +1 -0
  151. package/tableview/api/action/descriptors/action-editor.descriptor.d.ts +12 -4
  152. package/tableview/api/action/descriptors/action-link.descriptor.d.ts +1 -0
  153. package/tableview/api/action/descriptors/action.descriptor.d.ts +5 -3
  154. package/tableview/api/action/models/execution/action-instance-state.model.d.ts +1 -1
  155. package/tableview/api/editor/descriptors/field-base.descriptor.d.ts +4 -10
  156. package/tableview/api/editor/descriptors/field-group.descriptor.d.ts +1 -1
  157. package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +6 -4
  158. package/tableview/editor/components/editor/form-editor.component.d.ts +3 -2
  159. package/tableview/editor/components/formly/fields/formly-field-fieldset/formly-field-fieldset.component.d.ts +1 -1
  160. package/tableview/editor/components/formly/fields/formly-field-type.abstract.component.d.ts +2 -1
  161. package/tableview/index.d.ts +0 -1
  162. package/version-info.json +6 -6
  163. package/esm2022/table/services/data-list.service.mjs +0 -29
  164. package/esm2022/tableview/action/models/execution/action-instance-state.model.mjs +0 -32
  165. package/table/services/data-list.service.d.ts +0 -19
  166. package/tableview/action/models/execution/action-instance-state.model.d.ts +0 -30
@@ -13,26 +13,25 @@ import { Table } from 'primeng/table';
13
13
  import { TagModule } from 'primeng/tag';
14
14
  import { ToggleButtonModule } from 'primeng/togglebutton';
15
15
  import { BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, skip } from 'rxjs';
16
- import { COMMONS_MODULE_CONFIG_IT, FilterMatchMode, TemplateDirective, findTemplateByName } from '@mediusinc/mng-commons/core';
17
- import { filterApplySerializationConfigToCmp, filterGetDateConfig, filterSetMetadataOnChange, filterSetMetadataOnDisplayChange } from '../../../helpers/filters';
18
- import { DataListService } from '../../../services/data-list.service';
16
+ import { FilterMatchMode, TemplateDirective, findTemplateByName } from '@mediusinc/mng-commons/core';
17
+ import { filterSetMetadataOnChange, filterSetMetadataOnDisplayChange } from '../../../helpers/filters';
18
+ import { TableDataService } from '../../../services/table-data.service';
19
19
  import { COMMONS_TABLE_FEATURE_CONFIG_IT } from '../../../services/table-feature-config.token';
20
- import { FilterActiveTagComponent } from '../filter-active-tag/filter-active-tag.component';
21
- import { FilterFormComponent } from '../filter-form/filter-form.component';
20
+ import { TableFilterActiveTagComponent } from '../filter-active-tag/filter-active-tag.component';
21
+ import { TableFilterFormComponent } from '../filter-form/filter-form.component';
22
22
  import * as i0 from "@angular/core";
23
23
  import * as i1 from "primeng/overlaypanel";
24
24
  import * as i2 from "@ngx-translate/core";
25
25
  import * as i3 from "primeng/inputtext";
26
26
  import * as i4 from "@angular/forms";
27
27
  import * as i5 from "primeng/togglebutton";
28
- export class FilterOverlayWithTagComponent {
28
+ export class TableFilterOverlayWithTagComponent {
29
29
  static { this.SEARCH_WORD_LIMIT_MAX = 4; }
30
30
  constructor() {
31
31
  this.primeTable = inject(Table);
32
- this.dataListService = inject((DataListService));
33
- this.moduleConfig = inject(COMMONS_MODULE_CONFIG_IT, { optional: true });
32
+ this.tableData = inject((TableDataService));
34
33
  this.tableConfig = inject(COMMONS_TABLE_FEATURE_CONFIG_IT, { optional: true });
35
- this.descriptors = input.required();
34
+ this.metadata = input.required();
36
35
  this.genericFilterDescriptor = input();
37
36
  this.model = input.required();
38
37
  this.enableSearch = input(false, { transform: booleanAttribute });
@@ -40,18 +39,18 @@ export class FilterOverlayWithTagComponent {
40
39
  this.searchLimitWordMax = input(undefined);
41
40
  this.enableCaseSensitive = input(true, { transform: booleanAttribute });
42
41
  this.filterOverlay = viewChild.required(OverlayPanel);
43
- this.filterFormComponent = viewChild(FilterFormComponent);
42
+ this.filterFormComponent = viewChild(TableFilterFormComponent);
44
43
  this.templates = contentChildren(TemplateDirective);
45
44
  this.titleTemplate = computed(() => findTemplateByName([...this.templates()], 'title'));
46
45
  this.filters = computed(() => {
47
- return this.setInitialFilters(this.dataListService.filterMeta());
46
+ return this.getInitialFilters(this.tableData.filterMeta(), this.metadata());
48
47
  });
49
- this.showFilterButton = computed(() => this.descriptors().length > 0);
48
+ this.showFilterButton = computed(() => this.metadata().length > 0);
50
49
  this.activeFilters = computed(() => {
51
50
  const filterEntry = this.filters();
52
- return this.descriptors()
51
+ return this.metadata()
53
52
  .filter(d => {
54
- const filter = filterEntry[d.property];
53
+ const filter = filterEntry[d.descriptor.property];
55
54
  return (filter &&
56
55
  filter.matchMode !== undefined &&
57
56
  filter.displayMatchMode !== undefined &&
@@ -59,11 +58,10 @@ export class FilterOverlayWithTagComponent {
59
58
  filter.matchMode === FilterMatchMode.DoesNotExist ||
60
59
  (filter.value !== undefined && filter.displayValue !== undefined)));
61
60
  })
62
- .map(d => filterEntry[d.property]);
61
+ .map(d => filterEntry[d.descriptor.property]);
63
62
  });
64
- this.activeFilterProperties = computed(() => this.activeFilters().map(f => f.descriptor.property));
63
+ this.activeFilterProperties = computed(() => this.activeFilters().map(f => f.metadata.descriptor.property));
65
64
  this.filterEdit = signal(undefined);
66
- this.serializationCfg = {};
67
65
  // global search model
68
66
  this.searchValue = computed(() => this.search()?.value);
69
67
  this.searchCaseSensitive = computed(() => this.search()?.caseSensitive);
@@ -73,28 +71,27 @@ export class FilterOverlayWithTagComponent {
73
71
  if (inputLimit !== undefined) {
74
72
  return inputLimit;
75
73
  }
76
- return this.tableConfig?.searchLimitMaxWords !== undefined ? this.tableConfig?.searchLimitMaxWords : FilterOverlayWithTagComponent.SEARCH_WORD_LIMIT_MAX;
74
+ return this.tableConfig?.searchLimitMaxWords !== undefined ? this.tableConfig?.searchLimitMaxWords : TableFilterOverlayWithTagComponent.SEARCH_WORD_LIMIT_MAX;
77
75
  });
78
76
  this.searchValueSubject = new BehaviorSubject(undefined);
79
77
  this.searchCaseSensitiveSubject = new BehaviorSubject(undefined);
80
78
  // UI utilities
81
79
  this.clickedOnFilterEvent = undefined;
82
- filterApplySerializationConfigToCmp(this.moduleConfig, this.serializationCfg);
83
80
  combineLatest([this.searchValueSubject.pipe(debounceTime(500), distinctUntilChanged()), this.searchCaseSensitiveSubject])
84
81
  // NOTE: skip is used to ignore propagating the initial value of the subjects
85
82
  .pipe(skip(1), takeUntilDestroyed())
86
83
  .subscribe(([value, caseSensitive]) => {
87
- this.updatePrimeTableGlobalFilter(value == null ? this.search()?.value ?? '' : value, caseSensitive == null ? this.search()?.caseSensitive ?? undefined : caseSensitive);
84
+ this.updatePrimeTableGlobalFilter(value == null ? (this.search()?.value ?? '') : value, caseSensitive == null ? (this.search()?.caseSensitive ?? undefined) : caseSensitive);
88
85
  });
89
86
  }
90
87
  onFilterFormApply(event) {
91
- const descriptor = this.descriptors().find(d => d.property === event.property);
92
- if (!descriptor) {
88
+ const filterMetadata = this.metadata().find(d => d.descriptor.property === event.property);
89
+ if (!filterMetadata) {
93
90
  return;
94
91
  }
95
92
  const filterData = {
96
- ...filterSetMetadataOnDisplayChange({ caseSensitive: event.caseSensitive }, event.matchMode, event.value, descriptor.filterType, filterGetDateConfig(descriptor, this.serializationCfg)),
97
- descriptor: descriptor
93
+ ...filterSetMetadataOnDisplayChange({ caseSensitive: event.caseSensitive }, event.matchMode, event.value, filterMetadata.descriptor.filterType, filterMetadata.dateConfig),
94
+ metadata: filterMetadata
98
95
  };
99
96
  this.updatePrimeTableFilter(filterData);
100
97
  // this keeps the UI updated properly before closing the overlay
@@ -105,7 +102,7 @@ export class FilterOverlayWithTagComponent {
105
102
  }
106
103
  onFilterRemove(event) {
107
104
  this.updatePrimeTableFilter({
108
- ...this.filters()[event.filter.descriptor.property],
105
+ ...this.filters()[event.filter.metadata.descriptor.property],
109
106
  matchMode: undefined,
110
107
  displayMatchMode: undefined,
111
108
  value: undefined,
@@ -155,7 +152,7 @@ export class FilterOverlayWithTagComponent {
155
152
  }
156
153
  onFilterAddOrEdit(filter, event) {
157
154
  // If user clicks on the same filter or add that is already open, close the overlay
158
- if (this.filterOverlay().overlayVisible && this.filterEdit()?.descriptor.property === filter?.descriptor.property) {
155
+ if (this.filterOverlay().overlayVisible && this.filterEdit()?.metadata.descriptor.property === filter?.metadata.descriptor.property) {
159
156
  this.filterOverlay().hide();
160
157
  return;
161
158
  }
@@ -170,23 +167,25 @@ export class FilterOverlayWithTagComponent {
170
167
  this.filterOverlay().show(event);
171
168
  }
172
169
  }
173
- setInitialFilters(filtersInit) {
170
+ getInitialFilters(filtersInit, metadata) {
174
171
  const filtersResult = {};
175
- for (const property in filtersInit) {
176
- const filterInit = filtersInit[property];
177
- const descriptor = this.descriptors().find(filterDescriptor => filterDescriptor.property === property);
178
- if (!descriptor) {
179
- continue;
172
+ if (filtersInit) {
173
+ for (const property in filtersInit) {
174
+ const filterInit = filtersInit[property];
175
+ const filterMetadata = metadata.find(m => m.descriptor.property === property);
176
+ if (!filterMetadata) {
177
+ continue;
178
+ }
179
+ filtersResult[property] = {
180
+ ...filterSetMetadataOnChange(filterInit, filterInit.matchMode, filterInit.value, filterMetadata.descriptor.filterType, filterMetadata.dateConfig),
181
+ metadata: filterMetadata
182
+ };
180
183
  }
181
- filtersResult[property] = {
182
- ...filterSetMetadataOnChange(filterInit, filterInit.matchMode, filterInit.value, descriptor.filterType, filterGetDateConfig(descriptor, this.serializationCfg)),
183
- descriptor: descriptor
184
- };
185
184
  }
186
185
  return filtersResult;
187
186
  }
188
187
  updatePrimeTableFilter(filter) {
189
- this.primeTable.filters[filter.descriptor.property] = { ...filter };
188
+ this.primeTable.filters[filter.metadata.descriptor.property] = { ...filter };
190
189
  this.primeTable._filter();
191
190
  }
192
191
  updatePrimeTableGlobalFilter(searchQuery, caseSensitive = false) {
@@ -194,18 +193,18 @@ export class FilterOverlayWithTagComponent {
194
193
  this.primeTable.filters['global'] = { ...{ value: searchQuery, matchMode: 'contains', caseSensitive: caseSensitive } };
195
194
  this.primeTable._filter();
196
195
  }
197
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: FilterOverlayWithTagComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
198
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: FilterOverlayWithTagComponent, isStandalone: true, selector: "mng-filter-overlay-with-tag", inputs: { descriptors: { classPropertyName: "descriptors", publicName: "descriptors", isSignal: true, isRequired: true, transformFunction: null }, genericFilterDescriptor: { classPropertyName: "genericFilterDescriptor", publicName: "genericFilterDescriptor", isSignal: true, isRequired: false, transformFunction: null }, model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, enableSearch: { classPropertyName: "enableSearch", publicName: "enableSearch", isSignal: true, isRequired: false, transformFunction: null }, search: { classPropertyName: "search", publicName: "search", isSignal: true, isRequired: false, transformFunction: null }, searchLimitWordMax: { classPropertyName: "searchLimitWordMax", publicName: "searchLimitWordMax", isSignal: true, isRequired: false, transformFunction: null }, enableCaseSensitive: { classPropertyName: "enableCaseSensitive", publicName: "enableCaseSensitive", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "templates", predicate: TemplateDirective, isSignal: true }], viewQueries: [{ propertyName: "filterOverlay", first: true, predicate: OverlayPanel, descendants: true, isSignal: true }, { propertyName: "filterFormComponent", first: true, predicate: FilterFormComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"flex align-items-center flex-grow-1\">\n @if (titleTemplate()) {\n <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n }\n @if (showFilterButton()) {\n <p-button\n icon=\"pi pi-filter\"\n rounded=\"true\"\n [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n size=\"small\"\n (click)=\"onFilterAdd($event)\"\n [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n </p-button>\n }\n @if (enableSearch()) {\n <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n <span class=\"p-input-icon-left w-full\">\n <i class=\"pi pi-search\"></i>\n <input\n [ngModel]=\"searchValue()\"\n (ngModelChange)=\"onSearchChange($event)\"\n name=\"globalSearch\"\n type=\"text\"\n pInputText\n class=\"search-input w-full\"\n [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n [placeholder]=\"'mngFilter.search.input' | translate\" />\n @if (enableCaseSensitive()) {\n <span class=\"toggle-button-input\">\n <p-toggleButton\n styleClass=\"ml-1 p-1 p-button-sm\"\n [ngModel]=\"searchCaseSensitive()\"\n (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n onLabel=\"Aa\"\n offLabel=\"Aa\" />\n </span>\n }\n </span>\n @if (searchWordLimitMaxError()) {\n <small class=\"p-error block\">\n {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n </small>\n }\n </div>\n }\n</div>\n@if (activeFilters().length > 0) {\n <div class=\"flex align-items-center flex-wrap mt-2\">\n @for (filter of activeFilters(); track filter.descriptor.property) {\n <mng-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n }\n </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n <mng-filter-form\n [model]=\"model()\"\n [descriptors]=\"descriptors()\"\n [genericDescriptor]=\"genericFilterDescriptor()\"\n [filter]=\"filterEdit()\"\n [disabledProperties]=\"activeFilterProperties()\"\n [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n [overlay]=\"op\"\n [enableCaseSensitive]=\"enableCaseSensitive()\"\n (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n", styles: [".toggle-button-input{position:absolute;right:.35rem;top:50%;transform:translateY(-50%)}\n"], dependencies: [{ kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i1.OverlayPanel, selector: "p-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: FilterFormComponent, selector: "mng-filter-form", inputs: ["title", "descriptors", "genericDescriptor", "model", "filter", "overlay", "disabledProperties", "enableCaseSensitive", "propertySearch"], outputs: ["apply"] }, { kind: "component", type: Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: FilterActiveTagComponent, selector: "mng-filter-active-tag", inputs: ["model", "filter"], outputs: ["edit", "remove"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i3.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "ngmodule", type: PaginatorModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ToggleButtonModule }, { kind: "component", type: i5.ToggleButton, selector: "p-toggleButton", inputs: ["onLabel", "offLabel", "onIcon", "offIcon", "ariaLabel", "ariaLabelledBy", "disabled", "style", "styleClass", "inputId", "tabindex", "iconPos", "autofocus"], outputs: ["onChange"] }, { kind: "ngmodule", type: InputGroupModule }, { kind: "ngmodule", type: InputGroupAddonModule }, { kind: "ngmodule", type: CheckboxModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
196
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TableFilterOverlayWithTagComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
197
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: TableFilterOverlayWithTagComponent, isStandalone: true, selector: "mng-table-filter-overlay-with-tag", inputs: { metadata: { classPropertyName: "metadata", publicName: "metadata", isSignal: true, isRequired: true, transformFunction: null }, genericFilterDescriptor: { classPropertyName: "genericFilterDescriptor", publicName: "genericFilterDescriptor", isSignal: true, isRequired: false, transformFunction: null }, model: { classPropertyName: "model", publicName: "model", isSignal: true, isRequired: true, transformFunction: null }, enableSearch: { classPropertyName: "enableSearch", publicName: "enableSearch", isSignal: true, isRequired: false, transformFunction: null }, search: { classPropertyName: "search", publicName: "search", isSignal: true, isRequired: false, transformFunction: null }, searchLimitWordMax: { classPropertyName: "searchLimitWordMax", publicName: "searchLimitWordMax", isSignal: true, isRequired: false, transformFunction: null }, enableCaseSensitive: { classPropertyName: "enableCaseSensitive", publicName: "enableCaseSensitive", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "templates", predicate: TemplateDirective, isSignal: true }], viewQueries: [{ propertyName: "filterOverlay", first: true, predicate: OverlayPanel, descendants: true, isSignal: true }, { propertyName: "filterFormComponent", first: true, predicate: TableFilterFormComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"flex align-items-center flex-grow-1\">\n @if (titleTemplate()) {\n <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n }\n @if (showFilterButton()) {\n <p-button\n icon=\"pi pi-filter\"\n rounded=\"true\"\n [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n size=\"small\"\n (click)=\"onFilterAdd($event)\"\n [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n </p-button>\n }\n @if (enableSearch()) {\n <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n <span class=\"p-input-icon-left w-full\">\n <i class=\"pi pi-search\"></i>\n <input\n [ngModel]=\"searchValue()\"\n (ngModelChange)=\"onSearchChange($event)\"\n name=\"globalSearch\"\n type=\"text\"\n pInputText\n class=\"search-input w-full\"\n [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n [placeholder]=\"'mngFilter.search.input' | translate\" />\n @if (enableCaseSensitive()) {\n <span class=\"toggle-button-input\">\n <p-toggleButton\n styleClass=\"ml-1 p-1 p-button-sm\"\n [ngModel]=\"searchCaseSensitive()\"\n (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n onLabel=\"Aa\"\n offLabel=\"Aa\" />\n </span>\n }\n </span>\n @if (searchWordLimitMaxError()) {\n <small class=\"p-error block\">\n {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n </small>\n }\n </div>\n }\n</div>\n@if (activeFilters().length > 0) {\n <div class=\"flex align-items-center flex-wrap mt-2\">\n @for (filter of activeFilters(); track filter.metadata.descriptor.property) {\n <mng-table-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n }\n </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n <mng-table-filter-form\n [model]=\"model()\"\n [metadata]=\"metadata()\"\n [genericDescriptor]=\"genericFilterDescriptor()\"\n [filter]=\"filterEdit()\"\n [disabledProperties]=\"activeFilterProperties()\"\n [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n [overlay]=\"op\"\n [enableCaseSensitive]=\"enableCaseSensitive()\"\n (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n", styles: [".toggle-button-input{position:absolute;right:.35rem;top:50%;transform:translateY(-50%)}\n"], dependencies: [{ kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i1.OverlayPanel, selector: "p-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: TableFilterFormComponent, selector: "mng-table-filter-form", inputs: ["title", "metadata", "genericDescriptor", "model", "filter", "overlay", "disabledProperties", "enableCaseSensitive", "propertySearch"], outputs: ["apply"] }, { kind: "component", type: Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: TableFilterActiveTagComponent, selector: "mng-table-filter-active-tag", inputs: ["model", "filter"], outputs: ["edit", "remove"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: InputTextModule }, { kind: "directive", type: i3.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "ngmodule", type: PaginatorModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ToggleButtonModule }, { kind: "component", type: i5.ToggleButton, selector: "p-toggleButton", inputs: ["onLabel", "offLabel", "onIcon", "offIcon", "ariaLabel", "ariaLabelledBy", "disabled", "style", "styleClass", "inputId", "tabindex", "iconPos", "autofocus"], outputs: ["onChange"] }, { kind: "ngmodule", type: InputGroupModule }, { kind: "ngmodule", type: InputGroupAddonModule }, { kind: "ngmodule", type: CheckboxModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
199
198
  }
200
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: FilterOverlayWithTagComponent, decorators: [{
199
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TableFilterOverlayWithTagComponent, decorators: [{
201
200
  type: Component,
202
- args: [{ standalone: true, selector: 'mng-filter-overlay-with-tag', imports: [
201
+ args: [{ standalone: true, selector: 'mng-table-filter-overlay-with-tag', imports: [
203
202
  OverlayPanelModule,
204
203
  TranslateModule,
205
204
  TagModule,
206
- FilterFormComponent,
205
+ TableFilterFormComponent,
207
206
  Button,
208
- FilterActiveTagComponent,
207
+ TableFilterActiveTagComponent,
209
208
  NgTemplateOutlet,
210
209
  InputTextModule,
211
210
  PaginatorModule,
@@ -215,6 +214,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
215
214
  InputGroupAddonModule,
216
215
  CheckboxModule,
217
216
  NgStyle
218
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex align-items-center flex-grow-1\">\n @if (titleTemplate()) {\n <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n }\n @if (showFilterButton()) {\n <p-button\n icon=\"pi pi-filter\"\n rounded=\"true\"\n [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n size=\"small\"\n (click)=\"onFilterAdd($event)\"\n [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n </p-button>\n }\n @if (enableSearch()) {\n <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n <span class=\"p-input-icon-left w-full\">\n <i class=\"pi pi-search\"></i>\n <input\n [ngModel]=\"searchValue()\"\n (ngModelChange)=\"onSearchChange($event)\"\n name=\"globalSearch\"\n type=\"text\"\n pInputText\n class=\"search-input w-full\"\n [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n [placeholder]=\"'mngFilter.search.input' | translate\" />\n @if (enableCaseSensitive()) {\n <span class=\"toggle-button-input\">\n <p-toggleButton\n styleClass=\"ml-1 p-1 p-button-sm\"\n [ngModel]=\"searchCaseSensitive()\"\n (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n onLabel=\"Aa\"\n offLabel=\"Aa\" />\n </span>\n }\n </span>\n @if (searchWordLimitMaxError()) {\n <small class=\"p-error block\">\n {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n </small>\n }\n </div>\n }\n</div>\n@if (activeFilters().length > 0) {\n <div class=\"flex align-items-center flex-wrap mt-2\">\n @for (filter of activeFilters(); track filter.descriptor.property) {\n <mng-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n }\n </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n <mng-filter-form\n [model]=\"model()\"\n [descriptors]=\"descriptors()\"\n [genericDescriptor]=\"genericFilterDescriptor()\"\n [filter]=\"filterEdit()\"\n [disabledProperties]=\"activeFilterProperties()\"\n [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n [overlay]=\"op\"\n [enableCaseSensitive]=\"enableCaseSensitive()\"\n (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n", styles: [".toggle-button-input{position:absolute;right:.35rem;top:50%;transform:translateY(-50%)}\n"] }]
217
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex align-items-center flex-grow-1\">\n @if (titleTemplate()) {\n <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n }\n @if (showFilterButton()) {\n <p-button\n icon=\"pi pi-filter\"\n rounded=\"true\"\n [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n size=\"small\"\n (click)=\"onFilterAdd($event)\"\n [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n </p-button>\n }\n @if (enableSearch()) {\n <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n <span class=\"p-input-icon-left w-full\">\n <i class=\"pi pi-search\"></i>\n <input\n [ngModel]=\"searchValue()\"\n (ngModelChange)=\"onSearchChange($event)\"\n name=\"globalSearch\"\n type=\"text\"\n pInputText\n class=\"search-input w-full\"\n [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n [placeholder]=\"'mngFilter.search.input' | translate\" />\n @if (enableCaseSensitive()) {\n <span class=\"toggle-button-input\">\n <p-toggleButton\n styleClass=\"ml-1 p-1 p-button-sm\"\n [ngModel]=\"searchCaseSensitive()\"\n (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n onLabel=\"Aa\"\n offLabel=\"Aa\" />\n </span>\n }\n </span>\n @if (searchWordLimitMaxError()) {\n <small class=\"p-error block\">\n {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n </small>\n }\n </div>\n }\n</div>\n@if (activeFilters().length > 0) {\n <div class=\"flex align-items-center flex-wrap mt-2\">\n @for (filter of activeFilters(); track filter.metadata.descriptor.property) {\n <mng-table-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n }\n </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n <mng-table-filter-form\n [model]=\"model()\"\n [metadata]=\"metadata()\"\n [genericDescriptor]=\"genericFilterDescriptor()\"\n [filter]=\"filterEdit()\"\n [disabledProperties]=\"activeFilterProperties()\"\n [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n [overlay]=\"op\"\n [enableCaseSensitive]=\"enableCaseSensitive()\"\n (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n", styles: [".toggle-button-input{position:absolute;right:.35rem;top:50%;transform:translateY(-50%)}\n"] }]
219
218
  }], ctorParameters: () => [] });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-overlay-with-tag.component.js","sourceRoot":"","sources":["../../../../../../table/src/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.ts","../../../../../../table/src/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgClass, NgStyle, NgTemplateOutlet} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, Signal, TemplateRef, booleanAttribute, computed, contentChildren, inject, input, signal, viewChild} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Button} from 'primeng/button';\nimport {CheckboxModule} from 'primeng/checkbox';\nimport {InputGroupModule} from 'primeng/inputgroup';\nimport {InputGroupAddonModule} from 'primeng/inputgroupaddon';\nimport {InputTextModule} from 'primeng/inputtext';\nimport {OverlayPanel, OverlayPanelModule} from 'primeng/overlaypanel';\nimport {PaginatorModule} from 'primeng/paginator';\nimport {Table} from 'primeng/table';\nimport {TagModule} from 'primeng/tag';\nimport {ToggleButtonModule} from 'primeng/togglebutton';\nimport {BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, skip} from 'rxjs';\n\nimport {COMMONS_MODULE_CONFIG_IT, CommonsFilterMetadata, CommonsSerializationConfig, FilterMatchMode, TemplateDirective, findTemplateByName} from '@mediusinc/mng-commons/core';\nimport {FilterDescriptor, FilterGenericDescriptor} from '@mediusinc/mng-commons/filter';\nimport {ModelDescriptor} from '@mediusinc/mng-commons/model';\n\nimport {filterApplySerializationConfigToCmp, filterGetDateConfig, filterSetMetadataOnChange, filterSetMetadataOnDisplayChange} from '../../../helpers/filters';\nimport {CommonsFilterMetadataWithDescriptor, FilterActiveTagEvent, FilterFormEmitEvent} from '../../../models/filter.model';\nimport {DataListService} from '../../../services/data-list.service';\nimport {COMMONS_TABLE_FEATURE_CONFIG_IT} from '../../../services/table-feature-config.token';\nimport {FilterActiveTagComponent} from '../filter-active-tag/filter-active-tag.component';\nimport {FilterFormComponent} from '../filter-form/filter-form.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-filter-overlay-with-tag',\n    templateUrl: './filter-overlay-with-tag.component.html',\n    styleUrls: ['./filter-overlay-with-tag.component.scss'],\n    imports: [\n        OverlayPanelModule,\n        TranslateModule,\n        TagModule,\n        FilterFormComponent,\n        Button,\n        FilterActiveTagComponent,\n        NgTemplateOutlet,\n        InputTextModule,\n        PaginatorModule,\n        NgClass,\n        ToggleButtonModule,\n        InputGroupModule,\n        InputGroupAddonModule,\n        CheckboxModule,\n        NgStyle\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FilterOverlayWithTagComponent {\n    private static readonly SEARCH_WORD_LIMIT_MAX = 4;\n\n    private readonly primeTable = inject(Table);\n    private readonly dataListService = inject(DataListService<any>);\n    private readonly moduleConfig = inject(COMMONS_MODULE_CONFIG_IT, {optional: true});\n    private readonly tableConfig = inject(COMMONS_TABLE_FEATURE_CONFIG_IT, {optional: true});\n\n    public descriptors = input.required<FilterDescriptor<any, any>[]>();\n    public genericFilterDescriptor = input<FilterGenericDescriptor>();\n    public model = input.required<ModelDescriptor<any>>();\n    public enableSearch = input(false, {transform: booleanAttribute});\n    public search = input<{value: string; caseSensitive: boolean} | undefined>();\n    public searchLimitWordMax = input<number | undefined | null>(undefined);\n    public enableCaseSensitive = input(true, {transform: booleanAttribute});\n\n    private filterOverlay = viewChild.required(OverlayPanel);\n    private filterFormComponent = viewChild(FilterFormComponent);\n\n    public templates = contentChildren(TemplateDirective);\n    public titleTemplate: Signal<TemplateRef<any> | null> = computed(() => findTemplateByName([...this.templates()], 'title'));\n\n    public filters = computed(() => {\n        return this.setInitialFilters(this.dataListService.filterMeta());\n    });\n\n    public showFilterButton = computed(() => this.descriptors().length > 0);\n\n    public activeFilters = computed(() => {\n        const filterEntry = this.filters();\n        return this.descriptors()\n            .filter(d => {\n                const filter = filterEntry[d.property];\n                return (\n                    filter &&\n                    filter.matchMode !== undefined &&\n                    filter.displayMatchMode !== undefined &&\n                    (filter.matchMode === FilterMatchMode.Exists ||\n                        filter.matchMode === FilterMatchMode.DoesNotExist ||\n                        (filter.value !== undefined && filter.displayValue !== undefined))\n                );\n            })\n            .map(d => filterEntry[d.property]!);\n    });\n    public activeFilterProperties = computed(() => this.activeFilters().map(f => f.descriptor.property));\n    public filterEdit = signal<CommonsFilterMetadataWithDescriptor | undefined>(undefined);\n\n    private serializationCfg: CommonsSerializationConfig = {};\n\n    // global search model\n    public searchValue = computed(() => this.search()?.value);\n    public searchCaseSensitive = computed(() => this.search()?.caseSensitive);\n    public searchWordLimitMaxError = signal(false);\n    private searchWordLimitMaxCmp = computed(() => {\n        const inputLimit = this.searchLimitWordMax();\n        if (inputLimit !== undefined) {\n            return inputLimit;\n        }\n        return this.tableConfig?.searchLimitMaxWords !== undefined ? this.tableConfig?.searchLimitMaxWords : FilterOverlayWithTagComponent.SEARCH_WORD_LIMIT_MAX;\n    });\n    private searchValueSubject = new BehaviorSubject<string | undefined>(undefined);\n    private searchCaseSensitiveSubject = new BehaviorSubject<boolean | undefined>(undefined);\n\n    // UI utilities\n    private clickedOnFilterEvent: {event?: Event; filter?: CommonsFilterMetadataWithDescriptor} | undefined = undefined;\n\n    constructor() {\n        filterApplySerializationConfigToCmp(this.moduleConfig, this.serializationCfg);\n\n        combineLatest([this.searchValueSubject.pipe(debounceTime(500), distinctUntilChanged()), this.searchCaseSensitiveSubject])\n            // NOTE: skip is used to ignore propagating the initial value of the subjects\n            .pipe(skip(1), takeUntilDestroyed())\n            .subscribe(([value, caseSensitive]) => {\n                this.updatePrimeTableGlobalFilter(\n                    value == null ? this.search()?.value ?? '' : value,\n                    caseSensitive == null ? this.search()?.caseSensitive ?? undefined : caseSensitive\n                );\n            });\n    }\n\n    onFilterFormApply(event: FilterFormEmitEvent) {\n        const descriptor = this.descriptors().find(d => d.property === event.property);\n        if (!descriptor) {\n            return;\n        }\n\n        const filterData = {\n            ...filterSetMetadataOnDisplayChange(\n                {caseSensitive: event.caseSensitive},\n                event.matchMode,\n                event.value,\n                descriptor.filterType,\n                filterGetDateConfig(descriptor, this.serializationCfg)\n            ),\n            descriptor: descriptor\n        };\n\n        this.updatePrimeTableFilter(filterData);\n\n        // this keeps the UI updated properly before closing the overlay\n        this.filterEdit.set(filterData);\n\n        // Resetting the form is done in the onOverlayHide callback because resetting the\n        // values here renders empty inputs for a split second before closing the overlay\n        this.filterOverlay().hide();\n    }\n\n    onFilterRemove(event: FilterActiveTagEvent) {\n        this.updatePrimeTableFilter({\n            ...this.filters()[event.filter.descriptor.property],\n            matchMode: undefined,\n            displayMatchMode: undefined,\n            value: undefined,\n            displayValue: undefined\n        });\n    }\n\n    onFilterEdit(event: FilterActiveTagEvent) {\n        this.onFilterAddOrEdit(event.filter, event.event);\n    }\n\n    onFilterAdd(event: Event) {\n        this.onFilterAddOrEdit(undefined, event);\n    }\n\n    onSearchChange(value: string): void {\n        const searchWordLimitMax = this.searchWordLimitMaxCmp();\n        if (searchWordLimitMax !== null) {\n            const wordCount = value.split(/\\s+/).filter(word => word.length > 0).length;\n            this.searchWordLimitMaxError.set(wordCount > searchWordLimitMax);\n        } else {\n            this.searchWordLimitMaxError.set(false);\n        }\n\n        if (!this.searchWordLimitMaxError()) {\n            this.searchValueSubject.next(value);\n        }\n    }\n\n    onSearchCaseSensitiveChange(value: boolean) {\n        this.searchCaseSensitiveSubject.next(value);\n    }\n\n    onOverlayHide() {\n        // resetting the form is done here for a smoother animation\n        if (this.filterFormComponent !== undefined) {\n            this.filterFormComponent()?.resetForm();\n        }\n\n        if (this.clickedOnFilterEvent) {\n            // show the overlay again if the user clicked another filter\n            setTimeout(() => {\n                this.filterEdit.set(this.clickedOnFilterEvent?.filter);\n                this.filterOverlay().show(this.clickedOnFilterEvent?.event);\n                this.clickedOnFilterEvent = undefined;\n            }, 0);\n            return;\n        } else {\n            // clean state\n            this.filterEdit.set(undefined);\n        }\n    }\n\n    private onFilterAddOrEdit(filter?: CommonsFilterMetadataWithDescriptor, event?: Event) {\n        // If user clicks on the same filter or add that is already open, close the overlay\n        if (this.filterOverlay().overlayVisible && this.filterEdit()?.descriptor.property === filter?.descriptor.property) {\n            this.filterOverlay().hide();\n            return;\n        }\n\n        if (this.filterOverlay().overlayVisible) {\n            // In case the user clicks another filter, 're-showing' the overlay in\n            // the new position is done in the onOverlayHide callback\n            this.clickedOnFilterEvent = {event, filter};\n            this.filterOverlay().hide();\n        } else {\n            this.filterEdit.set(filter);\n            this.filterOverlay().show(event);\n        }\n    }\n\n    private setInitialFilters(filtersInit: Record<string, CommonsFilterMetadata>) {\n        const filtersResult: {[p: string]: CommonsFilterMetadataWithDescriptor} = {};\n\n        for (const property in filtersInit) {\n            const filterInit = filtersInit[property];\n\n            const descriptor = this.descriptors().find(filterDescriptor => filterDescriptor.property === property);\n            if (!descriptor) {\n                continue;\n            }\n\n            filtersResult[property] = {\n                ...filterSetMetadataOnChange(filterInit, filterInit.matchMode, filterInit.value, descriptor.filterType, filterGetDateConfig(descriptor, this.serializationCfg)),\n                descriptor: descriptor\n            };\n        }\n\n        return filtersResult;\n    }\n\n    private updatePrimeTableFilter(filter: CommonsFilterMetadataWithDescriptor) {\n        this.primeTable.filters[filter.descriptor.property] = {...filter};\n        this.primeTable._filter();\n    }\n\n    private updatePrimeTableGlobalFilter(searchQuery: string | null, caseSensitive = false) {\n        // match mode needs to be set for inline search\n        this.primeTable.filters['global'] = {...{value: searchQuery, matchMode: 'contains', caseSensitive: caseSensitive}};\n        this.primeTable._filter();\n    }\n}\n","<div class=\"flex align-items-center flex-grow-1\">\n    @if (titleTemplate()) {\n        <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n    }\n    @if (showFilterButton()) {\n        <p-button\n            icon=\"pi pi-filter\"\n            rounded=\"true\"\n            [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n            size=\"small\"\n            (click)=\"onFilterAdd($event)\"\n            [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n        </p-button>\n    }\n    @if (enableSearch()) {\n        <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n            <span class=\"p-input-icon-left w-full\">\n                <i class=\"pi pi-search\"></i>\n                <input\n                    [ngModel]=\"searchValue()\"\n                    (ngModelChange)=\"onSearchChange($event)\"\n                    name=\"globalSearch\"\n                    type=\"text\"\n                    pInputText\n                    class=\"search-input w-full\"\n                    [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n                    [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n                    [placeholder]=\"'mngFilter.search.input' | translate\" />\n                @if (enableCaseSensitive()) {\n                    <span class=\"toggle-button-input\">\n                        <p-toggleButton\n                            styleClass=\"ml-1 p-1 p-button-sm\"\n                            [ngModel]=\"searchCaseSensitive()\"\n                            (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n                            onLabel=\"Aa\"\n                            offLabel=\"Aa\" />\n                    </span>\n                }\n            </span>\n            @if (searchWordLimitMaxError()) {\n                <small class=\"p-error block\">\n                    {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n                </small>\n            }\n        </div>\n    }\n</div>\n@if (activeFilters().length > 0) {\n    <div class=\"flex align-items-center flex-wrap mt-2\">\n        @for (filter of activeFilters(); track filter.descriptor.property) {\n            <mng-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n        }\n    </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n    <mng-filter-form\n        [model]=\"model()\"\n        [descriptors]=\"descriptors()\"\n        [genericDescriptor]=\"genericFilterDescriptor()\"\n        [filter]=\"filterEdit()\"\n        [disabledProperties]=\"activeFilterProperties()\"\n        [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n        [overlay]=\"op\"\n        [enableCaseSensitive]=\"enableCaseSensitive()\"\n        (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-overlay-with-tag.component.js","sourceRoot":"","sources":["../../../../../../table/src/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.ts","../../../../../../table/src/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgClass, NgStyle, NgTemplateOutlet} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, Signal, TemplateRef, booleanAttribute, computed, contentChildren, inject, input, signal, viewChild} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\nimport {TranslateModule} from '@ngx-translate/core';\nimport {Button} from 'primeng/button';\nimport {CheckboxModule} from 'primeng/checkbox';\nimport {InputGroupModule} from 'primeng/inputgroup';\nimport {InputGroupAddonModule} from 'primeng/inputgroupaddon';\nimport {InputTextModule} from 'primeng/inputtext';\nimport {OverlayPanel, OverlayPanelModule} from 'primeng/overlaypanel';\nimport {PaginatorModule} from 'primeng/paginator';\nimport {Table} from 'primeng/table';\nimport {TagModule} from 'primeng/tag';\nimport {ToggleButtonModule} from 'primeng/togglebutton';\nimport {BehaviorSubject, combineLatest, debounceTime, distinctUntilChanged, skip} from 'rxjs';\n\nimport {CommonsFilterMetadata, FilterMatchMode, TemplateDirective, findTemplateByName} from '@mediusinc/mng-commons/core';\nimport {FilterGenericDescriptor} from '@mediusinc/mng-commons/filter';\nimport {ModelDescriptor} from '@mediusinc/mng-commons/model';\n\nimport {filterSetMetadataOnChange, filterSetMetadataOnDisplayChange} from '../../../helpers/filters';\nimport {FilterActiveTagEvent, FilterFormEmitEvent, FilterMetadata, FilterState} from '../../../models/filter.model';\nimport {TableDataService} from '../../../services/table-data.service';\nimport {COMMONS_TABLE_FEATURE_CONFIG_IT} from '../../../services/table-feature-config.token';\nimport {TableFilterActiveTagComponent} from '../filter-active-tag/filter-active-tag.component';\nimport {TableFilterFormComponent} from '../filter-form/filter-form.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-table-filter-overlay-with-tag',\n    templateUrl: './filter-overlay-with-tag.component.html',\n    styleUrls: ['./filter-overlay-with-tag.component.scss'],\n    imports: [\n        OverlayPanelModule,\n        TranslateModule,\n        TagModule,\n        TableFilterFormComponent,\n        Button,\n        TableFilterActiveTagComponent,\n        NgTemplateOutlet,\n        InputTextModule,\n        PaginatorModule,\n        NgClass,\n        ToggleButtonModule,\n        InputGroupModule,\n        InputGroupAddonModule,\n        CheckboxModule,\n        NgStyle\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TableFilterOverlayWithTagComponent {\n    private static readonly SEARCH_WORD_LIMIT_MAX = 4;\n\n    private readonly primeTable = inject(Table);\n    private readonly tableData = inject(TableDataService<any>);\n    private readonly tableConfig = inject(COMMONS_TABLE_FEATURE_CONFIG_IT, {optional: true});\n\n    public metadata = input.required<FilterMetadata[]>();\n    public genericFilterDescriptor = input<FilterGenericDescriptor>();\n    public model = input.required<ModelDescriptor<any>>();\n    public enableSearch = input(false, {transform: booleanAttribute});\n    public search = input<{value: string; caseSensitive: boolean} | undefined>();\n    public searchLimitWordMax = input<number | undefined | null>(undefined);\n    public enableCaseSensitive = input(true, {transform: booleanAttribute});\n\n    private filterOverlay = viewChild.required(OverlayPanel);\n    private filterFormComponent = viewChild(TableFilterFormComponent);\n\n    public templates = contentChildren(TemplateDirective);\n    public titleTemplate: Signal<TemplateRef<any> | null> = computed(() => findTemplateByName([...this.templates()], 'title'));\n\n    public filters = computed(() => {\n        return this.getInitialFilters(this.tableData.filterMeta(), this.metadata());\n    });\n\n    public showFilterButton = computed(() => this.metadata().length > 0);\n\n    public activeFilters = computed(() => {\n        const filterEntry = this.filters();\n        return this.metadata()\n            .filter(d => {\n                const filter = filterEntry[d.descriptor.property];\n                return (\n                    filter &&\n                    filter.matchMode !== undefined &&\n                    filter.displayMatchMode !== undefined &&\n                    (filter.matchMode === FilterMatchMode.Exists ||\n                        filter.matchMode === FilterMatchMode.DoesNotExist ||\n                        (filter.value !== undefined && filter.displayValue !== undefined))\n                );\n            })\n            .map(d => filterEntry[d.descriptor.property]!);\n    });\n    public activeFilterProperties = computed(() => this.activeFilters().map(f => f.metadata.descriptor.property));\n    public filterEdit = signal<FilterState | undefined>(undefined);\n\n    // global search model\n    public searchValue = computed(() => this.search()?.value);\n    public searchCaseSensitive = computed(() => this.search()?.caseSensitive);\n    public searchWordLimitMaxError = signal(false);\n    private searchWordLimitMaxCmp = computed(() => {\n        const inputLimit = this.searchLimitWordMax();\n        if (inputLimit !== undefined) {\n            return inputLimit;\n        }\n        return this.tableConfig?.searchLimitMaxWords !== undefined ? this.tableConfig?.searchLimitMaxWords : TableFilterOverlayWithTagComponent.SEARCH_WORD_LIMIT_MAX;\n    });\n    private searchValueSubject = new BehaviorSubject<string | undefined>(undefined);\n    private searchCaseSensitiveSubject = new BehaviorSubject<boolean | undefined>(undefined);\n\n    // UI utilities\n    private clickedOnFilterEvent: {event?: Event; filter?: FilterState} | undefined = undefined;\n\n    constructor() {\n        combineLatest([this.searchValueSubject.pipe(debounceTime(500), distinctUntilChanged()), this.searchCaseSensitiveSubject])\n            // NOTE: skip is used to ignore propagating the initial value of the subjects\n            .pipe(skip(1), takeUntilDestroyed())\n            .subscribe(([value, caseSensitive]) => {\n                this.updatePrimeTableGlobalFilter(\n                    value == null ? (this.search()?.value ?? '') : value,\n                    caseSensitive == null ? (this.search()?.caseSensitive ?? undefined) : caseSensitive\n                );\n            });\n    }\n\n    onFilterFormApply(event: FilterFormEmitEvent) {\n        const filterMetadata = this.metadata().find(d => d.descriptor.property === event.property);\n        if (!filterMetadata) {\n            return;\n        }\n\n        const filterData: FilterState = {\n            ...filterSetMetadataOnDisplayChange(\n                {caseSensitive: event.caseSensitive},\n                event.matchMode,\n                event.value,\n                filterMetadata.descriptor.filterType,\n                filterMetadata.dateConfig\n            ),\n            metadata: filterMetadata\n        };\n\n        this.updatePrimeTableFilter(filterData);\n\n        // this keeps the UI updated properly before closing the overlay\n        this.filterEdit.set(filterData);\n\n        // Resetting the form is done in the onOverlayHide callback because resetting the\n        // values here renders empty inputs for a split second before closing the overlay\n        this.filterOverlay().hide();\n    }\n\n    onFilterRemove(event: FilterActiveTagEvent) {\n        this.updatePrimeTableFilter({\n            ...this.filters()[event.filter.metadata.descriptor.property],\n            matchMode: undefined,\n            displayMatchMode: undefined,\n            value: undefined,\n            displayValue: undefined\n        });\n    }\n\n    onFilterEdit(event: FilterActiveTagEvent) {\n        this.onFilterAddOrEdit(event.filter, event.event);\n    }\n\n    onFilterAdd(event: Event) {\n        this.onFilterAddOrEdit(undefined, event);\n    }\n\n    onSearchChange(value: string): void {\n        const searchWordLimitMax = this.searchWordLimitMaxCmp();\n        if (searchWordLimitMax !== null) {\n            const wordCount = value.split(/\\s+/).filter(word => word.length > 0).length;\n            this.searchWordLimitMaxError.set(wordCount > searchWordLimitMax);\n        } else {\n            this.searchWordLimitMaxError.set(false);\n        }\n\n        if (!this.searchWordLimitMaxError()) {\n            this.searchValueSubject.next(value);\n        }\n    }\n\n    onSearchCaseSensitiveChange(value: boolean) {\n        this.searchCaseSensitiveSubject.next(value);\n    }\n\n    onOverlayHide() {\n        // resetting the form is done here for a smoother animation\n        if (this.filterFormComponent !== undefined) {\n            this.filterFormComponent()?.resetForm();\n        }\n\n        if (this.clickedOnFilterEvent) {\n            // show the overlay again if the user clicked another filter\n            setTimeout(() => {\n                this.filterEdit.set(this.clickedOnFilterEvent?.filter);\n                this.filterOverlay().show(this.clickedOnFilterEvent?.event);\n                this.clickedOnFilterEvent = undefined;\n            }, 0);\n            return;\n        } else {\n            // clean state\n            this.filterEdit.set(undefined);\n        }\n    }\n\n    private onFilterAddOrEdit(filter?: FilterState, event?: Event) {\n        // If user clicks on the same filter or add that is already open, close the overlay\n        if (this.filterOverlay().overlayVisible && this.filterEdit()?.metadata.descriptor.property === filter?.metadata.descriptor.property) {\n            this.filterOverlay().hide();\n            return;\n        }\n\n        if (this.filterOverlay().overlayVisible) {\n            // In case the user clicks another filter, 're-showing' the overlay in\n            // the new position is done in the onOverlayHide callback\n            this.clickedOnFilterEvent = {event, filter};\n            this.filterOverlay().hide();\n        } else {\n            this.filterEdit.set(filter);\n            this.filterOverlay().show(event);\n        }\n    }\n\n    private getInitialFilters(filtersInit: Record<string, CommonsFilterMetadata> | undefined, metadata: FilterMetadata[]) {\n        const filtersResult: {[p: string]: FilterState} = {};\n\n        if (filtersInit) {\n            for (const property in filtersInit) {\n                const filterInit = filtersInit[property];\n\n                const filterMetadata = metadata.find(m => m.descriptor.property === property);\n                if (!filterMetadata) {\n                    continue;\n                }\n\n                filtersResult[property] = {\n                    ...filterSetMetadataOnChange(filterInit, filterInit.matchMode, filterInit.value, filterMetadata.descriptor.filterType, filterMetadata.dateConfig),\n                    metadata: filterMetadata\n                };\n            }\n        }\n\n        return filtersResult;\n    }\n\n    private updatePrimeTableFilter(filter: FilterState) {\n        this.primeTable.filters[filter.metadata.descriptor.property] = {...filter};\n        this.primeTable._filter();\n    }\n\n    private updatePrimeTableGlobalFilter(searchQuery: string | null, caseSensitive = false) {\n        // match mode needs to be set for inline search\n        this.primeTable.filters['global'] = {...{value: searchQuery, matchMode: 'contains', caseSensitive: caseSensitive}};\n        this.primeTable._filter();\n    }\n}\n","<div class=\"flex align-items-center flex-grow-1\">\n    @if (titleTemplate()) {\n        <ng-container *ngTemplateOutlet=\"titleTemplate()\"></ng-container>\n    }\n    @if (showFilterButton()) {\n        <p-button\n            icon=\"pi pi-filter\"\n            rounded=\"true\"\n            [severity]=\"activeFilters().length > 0 ? 'primary' : 'secondary'\"\n            size=\"small\"\n            (click)=\"onFilterAdd($event)\"\n            [styleClass]=\"'my-1 mr-2' + (titleTemplate() ? ' ml-3' : '')\">\n        </p-button>\n    }\n    @if (enableSearch()) {\n        <div class=\"col-4\" [ngClass]=\"{'ml-3': !showFilterButton() && titleTemplate()}\">\n            <span class=\"p-input-icon-left w-full\">\n                <i class=\"pi pi-search\"></i>\n                <input\n                    [ngModel]=\"searchValue()\"\n                    (ngModelChange)=\"onSearchChange($event)\"\n                    name=\"globalSearch\"\n                    type=\"text\"\n                    pInputText\n                    class=\"search-input w-full\"\n                    [ngClass]=\"{'ng-invalid': searchWordLimitMaxError()}\"\n                    [attr.placeholder]=\"'mngFilter.search.input' | translate\"\n                    [placeholder]=\"'mngFilter.search.input' | translate\" />\n                @if (enableCaseSensitive()) {\n                    <span class=\"toggle-button-input\">\n                        <p-toggleButton\n                            styleClass=\"ml-1 p-1 p-button-sm\"\n                            [ngModel]=\"searchCaseSensitive()\"\n                            (ngModelChange)=\"onSearchCaseSensitiveChange($event)\"\n                            onLabel=\"Aa\"\n                            offLabel=\"Aa\" />\n                    </span>\n                }\n            </span>\n            @if (searchWordLimitMaxError()) {\n                <small class=\"p-error block\">\n                    {{ 'mngFilter.search.maxWordsExceededMessage' | translate }}\n                </small>\n            }\n        </div>\n    }\n</div>\n@if (activeFilters().length > 0) {\n    <div class=\"flex align-items-center flex-wrap mt-2\">\n        @for (filter of activeFilters(); track filter.metadata.descriptor.property) {\n            <mng-table-filter-active-tag [model]=\"model()\" [filter]=\"filter\" (edit)=\"onFilterEdit($event)\" (remove)=\"onFilterRemove($event)\" />\n        }\n    </div>\n}\n<p-overlayPanel #op [showCloseIcon]=\"true\" (onHide)=\"onOverlayHide()\" appendTo=\"body\">\n    <mng-table-filter-form\n        [model]=\"model()\"\n        [metadata]=\"metadata()\"\n        [genericDescriptor]=\"genericFilterDescriptor()\"\n        [filter]=\"filterEdit()\"\n        [disabledProperties]=\"activeFilterProperties()\"\n        [propertySearch]=\"genericFilterDescriptor()?.propertySearch\"\n        [overlay]=\"op\"\n        [enableCaseSensitive]=\"enableCaseSensitive()\"\n        (apply)=\"onFilterFormApply($event)\" />\n</p-overlayPanel>\n"]}