@cuby-ui/core 0.0.557 → 0.0.559
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/components/date-range-calendar/date-range-calendar.component.d.ts +53 -0
- package/components/date-range-calendar/date-range-calendar.interfaces.d.ts +1 -0
- package/components/date-range-calendar/date-range-calendar.module.d.ts +7 -0
- package/components/date-range-calendar/index.d.ts +3 -0
- package/components/filter-bar/components/add-filter-button/add-filter-button.component.d.ts +10 -0
- package/components/filter-bar/components/date-filter/date-filter.component.d.ts +32 -0
- package/components/filter-bar/components/filter-remove-button/filter-remove-button.component.d.ts +8 -0
- package/components/filter-bar/components/index.d.ts +7 -0
- package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts +16 -0
- package/components/filter-bar/components/range-filter/range-filter.component.d.ts +23 -0
- package/components/filter-bar/components/select-filter/select-filter.component.d.ts +17 -0
- package/components/filter-bar/components/string-filter/string-filter.component.d.ts +17 -0
- package/components/filter-bar/filter-bar.component.d.ts +14 -0
- package/components/filter-bar/filter-bar.interfaces.d.ts +89 -0
- package/components/filter-bar/filter-bar.module.d.ts +7 -0
- package/components/filter-bar/filter-bar.utils.d.ts +3 -0
- package/components/filter-bar/index.d.ts +3 -0
- package/components/index.d.ts +2 -0
- package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
- package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
- package/esm2022/components/date-range-calendar/date-range-calendar.component.mjs +206 -0
- package/esm2022/components/date-range-calendar/date-range-calendar.interfaces.mjs +2 -0
- package/esm2022/components/date-range-calendar/date-range-calendar.module.mjs +16 -0
- package/esm2022/components/date-range-calendar/index.mjs +3 -0
- package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs +25 -0
- package/esm2022/components/filter-bar/components/date-filter/date-filter.component.mjs +147 -0
- package/esm2022/components/filter-bar/components/filter-remove-button/filter-remove-button.component.mjs +20 -0
- package/esm2022/components/filter-bar/components/index.mjs +8 -0
- package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs +70 -0
- package/esm2022/components/filter-bar/components/range-filter/range-filter.component.mjs +99 -0
- package/esm2022/components/filter-bar/components/select-filter/select-filter.component.mjs +63 -0
- package/esm2022/components/filter-bar/components/string-filter/string-filter.component.mjs +66 -0
- package/esm2022/components/filter-bar/filter-bar.component.mjs +52 -0
- package/esm2022/components/filter-bar/filter-bar.interfaces.mjs +3 -0
- package/esm2022/components/filter-bar/filter-bar.module.mjs +16 -0
- package/esm2022/components/filter-bar/filter-bar.utils.mjs +114 -0
- package/esm2022/components/filter-bar/index.mjs +3 -0
- package/esm2022/components/index.mjs +3 -1
- package/esm2022/components/input-number/input-number.component.mjs +2 -2
- package/esm2022/components/input-password/input-password.component.mjs +2 -2
- package/esm2022/components/input-text/input-text.component.mjs +2 -2
- package/esm2022/components/input-time/input-time.component.mjs +2 -2
- package/esm2022/components/textarea/textarea.component.mjs +2 -2
- package/fesm2022/cuby-ui-core.mjs +834 -24
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/package.json +4 -4
- package/styles/mixins/inputs.scss +10 -0
- package/widgets/ui/categories/components/category-item/category-item.component.d.ts +2 -2
- package/widgets/ui/loader/components/stated-loader/stated-loader.component.d.ts +1 -1
- package/widgets/ui/storage-list/components/storage-list-item/storage-list-item.component.d.ts +1 -1
package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
|
2
|
+
import { TranslocoPipe } from '@jsverse/transloco';
|
|
3
|
+
import { CuiCheckboxModule } from '../../../../components/checkbox';
|
|
4
|
+
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
5
|
+
import { CuiSvgModule } from '../../../../components/svg';
|
|
6
|
+
import { CuiTooltipDirective } from '../../../../directives';
|
|
7
|
+
import { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../../checkbox/checkbox.component";
|
|
10
|
+
import * as i2 from "../../../svg/svg.component";
|
|
11
|
+
export class CuiMultiSelectFilterComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.filter = input.required();
|
|
14
|
+
this.removed = output();
|
|
15
|
+
this.changed = output();
|
|
16
|
+
this.currentValues = computed(() => {
|
|
17
|
+
const f = this.filter();
|
|
18
|
+
return f.value.type === 'multiselect' ? f.value.values : [];
|
|
19
|
+
});
|
|
20
|
+
this.currentLabels = computed(() => {
|
|
21
|
+
const f = this.filter();
|
|
22
|
+
if (f.value.type !== 'multiselect') {
|
|
23
|
+
return '';
|
|
24
|
+
}
|
|
25
|
+
const field = f.field;
|
|
26
|
+
return f.value.values
|
|
27
|
+
.map((val) => field.multiSelectOptions?.find((opt) => opt.value === val)?.label ?? val)
|
|
28
|
+
.join(', ');
|
|
29
|
+
});
|
|
30
|
+
this.hasValue = computed(() => this.currentValues().length > 0);
|
|
31
|
+
this.options = computed(() => {
|
|
32
|
+
const field = this.filter().field;
|
|
33
|
+
return field.multiSelectOptions ?? [];
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
onRemove() {
|
|
37
|
+
this.removed.emit(this.filter().id);
|
|
38
|
+
}
|
|
39
|
+
isOptionSelected(value) {
|
|
40
|
+
return this.currentValues().includes(value);
|
|
41
|
+
}
|
|
42
|
+
toggleOption(value) {
|
|
43
|
+
const f = this.filter();
|
|
44
|
+
if (f.value.type !== 'multiselect') {
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const currentValues = f.value.values;
|
|
48
|
+
const newValues = currentValues.includes(value)
|
|
49
|
+
? currentValues.filter((v) => v !== value)
|
|
50
|
+
: [...currentValues, value];
|
|
51
|
+
this.changed.emit({
|
|
52
|
+
...f,
|
|
53
|
+
value: { ...f.value, values: newValues }
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiMultiSelectFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
57
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiMultiSelectFilterComponent, isStandalone: true, selector: "cui-multiselect-filter", inputs: { filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"multiselect-filter__trigger\"\n [class.multiselect-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n>\n @if (hasValue()) {\n <span\n class=\"multiselect-filter__value\"\n [cuiTooltip]=\"currentLabels()\"\n >\n {{ currentLabels() }}\n </span>\n } @else {\n <span class=\"multiselect-filter__placeholder\">{{ 'SELECT_VALUES' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"multiselect-filter__dropdown\">\n @for (opt of options(); track opt.value) {\n <label class=\"multiselect-filter__option\">\n <input\n type=\"checkbox\"\n cuiCheckbox\n [checked]=\"isOptionSelected(opt.value)\"\n (change)=\"toggleOption(opt.value)\"\n />\n <span>{{ opt.label }}</span>\n </label>\n }\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.multiselect-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.multiselect-filter__trigger:hover{background:var(--cui-base-200)}.multiselect-filter__trigger:focus{outline:none}.multiselect-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.multiselect-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.multiselect-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiselect-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.multiselect-filter__dropdown{display:flex;flex-direction:column;gap:0;padding-top:4px;padding-bottom:4px;min-width:165px;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.multiselect-filter__option{display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:flex-start;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.multiselect-filter__option:hover{background:var(--cui-base-50)}.multiselect-filter__option span{font-weight:400;font-size:13px;line-height:16px;color:var(--cui-base-900)}\n"], dependencies: [{ kind: "ngmodule", type: CuiCheckboxModule }, { kind: "component", type: i1.CuiCheckboxComponent, selector: "input[type=\"checkbox\"][cuiCheckbox]" }, { kind: "directive", type: CuiDropdownDirective, selector: "[cuiDropdown]", inputs: ["cuiDropdown", "orientation"], outputs: ["isOpened"], exportAs: ["cuiDropdown"] }, { kind: "component", type: CuiFilterRemoveButtonComponent, selector: "cui-filter-remove-button", inputs: ["label"], outputs: ["removed"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
|
+
}
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiMultiSelectFilterComponent, decorators: [{
|
|
60
|
+
type: Component,
|
|
61
|
+
args: [{ selector: 'cui-multiselect-filter', standalone: true, imports: [
|
|
62
|
+
CuiCheckboxModule,
|
|
63
|
+
CuiDropdownDirective,
|
|
64
|
+
CuiFilterRemoveButtonComponent,
|
|
65
|
+
CuiSvgModule,
|
|
66
|
+
CuiTooltipDirective,
|
|
67
|
+
TranslocoPipe
|
|
68
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"multiselect-filter__trigger\"\n [class.multiselect-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n>\n @if (hasValue()) {\n <span\n class=\"multiselect-filter__value\"\n [cuiTooltip]=\"currentLabels()\"\n >\n {{ currentLabels() }}\n </span>\n } @else {\n <span class=\"multiselect-filter__placeholder\">{{ 'SELECT_VALUES' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"multiselect-filter__dropdown\">\n @for (opt of options(); track opt.value) {\n <label class=\"multiselect-filter__option\">\n <input\n type=\"checkbox\"\n cuiCheckbox\n [checked]=\"isOptionSelected(opt.value)\"\n (change)=\"toggleOption(opt.value)\"\n />\n <span>{{ opt.label }}</span>\n </label>\n }\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.multiselect-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.multiselect-filter__trigger:hover{background:var(--cui-base-200)}.multiselect-filter__trigger:focus{outline:none}.multiselect-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.multiselect-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.multiselect-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multiselect-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.multiselect-filter__dropdown{display:flex;flex-direction:column;gap:0;padding-top:4px;padding-bottom:4px;min-width:165px;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.multiselect-filter__option{display:flex;flex-direction:row;gap:8px;align-items:center;justify-content:flex-start;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.multiselect-filter__option:hover{background:var(--cui-base-50)}.multiselect-filter__option span{font-weight:400;font-size:13px;line-height:16px;color:var(--cui-base-900)}\n"] }]
|
|
69
|
+
}] });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multiselect-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/multiselect-filter/multiselect-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/multiselect-filter/multiselect-filter.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\nimport { TranslocoPipe } from '@jsverse/transloco';\n\nimport { CuiCheckboxModule } from '../../../../components/checkbox';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport type { CuiActiveFilter, CuiMultiSelectFilterField } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\n@Component({\n    selector: 'cui-multiselect-filter',\n    standalone: true,\n    imports: [\n        CuiCheckboxModule,\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiSvgModule,\n        CuiTooltipDirective,\n        TranslocoPipe\n    ],\n    templateUrl: './multiselect-filter.template.html',\n    styleUrls: ['./multiselect-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiMultiSelectFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly currentValues = computed(() => {\n        const f = this.filter();\n\n        return f.value.type === 'multiselect' ? f.value.values : [];\n    });\n\n    protected readonly currentLabels = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'multiselect') {\n            return '';\n        }\n\n        const field = f.field as CuiMultiSelectFilterField;\n\n        return f.value.values\n            .map((val) => field.multiSelectOptions?.find((opt) => opt.value === val)?.label ?? val)\n            .join(', ');\n    });\n\n    protected readonly hasValue = computed(() => this.currentValues().length > 0);\n\n    protected readonly options = computed(() => {\n        const field = this.filter().field as CuiMultiSelectFilterField;\n\n        return field.multiSelectOptions ?? [];\n    });\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected isOptionSelected(value: string): boolean {\n        return this.currentValues().includes(value);\n    }\n\n    protected toggleOption(value: string): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'multiselect') {\n            return;\n        }\n\n        const currentValues = f.value.values;\n        const newValues = currentValues.includes(value)\n            ? currentValues.filter((v) => v !== value)\n            : [...currentValues, value];\n\n        this.changed.emit({\n            ...f,\n            value: { ...f.value, values: newValues }\n        });\n    }\n}","<cui-filter-remove-button\n    [label]=\"filter().field.label | transloco\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"multiselect-filter__trigger\"\n    [class.multiselect-filter__trigger--active]=\"hasValue()\"\n    [cuiDropdown]=\"dropdownTpl\"\n>\n    @if (hasValue()) {\n        <span\n            class=\"multiselect-filter__value\"\n            [cuiTooltip]=\"currentLabels()\"\n        >\n            {{ currentLabels() }}\n        </span>\n    } @else {\n        <span class=\"multiselect-filter__placeholder\">{{ 'SELECT_VALUES' | transloco }}</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n    <div class=\"multiselect-filter__dropdown\">\n        @for (opt of options(); track opt.value) {\n            <label class=\"multiselect-filter__option\">\n                <input\n                    type=\"checkbox\"\n                    cuiCheckbox\n                    [checked]=\"isOptionSelected(opt.value)\"\n                    (change)=\"toggleOption(opt.value)\"\n                />\n                <span>{{ opt.label }}</span>\n            </label>\n        }\n    </div>\n</ng-template>"]}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
3
|
+
import { TranslocoPipe } from '@jsverse/transloco';
|
|
4
|
+
import { CuiButtonModule } from '../../../../components/button';
|
|
5
|
+
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
6
|
+
import { CuiInputNumberModule } from '../../../../components/input-number';
|
|
7
|
+
import { CuiSvgModule } from '../../../../components/svg';
|
|
8
|
+
import { CuiTooltipDirective } from '../../../../directives';
|
|
9
|
+
import { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../../button/button.component";
|
|
12
|
+
import * as i2 from "../../../input-number/input-number.component";
|
|
13
|
+
import * as i3 from "../../../../directives/text-field-controller/text-field-placeholder.directive";
|
|
14
|
+
import * as i4 from "../../../svg/svg.component";
|
|
15
|
+
import * as i5 from "@angular/forms";
|
|
16
|
+
export class CuiRangeFilterComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.filter = input.required();
|
|
19
|
+
this.removed = output();
|
|
20
|
+
this.changed = output();
|
|
21
|
+
this.tmpMin = signal(null);
|
|
22
|
+
this.tmpMax = signal(null);
|
|
23
|
+
this.currentMin = computed(() => {
|
|
24
|
+
const f = this.filter();
|
|
25
|
+
return f.value.type === 'range' ? f.value.min : null;
|
|
26
|
+
});
|
|
27
|
+
this.currentMax = computed(() => {
|
|
28
|
+
const f = this.filter();
|
|
29
|
+
return f.value.type === 'range' ? f.value.max : null;
|
|
30
|
+
});
|
|
31
|
+
this.hasValue = computed(() => this.currentMin() !== null || this.currentMax() !== null);
|
|
32
|
+
this.displayValue = computed(() => {
|
|
33
|
+
const min = this.currentMin();
|
|
34
|
+
const max = this.currentMax();
|
|
35
|
+
if (min !== null && max !== null) {
|
|
36
|
+
return `${min} – ${max}`;
|
|
37
|
+
}
|
|
38
|
+
if (min !== null) {
|
|
39
|
+
return `≥ ${min}`;
|
|
40
|
+
}
|
|
41
|
+
if (max !== null) {
|
|
42
|
+
return `≤ ${max}`;
|
|
43
|
+
}
|
|
44
|
+
return '';
|
|
45
|
+
});
|
|
46
|
+
this.minPlaceholder = computed(() => {
|
|
47
|
+
const field = this.filter().field;
|
|
48
|
+
return field.rangeConfig?.minPlaceholder ?? 'MIN';
|
|
49
|
+
});
|
|
50
|
+
this.maxPlaceholder = computed(() => {
|
|
51
|
+
const field = this.filter().field;
|
|
52
|
+
return field.rangeConfig?.maxPlaceholder ?? 'MAX';
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
onRemove() {
|
|
56
|
+
this.removed.emit(this.filter().id);
|
|
57
|
+
}
|
|
58
|
+
onDropdownOpened(isOpened) {
|
|
59
|
+
if (isOpened) {
|
|
60
|
+
this.tmpMin.set(this.currentMin());
|
|
61
|
+
this.tmpMax.set(this.currentMax());
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
onTmpMinChange(value) {
|
|
65
|
+
this.tmpMin.set(value);
|
|
66
|
+
}
|
|
67
|
+
onTmpMaxChange(value) {
|
|
68
|
+
this.tmpMax.set(value);
|
|
69
|
+
}
|
|
70
|
+
applyValue(dropdown) {
|
|
71
|
+
const f = this.filter();
|
|
72
|
+
if (f.value.type !== 'range') {
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const newValue = {
|
|
76
|
+
type: 'range',
|
|
77
|
+
min: this.tmpMin(),
|
|
78
|
+
max: this.tmpMax()
|
|
79
|
+
};
|
|
80
|
+
this.changed.emit({ ...f, value: newValue });
|
|
81
|
+
dropdown.close();
|
|
82
|
+
}
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiRangeFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiRangeFilterComponent, isStandalone: true, selector: "cui-range-filter", inputs: { filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"range-filter__trigger\"\n [class.range-filter__trigger_active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n (isOpened)=\"onDropdownOpened($event)\"\n>\n @if (hasValue()) {\n <span\n class=\"range-filter__value\"\n [cuiTooltip]=\"displayValue()\"\n >\n {{ displayValue() }}\n </span>\n } @else {\n <span class=\"range-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"range-filter__dropdown\">\n <div class=\"range-filter__label\">\n {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n </div>\n <div class=\"range-filter__inputs\">\n <cui-input-number\n [ngModel]=\"tmpMin()\"\n (ngModelChange)=\"onTmpMinChange($event)\"\n [cuiTextFieldPlaceholder]=\"minPlaceholder() | transloco\"\n />\n <span class=\"range-filter__separator\">\u2013</span>\n <cui-input-number\n [ngModel]=\"tmpMax()\"\n (ngModelChange)=\"onTmpMaxChange($event)\"\n [cuiTextFieldPlaceholder]=\"maxPlaceholder() | transloco\"\n />\n </div>\n <div class=\"range-filter__footer\">\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"secondary\"\n (click)=\"dropdown.close()\"\n >\n {{ 'CANCEL' | transloco }}\n </button>\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"action-cyan\"\n (click)=\"applyValue(dropdown)\"\n >\n {{ 'APPLY' | transloco }}\n </button>\n </div>\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.range-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.range-filter__trigger:hover{background:var(--cui-base-200)}.range-filter__trigger:focus{outline:none}.range-filter__trigger_active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.range-filter__trigger_active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.range-filter__value{font-weight:500;font-size:12px;line-height:14px;max-width:200px;overflow:hidden;color:var(--cui-base-900);text-overflow:ellipsis;white-space:nowrap}.range-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.range-filter__dropdown{display:flex;flex-direction:column;gap:12px;padding:8px;width:300px;max-width:calc(100vw - 16px);overflow:hidden;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026}.range-filter__label{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-900)}.range-filter__inputs{display:flex;flex-direction:row;gap:8px;align-items:center}.range-filter__separator{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-500)}.range-filter__footer{display:flex;flex-direction:row;gap:8px;justify-content:flex-end}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "theme", "size"] }, { kind: "directive", type: CuiDropdownDirective, selector: "[cuiDropdown]", inputs: ["cuiDropdown", "orientation"], outputs: ["isOpened"], exportAs: ["cuiDropdown"] }, { kind: "component", type: CuiFilterRemoveButtonComponent, selector: "cui-filter-remove-button", inputs: ["label"], outputs: ["removed"] }, { kind: "ngmodule", type: CuiInputNumberModule }, { kind: "component", type: i2.CuiInputNumberComponent, selector: "cui-input-number", inputs: ["precision", "min", "max"] }, { kind: "directive", type: i3.CuiTextFieldPlaceholderDirective, selector: "[cuiTextFieldPlaceholder]", inputs: ["cuiTextFieldPlaceholder"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i4.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
85
|
+
}
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiRangeFilterComponent, decorators: [{
|
|
87
|
+
type: Component,
|
|
88
|
+
args: [{ selector: 'cui-range-filter', standalone: true, imports: [
|
|
89
|
+
CuiButtonModule,
|
|
90
|
+
CuiDropdownDirective,
|
|
91
|
+
CuiFilterRemoveButtonComponent,
|
|
92
|
+
CuiInputNumberModule,
|
|
93
|
+
CuiSvgModule,
|
|
94
|
+
CuiTooltipDirective,
|
|
95
|
+
FormsModule,
|
|
96
|
+
TranslocoPipe
|
|
97
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"range-filter__trigger\"\n [class.range-filter__trigger_active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n (isOpened)=\"onDropdownOpened($event)\"\n>\n @if (hasValue()) {\n <span\n class=\"range-filter__value\"\n [cuiTooltip]=\"displayValue()\"\n >\n {{ displayValue() }}\n </span>\n } @else {\n <span class=\"range-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"range-filter__dropdown\">\n <div class=\"range-filter__label\">\n {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n </div>\n <div class=\"range-filter__inputs\">\n <cui-input-number\n [ngModel]=\"tmpMin()\"\n (ngModelChange)=\"onTmpMinChange($event)\"\n [cuiTextFieldPlaceholder]=\"minPlaceholder() | transloco\"\n />\n <span class=\"range-filter__separator\">\u2013</span>\n <cui-input-number\n [ngModel]=\"tmpMax()\"\n (ngModelChange)=\"onTmpMaxChange($event)\"\n [cuiTextFieldPlaceholder]=\"maxPlaceholder() | transloco\"\n />\n </div>\n <div class=\"range-filter__footer\">\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"secondary\"\n (click)=\"dropdown.close()\"\n >\n {{ 'CANCEL' | transloco }}\n </button>\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"action-cyan\"\n (click)=\"applyValue(dropdown)\"\n >\n {{ 'APPLY' | transloco }}\n </button>\n </div>\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.range-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.range-filter__trigger:hover{background:var(--cui-base-200)}.range-filter__trigger:focus{outline:none}.range-filter__trigger_active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.range-filter__trigger_active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.range-filter__value{font-weight:500;font-size:12px;line-height:14px;max-width:200px;overflow:hidden;color:var(--cui-base-900);text-overflow:ellipsis;white-space:nowrap}.range-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.range-filter__dropdown{display:flex;flex-direction:column;gap:12px;padding:8px;width:300px;max-width:calc(100vw - 16px);overflow:hidden;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026}.range-filter__label{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-900)}.range-filter__inputs{display:flex;flex-direction:row;gap:8px;align-items:center}.range-filter__separator{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-500)}.range-filter__footer{display:flex;flex-direction:row;gap:8px;justify-content:flex-end}\n"] }]
|
|
98
|
+
}] });
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/range-filter/range-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/range-filter/range-filter.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { TranslocoPipe } from '@jsverse/transloco';\n\nimport { CuiButtonModule } from '../../../../components/button';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiInputNumberModule } from '../../../../components/input-number';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport type { CuiActiveFilter, CuiFilterValue, CuiRangeFilterField } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\n@Component({\n    selector: 'cui-range-filter',\n    standalone: true,\n    imports: [\n        CuiButtonModule,\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiInputNumberModule,\n        CuiSvgModule,\n        CuiTooltipDirective,\n        FormsModule,\n        TranslocoPipe\n    ],\n    templateUrl: './range-filter.template.html',\n    styleUrls: ['./range-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiRangeFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly tmpMin = signal<number | null>(null);\n    protected readonly tmpMax = signal<number | null>(null);\n\n    protected readonly currentMin = computed(() => {\n        const f = this.filter();\n\n        return f.value.type === 'range' ? f.value.min : null;\n    });\n\n    protected readonly currentMax = computed(() => {\n        const f = this.filter();\n\n        return f.value.type === 'range' ? f.value.max : null;\n    });\n\n    protected readonly hasValue = computed(() => this.currentMin() !== null || this.currentMax() !== null);\n\n    protected readonly displayValue = computed(() => {\n        const min = this.currentMin();\n        const max = this.currentMax();\n\n        if (min !== null && max !== null) {\n            return `${min} – ${max}`;\n        }\n\n        if (min !== null) {\n            return `≥ ${min}`;\n        }\n\n        if (max !== null) {\n            return `≤ ${max}`;\n        }\n\n        return '';\n    });\n\n    protected readonly minPlaceholder = computed(() => {\n        const field = this.filter().field as CuiRangeFilterField;\n\n        return field.rangeConfig?.minPlaceholder ?? 'MIN';\n    });\n\n    protected readonly maxPlaceholder = computed(() => {\n        const field = this.filter().field as CuiRangeFilterField;\n\n        return field.rangeConfig?.maxPlaceholder ?? 'MAX';\n    });\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected onDropdownOpened(isOpened: boolean): void {\n        if (isOpened) {\n            this.tmpMin.set(this.currentMin());\n            this.tmpMax.set(this.currentMax());\n        }\n    }\n\n    protected onTmpMinChange(value: number | null): void {\n        this.tmpMin.set(value);\n    }\n\n    protected onTmpMaxChange(value: number | null): void {\n        this.tmpMax.set(value);\n    }\n\n    protected applyValue(dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'range') {\n            return;\n        }\n\n        const newValue: CuiFilterValue = {\n            type: 'range',\n            min: this.tmpMin(),\n            max: this.tmpMax()\n        };\n\n        this.changed.emit({ ...f, value: newValue });\n        dropdown.close();\n    }\n}","<cui-filter-remove-button\n    [label]=\"filter().field.label | transloco\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"range-filter__trigger\"\n    [class.range-filter__trigger_active]=\"hasValue()\"\n    [cuiDropdown]=\"dropdownTpl\"\n    #dropdown=\"cuiDropdown\"\n    (isOpened)=\"onDropdownOpened($event)\"\n>\n    @if (hasValue()) {\n        <span\n            class=\"range-filter__value\"\n            [cuiTooltip]=\"displayValue()\"\n        >\n            {{ displayValue() }}\n        </span>\n    } @else {\n        <span class=\"range-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n    <div class=\"range-filter__dropdown\">\n        <div class=\"range-filter__label\">\n            {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n        </div>\n        <div class=\"range-filter__inputs\">\n            <cui-input-number\n                [ngModel]=\"tmpMin()\"\n                (ngModelChange)=\"onTmpMinChange($event)\"\n                [cuiTextFieldPlaceholder]=\"minPlaceholder() | transloco\"\n            />\n            <span class=\"range-filter__separator\">–</span>\n            <cui-input-number\n                [ngModel]=\"tmpMax()\"\n                (ngModelChange)=\"onTmpMaxChange($event)\"\n                [cuiTextFieldPlaceholder]=\"maxPlaceholder() | transloco\"\n            />\n        </div>\n        <div class=\"range-filter__footer\">\n            <button\n                type=\"button\"\n                cuiButton\n                size=\"xs\"\n                appearance=\"secondary\"\n                (click)=\"dropdown.close()\"\n            >\n                {{ 'CANCEL' | transloco }}\n            </button>\n            <button\n                type=\"button\"\n                cuiButton\n                size=\"xs\"\n                appearance=\"action-cyan\"\n                (click)=\"applyValue(dropdown)\"\n            >\n                {{ 'APPLY' | transloco }}\n            </button>\n        </div>\n    </div>\n</ng-template>"]}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
|
2
|
+
import { TranslocoPipe } from '@jsverse/transloco';
|
|
3
|
+
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
4
|
+
import { CuiSvgModule } from '../../../../components/svg';
|
|
5
|
+
import { CuiTooltipDirective } from '../../../../directives';
|
|
6
|
+
import { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../../svg/svg.component";
|
|
9
|
+
export class CuiSelectFilterComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.filter = input.required();
|
|
12
|
+
this.removed = output();
|
|
13
|
+
this.changed = output();
|
|
14
|
+
this.currentValue = computed(() => {
|
|
15
|
+
const f = this.filter();
|
|
16
|
+
return f.value.type === 'select' ? f.value.value : null;
|
|
17
|
+
});
|
|
18
|
+
this.currentLabel = computed(() => {
|
|
19
|
+
const f = this.filter();
|
|
20
|
+
if (f.value.type !== 'select' || !f.value.value) {
|
|
21
|
+
return '';
|
|
22
|
+
}
|
|
23
|
+
const selectedValue = f.value.value;
|
|
24
|
+
const field = f.field;
|
|
25
|
+
return field.selectOptions?.find((opt) => opt.value === selectedValue)?.label ?? selectedValue;
|
|
26
|
+
});
|
|
27
|
+
this.hasValue = computed(() => !!this.currentValue());
|
|
28
|
+
this.options = computed(() => {
|
|
29
|
+
const field = this.filter().field;
|
|
30
|
+
return field.selectOptions ?? [];
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
onRemove() {
|
|
34
|
+
this.removed.emit(this.filter().id);
|
|
35
|
+
}
|
|
36
|
+
isOptionSelected(value) {
|
|
37
|
+
return this.currentValue() === value;
|
|
38
|
+
}
|
|
39
|
+
selectOption(value, dropdown) {
|
|
40
|
+
const f = this.filter();
|
|
41
|
+
if (f.value.type !== 'select') {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
this.changed.emit({
|
|
45
|
+
...f,
|
|
46
|
+
value: { ...f.value, value: f.value.value === value ? null : value }
|
|
47
|
+
});
|
|
48
|
+
dropdown.close();
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiSelectFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiSelectFilterComponent, isStandalone: true, selector: "cui-select-filter", inputs: { filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"select-filter__trigger\"\n [class.select-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n>\n @if (hasValue()) {\n <span\n class=\"select-filter__value\"\n [cuiTooltip]=\"currentLabel()\"\n >\n {{ currentLabel() }}\n </span>\n } @else {\n <span class=\"select-filter__placeholder\">{{ 'SELECT_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"select-filter__dropdown\">\n @for (opt of options(); track opt.value) {\n <button\n type=\"button\"\n class=\"select-filter__option\"\n [class.select-filter__option--selected]=\"isOptionSelected(opt.value)\"\n (click)=\"selectOption(opt.value, dropdown)\"\n >\n {{ opt.label }}\n </button>\n }\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.select-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.select-filter__trigger:hover{background:var(--cui-base-200)}.select-filter__trigger:focus{outline:none}.select-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.select-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.select-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.select-filter__dropdown{display:flex;flex-direction:column;gap:0;padding-top:4px;padding-bottom:4px;min-width:165px;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.select-filter__option{display:flex;flex-direction:row;gap:0;align-items:center;justify-content:flex-start;border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;font-weight:400;font-size:13px;line-height:16px;padding:8px 12px;width:100%;text-align:left;color:var(--cui-base-900);cursor:pointer;-webkit-user-select:none;user-select:none}.select-filter__option:hover{background:var(--cui-base-50)}.select-filter__option--selected{background:var(--cui-lavender-bg);font-weight:500}\n"], dependencies: [{ kind: "directive", type: CuiDropdownDirective, selector: "[cuiDropdown]", inputs: ["cuiDropdown", "orientation"], outputs: ["isOpened"], exportAs: ["cuiDropdown"] }, { kind: "component", type: CuiFilterRemoveButtonComponent, selector: "cui-filter-remove-button", inputs: ["label"], outputs: ["removed"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
52
|
+
}
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiSelectFilterComponent, decorators: [{
|
|
54
|
+
type: Component,
|
|
55
|
+
args: [{ selector: 'cui-select-filter', standalone: true, imports: [
|
|
56
|
+
CuiDropdownDirective,
|
|
57
|
+
CuiFilterRemoveButtonComponent,
|
|
58
|
+
CuiSvgModule,
|
|
59
|
+
CuiTooltipDirective,
|
|
60
|
+
TranslocoPipe
|
|
61
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"select-filter__trigger\"\n [class.select-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n>\n @if (hasValue()) {\n <span\n class=\"select-filter__value\"\n [cuiTooltip]=\"currentLabel()\"\n >\n {{ currentLabel() }}\n </span>\n } @else {\n <span class=\"select-filter__placeholder\">{{ 'SELECT_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"select-filter__dropdown\">\n @for (opt of options(); track opt.value) {\n <button\n type=\"button\"\n class=\"select-filter__option\"\n [class.select-filter__option--selected]=\"isOptionSelected(opt.value)\"\n (click)=\"selectOption(opt.value, dropdown)\"\n >\n {{ opt.label }}\n </button>\n }\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.select-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.select-filter__trigger:hover{background:var(--cui-base-200)}.select-filter__trigger:focus{outline:none}.select-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.select-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.select-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.select-filter__dropdown{display:flex;flex-direction:column;gap:0;padding-top:4px;padding-bottom:4px;min-width:165px;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.select-filter__option{display:flex;flex-direction:row;gap:0;align-items:center;justify-content:flex-start;border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;font-weight:400;font-size:13px;line-height:16px;padding:8px 12px;width:100%;text-align:left;color:var(--cui-base-900);cursor:pointer;-webkit-user-select:none;user-select:none}.select-filter__option:hover{background:var(--cui-base-50)}.select-filter__option--selected{background:var(--cui-lavender-bg);font-weight:500}\n"] }]
|
|
62
|
+
}] });
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/select-filter/select-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/select-filter/select-filter.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\nimport { TranslocoPipe } from '@jsverse/transloco';\n\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport type { CuiActiveFilter, CuiSelectFilterField } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\n@Component({\n    selector: 'cui-select-filter',\n    standalone: true,\n    imports: [\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiSvgModule,\n        CuiTooltipDirective,\n        TranslocoPipe\n    ],\n    templateUrl: './select-filter.template.html',\n    styleUrls: ['./select-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiSelectFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly currentValue = computed(() => {\n        const f = this.filter();\n\n        return f.value.type === 'select' ? f.value.value : null;\n    });\n\n    protected readonly currentLabel = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'select' || !f.value.value) {\n            return '';\n        }\n\n        const selectedValue = f.value.value;\n        const field = f.field as CuiSelectFilterField;\n\n        return field.selectOptions?.find((opt) => opt.value === selectedValue)?.label ?? selectedValue;\n    });\n\n    protected readonly hasValue = computed(() => !!this.currentValue());\n\n    protected readonly options = computed(() => {\n        const field = this.filter().field as CuiSelectFilterField;\n\n        return field.selectOptions ?? [];\n    });\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected isOptionSelected(value: string): boolean {\n        return this.currentValue() === value;\n    }\n\n    protected selectOption(value: string, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'select') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: { ...f.value, value: f.value.value === value ? null : value }\n        });\n        dropdown.close();\n    }\n}","<cui-filter-remove-button\n    [label]=\"filter().field.label | transloco\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"select-filter__trigger\"\n    [class.select-filter__trigger--active]=\"hasValue()\"\n    [cuiDropdown]=\"dropdownTpl\"\n    #dropdown=\"cuiDropdown\"\n>\n    @if (hasValue()) {\n        <span\n            class=\"select-filter__value\"\n            [cuiTooltip]=\"currentLabel()\"\n        >\n            {{ currentLabel() }}\n        </span>\n    } @else {\n        <span class=\"select-filter__placeholder\">{{ 'SELECT_VALUE' | transloco }}</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n    <div class=\"select-filter__dropdown\">\n        @for (opt of options(); track opt.value) {\n            <button\n                type=\"button\"\n                class=\"select-filter__option\"\n                [class.select-filter__option--selected]=\"isOptionSelected(opt.value)\"\n                (click)=\"selectOption(opt.value, dropdown)\"\n            >\n                {{ opt.label }}\n            </button>\n        }\n    </div>\n</ng-template>"]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
3
|
+
import { TranslocoPipe } from '@jsverse/transloco';
|
|
4
|
+
import { CuiButtonModule } from '../../../../components/button';
|
|
5
|
+
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
6
|
+
import { CuiInputModule } from '../../../../components/input-text';
|
|
7
|
+
import { CuiSvgModule } from '../../../../components/svg';
|
|
8
|
+
import { CuiTooltipDirective } from '../../../../directives';
|
|
9
|
+
import { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../../button/button.component";
|
|
12
|
+
import * as i2 from "../../../input-text/input-text.component";
|
|
13
|
+
import * as i3 from "../../../../directives/text-field-controller/text-field-placeholder.directive";
|
|
14
|
+
import * as i4 from "../../../svg/svg.component";
|
|
15
|
+
import * as i5 from "@angular/forms";
|
|
16
|
+
export class CuiStringFilterComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.filter = input.required();
|
|
19
|
+
this.removed = output();
|
|
20
|
+
this.changed = output();
|
|
21
|
+
this.tmpValue = signal('');
|
|
22
|
+
this.currentValue = computed(() => {
|
|
23
|
+
const f = this.filter();
|
|
24
|
+
return f.value.type === 'string' ? f.value.value : '';
|
|
25
|
+
});
|
|
26
|
+
this.hasValue = computed(() => !!this.currentValue());
|
|
27
|
+
}
|
|
28
|
+
onRemove() {
|
|
29
|
+
this.removed.emit(this.filter().id);
|
|
30
|
+
}
|
|
31
|
+
onDropdownOpened(opened) {
|
|
32
|
+
if (opened) {
|
|
33
|
+
this.tmpValue.set(this.currentValue());
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
onTmpValueChange(value) {
|
|
37
|
+
this.tmpValue.set(value);
|
|
38
|
+
}
|
|
39
|
+
applyValue(dropdown) {
|
|
40
|
+
const f = this.filter();
|
|
41
|
+
if (f.value.type !== 'string') {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
this.changed.emit({
|
|
45
|
+
...f,
|
|
46
|
+
value: { ...f.value, value: this.tmpValue() }
|
|
47
|
+
});
|
|
48
|
+
dropdown.close();
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiStringFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiStringFilterComponent, isStandalone: true, selector: "cui-string-filter", inputs: { filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"string-filter__trigger\"\n [class.string-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n (isOpened)=\"onDropdownOpened($event)\"\n>\n @if (hasValue()) {\n <span\n class=\"string-filter__value\"\n [cuiTooltip]=\"currentValue()\"\n >\n {{ currentValue() }}\n </span>\n } @else {\n <span class=\"string-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"string-filter__dropdown\">\n <div class=\"string-filter__label\">\n {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n </div>\n <cui-input-text\n [ngModel]=\"tmpValue()\"\n (ngModelChange)=\"onTmpValueChange($event)\"\n maxlength=\"25\"\n [cuiTextFieldPlaceholder]=\"'ENTER_VALUE' | transloco\"\n />\n <div class=\"string-filter__footer\">\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"secondary\"\n (click)=\"dropdown.close()\"\n >\n {{ 'CANCEL' | transloco }}\n </button>\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"action-cyan\"\n (click)=\"applyValue(dropdown)\"\n >\n {{ 'APPLY' | transloco }}\n </button>\n </div>\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.string-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.string-filter__trigger:hover{background:var(--cui-base-200)}.string-filter__trigger:focus{outline:none}.string-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.string-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.string-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.string-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.string-filter__dropdown{display:flex;flex-direction:column;gap:12px;padding:8px;width:300px;max-width:calc(100vw - 16px);background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.string-filter__label{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-900)}.string-filter__footer{display:flex;flex-direction:row;gap:8px;justify-content:flex-end}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: i1.CuiButtonComponent, selector: "button[cuiButton], a[cuiButton]", inputs: ["shape", "disabled", "isLoaderShown", "icon", "iconRight", "appearance", "theme", "size"] }, { kind: "directive", type: CuiDropdownDirective, selector: "[cuiDropdown]", inputs: ["cuiDropdown", "orientation"], outputs: ["isOpened"], exportAs: ["cuiDropdown"] }, { kind: "component", type: CuiFilterRemoveButtonComponent, selector: "cui-filter-remove-button", inputs: ["label"], outputs: ["removed"] }, { kind: "ngmodule", type: CuiInputModule }, { kind: "component", type: i2.CuiInputTextComponent, selector: "cui-input-text" }, { kind: "directive", type: i3.CuiTextFieldPlaceholderDirective, selector: "[cuiTextFieldPlaceholder]", inputs: ["cuiTextFieldPlaceholder"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i4.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "directive", type: CuiTooltipDirective, selector: "[cuiTooltip]:not(ng-container):not(ng-template)", inputs: ["cuiTooltipContext", "cuiTooltipAppearance", "cuiTooltip"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
52
|
+
}
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiStringFilterComponent, decorators: [{
|
|
54
|
+
type: Component,
|
|
55
|
+
args: [{ selector: 'cui-string-filter', standalone: true, imports: [
|
|
56
|
+
CuiButtonModule,
|
|
57
|
+
CuiDropdownDirective,
|
|
58
|
+
CuiFilterRemoveButtonComponent,
|
|
59
|
+
CuiInputModule,
|
|
60
|
+
CuiSvgModule,
|
|
61
|
+
CuiTooltipDirective,
|
|
62
|
+
FormsModule,
|
|
63
|
+
TranslocoPipe
|
|
64
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label | transloco\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"string-filter__trigger\"\n [class.string-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n (isOpened)=\"onDropdownOpened($event)\"\n>\n @if (hasValue()) {\n <span\n class=\"string-filter__value\"\n [cuiTooltip]=\"currentValue()\"\n >\n {{ currentValue() }}\n </span>\n } @else {\n <span class=\"string-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n <div class=\"string-filter__dropdown\">\n <div class=\"string-filter__label\">\n {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n </div>\n <cui-input-text\n [ngModel]=\"tmpValue()\"\n (ngModelChange)=\"onTmpValueChange($event)\"\n maxlength=\"25\"\n [cuiTextFieldPlaceholder]=\"'ENTER_VALUE' | transloco\"\n />\n <div class=\"string-filter__footer\">\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"secondary\"\n (click)=\"dropdown.close()\"\n >\n {{ 'CANCEL' | transloco }}\n </button>\n <button\n type=\"button\"\n cuiButton\n size=\"xs\"\n appearance=\"action-cyan\"\n (click)=\"applyValue(dropdown)\"\n >\n {{ 'APPLY' | transloco }}\n </button>\n </div>\n </div>\n</ng-template>", styles: [":host{display:inline-flex}.string-filter__trigger{padding:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:8px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-right-radius:8px;border-bottom-right-radius:8px;cursor:pointer}.string-filter__trigger:hover{background:var(--cui-base-200)}.string-filter__trigger:focus{outline:none}.string-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.string-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.string-filter__value{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.string-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.string-filter__dropdown{display:flex;flex-direction:column;gap:12px;padding:8px;width:300px;max-width:calc(100vw - 16px);background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.string-filter__label{font-weight:500;font-size:13px;line-height:16px;color:var(--cui-base-900)}.string-filter__footer{display:flex;flex-direction:row;gap:8px;justify-content:flex-end}\n"] }]
|
|
65
|
+
}] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"string-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/string-filter/string-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/string-filter/string-filter.template.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAEnD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAE7D,OAAO,EAAE,8BAA8B,EAAE,MAAM,wDAAwD,CAAC;;;;;;;AAmBxG,MAAM,OAAO,wBAAwB;IAjBrC;QAkBoB,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAmB,CAAC;QAC3C,YAAO,GAAG,MAAM,EAAU,CAAC;QAC3B,YAAO,GAAG,MAAM,EAAmB,CAAC;QAEjC,aAAQ,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAEtB,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC5C,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAExB,OAAO,CAAC,CAAC,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEgB,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;KA6BvE;IA3Ba,QAAQ;QACd,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;IACxC,CAAC;IAES,gBAAgB,CAAC,MAAe;QACtC,IAAI,MAAM,EAAE,CAAC;YACT,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAC3C,CAAC;IACL,CAAC;IAES,gBAAgB,CAAC,KAAa;QACpC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAES,UAAU,CAAC,QAA8B;QAC/C,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAExB,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC5B,OAAO;QACX,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YACd,GAAG,CAAC;YACJ,KAAK,EAAE,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE;SAChD,CAAC,CAAC;QACH,QAAQ,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;+GAzCQ,wBAAwB;mGAAxB,wBAAwB,wQC7BrC,kyDA0Dc,62CD1CN,eAAe,oOACf,oBAAoB,oJACpB,8BAA8B,6GAC9B,cAAc,+PACd,YAAY,wKACZ,mBAAmB,gKACnB,WAAW,6fACX,aAAa;;4FAMR,wBAAwB;kBAjBpC,SAAS;+BACI,mBAAmB,cACjB,IAAI,WACP;wBACL,eAAe;wBACf,oBAAoB;wBACpB,8BAA8B;wBAC9B,cAAc;wBACd,YAAY;wBACZ,mBAAmB;wBACnB,WAAW;wBACX,aAAa;qBAChB,mBAGgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { TranslocoPipe } from '@jsverse/transloco';\n\nimport { CuiButtonModule } from '../../../../components/button';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiInputModule } from '../../../../components/input-text';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport type { CuiActiveFilter } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\n@Component({\n    selector: 'cui-string-filter',\n    standalone: true,\n    imports: [\n        CuiButtonModule,\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiInputModule,\n        CuiSvgModule,\n        CuiTooltipDirective,\n        FormsModule,\n        TranslocoPipe\n    ],\n    templateUrl: './string-filter.template.html',\n    styleUrls: ['./string-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiStringFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly tmpValue = signal('');\n\n    protected readonly currentValue = computed(() => {\n        const f = this.filter();\n\n        return f.value.type === 'string' ? f.value.value : '';\n    });\n\n    protected readonly hasValue = computed(() => !!this.currentValue());\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected onDropdownOpened(opened: boolean): void {\n        if (opened) {\n            this.tmpValue.set(this.currentValue());\n        }\n    }\n\n    protected onTmpValueChange(value: string): void {\n        this.tmpValue.set(value);\n    }\n\n    protected applyValue(dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'string') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: { ...f.value, value: this.tmpValue() }\n        });\n        dropdown.close();\n    }\n}","<cui-filter-remove-button\n    [label]=\"filter().field.label | transloco\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"string-filter__trigger\"\n    [class.string-filter__trigger--active]=\"hasValue()\"\n    [cuiDropdown]=\"dropdownTpl\"\n    #dropdown=\"cuiDropdown\"\n    (isOpened)=\"onDropdownOpened($event)\"\n>\n    @if (hasValue()) {\n        <span\n            class=\"string-filter__value\"\n            [cuiTooltip]=\"currentValue()\"\n        >\n            {{ currentValue() }}\n        </span>\n    } @else {\n        <span class=\"string-filter__placeholder\">{{ 'ENTER_VALUE' | transloco }}</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #dropdownTpl>\n    <div class=\"string-filter__dropdown\">\n        <div class=\"string-filter__label\">\n            {{ 'FILTER_BY' | transloco: { field: filter().field.label | transloco } }}\n        </div>\n        <cui-input-text\n            [ngModel]=\"tmpValue()\"\n            (ngModelChange)=\"onTmpValueChange($event)\"\n            maxlength=\"25\"\n            [cuiTextFieldPlaceholder]=\"'ENTER_VALUE' | transloco\"\n        />\n        <div class=\"string-filter__footer\">\n            <button\n                type=\"button\"\n                cuiButton\n                size=\"xs\"\n                appearance=\"secondary\"\n                (click)=\"dropdown.close()\"\n            >\n                {{ 'CANCEL' | transloco }}\n            </button>\n            <button\n                type=\"button\"\n                cuiButton\n                size=\"xs\"\n                appearance=\"action-cyan\"\n                (click)=\"applyValue(dropdown)\"\n            >\n                {{ 'APPLY' | transloco }}\n            </button>\n        </div>\n    </div>\n</ng-template>"]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';
|
|
2
|
+
import { CuiAddFilterButtonComponent, CuiDateFilterComponent, CuiFilterRemoveButtonComponent, CuiMultiSelectFilterComponent, CuiRangeFilterComponent, CuiSelectFilterComponent, CuiStringFilterComponent } from './components';
|
|
3
|
+
import { buildDefaultValue, buildOutputObject } from './filter-bar.utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class CuiFilterBarComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.fields = input.required();
|
|
8
|
+
this.filterChange = output();
|
|
9
|
+
this._filters = signal([]);
|
|
10
|
+
this.availableFields = computed(() => {
|
|
11
|
+
const usedIds = new Set(this._filters().map(f => f.id));
|
|
12
|
+
return this.fields().filter(f => !usedIds.has(f.id));
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
selectField(field) {
|
|
16
|
+
const newFilter = {
|
|
17
|
+
id: crypto.randomUUID(),
|
|
18
|
+
field,
|
|
19
|
+
value: buildDefaultValue(field)
|
|
20
|
+
};
|
|
21
|
+
this._filters.set([...this._filters(), newFilter]);
|
|
22
|
+
this.emitFilterChange();
|
|
23
|
+
}
|
|
24
|
+
onFilterChanged(updated) {
|
|
25
|
+
const next = this._filters().map(f => (f.id === updated.id ? updated : f));
|
|
26
|
+
this._filters.set(next);
|
|
27
|
+
this.emitFilterChange();
|
|
28
|
+
}
|
|
29
|
+
onFilterRemoved(id) {
|
|
30
|
+
const next = this._filters().filter(f => f.id !== id);
|
|
31
|
+
this._filters.set(next);
|
|
32
|
+
this.emitFilterChange();
|
|
33
|
+
}
|
|
34
|
+
emitFilterChange() {
|
|
35
|
+
this.filterChange.emit(buildOutputObject(this._filters()));
|
|
36
|
+
}
|
|
37
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiFilterBarComponent, isStandalone: true, selector: "cui-filter-bar", inputs: { fields: { classPropertyName: "fields", publicName: "fields", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "<div class=\"cui-filter-bar\">\n <div class=\"cui-filter-bar__list\">\n @for (filter of _filters(); track filter.id) {\n @switch (filter.field.type) {\n @case ('string') {\n <cui-string-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('date') {\n <cui-date-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('range') {\n <cui-range-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('select') {\n <cui-select-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('multiselect') {\n <cui-multiselect-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n }\n }\n\n @if (availableFields().length > 0) {\n <cui-add-filter-button\n [availableFields]=\"availableFields()\"\n (fieldSelected)=\"selectField($event)\"\n />\n }\n </div>\n</div>\n", styles: [".cui-filter-bar{display:flex;flex-direction:row;gap:12px}.cui-filter-bar__list{display:flex;flex-direction:row;gap:8px;flex-wrap:wrap}\n"], dependencies: [{ kind: "component", type: CuiAddFilterButtonComponent, selector: "cui-add-filter-button", inputs: ["availableFields"], outputs: ["fieldSelected"] }, { kind: "component", type: CuiDateFilterComponent, selector: "cui-date-filter", inputs: ["filter"], outputs: ["removed", "changed"] }, { kind: "component", type: CuiMultiSelectFilterComponent, selector: "cui-multiselect-filter", inputs: ["filter"], outputs: ["removed", "changed"] }, { kind: "component", type: CuiRangeFilterComponent, selector: "cui-range-filter", inputs: ["filter"], outputs: ["removed", "changed"] }, { kind: "component", type: CuiSelectFilterComponent, selector: "cui-select-filter", inputs: ["filter"], outputs: ["removed", "changed"] }, { kind: "component", type: CuiStringFilterComponent, selector: "cui-string-filter", inputs: ["filter"], outputs: ["removed", "changed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
39
|
+
}
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarComponent, decorators: [{
|
|
41
|
+
type: Component,
|
|
42
|
+
args: [{ selector: 'cui-filter-bar', standalone: true, imports: [
|
|
43
|
+
CuiAddFilterButtonComponent,
|
|
44
|
+
CuiDateFilterComponent,
|
|
45
|
+
CuiFilterRemoveButtonComponent,
|
|
46
|
+
CuiMultiSelectFilterComponent,
|
|
47
|
+
CuiRangeFilterComponent,
|
|
48
|
+
CuiSelectFilterComponent,
|
|
49
|
+
CuiStringFilterComponent
|
|
50
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cui-filter-bar\">\n <div class=\"cui-filter-bar__list\">\n @for (filter of _filters(); track filter.id) {\n @switch (filter.field.type) {\n @case ('string') {\n <cui-string-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('date') {\n <cui-date-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('range') {\n <cui-range-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('select') {\n <cui-select-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n @case ('multiselect') {\n <cui-multiselect-filter\n [filter]=\"filter\"\n (changed)=\"onFilterChanged($event)\"\n (removed)=\"onFilterRemoved($event)\"\n />\n }\n }\n }\n\n @if (availableFields().length > 0) {\n <cui-add-filter-button\n [availableFields]=\"availableFields()\"\n (fieldSelected)=\"selectField($event)\"\n />\n }\n </div>\n</div>\n", styles: [".cui-filter-bar{display:flex;flex-direction:row;gap:12px}.cui-filter-bar__list{display:flex;flex-direction:row;gap:8px;flex-wrap:wrap}\n"] }]
|
|
51
|
+
}] });
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/filter-bar/filter-bar.component.ts","../../../../../projects/core/components/filter-bar/filter-bar.template.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEpG,OAAO,EACH,2BAA2B,EAC3B,sBAAsB,EACtB,8BAA8B,EAC9B,6BAA6B,EAC7B,uBAAuB,EACvB,wBAAwB,EACxB,wBAAwB,EAC3B,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;;AAkB1E,MAAM,OAAO,qBAAqB;IAhBlC;QAiBa,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAoB,CAAC;QAE5C,iBAAY,GAAG,MAAM,EAA2B,CAAC;QAEjD,aAAQ,GAAG,MAAM,CAAoB,EAAE,CAAC,CAAC;QAEzC,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrC,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACxD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;KA4BN;IA1Ba,WAAW,CAAC,KAAqB;QACvC,MAAM,SAAS,GAAoB;YAC/B,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE;YACvB,KAAK;YACL,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC;SAClC,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAES,eAAe,CAAC,OAAwB;QAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAES,eAAe,CAAC,EAAU;QAChC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACxB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC/D,CAAC;+GArCQ,qBAAqB;mGAArB,qBAAqB,2PC9BlC,42DAkDA,kMDhCQ,2BAA2B,2HAC3B,sBAAsB,iHAEtB,6BAA6B,wHAC7B,uBAAuB,kHACvB,wBAAwB,mHACxB,wBAAwB;;4FAMnB,qBAAqB;kBAhBjC,SAAS;+BACI,gBAAgB,cACd,IAAI,WACP;wBACL,2BAA2B;wBAC3B,sBAAsB;wBACtB,8BAA8B;wBAC9B,6BAA6B;wBAC7B,uBAAuB;wBACvB,wBAAwB;wBACxB,wBAAwB;qBAC3B,mBAGgB,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';\n\nimport {\n    CuiAddFilterButtonComponent,\n    CuiDateFilterComponent,\n    CuiFilterRemoveButtonComponent,\n    CuiMultiSelectFilterComponent,\n    CuiRangeFilterComponent,\n    CuiSelectFilterComponent,\n    CuiStringFilterComponent\n} from './components';\nimport type { CuiActiveFilter, CuiFilterField } from './filter-bar.interfaces';\nimport { buildDefaultValue, buildOutputObject } from './filter-bar.utils';\n\n@Component({\n    selector: 'cui-filter-bar',\n    standalone: true,\n    imports: [\n        CuiAddFilterButtonComponent,\n        CuiDateFilterComponent,\n        CuiFilterRemoveButtonComponent,\n        CuiMultiSelectFilterComponent,\n        CuiRangeFilterComponent,\n        CuiSelectFilterComponent,\n        CuiStringFilterComponent\n    ],\n    templateUrl: './filter-bar.template.html',\n    styleUrls: ['./filter-bar.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiFilterBarComponent {\n    readonly fields = input.required<CuiFilterField[]>();\n\n    readonly filterChange = output<Record<string, unknown>>();\n\n    readonly _filters = signal<CuiActiveFilter[]>([]);\n\n    readonly availableFields = computed(() => {\n        const usedIds = new Set(this._filters().map(f => f.id));\n        return this.fields().filter(f => !usedIds.has(f.id));\n    });\n\n    protected selectField(field: CuiFilterField): void {\n        const newFilter: CuiActiveFilter = {\n            id: crypto.randomUUID(),\n            field,\n            value: buildDefaultValue(field)\n        };\n\n        this._filters.set([...this._filters(), newFilter]);\n        this.emitFilterChange();\n    }\n\n    protected onFilterChanged(updated: CuiActiveFilter): void {\n        const next = this._filters().map(f => (f.id === updated.id ? updated : f));\n        this._filters.set(next);\n        this.emitFilterChange();\n    }\n\n    protected onFilterRemoved(id: string): void {\n        const next = this._filters().filter(f => f.id !== id);\n        this._filters.set(next);\n        this.emitFilterChange();\n    }\n\n    private emitFilterChange(): void {\n        this.filterChange.emit(buildOutputObject(this._filters()));\n    }\n}\n","<div class=\"cui-filter-bar\">\n    <div class=\"cui-filter-bar__list\">\n        @for (filter of _filters(); track filter.id) {\n            @switch (filter.field.type) {\n                @case ('string') {\n                    <cui-string-filter\n                        [filter]=\"filter\"\n                        (changed)=\"onFilterChanged($event)\"\n                        (removed)=\"onFilterRemoved($event)\"\n                    />\n                }\n                @case ('date') {\n                    <cui-date-filter\n                        [filter]=\"filter\"\n                        (changed)=\"onFilterChanged($event)\"\n                        (removed)=\"onFilterRemoved($event)\"\n                    />\n                }\n                @case ('range') {\n                    <cui-range-filter\n                        [filter]=\"filter\"\n                        (changed)=\"onFilterChanged($event)\"\n                        (removed)=\"onFilterRemoved($event)\"\n                    />\n                }\n                @case ('select') {\n                    <cui-select-filter\n                        [filter]=\"filter\"\n                        (changed)=\"onFilterChanged($event)\"\n                        (removed)=\"onFilterRemoved($event)\"\n                    />\n                }\n                @case ('multiselect') {\n                    <cui-multiselect-filter\n                        [filter]=\"filter\"\n                        (changed)=\"onFilterChanged($event)\"\n                        (removed)=\"onFilterRemoved($event)\"\n                    />\n                }\n            }\n        }\n\n        @if (availableFields().length > 0) {\n            <cui-add-filter-button\n                [availableFields]=\"availableFields()\"\n                (fieldSelected)=\"selectField($event)\"\n            />\n        }\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// --- Public types (exported in public API) ---
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci5pbnRlcmZhY2VzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvZmlsdGVyLWJhci5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGdEQUFnRCIsInNvdXJjZXNDb250ZW50IjpbIi8vIC0tLSBQdWJsaWMgdHlwZXMgKGV4cG9ydGVkIGluIHB1YmxpYyBBUEkpIC0tLVxuXG5leHBvcnQgaW50ZXJmYWNlIEN1aUJhc2VGaWx0ZXJGaWVsZCB7XG4gICAgcmVhZG9ubHkgaWQ6IHN0cmluZztcbiAgICByZWFkb25seSBsYWJlbDogc3RyaW5nO1xuICAgIHJlYWRvbmx5IG9wZXJhdG9yTGFiZWxzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDdWlTdHJpbmdGaWx0ZXJGaWVsZCBleHRlbmRzIEN1aUJhc2VGaWx0ZXJGaWVsZCB7XG4gICAgcmVhZG9ubHkgdHlwZTogJ3N0cmluZyc7XG4gICAgcmVhZG9ubHkgb3V0cHV0TWFwcGluZzogQ3VpU3RyaW5nT3V0cHV0TWFwcGluZztcbiAgICByZWFkb25seSBzdHJpbmdPcGVyYXRvcnM/OiBDdWlTdHJpbmdPcGVyYXRvcltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEN1aVNlbGVjdEZpbHRlckZpZWxkIGV4dGVuZHMgQ3VpQmFzZUZpbHRlckZpZWxkIHtcbiAgICByZWFkb25seSB0eXBlOiAnc2VsZWN0JztcbiAgICByZWFkb25seSBvdXRwdXRNYXBwaW5nOiBDdWlTZWxlY3RPdXRwdXRNYXBwaW5nO1xuICAgIHJlYWRvbmx5IHNlbGVjdE9wdGlvbnM6IEN1aUZpbHRlck9wdGlvbltdO1xuICAgIHJlYWRvbmx5IHNlbGVjdE9wZXJhdG9ycz86IEN1aVNlbGVjdE9wZXJhdG9yW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VpTXVsdGlTZWxlY3RGaWx0ZXJGaWVsZCBleHRlbmRzIEN1aUJhc2VGaWx0ZXJGaWVsZCB7XG4gICAgcmVhZG9ubHkgdHlwZTogJ211bHRpc2VsZWN0JztcbiAgICByZWFkb25seSBvdXRwdXRNYXBwaW5nOiBDdWlNdWx0aVNlbGVjdE91dHB1dE1hcHBpbmc7XG4gICAgcmVhZG9ubHkgbXVsdGlTZWxlY3RPcHRpb25zOiBDdWlGaWx0ZXJPcHRpb25bXTtcbiAgICByZWFkb25seSBtdWx0aVNlbGVjdE9wZXJhdG9ycz86IEN1aU11bHRpU2VsZWN0T3BlcmF0b3JbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDdWlEYXRlRmlsdGVyRmllbGQgZXh0ZW5kcyBDdWlCYXNlRmlsdGVyRmllbGQge1xuICAgIHJlYWRvbmx5IHR5cGU6ICdkYXRlJztcbiAgICByZWFkb25seSBvdXRwdXRNYXBwaW5nOiBDdWlEYXRlT3V0cHV0TWFwcGluZztcbiAgICByZWFkb25seSBkYXRlT3BlcmF0b3JzPzogQ3VpRGF0ZU9wZXJhdG9yW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VpUmFuZ2VGaWx0ZXJGaWVsZCBleHRlbmRzIEN1aUJhc2VGaWx0ZXJGaWVsZCB7XG4gICAgcmVhZG9ubHkgdHlwZTogJ3JhbmdlJztcbiAgICByZWFkb25seSBvdXRwdXRNYXBwaW5nOiBDdWlSYW5nZU91dHB1dE1hcHBpbmc7XG4gICAgcmVhZG9ubHkgcmFuZ2VDb25maWc/OiB7IHJlYWRvbmx5IG1pblBsYWNlaG9sZGVyPzogc3RyaW5nOyByZWFkb25seSBtYXhQbGFjZWhvbGRlcj86IHN0cmluZyB9O1xufVxuXG5leHBvcnQgdHlwZSBDdWlGaWx0ZXJGaWVsZCA9XG4gICAgfCBDdWlTdHJpbmdGaWx0ZXJGaWVsZFxuICAgIHwgQ3VpU2VsZWN0RmlsdGVyRmllbGRcbiAgICB8IEN1aU11bHRpU2VsZWN0RmlsdGVyRmllbGRcbiAgICB8IEN1aURhdGVGaWx0ZXJGaWVsZFxuICAgIHwgQ3VpUmFuZ2VGaWx0ZXJGaWVsZDtcblxuZXhwb3J0IHR5cGUgQ3VpU3RyaW5nT3V0cHV0TWFwcGluZyA9IHsgcmVhZG9ubHkgdmFsdWU6IHN0cmluZyB9O1xuZXhwb3J0IHR5cGUgQ3VpU2VsZWN0T3V0cHV0TWFwcGluZyA9IHsgcmVhZG9ubHkgdmFsdWU6IHN0cmluZyB9O1xuZXhwb3J0IHR5cGUgQ3VpTXVsdGlTZWxlY3RPdXRwdXRNYXBwaW5nID0geyByZWFkb25seSB2YWx1ZXM6IHN0cmluZyB9O1xuZXhwb3J0IHR5cGUgQ3VpRGF0ZU91dHB1dE1hcHBpbmcgPSB7IHJlYWRvbmx5IHN0YXJ0OiBzdHJpbmc7IHJlYWRvbmx5IGVuZDogc3RyaW5nIH07XG5leHBvcnQgdHlwZSBDdWlSYW5nZU91dHB1dE1hcHBpbmcgPSB7IHJlYWRvbmx5IG1pbjogc3RyaW5nOyByZWFkb25seSBtYXg6IHN0cmluZyB9O1xuXG5leHBvcnQgaW50ZXJmYWNlIEN1aUZpbHRlck9wdGlvbiB7XG4gICAgcmVhZG9ubHkgdmFsdWU6IHN0cmluZztcbiAgICByZWFkb25seSBsYWJlbDogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBDdWlTdHJpbmdPcGVyYXRvciA9ICdjb250YWlucycgfCAnZXF1YWxzJyB8ICdzdGFydHNXaXRoJyB8ICdlbmRzV2l0aCc7XG5leHBvcnQgdHlwZSBDdWlTZWxlY3RPcGVyYXRvciA9ICdlcXVhbHMnIHwgJ25vdEVxdWFscyc7XG5leHBvcnQgdHlwZSBDdWlNdWx0aVNlbGVjdE9wZXJhdG9yID0gJ2luJyB8ICdub3RJbicgfCAnY29udGFpbnNBbGwnO1xuZXhwb3J0IHR5cGUgQ3VpRGF0ZU9wZXJhdG9yID0gJ2JldHdlZW4nIHwgJ29uJyB8ICdhZnRlcicgfCAnYmVmb3JlJztcblxuLy8gLS0tIEludGVybmFsIHR5cGVzIChOT1QgZXhwb3J0ZWQgaW4gcHVibGljIEFQSSkgLS0tXG5cbmV4cG9ydCB0eXBlIEN1aUZpbHRlclZhbHVlID1cbiAgICB8IHsgcmVhZG9ubHkgdHlwZTogJ3N0cmluZyc7IHJlYWRvbmx5IG9wZXJhdG9yOiBDdWlTdHJpbmdPcGVyYXRvcjsgcmVhZG9ubHkgdmFsdWU6IHN0cmluZyB9XG4gICAgfCB7IHJlYWRvbmx5IHR5cGU6ICdzZWxlY3QnOyByZWFkb25seSBvcGVyYXRvcjogQ3VpU2VsZWN0T3BlcmF0b3I7IHJlYWRvbmx5IHZhbHVlOiBzdHJpbmcgfCBudWxsIH1cbiAgICB8IHsgcmVhZG9ubHkgdHlwZTogJ211bHRpc2VsZWN0JzsgcmVhZG9ubHkgb3BlcmF0b3I6IEN1aU11bHRpU2VsZWN0T3BlcmF0b3I7IHJlYWRvbmx5IHZhbHVlczogc3RyaW5nW10gfVxuICAgIHwgeyByZWFkb25seSB0eXBlOiAnZGF0ZSc7IHJlYWRvbmx5IG9wZXJhdG9yOiBDdWlEYXRlT3BlcmF0b3I7IHJlYWRvbmx5IHZhbHVlOiBEYXRlIHwgbnVsbDsgcmVhZG9ubHkgcmFuZ2VTdGFydDogRGF0ZSB8IG51bGw7IHJlYWRvbmx5IHJhbmdlRW5kOiBEYXRlIHwgbnVsbCB9XG4gICAgfCB7IHJlYWRvbmx5IHR5cGU6ICdyYW5nZSc7IHJlYWRvbmx5IG1pbjogbnVtYmVyIHwgbnVsbDsgcmVhZG9ubHkgbWF4OiBudW1iZXIgfCBudWxsIH07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ3VpQWN0aXZlRmlsdGVyIHtcbiAgICByZWFkb25seSBpZDogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGZpZWxkOiBDdWlGaWx0ZXJGaWVsZDtcbiAgICByZWFkb25seSB2YWx1ZTogQ3VpRmlsdGVyVmFsdWU7XG59XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CuiFilterBarComponent } from './filter-bar.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class CuiFilterBarModule {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarModule, imports: [CuiFilterBarComponent], exports: [CuiFilterBarComponent] }); }
|
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarModule, imports: [CuiFilterBarComponent] }); }
|
|
8
|
+
}
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterBarModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
imports: [CuiFilterBarComponent],
|
|
13
|
+
exports: [CuiFilterBarComponent]
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9maWx0ZXItYmFyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU0vRCxNQUFNLE9BQU8sa0JBQWtCOytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixZQUhqQixxQkFBcUIsYUFDckIscUJBQXFCO2dIQUV0QixrQkFBa0IsWUFIakIscUJBQXFCOzs0RkFHdEIsa0JBQWtCO2tCQUo5QixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDbkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBDdWlGaWx0ZXJCYXJDb21wb25lbnQgfSBmcm9tICcuL2ZpbHRlci1iYXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ3VpRmlsdGVyQmFyQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbQ3VpRmlsdGVyQmFyQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBDdWlGaWx0ZXJCYXJNb2R1bGUge31cbiJdfQ==
|