@updevs/components 1.0.0-alpha.96 → 1.0.0-alpha.98

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,9 +1,9 @@
1
- import { Component, signal, inject, input, model, HostBinding, Output, EventEmitter } from '@angular/core';
1
+ import { Component, signal, inject, input, HostBinding, Output, EventEmitter, computed } from '@angular/core';
2
2
  import { TextService } from '@updevs/sdk';
3
3
  import { FilterTypeEnum } from '@updevs/sdk/stores';
4
4
  import { BaseComponent } from '@updevs/sdk/layout';
5
- import { UpdTableConfigService } from '../../services/upd-table-config.service';
6
5
  import { FiltersOperandsService } from '../../abstractions/filters-operands.service';
6
+ import { CurrentSearchRequestService } from '../../services/current-search-request.service';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@updevs/components/button";
9
9
  import * as i2 from "@updevs/components/form-controls/input";
@@ -14,12 +14,11 @@ export class FilterRowComponent extends BaseComponent {
14
14
  this.wrapperClasses = 'd-flex gap-2';
15
15
  this.removed = new EventEmitter();
16
16
  this.FilterTypeEnum = FilterTypeEnum;
17
- this.activeFilters = model.required();
17
+ this.config = input.required();
18
18
  this.rowIndex = input.required();
19
- this.columns = input.required();
20
19
  this.isDisabled = input.required();
21
- this.store = input();
22
- this.filterFields = input();
20
+ this.filterFields = computed(() => this.config().shouldLoadFilterFieldsFromServer ? this.currentSearchRequestService.filterFields() : this.config().filterFields);
21
+ this.columns = computed(() => this.config().columns);
23
22
  this.currentFilter = input();
24
23
  this.currentField = signal(undefined);
25
24
  this.currentOperand = signal(undefined);
@@ -28,9 +27,9 @@ export class FilterRowComponent extends BaseComponent {
28
27
  this.fieldAllowedValues = signal([]);
29
28
  this.isValueSectionEnabled = signal(true);
30
29
  this.currentOperands = [];
31
- this.configService = inject(UpdTableConfigService);
32
30
  this.filtersOperandsService = inject(FiltersOperandsService);
33
31
  this.textService = inject(TextService);
32
+ this.currentSearchRequestService = inject(CurrentSearchRequestService);
34
33
  }
35
34
  get fieldType() {
36
35
  return this.currentField()?.objectData || FilterTypeEnum.Text;
@@ -55,20 +54,12 @@ export class FilterRowComponent extends BaseComponent {
55
54
  // Priority 1: User-defined filter fields
56
55
  if (!!this.filterFields() && this.filterFields().length > 0) {
57
56
  this.fieldsOptions.set(this.filterFields().map(f => ({
58
- value: f.name,
59
- text: this.textService.getText(f.label),
60
- objectData: f.type
61
- })));
62
- }
63
- // Priority 2: Server-loaded fields
64
- else if (!!this.store() && this.configService.config.shouldLoadFieldsFromServer) {
65
- this.store().getFilterableFields().subscribe(fields => this.fieldsOptions.set(fields.map(f => ({
66
57
  value: f.name,
67
58
  text: f.description,
68
59
  objectData: f.type
69
- }))));
60
+ })));
70
61
  }
