@updevs/components 1.0.0-alpha.91 → 1.0.0-alpha.93

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,3 +1,4 @@
1
+ export * from './base.column';
1
2
  export * from './base-column.model';
2
3
  export * from './filters-operands.service';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy90YWJsZS9zcmMvYWJzdHJhY3Rpb25zL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9iYXNlLWNvbHVtbi5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMtb3BlcmFuZHMuc2VydmljZSc7XG4iXX0=
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy90YWJsZS9zcmMvYWJzdHJhY3Rpb25zL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9iYXNlLmNvbHVtbic7XG5leHBvcnQgKiBmcm9tICcuL2Jhc2UtY29sdW1uLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVycy1vcGVyYW5kcy5zZXJ2aWNlJztcbiJdfQ==
@@ -25,21 +25,22 @@ export class SearchSectionComponent extends BaseComponent {
25
25
  this.isFilterSectionOpen = signal(false);
26
26
  this.canApplyFilters = computed(() => this.activeFilters().length > 0
27
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);
28
29
  this.canPerformActions = computed(() => this.canApplyFilters() && !this.isSearching());
29
- this.badgeConfig = computed(() => (this.searchRequest().filters?.length || 0) > 0
30
+ this.badgeConfig = computed(() => this.visibleFiltersCount() > 0
30
31
  ? ({
31
32
  isNotification: true,
32
33
  isPill: true,
33
34
  bgColor: 'primary-lt',
34
- text: { text: this.searchRequest().filters.length.toString(), isTranslated: true }
35
+ text: { text: this.visibleFiltersCount().toString(), isTranslated: true }
35
36
  })
36
37
  : undefined);
37
38
  this.filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? 'primary' : undefined);
38
39
  this.searchSubject = new Subject();
39
40
  this.filtersOperandsService = inject(FiltersOperandsService);
40
41
  effect(() => {
41
- if ((this.searchRequest().filters?.length || 0) > 0) {
42
- this.activeFilters.set([...FilterTools.convertToFilterItem(this.searchRequest().filters || [], this.filtersOperandsService.getAllOperands())]);
42
+ if (this.visibleFiltersCount() > 0) {
43
+ this.activeFilters.set([...FilterTools.convertToFilterItem(this.searchRequest().filters?.filter(af => !af.isHidden) || [], this.filtersOperandsService.getAllOperands())]);
43
44
  }
44
45
  else {
45
46
  this.activeFilters.set([]);
@@ -90,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
90
91
  type: HostBinding,
91
92
  args: ['class']
92
93
  }] } });
93
- //# 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    searchRequest = model.required<SearchRequestModel>();\n    hasChanges = model.required<boolean>();\n    columns = input.required<BaseColumnModel[]>();\n    isSearching = input.required<boolean>();\n    searchRequestSubject = input.required<Subject<SearchRequestModel>>();\n    config = input.required<TableConfigModel<T>>();\n    actionsTpl = input<TemplateRef<any>>();\n    activeFilters = signal<FilterItemModel[]>([]);\n    isFilterSectionOpen = signal(false);\n    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    canPerformActions = computed(() => this.canApplyFilters() && !this.isSearching());\n    badgeConfig = computed<OptionalType<BadgeConfig>>(() =>\n        (this.searchRequest().filters?.length || 0) > 0\n            ? ({\n                isNotification: true,\n                isPill: true,\n                bgColor: 'primary-lt',\n                text: { text: this.searchRequest().filters!.length.toString(), isTranslated: true }\n            })\n            : undefined\n    );\n    filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? <BgColorStyleType>'primary' : undefined);\n\n    readonly searchSubject = new Subject<string>();\n\n    private readonly filtersOperandsService = inject(FiltersOperandsService);\n\n    constructor() {\n        super();\n\n        effect(() => {\n            if ((this.searchRequest().filters?.length || 0) > 0) {\n                this.activeFilters.set(\n                    [...FilterTools.convertToFilterItem(this.searchRequest().filters || [], 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().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}\" [isAppendButton]=\"true\"\n            (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'\" [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\" [columns]=\"columns()\"\n                [rowIndex]=\"i\" (removed)=\"onRowRemoved()\" [isDisabled]=\"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()\" (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>\n"]}
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().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}\" [isAppendButton]=\"true\"\n            (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'\" [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\" [columns]=\"columns()\"\n                [rowIndex]=\"i\" (removed)=\"onRowRemoved()\" [isDisabled]=\"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()\" (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>\n"]}
@@ -1,8 +1,8 @@
1
- import { DataTypeEnum, StringColumnFilter, GuidColumnFilter, NumberColumnFilter, DateColumnFilter, BooleanColumnFilter, SortDirectionEnum, ColumnSort, BaseStore, FilterOperandEnum, FilterDateOperandEnum, FilterNumberOperandEnum, FilterBooleanOperandEnum, FilterGuidOperandEnum } from '@updevs/sdk/stores';
2
1
  import * as i0 from '@angular/core';
