@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.
- package/esm2022/table/abstractions/public-api.mjs +2 -1
- package/esm2022/table/components/search-section/search-section.component.mjs +6 -5
- package/fesm2022/updevs-components-table.mjs +61 -60
- package/fesm2022/updevs-components-table.mjs.map +1 -1
- package/package.json +29 -29
- package/table/abstractions/public-api.d.ts +1 -0
- package/table/components/search-section/search-section.component.d.ts +14 -13
|
@@ -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,
|
|
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(() =>
|
|
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.
|
|
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 (
|
|
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(() =>
|
|
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.
|
|
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 (
|
|
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
|