71
- // Priority 3: Fallback to columns
62
+ // Priority 2: Fallback to columns
72
63
  else {
73
64
  this.fieldsOptions.set(this.columns().filter(c => !!c.title).map(c => ({
74
65
  value: c.name,
@@ -96,38 +87,30 @@ export class FilterRowComponent extends BaseComponent {
96
87
  else {
97
88
  this.comparisonOperatorOptions.set([]);
98
89
  }
99
- this.activeFilters.update(curr => {
100
- curr[this.rowIndex()].name = this.currentField()?.value;
101
- return [...curr];
90
+ this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), {
91
+ column: this.currentField()?.value,
92
+ type: this.fieldType,
93
+ dataType: dataType
102
94
  });
103
95
  }
104
96
  onSelectOperand(item) {
105
97
  this.currentOperand.set(this.currentOperands.find(co => co.operand === item?.value));
106
98
  this.isValueSectionEnabled.set(!!this.currentOperand()?.requiresValue);
107
- this.activeFilters.update(curr => {
108
- curr[this.rowIndex()].operandConfig = this.currentOperand();
109
- return [...curr];
110
- });
99
+ this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), { operand: this.currentOperand()?.operand });
111
100
  if (this.fieldType === FilterTypeEnum.Select) {
112
101
  const values = this.filterFields()?.find(f => f.name === this.currentField()?.value)?.allowedValues || [];
113
102
  this.fieldAllowedValues.set(values.map(v => ({ value: v.key, text: v.value })));
114
103
  }
115
104
  }
116
105
  updateValue(value) {
117
- this.activeFilters.update(curr => {
118
- curr[this.rowIndex()].value = value;
119
- return [...curr];
120
- });
106
+ this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), { value });
121
107
  }
122
108
  removeFilterItem() {
123
- this.activeFilters.update(curr => {
124
- curr.splice(this.rowIndex(), 1);
125
- return [...curr];
126
- });
109
+ this.currentSearchRequestService.removeFilterByIndex(this.rowIndex());
127
110
  this.removed.emit();
128
111
  }
129
112
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FilterRowComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
130
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: FilterRowComponent, selector: "upd-filter-row", inputs: { activeFilters: { classPropertyName: "activeFilters", publicName: "activeFilters", isSignal: true, isRequired: true, transformFunction: null }, rowIndex: { classPropertyName: "rowIndex", publicName: "rowIndex", isSignal: true, isRequired: true, transformFunction: null }, columns: { classPropertyName: "columns", publicName: "columns", isSignal: true, isRequired: true, transformFunction: null }, isDisabled: { classPropertyName: "isDisabled", publicName: "isDisabled", isSignal: true, isRequired: true, transformFunction: null }, store: { classPropertyName: "store", publicName: "store", isSignal: true, isRequired: false, transformFunction: null }, filterFields: { classPropertyName: "filterFields", publicName: "filterFields", isSignal: true, isRequired: false, transformFunction: null }, currentFilter: { classPropertyName: "currentFilter", publicName: "currentFilter", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { removed: "removed", activeFilters: "activeFiltersChange" }, host: { properties: { "class": "this.wrapperClasses" } }, usesInheritance: true, ngImport: i0, template: "<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldsOptions()\" (selectedItem)=\"onSelectField($event)\"\n [value]=\"selectedField?.value\">\n</upd-select>\n<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"comparisonOperatorOptions()\"\n (selectedItem)=\"onSelectOperand($event)\" [value]=\"selectedOperand?.value\">\n</upd-select>\n\n@if (isValueSectionEnabled()) {\n @switch (fieldType) {\n @case (FilterTypeEnum.Number) {\n <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"number\" (valueChange)=\"updateValue($event)\"\n [value]=\"selectedValue\"></upd-input>\n }\n @case (FilterTypeEnum.Date) {\n\n }\n @case (FilterTypeEnum.Select) {\n <upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldAllowedValues()\"\n (selectedItem)=\"updateValue($event?.value)\" [value]=\"selectedValue\">\n </upd-select>\n }\n @default {\n <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"text\" (valueChange)=\"updateValue($event)\"\n [value]=\"selectedValue\"></upd-input>\n }\n }\n} @else {\n <div class=\"w-100\">\n <input type=\"text\" class=\"form-control h-100\" disabled>\n </div>\n}\n\n<upd-button class=\"flex-shrink-1\" colorStyle=\"danger\" [isDisabled]=\"isDisabled()\" [isOutline]=\"true\" [isIcon]=\"true\"\n [iconModel]=\"{tablerIcon:'x'}\" (clicked)=\"removeFilterItem()\"></upd-button>", styles: [""], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title", "stopPropagation"], outputs: ["clicked"] }, { kind: "component", type: i2.InputComponent, selector: "upd-input", inputs: ["type", "mask", "maskConfig", "value", "size", "customClasses", "wrapperClasses", "maxLength", "isPlainText", "isReadOnly", "isLoading", "isRound", "isFlush", "isInputGroupFlat", "isPrependButton", "isAppendButton", "isFloating", "loaderPosition", "prependIconModel", "appendIconModel", "isValidationStatusLight", "layout"], outputs: ["valueChange", "blurred", "keyDown", "keyDownEsc", "keyUpEnter"] }, { kind: "component", type: i3.SelectComponent, selector: "upd-select", inputs: ["useSystemStyle", "shouldShowClearButton", "shouldTruncateSelectedText", "isCompact", "value"], outputs: ["valueChange", "selectedItem"] }] }); }
113
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: FilterRowComponent, selector: "upd-filter-row", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, rowIndex: { classPropertyName: "rowIndex", publicName: "rowIndex", isSignal: true, isRequired: true, transformFunction: null }, isDisabled: { classPropertyName: "isDisabled", publicName: "isDisabled", isSignal: true, isRequired: true, transformFunction: null }, currentFilter: { classPropertyName: "currentFilter", publicName: "currentFilter", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { removed: "removed" }, host: { properties: { "class": "this.wrapperClasses" } }, usesInheritance: true, ngImport: i0, template: "<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldsOptions()\" (selectedItem)=\"onSelectField($event)\"\n [value]=\"selectedField?.value\">\n</upd-select>\n<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"comparisonOperatorOptions()\"\n (selectedItem)=\"onSelectOperand($event)\" [value]=\"selectedOperand?.value\">\n</upd-select>\n\n@if (isValueSectionEnabled()) {\n @switch (fieldType) {\n @case (FilterTypeEnum.Number) {\n <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"number\" (valueChange)=\"updateValue($event)\"\n [value]=\"selectedValue\"></upd-input>\n }\n @case (FilterTypeEnum.Date) {\n\n }\n @case (FilterTypeEnum.Select) {\n <upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldAllowedValues()\"\n (selectedItem)=\"updateValue($event?.value)\" [value]=\"selectedValue\">\n </upd-select>\n }\n @default {\n <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"text\" (valueChange)=\"updateValue($event)\"\n [value]=\"selectedValue\"></upd-input>\n }\n }\n} @else {\n <div class=\"w-100\">\n <input type=\"text\" class=\"form-control h-100\" disabled>\n </div>\n}\n\n<upd-button class=\"flex-shrink-1\" colorStyle=\"danger\" [isDisabled]=\"isDisabled()\" [isOutline]=\"true\" [isIcon]=\"true\"\n [iconModel]=\"{tablerIcon:'x'}\" (clicked)=\"removeFilterItem()\"></upd-button>", styles: [""], dependencies: [{ kind: "component", type: i1.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title", "stopPropagation"], outputs: ["clicked"] }, { kind: "component", type: i2.InputComponent, selector: "upd-input", inputs: ["type", "mask", "maskConfig", "value", "size", "customClasses", "wrapperClasses", "maxLength", "isPlainText", "isReadOnly", "isLoading", "isRound", "isFlush", "isInputGroupFlat", "isPrependButton", "isAppendButton", "isFloating", "loaderPosition", "prependIconModel", "appendIconModel", "isValidationStatusLight", "layout"], outputs: ["valueChange", "blurred", "keyDown", "keyDownEsc", "keyUpEnter"] }, { kind: "component", type: i3.SelectComponent, selector: "upd-select", inputs: ["useSystemStyle", "shouldShowClearButton", "shouldTruncateSelectedText", "isCompact", "value"], outputs: ["valueChange", "selectedItem"] }] }); }
131
114
  }
132
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FilterRowComponent, decorators: [{
133
116
  type: Component,
@@ -138,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
138
121
  }], removed: [{
139
122
  type: Output
140
123
  }] } });
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-row.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/table/src/components/filter-row/filter-row.component.ts","../../../../../../../libs/components/table/src/components/filter-row/filter-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, inject, OnInit, input, model, HostBinding, Output, EventEmitter } from '@angular/core';\nimport { TextService } from '@updevs/sdk';\nimport { BaseSearchStore, FilterTypeEnum } from '@updevs/sdk/stores';\nimport { OptionalType } from '@updevs/sdk/types';\nimport { SelectItem } from '@updevs/components/form-controls/select';\nimport { BaseComponent } from '@updevs/sdk/layout';\n\nimport { UpdTableConfigService } from '../../services/upd-table-config.service';\nimport { FiltersOperandsService } from '../../abstractions/filters-operands.service';\nimport { FilterItemModel } from '../../models/filter-item.model';\nimport { BaseColumnModel } from '../../abstractions/base-column.model';\nimport { FilterOperandConfig } from '../../models/filter-operand.config';\nimport { FilterFieldConfig } from '../../models/filter-field.config';\n\n@Component({\n    selector: 'upd-filter-row',\n    templateUrl: './filter-row.component.html',\n    styleUrl: './filter-row.component.scss'\n})\nexport class FilterRowComponent extends BaseComponent implements OnInit {\n    @HostBinding('class') wrapperClasses = 'd-flex gap-2';\n\n    @Output() readonly removed: EventEmitter<void> = new EventEmitter();\n\n    FilterTypeEnum = FilterTypeEnum;\n\n    activeFilters = model.required<FilterItemModel[]>();\n    rowIndex = input.required<number>();\n    columns = input.required<BaseColumnModel[]>();\n    isDisabled = input.required<boolean>();\n    store = input<BaseSearchStore>();\n    filterFields = input<FilterFieldConfig[]>();\n    currentFilter = input<FilterItemModel>();\n    currentField = signal<OptionalType<SelectItem>>(undefined);\n    currentOperand = signal<OptionalType<FilterOperandConfig>>(undefined);\n    fieldsOptions = signal<SelectItem[]>([]);\n    comparisonOperatorOptions = signal<SelectItem[]>([]);\n    fieldAllowedValues = signal<SelectItem[]>([]);\n    isValueSectionEnabled = signal<boolean>(true);\n\n    get fieldType(): FilterTypeEnum {\n        return this.currentField()?.objectData || FilterTypeEnum.Text;\n    }\n    get selectedField(): OptionalType<SelectItem> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name\n            ? this.fieldsOptions().find(f => f.value === currentFilter.name)\n            : undefined;\n    }\n    get selectedOperand(): OptionalType<SelectItem> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name\n            ? this.comparisonOperatorOptions().find(co => co.value === currentFilter.operandConfig?.operand)\n            : undefined;\n    }\n    get selectedValue(): OptionalType<any> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name ? currentFilter.value : undefined;\n    }\n\n    private currentOperands: FilterOperandConfig[] = [];\n    private readonly configService = inject(UpdTableConfigService);\n    private readonly filtersOperandsService = inject(FiltersOperandsService);\n    private readonly textService = inject(TextService);\n\n    ngOnInit(): void {\n        // Priority 1: User-defined filter fields\n        if (!!this.filterFields() && this.filterFields()!.length > 0) {\n            this.fieldsOptions.set(\n                this.filterFields()!.map(f => ({\n                    value: f.name,\n                    text: this.textService.getText(f.label),\n                    objectData: f.type\n                }))\n            );\n        }\n        // Priority 2: Server-loaded fields\n        else if (!!this.store() && this.configService.config.shouldLoadFieldsFromServer) {\n            this.store()!.getFilterableFields().subscribe(fields =>\n                this.fieldsOptions.set(fields.map(f => ({\n                    value: f.name!,\n                    text: f.description!,\n                    objectData: f.type\n                })))\n            );\n        }\n        // Priority 3: Fallback to columns\n        else {\n            this.fieldsOptions.set(\n                this.columns().filter(c => !!c.title).map(c =>\n                ({\n                    value: c.name,\n                    text: this.textService.getText(c.title),\n                    objectData: c.dataType\n                }))\n            );\n        }\n\n        if (!!this.selectedField) {\n            this.onSelectField(this.selectedField);\n\n            if (!!this.selectedOperand) {\n                this.onSelectOperand(this.selectedOperand);\n            }\n\n            if (!!this.selectedValue) {\n                this.updateValue(this.selectedValue);\n            }\n        }\n    }\n\n    onSelectField(item?: SelectItem): void {\n        this.currentField.set(item);\n\n        const dataType = item?.objectData;\n\n        if (!!dataType) {\n            this.currentOperands = this.filtersOperandsService.getOperands(dataType);\n            this.comparisonOperatorOptions.set(\n                this.currentOperands.map(o => ({ value: o.operand, text: this.textService.getText(o.text), listItem: { icon: o.icon } }))\n            );\n        } else {\n            this.comparisonOperatorOptions.set([]);\n        }\n\n        this.activeFilters.update(curr => {\n            curr[this.rowIndex()].name = this.currentField()?.value;\n            return [...curr];\n        });\n    }\n\n    onSelectOperand(item?: SelectItem): void {\n        this.currentOperand.set(this.currentOperands.find(co => co.operand === item?.value));\n        this.isValueSectionEnabled.set(!!this.currentOperand()?.requiresValue);\n        this.activeFilters.update(curr => {\n            curr[this.rowIndex()].operandConfig = this.currentOperand();\n            return [...curr];\n        });\n\n        if (this.fieldType === FilterTypeEnum.Select) {\n            const values = this.filterFields()?.find(f => f.name === this.currentField()?.value)?.allowedValues || [];\n            this.fieldAllowedValues.set(values.map(v => ({ value: v.key, text: v.value })));\n        }\n    }\n\n    updateValue(value?: any): void {\n        this.activeFilters.update(curr => {\n            curr[this.rowIndex()].value = value;\n            return [...curr];\n        });\n    }\n\n    removeFilterItem(): void {\n        this.activeFilters.update(curr => {\n            curr.splice(this.rowIndex(), 1);\n            return [...curr];\n        });\n        this.removed.emit();\n    }\n}\n","<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldsOptions()\" (selectedItem)=\"onSelectField($event)\"\n    [value]=\"selectedField?.value\">\n</upd-select>\n<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"comparisonOperatorOptions()\"\n    (selectedItem)=\"onSelectOperand($event)\" [value]=\"selectedOperand?.value\">\n</upd-select>\n\n@if (isValueSectionEnabled()) {\n    @switch (fieldType) {\n        @case (FilterTypeEnum.Number) {\n            <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"number\" (valueChange)=\"updateValue($event)\"\n                [value]=\"selectedValue\"></upd-input>\n        }\n        @case (FilterTypeEnum.Date) {\n\n        }\n        @case (FilterTypeEnum.Select) {\n            <upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldAllowedValues()\"\n                (selectedItem)=\"updateValue($event?.value)\" [value]=\"selectedValue\">\n            </upd-select>\n        }\n        @default {\n            <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"text\" (valueChange)=\"updateValue($event)\"\n                [value]=\"selectedValue\"></upd-input>\n        }\n    }\n} @else {\n    <div class=\"w-100\">\n        <input type=\"text\" class=\"form-control h-100\" disabled>\n    </div>\n}\n\n<upd-button class=\"flex-shrink-1\" colorStyle=\"danger\" [isDisabled]=\"isDisabled()\" [isOutline]=\"true\" [isIcon]=\"true\"\n    [iconModel]=\"{tablerIcon:'x'}\" (clicked)=\"removeFilterItem()\"></upd-button>"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-row.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/table/src/components/filter-row/filter-row.component.ts","../../../../../../../libs/components/table/src/components/filter-row/filter-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, signal, inject, OnInit, input, HostBinding, Output, EventEmitter, computed } from '@angular/core';\nimport { TextService } from '@updevs/sdk';\nimport { FilterTypeEnum } from '@updevs/sdk/stores';\nimport { OptionalType } from '@updevs/sdk/types';\nimport { SelectItem } from '@updevs/components/form-controls/select';\nimport { BaseComponent } from '@updevs/sdk/layout';\n\nimport { FiltersOperandsService } from '../../abstractions/filters-operands.service';\nimport { FilterItemModel } from '../../models/filter-item.model';\nimport { FilterOperandConfig } from '../../models/filter-operand.config';\nimport { CurrentSearchRequestService } from '../../services/current-search-request.service';\nimport { TableConfigModel } from '../../models/table-config.model';\n\n@Component({\n    selector: 'upd-filter-row',\n    templateUrl: './filter-row.component.html',\n    styleUrl: './filter-row.component.scss'\n})\nexport class FilterRowComponent extends BaseComponent implements OnInit {\n    @HostBinding('class') wrapperClasses = 'd-flex gap-2';\n\n    @Output() readonly removed: EventEmitter<void> = new EventEmitter();\n\n    FilterTypeEnum = FilterTypeEnum;\n\n    config = input.required<TableConfigModel<any>>();\n    rowIndex = input.required<number>();\n    isDisabled = input.required<boolean>();\n    filterFields = computed(() => this.config().shouldLoadFilterFieldsFromServer ? this.currentSearchRequestService.filterFields() : this.config().filterFields);\n    columns = computed(() => this.config().columns);\n    currentFilter = input<FilterItemModel>();\n    currentField = signal<OptionalType<SelectItem>>(undefined);\n    currentOperand = signal<OptionalType<FilterOperandConfig>>(undefined);\n    fieldsOptions = signal<SelectItem[]>([]);\n    comparisonOperatorOptions = signal<SelectItem[]>([]);\n    fieldAllowedValues = signal<SelectItem[]>([]);\n    isValueSectionEnabled = signal<boolean>(true);\n\n    get fieldType(): FilterTypeEnum {\n        return this.currentField()?.objectData || FilterTypeEnum.Text;\n    }\n    get selectedField(): OptionalType<SelectItem> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name\n            ? this.fieldsOptions().find(f => f.value === currentFilter.name)\n            : undefined;\n    }\n    get selectedOperand(): OptionalType<SelectItem> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name\n            ? this.comparisonOperatorOptions().find(co => co.value === currentFilter.operandConfig?.operand)\n            : undefined;\n    }\n    get selectedValue(): OptionalType<any> {\n        const currentFilter = this.currentFilter();\n        return !!currentFilter?.name ? currentFilter.value : undefined;\n    }\n\n    private currentOperands: FilterOperandConfig[] = [];\n    private readonly filtersOperandsService = inject(FiltersOperandsService);\n    private readonly textService = inject(TextService);\n    private readonly currentSearchRequestService = inject(CurrentSearchRequestService);\n\n    ngOnInit(): void {\n        // Priority 1: User-defined filter fields\n        if (!!this.filterFields() && this.filterFields()!.length > 0) {\n            this.fieldsOptions.set(\n                this.filterFields()!.map(f => ({\n                    value: f.name,\n                    text: f.description,\n                    objectData: f.type\n                }))\n            );\n        }\n        // Priority 2: Fallback to columns\n        else {\n            this.fieldsOptions.set(\n                this.columns().filter(c => !!c.title).map(c =>\n                ({\n                    value: c.name,\n                    text: this.textService.getText(c.title),\n                    objectData: c.dataType\n                }))\n            );\n        }\n\n        if (!!this.selectedField) {\n            this.onSelectField(this.selectedField);\n\n            if (!!this.selectedOperand) {\n                this.onSelectOperand(this.selectedOperand);\n            }\n\n            if (!!this.selectedValue) {\n                this.updateValue(this.selectedValue);\n            }\n        }\n    }\n\n    onSelectField(item?: SelectItem): void {\n        this.currentField.set(item);\n\n        const dataType = item?.objectData;\n\n        if (!!dataType) {\n            this.currentOperands = this.filtersOperandsService.getOperands(dataType);\n            this.comparisonOperatorOptions.set(\n                this.currentOperands.map(o => ({ value: o.operand, text: this.textService.getText(o.text), listItem: { icon: o.icon } }))\n            );\n        } else {\n            this.comparisonOperatorOptions.set([]);\n        }\n\n        this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), {\n            column: this.currentField()?.value,\n            type: this.fieldType,\n            dataType: dataType\n        });\n    }\n\n    onSelectOperand(item?: SelectItem): void {\n        this.currentOperand.set(this.currentOperands.find(co => co.operand === item?.value));\n        this.isValueSectionEnabled.set(!!this.currentOperand()?.requiresValue);\n        this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), { operand: this.currentOperand()?.operand });\n\n        if (this.fieldType === FilterTypeEnum.Select) {\n            const values = this.filterFields()?.find(f => f.name === this.currentField()?.value)?.allowedValues || [];\n            this.fieldAllowedValues.set(values.map(v => ({ value: v.key, text: v.value })));\n        }\n    }\n\n    updateValue(value?: any): void {\n        this.currentSearchRequestService.updateFilterByIndex(this.rowIndex(), { value });\n    }\n\n    removeFilterItem(): void {\n        this.currentSearchRequestService.removeFilterByIndex(this.rowIndex());\n        this.removed.emit();\n    }\n}\n","<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldsOptions()\" (selectedItem)=\"onSelectField($event)\"\n    [value]=\"selectedField?.value\">\n</upd-select>\n<upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"comparisonOperatorOptions()\"\n    (selectedItem)=\"onSelectOperand($event)\" [value]=\"selectedOperand?.value\">\n</upd-select>\n\n@if (isValueSectionEnabled()) {\n    @switch (fieldType) {\n        @case (FilterTypeEnum.Number) {\n            <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"number\" (valueChange)=\"updateValue($event)\"\n                [value]=\"selectedValue\"></upd-input>\n        }\n        @case (FilterTypeEnum.Date) {\n\n        }\n        @case (FilterTypeEnum.Select) {\n            <upd-select class=\"w-100\" [isDisabled]=\"isDisabled()\" [items]=\"fieldAllowedValues()\"\n                (selectedItem)=\"updateValue($event?.value)\" [value]=\"selectedValue\">\n            </upd-select>\n        }\n        @default {\n            <upd-input wrapperClasses=\"w-100\" customClasses=\"h-100\" type=\"text\" (valueChange)=\"updateValue($event)\"\n                [value]=\"selectedValue\"></upd-input>\n        }\n    }\n} @else {\n    <div class=\"w-100\">\n        <input type=\"text\" class=\"form-control h-100\" disabled>\n    </div>\n}\n\n<upd-button class=\"flex-shrink-1\" colorStyle=\"danger\" [isDisabled]=\"isDisabled()\" [isOutline]=\"true\" [isIcon]=\"true\"\n    [iconModel]=\"{tablerIcon:'x'}\" (clicked)=\"removeFilterItem()\"></upd-button>"]}
@@ -1,8 +1,9 @@
1
- import { Component, input, HostBinding, signal, computed, model, effect, inject } from '@angular/core';
1
+ import { Component, input, HostBinding, signal, computed, effect, inject } from '@angular/core';
2
2
  import { BaseComponent } from '@updevs/sdk/layout';
3
3
  import { Subject, distinctUntilChanged, debounceTime } from 'rxjs';
4
4
  import { FilterTools } from '../../tools/filters.tools';
5
5
  import { FiltersOperandsService } from '../../abstractions/filters-operands.service';
6
+ import { CurrentSearchRequestService } from '../../services/current-search-request.service';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
9
  import * as i2 from "@jsverse/transloco";
@@ -14,36 +15,31 @@ export class SearchSectionComponent extends BaseComponent {
14
15
  constructor() {
15
16
  super();
16
17
  this.wrapperClass = 'card-body border-bottom py-3 d-flex flex-column gap-2';
17
- this.searchRequest = model.required();
18
- this.hasChanges = model.required();
19
18
  this.columns = input.required();
20
- this.isSearching = input.required();
21
- this.searchRequestSubject = input.required();
22
19
  this.config = input.required();
23
20
  this.actionsTpl = input();
24
- this.activeFilters = signal([]);
21
+ this.activeFilters = computed(() => FilterTools.convertToFilterItem(this.currentSearchRequestService.searchRequest().filters?.filter(af => !af.isHidden) || [], this.filtersOperandsService.getAllOperands()));
25
22
  this.isFilterSectionOpen = signal(false);
26
- this.canApplyFilters = computed(() => this.activeFilters().length > 0
27
- && this.activeFilters().every(af => !af.isHidden && !!af.name && !!af.operandConfig?.operand && (!af.operandConfig?.requiresValue || !!af.value)));
28
- this.visibleFiltersCount = computed(() => this.searchRequest().filters?.filter(af => !af.isHidden).length || 0);
29
- this.canPerformActions = computed(() => this.canApplyFilters() && !this.isSearching());
30
- this.badgeConfig = computed(() => this.visibleFiltersCount() > 0
23
+ this.canApplyFilters = computed(() => this.activeFilters().length > 0 && this.activeFilters().every(af => {
24
+ const valid = !af.isHidden && !!af.name && !!af.operandConfig?.operand && (!af.operandConfig?.requiresValue || !!af.value);
25
+ return valid;
26
+ }));
27
+ this.canPerformActions = computed(() => this.canApplyFilters() && !this.currentSearchRequestService.isSearching());
28
+ this.badgeConfig = computed(() => this.currentSearchRequestService.visibleFilterCount() > 0
31
29
  ? ({
32
30
  isNotification: true,
33
31
  isPill: true,
34
32
  bgColor: 'primary-lt',
35
- text: { text: this.visibleFiltersCount().toString(), isTranslated: true }
33
+ text: { text: this.currentSearchRequestService.visibleFilterCount().toString(), isTranslated: true }
36
34
  })
37
35
  : undefined);
38
36
  this.filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? 'primary' : undefined);
39
37
  this.searchSubject = new Subject();
40
38
  this.filtersOperandsService = inject(FiltersOperandsService);
39
+ this.currentSearchRequestService = inject(CurrentSearchRequestService);
41
40
  effect(() => {
42
- if (this.visibleFiltersCount() > 0) {
43
- this.activeFilters.set([...FilterTools.convertToFilterItem(this.searchRequest().filters?.filter(af => !af.isHidden) || [], this.filtersOperandsService.getAllOperands())]);
44
- }
45
- else {
46
- this.activeFilters.set([]);
41
+ // Auto-close filter section when all filters are removed
42
+ if (this.currentSearchRequestService.visibleFilterCount() === 0 && this.isFilterSectionOpen()) {
47
43
  this.isFilterSectionOpen.set(false);
48
44
  }
49
45
  }, { allowSignalWrites: true });
@@ -51,17 +47,14 @@ export class SearchSectionComponent extends BaseComponent {
51
47
  ngOnInit() {
52
48
  const searchSub = this.searchSubject
53
49
  .pipe(distinctUntilChanged(), debounceTime(this.config().searchInputDebounceTime))
54
- .subscribe(term => this.searchRequestSubject().next({
55
- ...this.searchRequest(),
56
- description: term
57
- }));
50
+ .subscribe(term => this.currentSearchRequestService.setDescription(term));
58
51
  this.addSubscriptions(searchSub);
59
52
  }
60
53
  search() {
61
- this.searchRequestSubject().next({
62
- ...this.searchRequest(),
54
+ this.currentSearchRequestService.patchSearchRequest({
63
55
  filters: FilterTools.convertToRequestFilter(this.activeFilters(), this.config().filterFields, this.config().columns)
64
56
  });
57
+ this.currentSearchRequestService.triggerSearch();
65
58
  }
66
59
  toggleFilterSection() {
67
60
  if (this.activeFilters().length === 0) {
@@ -76,19 +69,16 @@ export class SearchSectionComponent extends BaseComponent {
76
69
  this.search();
77
70
  }
78
71
  addEmptyFilterRow() {
79
- this.activeFilters.update(curr => {
80
- curr.push({});
81
- return [...curr];
82
- });
72
+ this.currentSearchRequestService.addFilter({});
83
73
  }
84
74
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SearchSectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
85
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: SearchSectionComponent, selector: "upd-search-section", inputs: { searchRequest: { classPropertyName: "searchRequest", publicName: "searchRequest", isSignal: true, isRequired: true, transformFunction: null }, hasChanges: { classPropertyName: "hasChanges", publicName: "hasChanges", isSignal: true, isRequired: true, transformFunction: null }, columns: { classPropertyName: "columns", publicName: "columns", isSignal: true, isRequired: true, transformFunction: null }, isSearching: { classPropertyName: "isSearching", publicName: "isSearching", isSignal: true, isRequired: true, transformFunction: null }, searchRequestSubject: { classPropertyName: "searchRequestSubject", publicName: "searchRequestSubject", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, actionsTpl: { classPropertyName: "actionsTpl", publicName: "actionsTpl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { searchRequest: "searchRequestChange", hasChanges: "hasChangesChange" }, host: { properties: { "class": "this.wrapperClass" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n @if (!!actionsTpl()) {\n <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n }\n\n <div class=\"d-flex align-items-center gap-2\">\n <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\" [value]=\"searchRequest().description\">\n <ng-template updInputAppend>\n <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n [badgeConfig]=\"badgeConfig()\">\n <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n </ng-template>\n </upd-input>\n </div>\n\n @if (isFilterSectionOpen()) {\n @for (row of activeFilters(); track row; let i = $index) {\n <upd-filter-row [store]=\"config().store\" [currentFilter]=\"row\" [(activeFilters)]=\"activeFilters\"\n [columns]=\"columns()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\" [isDisabled]=\"isSearching()\"\n [filterFields]=\"config().filterFields\">\n </upd-filter-row>\n }\n\n <div class=\"ms-auto d-flex gap-2\">\n <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n [isDisabled]=\"!canPerformActions()\">\n <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('AddNewFilter') }}\n </upd-button>\n <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n (clicked)=\"search()\">\n <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('ApplyFilters') }}\n </upd-button>\n </div>\n }\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: i3.IconComponent, selector: "upd-icon", inputs: ["model", "wrapperClasses", "color", "colorClass", "removeDefaultClasses", "customClasses", "tablerIcon", "tablerIconWeight", "tablerIconType", "tablerIconSize", "heroIcon", "heroIconSize", "heroIconType"] }, { kind: "component", type: i4.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title", "stopPropagation"], outputs: ["clicked"] }, { kind: "component", type: i5.InputComponent, selector: "upd-input", inputs: ["type", "mask", "maskConfig", "value", "size", "customClasses", "wrapperClasses", "maxLength", "isPlainText", "isReadOnly", "isLoading", "isRound", "isFlush", "isInputGroupFlat", "isPrependButton", "isAppendButton", "isFloating", "loaderPosition", "prependIconModel", "appendIconModel", "isValidationStatusLight", "layout"], outputs: ["valueChange", "blurred", "keyDown", "keyDownEsc", "keyUpEnter"] }, { kind: "directive", type: i5.InputAppendDirective, selector: "ng-template[updInputAppend]" }, { kind: "component", type: i6.FilterRowComponent, selector: "upd-filter-row", inputs: ["activeFilters", "rowIndex", "columns", "isDisabled", "store", "filterFields", "currentFilter"], outputs: ["removed", "activeFiltersChange"] }] }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: SearchSectionComponent, selector: "upd-search-section", inputs: { columns: { classPropertyName: "columns", publicName: "columns", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, actionsTpl: { classPropertyName: "actionsTpl", publicName: "actionsTpl", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.wrapperClass" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n @if (!!actionsTpl()) {\n <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n }\n\n <div class=\"d-flex align-items-center gap-2\">\n <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\"\n [value]=\"currentSearchRequestService.searchRequest().description\">\n <ng-template updInputAppend>\n <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n [badgeConfig]=\"badgeConfig()\">\n <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n </ng-template>\n </upd-input>\n </div>\n\n @if (isFilterSectionOpen()) {\n @for (row of activeFilters(); track row.name; let i = $index) {\n <upd-filter-row [currentFilter]=\"row\" [config]=\"config()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\"\n [isDisabled]=\"currentSearchRequestService.isSearching()\">\n </upd-filter-row>\n }\n\n <div class=\"ms-auto d-flex gap-2\">\n <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n [isDisabled]=\"!canPerformActions()\">\n <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('AddNewFilter') }}\n </upd-button>\n <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n (clicked)=\"search()\">\n <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('ApplyFilters') }}\n </upd-button>\n </div>\n }\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: i3.IconComponent, selector: "upd-icon", inputs: ["model", "wrapperClasses", "color", "colorClass", "removeDefaultClasses", "customClasses", "tablerIcon", "tablerIconWeight", "tablerIconType", "tablerIconSize", "heroIcon", "heroIconSize", "heroIconType"] }, { kind: "component", type: i4.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title", "stopPropagation"], outputs: ["clicked"] }, { kind: "component", type: i5.InputComponent, selector: "upd-input", inputs: ["type", "mask", "maskConfig", "value", "size", "customClasses", "wrapperClasses", "maxLength", "isPlainText", "isReadOnly", "isLoading", "isRound", "isFlush", "isInputGroupFlat", "isPrependButton", "isAppendButton", "isFloating", "loaderPosition", "prependIconModel", "appendIconModel", "isValidationStatusLight", "layout"], outputs: ["valueChange", "blurred", "keyDown", "keyDownEsc", "keyUpEnter"] }, { kind: "directive", type: i5.InputAppendDirective, selector: "ng-template[updInputAppend]" }, { kind: "component", type: i6.FilterRowComponent, selector: "upd-filter-row", inputs: ["config", "rowIndex", "isDisabled", "currentFilter"], outputs: ["removed"] }] }); }
86
76
  }
87
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: SearchSectionComponent, decorators: [{
88
78
  type: Component,
89
- args: [{ selector: 'upd-search-section', template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n @if (!!actionsTpl()) {\n <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n }\n\n <div class=\"d-flex align-items-center gap-2\">\n <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\" [value]=\"searchRequest().description\">\n <ng-template updInputAppend>\n <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n [badgeConfig]=\"badgeConfig()\">\n <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n </ng-template>\n </upd-input>\n </div>\n\n @if (isFilterSectionOpen()) {\n @for (row of activeFilters(); track row; let i = $index) {\n <upd-filter-row [store]=\"config().store\" [currentFilter]=\"row\" [(activeFilters)]=\"activeFilters\"\n [columns]=\"columns()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\" [isDisabled]=\"isSearching()\"\n [filterFields]=\"config().filterFields\">\n </upd-filter-row>\n }\n\n <div class=\"ms-auto d-flex gap-2\">\n <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n [isDisabled]=\"!canPerformActions()\">\n <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('AddNewFilter') }}\n </upd-button>\n <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n (clicked)=\"search()\">\n <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('ApplyFilters') }}\n </upd-button>\n </div>\n }\n</ng-container>" }]
79
+ args: [{ selector: 'upd-search-section', template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n @if (!!actionsTpl()) {\n <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n }\n\n <div class=\"d-flex align-items-center gap-2\">\n <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\"\n [value]=\"currentSearchRequestService.searchRequest().description\">\n <ng-template updInputAppend>\n <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n [badgeConfig]=\"badgeConfig()\">\n <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n </ng-template>\n </upd-input>\n </div>\n\n @if (isFilterSectionOpen()) {\n @for (row of activeFilters(); track row.name; let i = $index) {\n <upd-filter-row [currentFilter]=\"row\" [config]=\"config()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\"\n [isDisabled]=\"currentSearchRequestService.isSearching()\">\n </upd-filter-row>\n }\n\n <div class=\"ms-auto d-flex gap-2\">\n <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n [isDisabled]=\"!canPerformActions()\">\n <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('AddNewFilter') }}\n </upd-button>\n <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n (clicked)=\"search()\">\n <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('ApplyFilters') }}\n </upd-button>\n </div>\n }\n</ng-container>" }]
90
80
  }], ctorParameters: () => [], propDecorators: { wrapperClass: [{
91
81
  type: HostBinding,
92
82
  args: ['class']
93
83
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-section.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/table/src/components/search-section/search-section.component.ts","../../../../../../../libs/components/table/src/components/search-section/search-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, TemplateRef, HostBinding, signal, computed, model, OnInit, effect, inject } from '@angular/core';\nimport { SearchRequestModel } from '@updevs/sdk/stores';\nimport { BaseComponent } from '@updevs/sdk/layout';\nimport { OptionalType, BgColorStyleType } from '@updevs/sdk/types';\nimport { BadgeConfig } from '@updevs/components/badge';\nimport { Subject, distinctUntilChanged, debounceTime } from 'rxjs';\n\nimport { FilterItemModel } from '../../models/filter-item.model';\nimport { TableConfigModel } from '../../models/table-config.model';\nimport { FilterTools } from '../../tools/filters.tools';\nimport { BaseColumnModel } from '../../abstractions/base-column.model';\nimport { FiltersOperandsService } from '../../abstractions/filters-operands.service';\n\n@Component({\n    selector: 'upd-search-section',\n    templateUrl: './search-section.component.html',\n    styleUrl: './search-section.component.scss'\n})\nexport class SearchSectionComponent<T> extends BaseComponent implements OnInit {\n    @HostBinding('class') wrapperClass = 'card-body border-bottom py-3 d-flex flex-column gap-2';\n\n    readonly searchRequest = model.required<SearchRequestModel>();\n    readonly hasChanges = model.required<boolean>();\n    readonly columns = input.required<BaseColumnModel[]>();\n    readonly isSearching = input.required<boolean>();\n    readonly searchRequestSubject = input.required<Subject<SearchRequestModel>>();\n    readonly config = input.required<TableConfigModel<T>>();\n    readonly actionsTpl = input<TemplateRef<any>>();\n    readonly activeFilters = signal<FilterItemModel[]>([]);\n    readonly isFilterSectionOpen = signal(false);\n    readonly canApplyFilters = computed(() => this.activeFilters().length > 0\n        && this.activeFilters().every(af =>\n            !af.isHidden && !!af.name && !!af.operandConfig?.operand && (!af.operandConfig?.requiresValue || !!af.value)\n        )\n    );\n    readonly visibleFiltersCount = computed(() => this.searchRequest().filters?.filter(af => !af.isHidden).length || 0);\n    readonly canPerformActions = computed(() => this.canApplyFilters() && !this.isSearching());\n    readonly badgeConfig = computed<OptionalType<BadgeConfig>>(() =>\n        this.visibleFiltersCount() > 0\n            ? ({\n                isNotification: true,\n                isPill: true,\n                bgColor: 'primary-lt',\n                text: { text: this.visibleFiltersCount().toString(), isTranslated: true }\n            })\n            : undefined\n    );\n    readonly filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? <BgColorStyleType>'primary' : undefined);\n    readonly searchSubject = new Subject<string>();\n\n    private readonly filtersOperandsService = inject(FiltersOperandsService);\n\n    constructor() {\n        super();\n\n        effect(() => {\n            if (this.visibleFiltersCount() > 0) {\n                this.activeFilters.set(\n                    [...FilterTools.convertToFilterItem(this.searchRequest().filters?.filter(af => !af.isHidden) || [], this.filtersOperandsService.getAllOperands())]\n                );\n            } else {\n                this.activeFilters.set([]);\n                this.isFilterSectionOpen.set(false);\n            }\n        }, { allowSignalWrites: true });\n    }\n\n    ngOnInit(): void {\n        const searchSub = this.searchSubject\n            .pipe(\n                distinctUntilChanged(),\n                debounceTime(this.config().searchInputDebounceTime)\n            )\n            .subscribe(term =>\n                this.searchRequestSubject().next({\n                    ...this.searchRequest(),\n                    description: term\n                })\n            );\n\n        this.addSubscriptions(searchSub);\n    }\n\n    search(): void {\n        this.searchRequestSubject().next({\n            ...this.searchRequest(),\n            filters: FilterTools.convertToRequestFilter(this.activeFilters(), this.config().filterFields, this.config().columns)\n        });\n    }\n\n    toggleFilterSection(): void {\n        if (this.activeFilters().length === 0) {\n            this.addEmptyFilterRow();\n        }\n\n        this.isFilterSectionOpen.update(isOpen => !isOpen);\n    }\n\n    onRowRemoved(): void {\n        if (this.activeFilters().length === 0) {\n            this.isFilterSectionOpen.set(false);\n        }\n\n        this.search();\n    }\n\n    addEmptyFilterRow(): void {\n        this.activeFilters.update(curr => {\n            curr.push({});\n            return [...curr];\n        });\n    }\n}\n","<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n    @if (!!actionsTpl()) {\n        <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n    }\n\n    <div class=\"d-flex align-items-center gap-2\">\n        <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n            [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\" [value]=\"searchRequest().description\">\n            <ng-template updInputAppend>\n                <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n                    [badgeConfig]=\"badgeConfig()\">\n                    <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n                        [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            </ng-template>\n        </upd-input>\n    </div>\n\n    @if (isFilterSectionOpen()) {\n        @for (row of activeFilters(); track row; let i = $index) {\n            <upd-filter-row [store]=\"config().store\" [currentFilter]=\"row\" [(activeFilters)]=\"activeFilters\"\n                [columns]=\"columns()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\" [isDisabled]=\"isSearching()\"\n                [filterFields]=\"config().filterFields\">\n            </upd-filter-row>\n        }\n\n        <div class=\"ms-auto d-flex gap-2\">\n            <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n                [isDisabled]=\"!canPerformActions()\">\n                <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n                {{ t('AddNewFilter') }}\n            </upd-button>\n            <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n                (clicked)=\"search()\">\n                <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n                {{ t('ApplyFilters') }}\n            </upd-button>\n        </div>\n    }\n</ng-container>"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-section.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/table/src/components/search-section/search-section.component.ts","../../../../../../../libs/components/table/src/components/search-section/search-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, TemplateRef, HostBinding, signal, computed, OnInit, effect, inject } from '@angular/core';\nimport { BaseComponent } from '@updevs/sdk/layout';\nimport { OptionalType, BgColorStyleType } from '@updevs/sdk/types';\nimport { BadgeConfig } from '@updevs/components/badge';\nimport { Subject, distinctUntilChanged, debounceTime } from 'rxjs';\n\nimport { FilterItemModel } from '../../models/filter-item.model';\nimport { TableConfigModel } from '../../models/table-config.model';\nimport { FilterTools } from '../../tools/filters.tools';\nimport { BaseColumnModel } from '../../abstractions/base-column.model';\nimport { FiltersOperandsService } from '../../abstractions/filters-operands.service';\nimport { CurrentSearchRequestService } from '../../services/current-search-request.service';\n\n@Component({\n    selector: 'upd-search-section',\n    templateUrl: './search-section.component.html',\n    styleUrl: './search-section.component.scss'\n})\nexport class SearchSectionComponent<T> extends BaseComponent implements OnInit {\n    @HostBinding('class') wrapperClass = 'card-body border-bottom py-3 d-flex flex-column gap-2';\n\n    readonly columns = input.required<BaseColumnModel[]>();\n    readonly config = input.required<TableConfigModel<T>>();\n    readonly actionsTpl = input<TemplateRef<any>>();\n    readonly activeFilters = computed<FilterItemModel[]>(() =>\n        FilterTools.convertToFilterItem(\n            this.currentSearchRequestService.searchRequest().filters?.filter(af => !af.isHidden) || [],\n            this.filtersOperandsService.getAllOperands()\n        )\n    );\n    readonly isFilterSectionOpen = signal(false);\n    readonly canApplyFilters = computed(() => this.activeFilters().length > 0 && this.activeFilters().every(af => {\n        const valid = !af.isHidden && !!af.name && !!af.operandConfig?.operand && (!af.operandConfig?.requiresValue || !!af.value);\n        return valid;\n    }));\n    readonly canPerformActions = computed(() => this.canApplyFilters() && !this.currentSearchRequestService.isSearching());\n    readonly badgeConfig = computed<OptionalType<BadgeConfig>>(() =>\n        this.currentSearchRequestService.visibleFilterCount() > 0\n            ? ({\n                isNotification: true,\n                isPill: true,\n                bgColor: 'primary-lt',\n                text: { text: this.currentSearchRequestService.visibleFilterCount().toString(), isTranslated: true }\n            })\n            : undefined\n    );\n    readonly filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? <BgColorStyleType>'primary' : undefined);\n    readonly searchSubject = new Subject<string>();\n\n    private readonly filtersOperandsService = inject(FiltersOperandsService);\n    readonly currentSearchRequestService = inject(CurrentSearchRequestService);\n\n    constructor() {\n        super();\n\n        effect(() => {\n            // Auto-close filter section when all filters are removed\n            if (this.currentSearchRequestService.visibleFilterCount() === 0 && this.isFilterSectionOpen()) {\n                this.isFilterSectionOpen.set(false);\n            }\n        }, { allowSignalWrites: true });\n    }\n\n    ngOnInit(): void {\n        const searchSub = this.searchSubject\n            .pipe(\n                distinctUntilChanged(),\n                debounceTime(this.config().searchInputDebounceTime)\n            )\n            .subscribe(term =>\n                this.currentSearchRequestService.setDescription(term)\n            );\n\n        this.addSubscriptions(searchSub);\n    }\n\n    search(): void {\n        this.currentSearchRequestService.patchSearchRequest({\n            filters: FilterTools.convertToRequestFilter(this.activeFilters(), this.config().filterFields, this.config().columns)\n        });\n        this.currentSearchRequestService.triggerSearch();\n    }\n\n    toggleFilterSection(): void {\n        if (this.activeFilters().length === 0) {\n            this.addEmptyFilterRow();\n        }\n\n        this.isFilterSectionOpen.update(isOpen => !isOpen);\n    }\n\n    onRowRemoved(): void {\n        if (this.activeFilters().length === 0) {\n            this.isFilterSectionOpen.set(false);\n        }\n\n        this.search();\n    }\n\n    addEmptyFilterRow(): void {\n        this.currentSearchRequestService.addFilter({} as any);\n    }\n}\n","<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n    @if (!!actionsTpl()) {\n        <ng-template [ngTemplateOutlet]=\"actionsTpl()!\"></ng-template>\n    }\n\n    <div class=\"d-flex align-items-center gap-2\">\n        <upd-input wrapperClasses=\"w-100\" [placeholder]=\"{text:'UpDevs.Table.Search', isTranslated:false}\"\n            [isAppendButton]=\"true\" (valueChange)=\"searchSubject.next($event)\"\n            [value]=\"currentSearchRequestService.searchRequest().description\">\n            <ng-template updInputAppend>\n                <upd-button [isIcon]=\"true\" [colorStyle]=\"filterSectionBtnColor()\" (clicked)=\"toggleFilterSection()\"\n                    [badgeConfig]=\"badgeConfig()\">\n                    <upd-icon [tablerIcon]=\"isFilterSectionOpen() ? 'filter-up' : 'filter-down'\"\n                        [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            </ng-template>\n        </upd-input>\n    </div>\n\n    @if (isFilterSectionOpen()) {\n        @for (row of activeFilters(); track row.name; let i = $index) {\n            <upd-filter-row [currentFilter]=\"row\" [config]=\"config()\" [rowIndex]=\"i\" (removed)=\"onRowRemoved()\"\n                [isDisabled]=\"currentSearchRequestService.isSearching()\">\n            </upd-filter-row>\n        }\n\n        <div class=\"ms-auto d-flex gap-2\">\n            <upd-button customClasses=\"gap-2\" colorStyle=\"primary\" [isOutline]=\"true\" (clicked)=\"addEmptyFilterRow()\"\n                [isDisabled]=\"!canPerformActions()\">\n                <upd-icon tablerIcon=\"plus\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n                {{ t('AddNewFilter') }}\n            </upd-button>\n            <upd-button customClasses=\"gap-2\" colorStyle=\"success\" [isDisabled]=\"!canPerformActions()\"\n                (clicked)=\"search()\">\n                <upd-icon tablerIcon=\"checks\" tablerIconWeight=\"bold\" [tablerIconSize]=\"20\"></upd-icon>\n                {{ t('ApplyFilters') }}\n            </upd-button>\n        </div>\n    }\n</ng-container>"]}
@@ -12,6 +12,7 @@ export class TableConfigModel {
12
12
  this.data = [];
13
13
  this.preSelectedItems = [];
14
14
  this.searchInputDebounceTime = 300;
15
+ this.shouldLoadFilterFieldsFromServer = false;
15
16
  /**
16
17
  * Actions added to each record row as a group of buttons.
17
18
  */
@@ -36,4 +37,4 @@ export class TableConfigModel {
36
37
  }
37
38
  }
38
39
  }
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RhYmxlL3NyYy9tb2RlbHMvdGFibGUtY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNBLE1BQU0sT0FBTyxnQkFBZ0I7SUFtQ3pCLFlBQVksSUFBcUI7UUFoQ2pDLFlBQU8sR0FBc0IsRUFBRSxDQUFDO1FBRWhDLGNBQVMsR0FBRyxJQUFJLENBQUM7UUFDakIsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFDcEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLHFCQUFnQixHQUFHLElBQUksQ0FBQztRQUN4QixxQkFBZ0IsR0FBRyxJQUFJLENBQUM7UUFDeEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLFNBQUksR0FBUSxFQUFFLENBQUM7UUFDZixxQkFBZ0IsR0FBUSxFQUFFLENBQUM7UUFDM0IsNEJBQXVCLEdBQUcsR0FBRyxDQUFDO1FBQzlCOztXQUVHO1FBQ0gsa0JBQWEsR0FBa0IsRUFBRSxDQUFDO1FBQ2xDOztXQUVHO1FBQ0gsd0JBQW1CLEdBQWtCLEVBQUUsQ0FBQztRQUN4Qzs7O1dBR0c7UUFDSCxpQkFBWSxHQUF3QixFQUFFLENBQUM7UUFDdkM7OztXQUdHO1FBQ0gsd0JBQW1CLEdBQUcsS0FBSyxDQUFDO1FBUTVCLGtCQUFhLEdBQW1CLENBQUMsSUFBTyxFQUFFLEVBQUUsQ0FBRSxJQUFZLENBQUMsRUFBRSxDQUFDO1FBTDFELElBQUksQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ1QsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDOUIsQ0FBQztJQUNMLENBQUM7Q0FHSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRleHRNb2RlbCB9IGZyb20gJ0B1cGRldnMvc2RrJztcbmltcG9ydCB7IEJ1dHRvbk1vZGVsIH0gZnJvbSAnQHVwZGV2cy9zZGsvbGF5b3V0JztcbmltcG9ydCB7IEJhc2VTZWFyY2hTdG9yZSB9IGZyb20gJ0B1cGRldnMvc2RrL3N0b3Jlcyc7XG5pbXBvcnQgeyBHZXRCeUlkVHlwZSB9IGZyb20gJ0B1cGRldnMvc2RrL3R5cGVzJztcblxuaW1wb3J0IHsgVGFibGVDb25maWcgfSBmcm9tICcuL3RhYmxlLmNvbmZpZyc7XG5pbXBvcnQgeyBCYXNlQ29sdW1uTW9kZWwgfSBmcm9tICcuLi9hYnN0cmFjdGlvbnMvYmFzZS1jb2x1bW4ubW9kZWwnO1xuaW1wb3J0IHsgRmlsdGVyRmllbGRDb25maWcgfSBmcm9tICcuL2ZpbHRlci1maWVsZC5jb25maWcnO1xuXG5leHBvcnQgY2xhc3MgVGFibGVDb25maWdNb2RlbDxUPiBpbXBsZW1lbnRzIFRhYmxlQ29uZmlnPFQ+IHtcbiAgICBuYW1lITogc3RyaW5nO1xuICAgIHN0b3JlPzogQmFzZVNlYXJjaFN0b3JlPFQ+O1xuICAgIGNvbHVtbnM6IEJhc2VDb2x1bW5Nb2RlbFtdID0gW107XG4gICAgdGl0bGU/OiBUZXh0TW9kZWw7XG4gICAgY2FuU2VhcmNoID0gdHJ1ZTtcbiAgICBjYW5TYXZlVmlld3MgPSB0cnVlO1xuICAgIGNhbkxvYWRTYXZlZFZpZXdzID0gdHJ1ZTtcbiAgICBjYW5NYW5hZ2VDb2x1bW5zID0gdHJ1ZTtcbiAgICBzaG91bGRBdXRvU2VhcmNoID0gdHJ1ZTtcbiAgICBoYXNDaGVja2JveENvbHVtbiA9IHRydWU7XG4gICAgaXNSZXNwb25zaXZlID0gdHJ1ZTtcbiAgICBoYXNTdGlja3lIZWFkZXIgPSBmYWxzZTtcbiAgICBkYXRhOiBUW10gPSBbXTtcbiAgICBwcmVTZWxlY3RlZEl0ZW1zOiBUW10gPSBbXTtcbiAgICBzZWFyY2hJbnB1dERlYm91bmNlVGltZSA9IDMwMDtcbiAgICAvKipcbiAgICAgKiBBY3Rpb25zIGFkZGVkIHRvIGVhY2ggcmVjb3JkIHJvdyBhcyBhIGdyb3VwIG9mIGJ1dHRvbnMuXG4gICAgICovXG4gICAgY3VzdG9tQWN0aW9uczogQnV0dG9uTW9kZWxbXSA9IFtdO1xuICAgIC8qKlxuICAgICAqIEFjdGlvbnMgYWRkZWQgdG8gdGhlIGhlYWRlciBvZiB0aGUgdGFibGUgYXMgcmVndWxhciBidXR0b25zLlxuICAgICAqL1xuICAgIGN1c3RvbUhlYWRlckFjdGlvbnM6IEJ1dHRvbk1vZGVsW10gPSBbXTtcbiAgICAvKipcbiAgICAgKiBEZWZpbmUgY3VzdG9tIGZpbHRlcmFibGUgZmllbGRzLlxuICAgICAqIElmIG5vdCBwcm92aWRlZCBhbmQgdXNlQ29sdW1uc0FzRmlsdGVycyBpcyB0cnVlLCBmaWx0ZXJzIHdpbGwgYmUgYXV0by1nZW5lcmF0ZWQgZnJvbSBjb2x1bW5zLlxuICAgICAqL1xuICAgIGZpbHRlckZpZWxkczogRmlsdGVyRmllbGRDb25maWdbXSA9IFtdO1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdG8gdXNlIGNvbHVtbnMgYXMgZmlsdGVycy5cbiAgICAgKiBJZiBmYWxzZSwgZmlsdGVyRmllbGRzIG11c3QgYmUgcHJvdmlkZWQuXG4gICAgICovXG4gICAgdXNlQ29sdW1uc0FzRmlsdGVycyA9IGZhbHNlO1xuXG4gICAgY29uc3RydWN0b3IoaW5pdD86IFRhYmxlQ29uZmlnPFQ+KSB7XG4gICAgICAgIGlmICghIWluaXQpIHtcbiAgICAgICAgICAgIE9iamVjdC5hc3NpZ24odGhpcywgaW5pdCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBnZXRJZEZ1bmN0aW9uOiBHZXRCeUlkVHlwZTxUPiA9IChpdGVtOiBUKSA9PiAoaXRlbSBhcyBhbnkpLmlkO1xufVxuIl19
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29uZmlnLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RhYmxlL3NyYy9tb2RlbHMvdGFibGUtY29uZmlnLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE1BQU0sT0FBTyxnQkFBZ0I7SUFvQ3pCLFlBQVksSUFBcUI7UUFqQ2pDLFlBQU8sR0FBc0IsRUFBRSxDQUFDO1FBRWhDLGNBQVMsR0FBRyxJQUFJLENBQUM7UUFDakIsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFDcEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLHFCQUFnQixHQUFHLElBQUksQ0FBQztRQUN4QixxQkFBZ0IsR0FBRyxJQUFJLENBQUM7UUFDeEIsc0JBQWlCLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLFNBQUksR0FBUSxFQUFFLENBQUM7UUFDZixxQkFBZ0IsR0FBUSxFQUFFLENBQUM7UUFDM0IsNEJBQXVCLEdBQUcsR0FBRyxDQUFDO1FBQzlCLHFDQUFnQyxHQUFHLEtBQUssQ0FBQztRQUN6Qzs7V0FFRztRQUNILGtCQUFhLEdBQWtCLEVBQUUsQ0FBQztRQUNsQzs7V0FFRztRQUNILHdCQUFtQixHQUFrQixFQUFFLENBQUM7UUFDeEM7OztXQUdHO1FBQ0gsaUJBQVksR0FBd0IsRUFBRSxDQUFDO1FBQ3ZDOzs7V0FHRztRQUNILHdCQUFtQixHQUFHLEtBQUssQ0FBQztRQVE1QixrQkFBYSxHQUFtQixDQUFDLElBQU8sRUFBRSxFQUFFLENBQUUsSUFBWSxDQUFDLEVBQUUsQ0FBQztRQUwxRCxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNULE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQzlCLENBQUM7SUFDTCxDQUFDO0NBR0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0TW9kZWwgfSBmcm9tICdAdXBkZXZzL3Nkayc7XG5pbXBvcnQgeyBCdXR0b25Nb2RlbCB9IGZyb20gJ0B1cGRldnMvc2RrL2xheW91dCc7XG5pbXBvcnQgeyBCYXNlU2VhcmNoU3RvcmUsIEZpbHRlckZpZWxkQ29uZmlnIH0gZnJvbSAnQHVwZGV2cy9zZGsvc3RvcmVzJztcbmltcG9ydCB7IEdldEJ5SWRUeXBlIH0gZnJvbSAnQHVwZGV2cy9zZGsvdHlwZXMnO1xuXG5pbXBvcnQgeyBUYWJsZUNvbmZpZyB9IGZyb20gJy4vdGFibGUuY29uZmlnJztcbmltcG9ydCB7IEJhc2VDb2x1bW5Nb2RlbCB9IGZyb20gJy4uL2Fic3RyYWN0aW9ucy9iYXNlLWNvbHVtbi5tb2RlbCc7XG5cbmV4cG9ydCBjbGFzcyBUYWJsZUNvbmZpZ01vZGVsPFQ+IGltcGxlbWVudHMgVGFibGVDb25maWc8VD4ge1xuICAgIG5hbWUhOiBzdHJpbmc7XG4gICAgc3RvcmU/OiBCYXNlU2VhcmNoU3RvcmU8VD47XG4gICAgY29sdW1uczogQmFzZUNvbHVtbk1vZGVsW10gPSBbXTtcbiAgICB0aXRsZT86IFRleHRNb2RlbDtcbiAgICBjYW5TZWFyY2ggPSB0cnVlO1xuICAgIGNhblNhdmVWaWV3cyA9IHRydWU7XG4gICAgY2FuTG9hZFNhdmVkVmlld3MgPSB0cnVlO1xuICAgIGNhbk1hbmFnZUNvbHVtbnMgPSB0cnVlO1xuICAgIHNob3VsZEF1dG9TZWFyY2ggPSB0cnVlO1xuICAgIGhhc0NoZWNrYm94Q29sdW1uID0gdHJ1ZTtcbiAgICBpc1Jlc3BvbnNpdmUgPSB0cnVlO1xuICAgIGhhc1N0aWNreUhlYWRlciA9IGZhbHNlO1xuICAgIGRhdGE6IFRbXSA9IFtdO1xuICAgIHByZVNlbGVjdGVkSXRlbXM6IFRbXSA9IFtdO1xuICAgIHNlYXJjaElucHV0RGVib3VuY2VUaW1lID0gMzAwO1xuICAgIHNob3VsZExvYWRGaWx0ZXJGaWVsZHNGcm9tU2VydmVyID0gZmFsc2U7XG4gICAgLyoqXG4gICAgICogQWN0aW9ucyBhZGRlZCB0byBlYWNoIHJlY29yZCByb3cgYXMgYSBncm91cCBvZiBidXR0b25zLlxuICAgICAqL1xuICAgIGN1c3RvbUFjdGlvbnM6IEJ1dHRvbk1vZGVsW10gPSBbXTtcbiAgICAvKipcbiAgICAgKiBBY3Rpb25zIGFkZGVkIHRvIHRoZSBoZWFkZXIgb2YgdGhlIHRhYmxlIGFzIHJlZ3VsYXIgYnV0dG9ucy5cbiAgICAgKi9cbiAgICBjdXN0b21IZWFkZXJBY3Rpb25zOiBCdXR0b25Nb2RlbFtdID0gW107XG4gICAgLyoqXG4gICAgICogRGVmaW5lIGN1c3RvbSBmaWx0ZXJhYmxlIGZpZWxkcy5cbiAgICAgKiBJZiBub3QgcHJvdmlkZWQgYW5kIHVzZUNvbHVtbnNBc0ZpbHRlcnMgaXMgdHJ1ZSwgZmlsdGVycyB3aWxsIGJlIGF1dG8tZ2VuZXJhdGVkIGZyb20gY29sdW1ucy5cbiAgICAgKi9cbiAgICBmaWx0ZXJGaWVsZHM6IEZpbHRlckZpZWxkQ29uZmlnW10gPSBbXTtcbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRvIHVzZSBjb2x1bW5zIGFzIGZpbHRlcnMuXG4gICAgICogSWYgZmFsc2UsIGZpbHRlckZpZWxkcyBtdXN0IGJlIHByb3ZpZGVkLlxuICAgICAqL1xuICAgIHVzZUNvbHVtbnNBc0ZpbHRlcnMgPSBmYWxzZTtcblxuICAgIGNvbnN0cnVjdG9yKGluaXQ/OiBUYWJsZUNvbmZpZzxUPikge1xuICAgICAgICBpZiAoISFpbml0KSB7XG4gICAgICAgICAgICBPYmplY3QuYXNzaWduKHRoaXMsIGluaXQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgZ2V0SWRGdW5jdGlvbjogR2V0QnlJZFR5cGU8VD4gPSAoaXRlbTogVCkgPT4gKGl0ZW0gYXMgYW55KS5pZDtcbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RhYmxlL3NyYy9tb2RlbHMvdGFibGUuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0TW9kZWwgfSBmcm9tICdAdXBkZXZzL3Nkayc7XG5pbXBvcnQgeyBCdXR0b25Nb2RlbCB9IGZyb20gJ0B1cGRldnMvc2RrL2xheW91dCc7XG5pbXBvcnQgeyBCYXNlU2VhcmNoU3RvcmUgfSBmcm9tICdAdXBkZXZzL3Nkay9zdG9yZXMnO1xuaW1wb3J0IHsgR2V0QnlJZFR5cGUgfSBmcm9tICdAdXBkZXZzL3Nkay90eXBlcyc7XG5cbmltcG9ydCB7IEJhc2VDb2x1bW5Nb2RlbCB9IGZyb20gJy4uL2Fic3RyYWN0aW9ucy9iYXNlLWNvbHVtbi5tb2RlbCc7XG5pbXBvcnQgeyBGaWx0ZXJGaWVsZENvbmZpZyB9IGZyb20gJy4vZmlsdGVyLWZpZWxkLmNvbmZpZyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDb25maWc8VD4ge1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBzdG9yZT86IEJhc2VTZWFyY2hTdG9yZTxUPjtcbiAgICBjb2x1bW5zOiBCYXNlQ29sdW1uTW9kZWxbXTtcbiAgICBnZXRJZEZ1bmN0aW9uPzogR2V0QnlJZFR5cGU8VD47XG4gICAgdGl0bGU/OiBUZXh0TW9kZWw7XG4gICAgY2FuU2VhcmNoPzogYm9vbGVhbjtcbiAgICBjYW5TYXZlVmlld3M/OiBib29sZWFuO1xuICAgIGNhbkxvYWRTYXZlZFZpZXdzPzogYm9vbGVhbjtcbiAgICBjYW5NYW5hZ2VDb2x1bW5zPzogYm9vbGVhbjtcbiAgICBzaG91bGRBdXRvU2VhcmNoPzogYm9vbGVhbjtcbiAgICBoYXNDaGVja2JveENvbHVtbj86IGJvb2xlYW47XG4gICAgaXNSZXNwb25zaXZlPzogYm9vbGVhbjtcbiAgICBoYXNTdGlja3lIZWFkZXI/OiBib29sZWFuO1xuICAgIGRhdGE/OiBUW107XG4gICAgcHJlU2VsZWN0ZWRJdGVtcz86IFRbXTtcbiAgICBzZWFyY2hJbnB1dERlYm91bmNlVGltZT86IG51bWJlcjtcbiAgICAvKipcbiAgICAgKiBBY3Rpb25zIGFkZGVkIHRvIGVhY2ggcmVjb3JkIHJvdyBhcyBhIGdyb3VwIG9mIGJ1dHRvbnMuXG4gICAgICovXG4gICAgY3VzdG9tQWN0aW9ucz86IEJ1dHRvbk1vZGVsW107XG4gICAgLyoqXG4gICAgICogQWN0aW9ucyBhZGRlZCB0byB0aGUgaGVhZGVyIG9mIHRoZSB0YWJsZSBhcyByZWd1bGFyIGJ1dHRvbnMuXG4gICAgICovXG4gICAgY3VzdG9tSGVhZGVyQWN0aW9ucz86IEJ1dHRvbk1vZGVsW107XG4gICAgLyoqXG4gICAgICogRGVmaW5lIGN1c3RvbSBmaWx0ZXJhYmxlIGZpZWxkcy5cbiAgICAgKiBJZiBub3QgcHJvdmlkZWQgYW5kIHVzZUNvbHVtbnNBc0ZpbHRlcnMgaXMgdHJ1ZSwgZmlsdGVycyB3aWxsIGJlIGF1dG8tZ2VuZXJhdGVkIGZyb20gY29sdW1ucy5cbiAgICAgKi9cbiAgICBmaWx0ZXJGaWVsZHM/OiBGaWx0ZXJGaWVsZENvbmZpZ1tdO1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdG8gdXNlIGNvbHVtbnMgYXMgZmlsdGVycy5cbiAgICAgKiBJZiBmYWxzZSwgZmlsdGVyRmllbGRzIG11c3QgYmUgcHJvdmlkZWQuXG4gICAgICovXG4gICAgdXNlQ29sdW1uc0FzRmlsdGVycz86IGJvb2xlYW47XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RhYmxlL3NyYy9tb2RlbHMvdGFibGUuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0TW9kZWwgfSBmcm9tICdAdXBkZXZzL3Nkayc7XG5pbXBvcnQgeyBCdXR0b25Nb2RlbCB9IGZyb20gJ0B1cGRldnMvc2RrL2xheW91dCc7XG5pbXBvcnQgeyBCYXNlU2VhcmNoU3RvcmUsIEZpbHRlckZpZWxkQ29uZmlnIH0gZnJvbSAnQHVwZGV2cy9zZGsvc3RvcmVzJztcbmltcG9ydCB7IEdldEJ5SWRUeXBlIH0gZnJvbSAnQHVwZGV2cy9zZGsvdHlwZXMnO1xuXG5pbXBvcnQgeyBCYXNlQ29sdW1uTW9kZWwgfSBmcm9tICcuLi9hYnN0cmFjdGlvbnMvYmFzZS1jb2x1bW4ubW9kZWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ29uZmlnPFQ+IHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgc3RvcmU/OiBCYXNlU2VhcmNoU3RvcmU8VD47XG4gICAgY29sdW1uczogQmFzZUNvbHVtbk1vZGVsW107XG4gICAgZ2V0SWRGdW5jdGlvbj86IEdldEJ5SWRUeXBlPFQ+O1xuICAgIHRpdGxlPzogVGV4dE1vZGVsO1xuICAgIGNhblNlYXJjaD86IGJvb2xlYW47XG4gICAgY2FuU2F2ZVZpZXdzPzogYm9vbGVhbjtcbiAgICBjYW5Mb2FkU2F2ZWRWaWV3cz86IGJvb2xlYW47XG4gICAgY2FuTWFuYWdlQ29sdW1ucz86IGJvb2xlYW47XG4gICAgc2hvdWxkQXV0b1NlYXJjaD86IGJvb2xlYW47XG4gICAgaGFzQ2hlY2tib3hDb2x1bW4/OiBib29sZWFuO1xuICAgIGlzUmVzcG9uc2l2ZT86IGJvb2xlYW47XG4gICAgaGFzU3RpY2t5SGVhZGVyPzogYm9vbGVhbjtcbiAgICBkYXRhPzogVFtdO1xuICAgIHByZVNlbGVjdGVkSXRlbXM/OiBUW107XG4gICAgc2VhcmNoSW5wdXREZWJvdW5jZVRpbWU/OiBudW1iZXI7XG4gICAgc2hvdWxkTG9hZEZpbHRlckZpZWxkc0Zyb21TZXJ2ZXI/OiBib29sZWFuO1xuICAgIC8qKlxuICAgICAqIEFjdGlvbnMgYWRkZWQgdG8gZWFjaCByZWNvcmQgcm93IGFzIGEgZ3JvdXAgb2YgYnV0dG9ucy5cbiAgICAgKi9cbiAgICBjdXN0b21BY3Rpb25zPzogQnV0dG9uTW9kZWxbXTtcbiAgICAvKipcbiAgICAgKiBBY3Rpb25zIGFkZGVkIHRvIHRoZSBoZWFkZXIgb2YgdGhlIHRhYmxlIGFzIHJlZ3VsYXIgYnV0dG9ucy5cbiAgICAgKi9cbiAgICBjdXN0b21IZWFkZXJBY3Rpb25zPzogQnV0dG9uTW9kZWxbXTtcbiAgICAvKipcbiAgICAgKiBEZWZpbmUgY3VzdG9tIGZpbHRlcmFibGUgZmllbGRzLlxuICAgICAqIElmIG5vdCBwcm92aWRlZCBhbmQgdXNlQ29sdW1uc0FzRmlsdGVycyBpcyB0cnVlLCBmaWx0ZXJzIHdpbGwgYmUgYXV0by1nZW5lcmF0ZWQgZnJvbSBjb2x1bW5zLlxuICAgICAqL1xuICAgIGZpbHRlckZpZWxkcz86IEZpbHRlckZpZWxkQ29uZmlnW107XG4gICAgLyoqXG4gICAgICogV2hldGhlciB0byB1c2UgY29sdW1ucyBhcyBmaWx0ZXJzLlxuICAgICAqIElmIGZhbHNlLCBmaWx0ZXJGaWVsZHMgbXVzdCBiZSBwcm92aWRlZC5cbiAgICAgKi9cbiAgICB1c2VDb2x1bW5zQXNGaWx0ZXJzPzogYm9vbGVhbjtcbn1cbiJdfQ==