3
2
  import { inject, Directive, Component, input, ViewContainerRef, effect, computed, signal, Injectable, model, InjectionToken, Inject, EventEmitter, Output, HostBinding, viewChild, ElementRef, NgModule } from '@angular/core';
4
- import { DynamicComponentLoaderService, BaseComponent, ButtonModel } from '@updevs/sdk/layout';
5
3
  import { TextService } from '@updevs/sdk';
4
+ import { DataTypeEnum, StringColumnFilter, GuidColumnFilter, NumberColumnFilter, DateColumnFilter, BooleanColumnFilter, SortDirectionEnum, ColumnSort, BaseStore, FilterOperandEnum, FilterDateOperandEnum, FilterNumberOperandEnum, FilterBooleanOperandEnum, FilterGuidOperandEnum } from '@updevs/sdk/stores';
5
+ import { DynamicComponentLoaderService, BaseComponent, ButtonModel } from '@updevs/sdk/layout';
6
6
  import * as i1 from '@angular/common';
7
7
  import { CommonModule } from '@angular/common';
8
8
  import * as i3 from '@updevs/icons';
@@ -50,59 +50,6 @@ var ColumnTypeEnum;
50
50
  ColumnTypeEnum[ColumnTypeEnum["Guid"] = 11] = "Guid";
51
51
  })(ColumnTypeEnum || (ColumnTypeEnum = {}));
52
52
 
53
- class BaseColumnModel {
54
- get dataType() {
55
- switch (this.type) {
56
- case ColumnTypeEnum.Boolean:
57
- return DataTypeEnum.Boolean;
58
- case ColumnTypeEnum.DateTime:
59
- case ColumnTypeEnum.Date:
60
- case ColumnTypeEnum.Time:
61
- return DataTypeEnum.Date;
62
- case ColumnTypeEnum.Currency:
63
- case ColumnTypeEnum.Number:
64
- return DataTypeEnum.Number;
65
- case ColumnTypeEnum.Guid:
66
- return DataTypeEnum.Guid;
67
- default:
68
- return DataTypeEnum.String;
69
- }
70
- }
71
- get widthClass() {
72
- if (!this.width || !!this.width.pixels) {
73
- return '';
74
- }
75
- const prefix = !!this.width.gridColumn ? 'col' : 'w';
76
- const auto = !!this.width.gridColumn && this.width.gridColumn === 0 ? 'auto' : '';
77
- return `${prefix}-${auto || this.widthSize}`;
78
- }
79
- get widthSize() {
80
- return !this.width ? 0 : this.width.gridColumn || this.width.percentage || 0;
81
- }
82
- get pixelsSize() {
83
- return this.width?.pixels;
84
- }
85
- constructor(columnType, init) {
86
- this.titleAlignment = 'left';
87
- this.allowSort = true;
88
- this.isItalic = false;
89
- this.type = ColumnTypeEnum.Text;
90
- this.alignment = 'left';
91
- this.weight = 'normal';
92
- this.overflowStrategy = 'truncate';
93
- this.shouldSpaceAfterPrefix = true;
94
- this.shouldSpaceBeforeSuffix = true;
95
- this.isHidden = false;
96
- if (!!init) {
97
- Object.assign(this, init);
98
- }
99
- this.type = columnType;
100
- }
101
- }
102
-
103
- class FiltersOperandsService {
104
- }
105
-
106
53
  class BaseColumn {
107
54
  constructor() {
108
55
  this.textService = inject(TextService);
@@ -183,6 +130,59 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
183
130
  type: Directive
184
131
  }] });
185
132
 
133
+ class BaseColumnModel {
134
+ get dataType() {
135
+ switch (this.type) {
136
+ case ColumnTypeEnum.Boolean:
137
+ return DataTypeEnum.Boolean;
138
+ case ColumnTypeEnum.DateTime:
139
+ case ColumnTypeEnum.Date:
140
+ case ColumnTypeEnum.Time:
141
+ return DataTypeEnum.Date;
142
+ case ColumnTypeEnum.Currency:
143
+ case ColumnTypeEnum.Number:
144
+ return DataTypeEnum.Number;
145
+ case ColumnTypeEnum.Guid:
146
+ return DataTypeEnum.Guid;
147
+ default:
148
+ return DataTypeEnum.String;
149
+ }
150
+ }
151
+ get widthClass() {
152
+ if (!this.width || !!this.width.pixels) {
153
+ return '';
154
+ }
155
+ const prefix = !!this.width.gridColumn ? 'col' : 'w';
156
+ const auto = !!this.width.gridColumn && this.width.gridColumn === 0 ? 'auto' : '';
157
+ return `${prefix}-${auto || this.widthSize}`;
158
+ }
159
+ get widthSize() {
160
+ return !this.width ? 0 : this.width.gridColumn || this.width.percentage || 0;
161
+ }
162
+ get pixelsSize() {
163
+ return this.width?.pixels;
164
+ }
165
+ constructor(columnType, init) {
166
+ this.titleAlignment = 'left';
167
+ this.allowSort = true;
168
+ this.isItalic = false;
169
+ this.type = ColumnTypeEnum.Text;
170
+ this.alignment = 'left';
171
+ this.weight = 'normal';
172
+ this.overflowStrategy = 'truncate';
173
+ this.shouldSpaceAfterPrefix = true;
174
+ this.shouldSpaceBeforeSuffix = true;
175
+ this.isHidden = false;
176
+ if (!!init) {
177
+ Object.assign(this, init);
178
+ }
179
+ this.type = columnType;
180
+ }
181
+ }
182
+
183
+ class FiltersOperandsService {
184
+ }
185
+
186
186
  class TextColumnComponent extends BaseColumn {
187
187
  getClasses() {
188
188
  return [
@@ -765,21 +765,22 @@ class SearchSectionComponent extends BaseComponent {
765
765
  this.isFilterSectionOpen = signal(false);
766
766
  this.canApplyFilters = computed(() => this.activeFilters().length > 0
767
767
  && this.activeFilters().every(af => !af.isHidden && !!af.name && !!af.operandConfig?.operand && (!af.operandConfig?.requiresValue || !!af.value)));
768
+ this.visibleFiltersCount = computed(() => this.searchRequest().filters?.filter(af => !af.isHidden).length || 0);
768
769
  this.canPerformActions = computed(() => this.canApplyFilters() && !this.isSearching());
769
- this.badgeConfig = computed(() => (this.searchRequest().filters?.length || 0) > 0
770
+ this.badgeConfig = computed(() => this.visibleFiltersCount() > 0
770
771
  ? ({
771
772
  isNotification: true,
772
773
  isPill: true,
773
774
  bgColor: 'primary-lt',
774
- text: { text: this.searchRequest().filters.length.toString(), isTranslated: true }
775
+ text: { text: this.visibleFiltersCount().toString(), isTranslated: true }
775
776
  })
776
777
  : undefined);
777
778
  this.filterSectionBtnColor = computed(() => this.isFilterSectionOpen() ? 'primary' : undefined);
778
779
  this.searchSubject = new Subject();
779
780
  this.filtersOperandsService = inject(FiltersOperandsService);
780
781
  effect(() => {
781
- if ((this.searchRequest().filters?.length || 0) > 0) {
782
- this.activeFilters.set([...FilterTools.convertToFilterItem(this.searchRequest().filters || [], this.filtersOperandsService.getAllOperands())]);
782
+ if (this.visibleFiltersCount() > 0) {
783
+ this.activeFilters.set([...FilterTools.convertToFilterItem(this.searchRequest().filters?.filter(af => !af.isHidden) || [], this.filtersOperandsService.getAllOperands())]);
783
784
  }
784
785
  else {
785
786
  this.activeFilters.set([]);
@@ -1767,5 +1768,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
1767
1768
  * Generated bundle index. Do not edit.
1768
1769
  */
1769
1770
 
1770
- export { BaseColumnModel, BooleanColumnModel, ColumnTypeEnum, CustomColumnModel, DateTimeColumnModel, FiltersOperandsService, GuidColumnModel, ImageColumnModel, NumberColumnModel, TableColumnDirective, TableComponent, TextColumnModel, UpdTableModule };
1771
+ export { BaseColumn, BaseColumnModel, BooleanColumnModel, ColumnTypeEnum, CustomColumnModel, DateTimeColumnModel, FiltersOperandsService, GuidColumnModel, ImageColumnModel, NumberColumnModel, TableColumnDirective, TableComponent, TextColumnModel, UpdTableModule };
1771
1772
  //# sourceMappingURL=updevs-components-table.mjs.map