@cuby-ui/core 0.0.561 → 0.0.563
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/filter-bar/components/add-filter-button/add-filter-button.component.d.ts +2 -1
- package/components/filter-bar/components/date-filter/date-filter.component.d.ts +3 -2
- package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts +3 -2
- package/components/filter-bar/components/range-filter/range-filter.component.d.ts +3 -2
- package/components/filter-bar/components/select-filter/select-filter.component.d.ts +3 -2
- package/components/filter-bar/components/string-filter/string-filter.component.d.ts +3 -2
- package/components/filter-bar/filter-bar.component.d.ts +3 -2
- package/components/filter-bar/filter-bar.interfaces.d.ts +10 -0
- package/components/filter-bar/index.d.ts +2 -1
- package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs +4 -4
- package/esm2022/components/filter-bar/components/date-filter/date-filter.component.mjs +3 -2
- package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs +5 -6
- package/esm2022/components/filter-bar/components/range-filter/range-filter.component.mjs +5 -6
- package/esm2022/components/filter-bar/components/select-filter/select-filter.component.mjs +5 -6
- package/esm2022/components/filter-bar/components/string-filter/string-filter.component.mjs +5 -6
- package/esm2022/components/filter-bar/filter-bar.component.mjs +5 -3
- package/esm2022/components/filter-bar/filter-bar.interfaces.mjs +10 -2
- package/esm2022/components/filter-bar/index.mjs +2 -1
- package/fesm2022/cuby-ui-core.mjs +36 -22
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/package.json +4 -4
|
@@ -3,8 +3,9 @@ import type { CuiFilterField } from '../../filter-bar.interfaces';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class CuiAddFilterButtonComponent {
|
|
5
5
|
readonly availableFields: import("@angular/core").InputSignal<CuiFilterField[]>;
|
|
6
|
+
readonly addFilterLabel: import("@angular/core").InputSignal<string>;
|
|
6
7
|
readonly fieldSelected: import("@angular/core").OutputEmitterRef<CuiFilterField>;
|
|
7
8
|
protected selectField(field: CuiFilterField, dropdown: CuiDropdownDirective): void;
|
|
8
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiAddFilterButtonComponent, never>;
|
|
9
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiAddFilterButtonComponent, "cui-add-filter-button", never, { "availableFields": { "alias": "availableFields"; "required": true; "isSignal": true; }; }, { "fieldSelected": "fieldSelected"; }, never, never, true, never>;
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiAddFilterButtonComponent, "cui-add-filter-button", never, { "availableFields": { "alias": "availableFields"; "required": true; "isSignal": true; }; "addFilterLabel": { "alias": "addFilterLabel"; "required": false; "isSignal": true; }; }, { "fieldSelected": "fieldSelected"; }, never, never, true, never>;
|
|
10
11
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
2
|
-
import type { CuiActiveFilter, CuiDateOperator } from '../../filter-bar.interfaces';
|
|
2
|
+
import type { CuiActiveFilter, CuiDateOperator, CuiFilterBarTranslations } from '../../filter-bar.interfaces';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
interface OperatorOption {
|
|
5
5
|
value: CuiDateOperator;
|
|
@@ -7,6 +7,7 @@ interface OperatorOption {
|
|
|
7
7
|
}
|
|
8
8
|
export declare class CuiDateFilterComponent {
|
|
9
9
|
readonly filter: import("@angular/core").InputSignal<CuiActiveFilter>;
|
|
10
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
10
11
|
readonly removed: import("@angular/core").OutputEmitterRef<string>;
|
|
11
12
|
readonly changed: import("@angular/core").OutputEmitterRef<CuiActiveFilter>;
|
|
12
13
|
protected readonly operatorOptions: import("@angular/core").Signal<OperatorOption[]>;
|
|
@@ -27,6 +28,6 @@ export declare class CuiDateFilterComponent {
|
|
|
27
28
|
protected onSingleDateSelected(date: Date, dropdown: CuiDropdownDirective): void;
|
|
28
29
|
private formatDate;
|
|
29
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiDateFilterComponent, never>;
|
|
30
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiDateFilterComponent, "cui-date-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
31
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiDateFilterComponent, "cui-date-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
31
32
|
}
|
|
32
33
|
export {};
|
package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import type { CuiActiveFilter } from '../../filter-bar.interfaces';
|
|
1
|
+
import type { CuiActiveFilter, CuiFilterBarTranslations } from '../../filter-bar.interfaces';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class CuiMultiSelectFilterComponent {
|
|
4
4
|
readonly filter: import("@angular/core").InputSignal<CuiActiveFilter>;
|
|
5
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
5
6
|
readonly removed: import("@angular/core").OutputEmitterRef<string>;
|
|
6
7
|
readonly changed: import("@angular/core").OutputEmitterRef<CuiActiveFilter>;
|
|
7
8
|
protected readonly currentValues: import("@angular/core").Signal<string[]>;
|
|
@@ -12,5 +13,5 @@ export declare class CuiMultiSelectFilterComponent {
|
|
|
12
13
|
protected isOptionSelected(value: string): boolean;
|
|
13
14
|
protected toggleOption(value: string): void;
|
|
14
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiMultiSelectFilterComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiMultiSelectFilterComponent, "cui-multiselect-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiMultiSelectFilterComponent, "cui-multiselect-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
16
17
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
2
|
-
import type { CuiActiveFilter } from '../../filter-bar.interfaces';
|
|
2
|
+
import type { CuiActiveFilter, CuiFilterBarTranslations } from '../../filter-bar.interfaces';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class CuiRangeFilterComponent {
|
|
5
5
|
readonly filter: import("@angular/core").InputSignal<CuiActiveFilter>;
|
|
6
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
6
7
|
readonly removed: import("@angular/core").OutputEmitterRef<string>;
|
|
7
8
|
readonly changed: import("@angular/core").OutputEmitterRef<CuiActiveFilter>;
|
|
8
9
|
protected readonly tmpMin: import("@angular/core").WritableSignal<number | null>;
|
|
@@ -19,5 +20,5 @@ export declare class CuiRangeFilterComponent {
|
|
|
19
20
|
protected onTmpMaxChange(value: number | null): void;
|
|
20
21
|
protected applyValue(dropdown: CuiDropdownDirective): void;
|
|
21
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiRangeFilterComponent, never>;
|
|
22
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiRangeFilterComponent, "cui-range-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
23
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiRangeFilterComponent, "cui-range-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
23
24
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
2
|
-
import type { CuiActiveFilter } from '../../filter-bar.interfaces';
|
|
2
|
+
import type { CuiActiveFilter, CuiFilterBarTranslations } from '../../filter-bar.interfaces';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class CuiSelectFilterComponent {
|
|
5
5
|
readonly filter: import("@angular/core").InputSignal<CuiActiveFilter>;
|
|
6
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
6
7
|
readonly removed: import("@angular/core").OutputEmitterRef<string>;
|
|
7
8
|
readonly changed: import("@angular/core").OutputEmitterRef<CuiActiveFilter>;
|
|
8
9
|
protected readonly currentValue: import("@angular/core").Signal<string | null>;
|
|
@@ -13,5 +14,5 @@ export declare class CuiSelectFilterComponent {
|
|
|
13
14
|
protected isOptionSelected(value: string): boolean;
|
|
14
15
|
protected selectOption(value: string, dropdown: CuiDropdownDirective): void;
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiSelectFilterComponent, never>;
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiSelectFilterComponent, "cui-select-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiSelectFilterComponent, "cui-select-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
17
18
|
}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
2
|
-
import type { CuiActiveFilter } from '../../filter-bar.interfaces';
|
|
2
|
+
import type { CuiActiveFilter, CuiFilterBarTranslations } from '../../filter-bar.interfaces';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class CuiStringFilterComponent {
|
|
5
5
|
readonly filter: import("@angular/core").InputSignal<CuiActiveFilter>;
|
|
6
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
6
7
|
readonly removed: import("@angular/core").OutputEmitterRef<string>;
|
|
7
8
|
readonly changed: import("@angular/core").OutputEmitterRef<CuiActiveFilter>;
|
|
8
9
|
protected readonly tmpValue: import("@angular/core").WritableSignal<string>;
|
|
@@ -13,5 +14,5 @@ export declare class CuiStringFilterComponent {
|
|
|
13
14
|
protected onTmpValueChange(value: string): void;
|
|
14
15
|
protected applyValue(dropdown: CuiDropdownDirective): void;
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiStringFilterComponent, never>;
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiStringFilterComponent, "cui-string-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiStringFilterComponent, "cui-string-filter", never, { "filter": { "alias": "filter"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": true; "isSignal": true; }; }, { "removed": "removed"; "changed": "changed"; }, never, never, true, never>;
|
|
17
18
|
}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import type { CuiActiveFilter, CuiFilterField } from './filter-bar.interfaces';
|
|
1
|
+
import type { CuiActiveFilter, CuiFilterBarTranslations, CuiFilterField } from './filter-bar.interfaces';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class CuiFilterBarComponent {
|
|
4
4
|
readonly fields: import("@angular/core").InputSignal<CuiFilterField[]>;
|
|
5
|
+
readonly translations: import("@angular/core").InputSignal<CuiFilterBarTranslations>;
|
|
5
6
|
readonly filterChange: import("@angular/core").OutputEmitterRef<Record<string, unknown>>;
|
|
6
7
|
readonly _filters: import("@angular/core").WritableSignal<CuiActiveFilter[]>;
|
|
7
8
|
readonly availableFields: import("@angular/core").Signal<CuiFilterField[]>;
|
|
@@ -10,5 +11,5 @@ export declare class CuiFilterBarComponent {
|
|
|
10
11
|
protected onFilterRemoved(id: string): void;
|
|
11
12
|
private emitFilterChange;
|
|
12
13
|
static ɵfac: i0.ɵɵFactoryDeclaration<CuiFilterBarComponent, never>;
|
|
13
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CuiFilterBarComponent, "cui-filter-bar", never, { "fields": { "alias": "fields"; "required": true; "isSignal": true; }; }, { "filterChange": "filterChange"; }, never, never, true, never>;
|
|
14
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CuiFilterBarComponent, "cui-filter-bar", never, { "fields": { "alias": "fields"; "required": true; "isSignal": true; }; "translations": { "alias": "translations"; "required": false; "isSignal": true; }; }, { "filterChange": "filterChange"; }, never, never, true, never>;
|
|
14
15
|
}
|
|
@@ -59,6 +59,16 @@ export type CuiStringOperator = 'contains' | 'equals' | 'startsWith' | 'endsWith
|
|
|
59
59
|
export type CuiSelectOperator = 'equals' | 'notEquals';
|
|
60
60
|
export type CuiMultiSelectOperator = 'in' | 'notIn' | 'containsAll';
|
|
61
61
|
export type CuiDateOperator = 'between' | 'on' | 'after' | 'before';
|
|
62
|
+
export interface CuiFilterBarTranslations {
|
|
63
|
+
readonly addFilter: string;
|
|
64
|
+
readonly apply: string;
|
|
65
|
+
readonly cancel: string;
|
|
66
|
+
readonly enterValue: string;
|
|
67
|
+
readonly selectValue: string;
|
|
68
|
+
readonly selectValues: string;
|
|
69
|
+
readonly filterBy: string;
|
|
70
|
+
}
|
|
71
|
+
export declare const CUI_FILTER_BAR_DEFAULT_TRANSLATIONS: CuiFilterBarTranslations;
|
|
62
72
|
export type CuiFilterValue = {
|
|
63
73
|
readonly type: 'string';
|
|
64
74
|
readonly operator: CuiStringOperator;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export { CuiFilterBarComponent } from './filter-bar.component';
|
|
2
2
|
export { CuiFilterBarModule } from './filter-bar.module';
|
|
3
|
-
export type { CuiFilterField, CuiStringFilterField, CuiSelectFilterField, CuiMultiSelectFilterField, CuiDateFilterField, CuiRangeFilterField, CuiBaseFilterField, CuiFilterOption, CuiStringOutputMapping, CuiSelectOutputMapping, CuiMultiSelectOutputMapping, CuiDateOutputMapping, CuiRangeOutputMapping, CuiStringOperator, CuiSelectOperator, CuiMultiSelectOperator, CuiDateOperator } from './filter-bar.interfaces';
|
|
3
|
+
export type { CuiFilterField, CuiStringFilterField, CuiSelectFilterField, CuiMultiSelectFilterField, CuiDateFilterField, CuiRangeFilterField, CuiBaseFilterField, CuiFilterOption, CuiStringOutputMapping, CuiSelectOutputMapping, CuiMultiSelectOutputMapping, CuiDateOutputMapping, CuiRangeOutputMapping, CuiStringOperator, CuiSelectOperator, CuiMultiSelectOperator, CuiDateOperator, CuiFilterBarTranslations } from './filter-bar.interfaces';
|
|
4
|
+
export { CUI_FILTER_BAR_DEFAULT_TRANSLATIONS } from './filter-bar.interfaces';
|
package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, input, output } from '@angular/core';
|
|
2
|
-
import { TranslocoPipe } from '@jsverse/transloco';
|
|
3
2
|
import { CuiButtonModule } from '../../../../components/button';
|
|
4
3
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
5
4
|
import { CuiSvgModule } from '../../../../components/svg';
|
|
@@ -9,6 +8,7 @@ import * as i2 from "../../../svg/svg.component";
|
|
|
9
8
|
export class CuiAddFilterButtonComponent {
|
|
10
9
|
constructor() {
|
|
11
10
|
this.availableFields = input.required();
|
|
11
|
+
this.addFilterLabel = input('Add filter');
|
|
12
12
|
this.fieldSelected = output();
|
|
13
13
|
}
|
|
14
14
|
selectField(field, dropdown) {
|
|
@@ -16,10 +16,10 @@ export class CuiAddFilterButtonComponent {
|
|
|
16
16
|
dropdown.close();
|
|
17
17
|
}
|
|
18
18
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiAddFilterButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiAddFilterButtonComponent, isStandalone: true, selector: "cui-add-filter-button", inputs: { availableFields: { classPropertyName: "availableFields", publicName: "availableFields", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { fieldSelected: "fieldSelected" }, ngImport: i0, template: "<div class=\"cui-add-filter\">\n <button\n type=\"button\"\n class=\"cui-add-filter__btn\"\n cuiButton\n size=\"xxs\"\n appearance=\"outlined\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n >\n <cui-svg\n icon=\"cuiIconPlusSm\"\n [width]=\"16\"\n color=\"var(--cui-info)\"\n />\n {{
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiAddFilterButtonComponent, isStandalone: true, selector: "cui-add-filter-button", inputs: { availableFields: { classPropertyName: "availableFields", publicName: "availableFields", isSignal: true, isRequired: true, transformFunction: null }, addFilterLabel: { classPropertyName: "addFilterLabel", publicName: "addFilterLabel", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { fieldSelected: "fieldSelected" }, ngImport: i0, template: "<div class=\"cui-add-filter\">\n <button\n type=\"button\"\n class=\"cui-add-filter__btn\"\n cuiButton\n size=\"xxs\"\n appearance=\"outlined\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n >\n <cui-svg\n icon=\"cuiIconPlusSm\"\n [width]=\"16\"\n color=\"var(--cui-info)\"\n />\n {{ addFilterLabel() }}\n </button>\n <ng-template #dropdownTpl>\n <div class=\"cui-add-filter__dropdown\">\n @for (field of availableFields(); track field.id) {\n <button\n type=\"button\"\n class=\"cui-add-filter__dropdown-item\"\n (click)=\"selectField(field, dropdown)\"\n >\n {{ field.label }}\n </button>\n }\n </div>\n </ng-template>\n</div>", styles: [".cui-add-filter{position:relative;align-self:flex-start}.cui-add-filter__btn{color:var(--cui-light-blue-600)}.cui-add-filter__dropdown{padding-top:4px;padding-bottom:4px;display:flex;flex-direction:column;gap:0;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;overflow:hidden}.cui-add-filter__dropdown-item{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;font-size:14px;line-height:20px;padding:8px 12px;display:block;width:100%;text-align:left;color:var(--cui-base-900);cursor:pointer}.cui-add-filter__dropdown-item:hover{background:var(--cui-base-50)}\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: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
20
20
|
}
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiAddFilterButtonComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
|
-
args: [{ selector: 'cui-add-filter-button', standalone: true, imports: [CuiButtonModule, CuiDropdownDirective, CuiSvgModule
|
|
23
|
+
args: [{ selector: 'cui-add-filter-button', standalone: true, imports: [CuiButtonModule, CuiDropdownDirective, CuiSvgModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cui-add-filter\">\n <button\n type=\"button\"\n class=\"cui-add-filter__btn\"\n cuiButton\n size=\"xxs\"\n appearance=\"outlined\"\n [cuiDropdown]=\"dropdownTpl\"\n #dropdown=\"cuiDropdown\"\n >\n <cui-svg\n icon=\"cuiIconPlusSm\"\n [width]=\"16\"\n color=\"var(--cui-info)\"\n />\n {{ addFilterLabel() }}\n </button>\n <ng-template #dropdownTpl>\n <div class=\"cui-add-filter__dropdown\">\n @for (field of availableFields(); track field.id) {\n <button\n type=\"button\"\n class=\"cui-add-filter__dropdown-item\"\n (click)=\"selectField(field, dropdown)\"\n >\n {{ field.label }}\n </button>\n }\n </div>\n </ng-template>\n</div>", styles: [".cui-add-filter{position:relative;align-self:flex-start}.cui-add-filter__btn{color:var(--cui-light-blue-600)}.cui-add-filter__dropdown{padding-top:4px;padding-bottom:4px;display:flex;flex-direction:column;gap:0;background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;overflow:hidden}.cui-add-filter__dropdown-item{border:0;flex-shrink:0;outline:none;appearance:none;color:inherit;font:inherit;background:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent;font-size:14px;line-height:20px;padding:8px 12px;display:block;width:100%;text-align:left;color:var(--cui-base-900);cursor:pointer}.cui-add-filter__dropdown-item:hover{background:var(--cui-base-50)}\n"] }]
|
|
24
24
|
}] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWZpbHRlci1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9hZGQtZmlsdGVyLWJ1dHRvbi9hZGQtZmlsdGVyLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2FkZC1maWx0ZXItYnV0dG9uL2FkZC1maWx0ZXItYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUN2RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7QUFXMUQsTUFBTSxPQUFPLDJCQUEyQjtJQVJ4QztRQVNvQixvQkFBZSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQW9CLENBQUM7UUFDckQsbUJBQWMsR0FBRyxLQUFLLENBQVMsWUFBWSxDQUFDLENBQUM7UUFFN0Msa0JBQWEsR0FBRyxNQUFNLEVBQWtCLENBQUM7S0FNNUQ7SUFKYSxXQUFXLENBQUMsS0FBcUIsRUFBRSxRQUE4QjtRQUN2RSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQixRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDckIsQ0FBQzsrR0FUUSwyQkFBMkI7bUdBQTNCLDJCQUEyQixrYkNmeEMsdzVCQThCTSxzeUJEcEJRLGVBQWUsb09BQUUsb0JBQW9CLG1KQUFFLFlBQVk7OzRGQUtwRCwyQkFBMkI7a0JBUnZDLFNBQVM7K0JBQ0ksdUJBQXVCLGNBQ3JCLElBQUksV0FDUCxDQUFDLGVBQWUsRUFBRSxvQkFBb0IsRUFBRSxZQUFZLENBQUMsbUJBRzdDLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbnB1dCwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEN1aUJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7IEN1aURyb3Bkb3duRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9kcm9wZG93bic7XG5pbXBvcnQgeyBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21wb25lbnRzL3N2Zyc7XG5pbXBvcnQgdHlwZSB7IEN1aUZpbHRlckZpZWxkIH0gZnJvbSAnLi4vLi4vZmlsdGVyLWJhci5pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdjdWktYWRkLWZpbHRlci1idXR0b24nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0N1aUJ1dHRvbk1vZHVsZSwgQ3VpRHJvcGRvd25EaXJlY3RpdmUsIEN1aVN2Z01vZHVsZV0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2FkZC1maWx0ZXItYnV0dG9uLnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2FkZC1maWx0ZXItYnV0dG9uLnN0eWxlLnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBDdWlBZGRGaWx0ZXJCdXR0b25Db21wb25lbnQge1xuICAgIHB1YmxpYyByZWFkb25seSBhdmFpbGFibGVGaWVsZHMgPSBpbnB1dC5yZXF1aXJlZDxDdWlGaWx0ZXJGaWVsZFtdPigpO1xuICAgIHB1YmxpYyByZWFkb25seSBhZGRGaWx0ZXJMYWJlbCA9IGlucHV0PHN0cmluZz4oJ0FkZCBmaWx0ZXInKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBmaWVsZFNlbGVjdGVkID0gb3V0cHV0PEN1aUZpbHRlckZpZWxkPigpO1xuXG4gICAgcHJvdGVjdGVkIHNlbGVjdEZpZWxkKGZpZWxkOiBDdWlGaWx0ZXJGaWVsZCwgZHJvcGRvd246IEN1aURyb3Bkb3duRGlyZWN0aXZlKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZmllbGRTZWxlY3RlZC5lbWl0KGZpZWxkKTtcbiAgICAgICAgZHJvcGRvd24uY2xvc2UoKTtcbiAgICB9XG59IiwiPGRpdiBjbGFzcz1cImN1aS1hZGQtZmlsdGVyXCI+XG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fYnRuXCJcbiAgICAgICAgY3VpQnV0dG9uXG4gICAgICAgIHNpemU9XCJ4eHNcIlxuICAgICAgICBhcHBlYXJhbmNlPVwib3V0bGluZWRcIlxuICAgICAgICBbY3VpRHJvcGRvd25dPVwiZHJvcGRvd25UcGxcIlxuICAgICAgICAjZHJvcGRvd249XCJjdWlEcm9wZG93blwiXG4gICAgPlxuICAgICAgICA8Y3VpLXN2Z1xuICAgICAgICAgICAgaWNvbj1cImN1aUljb25QbHVzU21cIlxuICAgICAgICAgICAgW3dpZHRoXT1cIjE2XCJcbiAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWluZm8pXCJcbiAgICAgICAgLz5cbiAgICAgICAge3sgYWRkRmlsdGVyTGFiZWwoKSB9fVxuICAgIDwvYnV0dG9uPlxuICAgIDxuZy10ZW1wbGF0ZSAjZHJvcGRvd25UcGw+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fZHJvcGRvd25cIj5cbiAgICAgICAgICAgIEBmb3IgKGZpZWxkIG9mIGF2YWlsYWJsZUZpZWxkcygpOyB0cmFjayBmaWVsZC5pZCkge1xuICAgICAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiY3VpLWFkZC1maWx0ZXJfX2Ryb3Bkb3duLWl0ZW1cIlxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwic2VsZWN0RmllbGQoZmllbGQsIGRyb3Bkb3duKVwiXG4gICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICB7eyBmaWVsZC5sYWJlbCB9fVxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgfVxuICAgICAgICA8L2Rpdj5cbiAgICA8L25nLXRlbXBsYXRlPlxuPC9kaXY+Il19
|
|
@@ -15,6 +15,7 @@ const DEFAULT_OPERATOR_LABELS = {
|
|
|
15
15
|
export class CuiDateFilterComponent {
|
|
16
16
|
constructor() {
|
|
17
17
|
this.filter = input.required();
|
|
18
|
+
this.translations = input.required();
|
|
18
19
|
this.removed = output();
|
|
19
20
|
this.changed = output();
|
|
20
21
|
this.operatorOptions = computed(() => {
|
|
@@ -132,7 +133,7 @@ export class CuiDateFilterComponent {
|
|
|
132
133
|
return date.toLocaleDateString();
|
|
133
134
|
}
|
|
134
135
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
135
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiDateFilterComponent, isStandalone: true, selector: "cui-date-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\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"date-filter__operator\"\n [cuiDropdown]=\"operatorDropdownTpl\"\n #operatorDropdown=\"cuiDropdown\"\n>\n <span class=\"date-filter__operator-label\">{{ operatorLabel() }}</span>\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<button\n type=\"button\"\n class=\"date-filter__trigger\"\n [class.date-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"calendarDropdownTpl\"\n #calendarDropdown=\"cuiDropdown\"\n>\n @if (dateLabel()) {\n <span class=\"date-filter__value\">\n {{ dateLabel() }}\n </span>\n } @else {\n <span class=\"date-filter__placeholder\">Select date</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #operatorDropdownTpl>\n <div class=\"date-filter__dropdown\">\n @for (op of operatorOptions(); track op.value) {\n <button\n type=\"button\"\n class=\"date-filter__option\"\n [class.date-filter__option--selected]=\"currentOperator() === op.value\"\n (click)=\"selectOperator(op.value, operatorDropdown)\"\n >\n {{ op.label }}\n </button>\n }\n </div>\n</ng-template>\n\n<ng-template #calendarDropdownTpl>\n <div class=\"date-filter__calendar-dropdown\">\n <cui-date-range-calendar\n [mode]=\"calendarMode()\"\n [startDate]=\"rangeStart()\"\n [endDate]=\"rangeEnd()\"\n [selectedDate]=\"selectedDate()\"\n (rangeSelected)=\"onRangeSelected($event, calendarDropdown)\"\n (dateSelected)=\"onSingleDateSelected($event, calendarDropdown)\"\n (cancelled)=\"calendarDropdown.close()\"\n />\n </div>\n</ng-template>\n", styles: [":host{display:inline-flex}.date-filter__operator{padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:4px;height:28px;background:transparent;border:1px solid var(--cui-base-200);cursor:pointer}.date-filter__operator:hover{background:var(--cui-base-200)}.date-filter__operator:focus{outline:none}.date-filter__operator-label{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900)}.date-filter__trigger{padding-right:6px;padding-left: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}.date-filter__trigger:hover{background:var(--cui-base-200)}.date-filter__trigger:focus{outline:none}.date-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.date-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.date-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}.date-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.date-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}.date-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}.date-filter__option:hover{background:var(--cui-base-50)}.date-filter__option--selected{background:var(--cui-lavender-bg)}.date-filter__calendar-dropdown{background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiDateRangeCalendarComponent, selector: "cui-date-range-calendar", inputs: ["mode", "startDate", "endDate", "selectedDate"], outputs: ["rangeSelected", "dateSelected", "cancelled"] }, { 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
136
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiDateFilterComponent, isStandalone: true, selector: "cui-date-filter", inputs: { filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: true, transformFunction: null }, translations: { classPropertyName: "translations", publicName: "translations", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"date-filter__operator\"\n [cuiDropdown]=\"operatorDropdownTpl\"\n #operatorDropdown=\"cuiDropdown\"\n>\n <span class=\"date-filter__operator-label\">{{ operatorLabel() }}</span>\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<button\n type=\"button\"\n class=\"date-filter__trigger\"\n [class.date-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"calendarDropdownTpl\"\n #calendarDropdown=\"cuiDropdown\"\n>\n @if (dateLabel()) {\n <span class=\"date-filter__value\">\n {{ dateLabel() }}\n </span>\n } @else {\n <span class=\"date-filter__placeholder\">Select date</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #operatorDropdownTpl>\n <div class=\"date-filter__dropdown\">\n @for (op of operatorOptions(); track op.value) {\n <button\n type=\"button\"\n class=\"date-filter__option\"\n [class.date-filter__option--selected]=\"currentOperator() === op.value\"\n (click)=\"selectOperator(op.value, operatorDropdown)\"\n >\n {{ op.label }}\n </button>\n }\n </div>\n</ng-template>\n\n<ng-template #calendarDropdownTpl>\n <div class=\"date-filter__calendar-dropdown\">\n <cui-date-range-calendar\n [mode]=\"calendarMode()\"\n [startDate]=\"rangeStart()\"\n [endDate]=\"rangeEnd()\"\n [selectedDate]=\"selectedDate()\"\n (rangeSelected)=\"onRangeSelected($event, calendarDropdown)\"\n (dateSelected)=\"onSingleDateSelected($event, calendarDropdown)\"\n (cancelled)=\"calendarDropdown.close()\"\n />\n </div>\n</ng-template>\n", styles: [":host{display:inline-flex}.date-filter__operator{padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:4px;height:28px;background:transparent;border:1px solid var(--cui-base-200);cursor:pointer}.date-filter__operator:hover{background:var(--cui-base-200)}.date-filter__operator:focus{outline:none}.date-filter__operator-label{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900)}.date-filter__trigger{padding-right:6px;padding-left: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}.date-filter__trigger:hover{background:var(--cui-base-200)}.date-filter__trigger:focus{outline:none}.date-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.date-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.date-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}.date-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.date-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}.date-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}.date-filter__option:hover{background:var(--cui-base-50)}.date-filter__option--selected{background:var(--cui-lavender-bg)}.date-filter__calendar-dropdown{background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}\n"], dependencies: [{ kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiDateRangeCalendarComponent, selector: "cui-date-range-calendar", inputs: ["mode", "startDate", "endDate", "selectedDate"], outputs: ["rangeSelected", "dateSelected", "cancelled"] }, { 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
136
137
|
}
|
|
137
138
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateFilterComponent, decorators: [{
|
|
138
139
|
type: Component,
|
|
@@ -144,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
144
145
|
CuiSvgModule
|
|
145
146
|
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label\"\n (removed)=\"onRemove()\"\n/>\n\n<button\n type=\"button\"\n class=\"date-filter__operator\"\n [cuiDropdown]=\"operatorDropdownTpl\"\n #operatorDropdown=\"cuiDropdown\"\n>\n <span class=\"date-filter__operator-label\">{{ operatorLabel() }}</span>\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<button\n type=\"button\"\n class=\"date-filter__trigger\"\n [class.date-filter__trigger--active]=\"hasValue()\"\n [cuiDropdown]=\"calendarDropdownTpl\"\n #calendarDropdown=\"cuiDropdown\"\n>\n @if (dateLabel()) {\n <span class=\"date-filter__value\">\n {{ dateLabel() }}\n </span>\n } @else {\n <span class=\"date-filter__placeholder\">Select date</span>\n }\n <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #operatorDropdownTpl>\n <div class=\"date-filter__dropdown\">\n @for (op of operatorOptions(); track op.value) {\n <button\n type=\"button\"\n class=\"date-filter__option\"\n [class.date-filter__option--selected]=\"currentOperator() === op.value\"\n (click)=\"selectOperator(op.value, operatorDropdown)\"\n >\n {{ op.label }}\n </button>\n }\n </div>\n</ng-template>\n\n<ng-template #calendarDropdownTpl>\n <div class=\"date-filter__calendar-dropdown\">\n <cui-date-range-calendar\n [mode]=\"calendarMode()\"\n [startDate]=\"rangeStart()\"\n [endDate]=\"rangeEnd()\"\n [selectedDate]=\"selectedDate()\"\n (rangeSelected)=\"onRangeSelected($event, calendarDropdown)\"\n (dateSelected)=\"onSingleDateSelected($event, calendarDropdown)\"\n (cancelled)=\"calendarDropdown.close()\"\n />\n </div>\n</ng-template>\n", styles: [":host{display:inline-flex}.date-filter__operator{padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;display:inline-flex;align-items:center;gap:4px;height:28px;background:transparent;border:1px solid var(--cui-base-200);cursor:pointer}.date-filter__operator:hover{background:var(--cui-base-200)}.date-filter__operator:focus{outline:none}.date-filter__operator-label{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-900)}.date-filter__trigger{padding-right:6px;padding-left: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}.date-filter__trigger:hover{background:var(--cui-base-200)}.date-filter__trigger:focus{outline:none}.date-filter__trigger--active{background:var(--cui-lavender-bg);border-color:var(--cui-badge-lavender-label)}.date-filter__trigger--active:hover{background:var(--cui-base-200);border-color:var(--cui-base-200)}.date-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}.date-filter__placeholder{font-weight:500;font-size:12px;line-height:14px;color:var(--cui-base-500)}.date-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}.date-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}.date-filter__option:hover{background:var(--cui-base-50)}.date-filter__option--selected{background:var(--cui-lavender-bg)}.date-filter__calendar-dropdown{background:var(--cui-base-0);border:1px solid var(--cui-base-200);border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}\n"] }]
|
|
146
147
|
}] });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/date-filter/date-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/date-filter/date-filter.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\n\nimport { CuiButtonModule } from '../../../../components/button';\nimport { CuiDateRangeCalendarComponent } from '../../../date-range-calendar';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport type { CuiActiveFilter, CuiDateFilterField, CuiDateOperator } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\ninterface OperatorOption {\n    value: CuiDateOperator;\n    label: string;\n}\n\nconst DEFAULT_OPERATOR_LABELS: Record<CuiDateOperator, string> = {\n    on: 'On',\n    before: 'Before',\n    after: 'After',\n    between: 'Between'\n};\n\n@Component({\n    selector: 'cui-date-filter',\n    standalone: true,\n    imports: [\n        CuiButtonModule,\n        CuiDateRangeCalendarComponent,\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiSvgModule\n    ],\n    templateUrl: './date-filter.template.html',\n    styleUrls: ['./date-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiDateFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly operatorOptions = computed((): OperatorOption[] => {\n        const field = this.filter().field as CuiDateFilterField;\n        const operators: CuiDateOperator[] = field.dateOperators ?? ['on', 'before', 'after', 'between'];\n\n        return operators.map((op) => ({\n            value: op,\n            label: field.operatorLabels?.[op] ?? DEFAULT_OPERATOR_LABELS[op]\n        }));\n    });\n\n    protected readonly currentOperator = computed((): CuiDateOperator => {\n        const f = this.filter();\n\n        return f.value.type === 'date' ? f.value.operator : 'on';\n    });\n\n    protected readonly operatorLabel = computed(() => {\n        const options = this.operatorOptions();\n        const op = options.find((o) => o.value === this.currentOperator());\n\n        return op?.label ?? '';\n    });\n\n    protected readonly dateLabel = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return '';\n        }\n\n        const dateValue = f.value;\n\n        if (dateValue.operator === 'between') {\n            if (dateValue.rangeStart && dateValue.rangeEnd) {\n                return `${this.formatDate(dateValue.rangeStart)} - ${this.formatDate(dateValue.rangeEnd)}`;\n            }\n\n            return '';\n        }\n\n        return dateValue.value ? this.formatDate(dateValue.value) : '';\n    });\n\n    protected readonly hasValue = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return false;\n        }\n\n        if (f.value.operator === 'between') {\n            return !!f.value.rangeStart && !!f.value.rangeEnd;\n        }\n\n        return !!f.value.value;\n    });\n\n    protected readonly rangeStart = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.rangeStart ? new Date(f.value.rangeStart) : null;\n    });\n\n    protected readonly rangeEnd = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.rangeEnd ? new Date(f.value.rangeEnd) : null;\n    });\n\n    protected readonly selectedDate = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.value ? new Date(f.value.value) : null;\n    });\n\n    protected readonly calendarMode = computed((): 'single' | 'range' => (this.currentOperator() === 'between' ? 'range' : 'single'));\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected selectOperator(operator: CuiDateOperator, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        const isBetween = operator === 'between';\n\n        const updated: CuiActiveFilter = {\n            ...f,\n            value: {\n                type: 'date',\n                operator,\n                value: isBetween ? null : f.value.value,\n                rangeStart: isBetween ? f.value.rangeStart : null,\n                rangeEnd: isBetween ? f.value.rangeEnd : null\n            }\n        };\n\n        this.changed.emit(updated);\n        dropdown.close();\n    }\n\n    protected onRangeSelected(range: { start: Date; end: Date }, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: {\n                type: 'date',\n                operator: 'between',\n                value: null,\n                rangeStart: range.start,\n                rangeEnd: range.end\n            }\n        });\n        dropdown.close();\n    }\n\n    protected onSingleDateSelected(date: Date, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: {\n                type: 'date',\n                operator: f.value.operator,\n                value: date,\n                rangeStart: null,\n                rangeEnd: null\n            }\n        });\n        dropdown.close();\n    }\n\n    private formatDate(date: Date): string {\n        return date.toLocaleDateString();\n    }\n}\n","<cui-filter-remove-button\n    [label]=\"filter().field.label\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"date-filter__operator\"\n    [cuiDropdown]=\"operatorDropdownTpl\"\n    #operatorDropdown=\"cuiDropdown\"\n>\n    <span class=\"date-filter__operator-label\">{{ operatorLabel() }}</span>\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<button\n    type=\"button\"\n    class=\"date-filter__trigger\"\n    [class.date-filter__trigger--active]=\"hasValue()\"\n    [cuiDropdown]=\"calendarDropdownTpl\"\n    #calendarDropdown=\"cuiDropdown\"\n>\n    @if (dateLabel()) {\n        <span class=\"date-filter__value\">\n            {{ dateLabel() }}\n        </span>\n    } @else {\n        <span class=\"date-filter__placeholder\">Select date</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #operatorDropdownTpl>\n    <div class=\"date-filter__dropdown\">\n        @for (op of operatorOptions(); track op.value) {\n            <button\n                type=\"button\"\n                class=\"date-filter__option\"\n                [class.date-filter__option--selected]=\"currentOperator() === op.value\"\n                (click)=\"selectOperator(op.value, operatorDropdown)\"\n            >\n                {{ op.label }}\n            </button>\n        }\n    </div>\n</ng-template>\n\n<ng-template #calendarDropdownTpl>\n    <div class=\"date-filter__calendar-dropdown\">\n        <cui-date-range-calendar\n            [mode]=\"calendarMode()\"\n            [startDate]=\"rangeStart()\"\n            [endDate]=\"rangeEnd()\"\n            [selectedDate]=\"selectedDate()\"\n            (rangeSelected)=\"onRangeSelected($event, calendarDropdown)\"\n            (dateSelected)=\"onSingleDateSelected($event, calendarDropdown)\"\n            (cancelled)=\"calendarDropdown.close()\"\n        />\n    </div>\n</ng-template>\n"]}
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/core/components/filter-bar/components/date-filter/date-filter.component.ts","../../../../../../../projects/core/components/filter-bar/components/date-filter/date-filter.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\n\nimport { CuiButtonModule } from '../../../../components/button';\nimport { CuiDateRangeCalendarComponent } from '../../../date-range-calendar';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport type { CuiActiveFilter, CuiDateFilterField, CuiDateOperator, CuiFilterBarTranslations } from '../../filter-bar.interfaces';\nimport { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';\n\ninterface OperatorOption {\n    value: CuiDateOperator;\n    label: string;\n}\n\nconst DEFAULT_OPERATOR_LABELS: Record<CuiDateOperator, string> = {\n    on: 'On',\n    before: 'Before',\n    after: 'After',\n    between: 'Between'\n};\n\n@Component({\n    selector: 'cui-date-filter',\n    standalone: true,\n    imports: [\n        CuiButtonModule,\n        CuiDateRangeCalendarComponent,\n        CuiDropdownDirective,\n        CuiFilterRemoveButtonComponent,\n        CuiSvgModule\n    ],\n    templateUrl: './date-filter.template.html',\n    styleUrls: ['./date-filter.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiDateFilterComponent {\n    public readonly filter = input.required<CuiActiveFilter>();\n    public readonly translations = input.required<CuiFilterBarTranslations>();\n    public readonly removed = output<string>();\n    public readonly changed = output<CuiActiveFilter>();\n\n    protected readonly operatorOptions = computed((): OperatorOption[] => {\n        const field = this.filter().field as CuiDateFilterField;\n        const operators: CuiDateOperator[] = field.dateOperators ?? ['on', 'before', 'after', 'between'];\n\n        return operators.map((op) => ({\n            value: op,\n            label: field.operatorLabels?.[op] ?? DEFAULT_OPERATOR_LABELS[op]\n        }));\n    });\n\n    protected readonly currentOperator = computed((): CuiDateOperator => {\n        const f = this.filter();\n\n        return f.value.type === 'date' ? f.value.operator : 'on';\n    });\n\n    protected readonly operatorLabel = computed(() => {\n        const options = this.operatorOptions();\n        const op = options.find((o) => o.value === this.currentOperator());\n\n        return op?.label ?? '';\n    });\n\n    protected readonly dateLabel = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return '';\n        }\n\n        const dateValue = f.value;\n\n        if (dateValue.operator === 'between') {\n            if (dateValue.rangeStart && dateValue.rangeEnd) {\n                return `${this.formatDate(dateValue.rangeStart)} - ${this.formatDate(dateValue.rangeEnd)}`;\n            }\n\n            return '';\n        }\n\n        return dateValue.value ? this.formatDate(dateValue.value) : '';\n    });\n\n    protected readonly hasValue = computed(() => {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return false;\n        }\n\n        if (f.value.operator === 'between') {\n            return !!f.value.rangeStart && !!f.value.rangeEnd;\n        }\n\n        return !!f.value.value;\n    });\n\n    protected readonly rangeStart = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.rangeStart ? new Date(f.value.rangeStart) : null;\n    });\n\n    protected readonly rangeEnd = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.rangeEnd ? new Date(f.value.rangeEnd) : null;\n    });\n\n    protected readonly selectedDate = computed((): Date | null => {\n        const f = this.filter();\n\n        return f.value.type === 'date' && f.value.value ? new Date(f.value.value) : null;\n    });\n\n    protected readonly calendarMode = computed((): 'single' | 'range' => (this.currentOperator() === 'between' ? 'range' : 'single'));\n\n    protected onRemove(): void {\n        this.removed.emit(this.filter().id);\n    }\n\n    protected selectOperator(operator: CuiDateOperator, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        const isBetween = operator === 'between';\n\n        const updated: CuiActiveFilter = {\n            ...f,\n            value: {\n                type: 'date',\n                operator,\n                value: isBetween ? null : f.value.value,\n                rangeStart: isBetween ? f.value.rangeStart : null,\n                rangeEnd: isBetween ? f.value.rangeEnd : null\n            }\n        };\n\n        this.changed.emit(updated);\n        dropdown.close();\n    }\n\n    protected onRangeSelected(range: { start: Date; end: Date }, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: {\n                type: 'date',\n                operator: 'between',\n                value: null,\n                rangeStart: range.start,\n                rangeEnd: range.end\n            }\n        });\n        dropdown.close();\n    }\n\n    protected onSingleDateSelected(date: Date, dropdown: CuiDropdownDirective): void {\n        const f = this.filter();\n\n        if (f.value.type !== 'date') {\n            return;\n        }\n\n        this.changed.emit({\n            ...f,\n            value: {\n                type: 'date',\n                operator: f.value.operator,\n                value: date,\n                rangeStart: null,\n                rangeEnd: null\n            }\n        });\n        dropdown.close();\n    }\n\n    private formatDate(date: Date): string {\n        return date.toLocaleDateString();\n    }\n}\n","<cui-filter-remove-button\n    [label]=\"filter().field.label\"\n    (removed)=\"onRemove()\"\n/>\n\n<button\n    type=\"button\"\n    class=\"date-filter__operator\"\n    [cuiDropdown]=\"operatorDropdownTpl\"\n    #operatorDropdown=\"cuiDropdown\"\n>\n    <span class=\"date-filter__operator-label\">{{ operatorLabel() }}</span>\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<button\n    type=\"button\"\n    class=\"date-filter__trigger\"\n    [class.date-filter__trigger--active]=\"hasValue()\"\n    [cuiDropdown]=\"calendarDropdownTpl\"\n    #calendarDropdown=\"cuiDropdown\"\n>\n    @if (dateLabel()) {\n        <span class=\"date-filter__value\">\n            {{ dateLabel() }}\n        </span>\n    } @else {\n        <span class=\"date-filter__placeholder\">Select date</span>\n    }\n    <cui-svg icon=\"cuiIconChevronDown\" />\n</button>\n\n<ng-template #operatorDropdownTpl>\n    <div class=\"date-filter__dropdown\">\n        @for (op of operatorOptions(); track op.value) {\n            <button\n                type=\"button\"\n                class=\"date-filter__option\"\n                [class.date-filter__option--selected]=\"currentOperator() === op.value\"\n                (click)=\"selectOperator(op.value, operatorDropdown)\"\n            >\n                {{ op.label }}\n            </button>\n        }\n    </div>\n</ng-template>\n\n<ng-template #calendarDropdownTpl>\n    <div class=\"date-filter__calendar-dropdown\">\n        <cui-date-range-calendar\n            [mode]=\"calendarMode()\"\n            [startDate]=\"rangeStart()\"\n            [endDate]=\"rangeEnd()\"\n            [selectedDate]=\"selectedDate()\"\n            (rangeSelected)=\"onRangeSelected($event, calendarDropdown)\"\n            (dateSelected)=\"onSingleDateSelected($event, calendarDropdown)\"\n            (cancelled)=\"calendarDropdown.close()\"\n        />\n    </div>\n</ng-template>\n"]}
|
package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
|
2
|
-
import { TranslocoPipe } from '@jsverse/transloco';
|
|
3
2
|
import { CuiCheckboxModule } from '../../../../components/checkbox';
|
|
4
3
|
import { CuiDropdownDirective } from '../../../../components/dropdown';
|
|
5
4
|
import { CuiSvgModule } from '../../../../components/svg';
|
|
@@ -11,6 +10,7 @@ import * as i2 from "../../../svg/svg.component";
|
|
|
11
10
|
export class CuiMultiSelectFilterComponent {
|
|
12
11
|
constructor() {
|
|
13
12
|
this.filter = input.required();
|
|
13
|
+
this.translations = input.required();
|
|
14
14
|
this.removed = output();
|
|
15
15
|
this.changed = output();
|
|
16
16
|
this.currentValues = computed(() => {
|
|
@@ -54,7 +54,7 @@ export class CuiMultiSelectFilterComponent {
|
|
|
54
54
|
});
|
|
55
55
|
}
|
|
56
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
|
|
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 }, translations: { classPropertyName: "translations", publicName: "translations", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed", changed: "changed" }, ngImport: i0, template: "<cui-filter-remove-button\n [label]=\"filter().field.label\"\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\">{{ translations().selectValues }}</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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
58
|
}
|
|
59
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiMultiSelectFilterComponent, decorators: [{
|
|
60
60
|
type: Component,
|
|
@@ -63,8 +63,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
63
63
|
CuiDropdownDirective,
|
|
64
64
|
CuiFilterRemoveButtonComponent,
|
|
65
65
|
CuiSvgModule,
|
|
66
|
-
CuiTooltipDirective
|
|
67
|
-
|
|
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"] }]
|
|
66
|
+
CuiTooltipDirective
|
|
67
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<cui-filter-remove-button\n [label]=\"filter().field.label\"\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\">{{ translations().selectValues }}</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
68
|
}] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# 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';\n\nimport { CuiCheckboxModule } from '../../../../components/checkbox';\nimport { CuiDropdownDirective } from '../../../../components/dropdown';\nimport { CuiSvgModule } from '../../../../components/svg';\nimport { CuiTooltipDirective } from '../../../../directives';\nimport type { CuiActiveFilter, CuiFilterBarTranslations, 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    ],\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 translations = input.required<CuiFilterBarTranslations>();\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\"\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\">{{ translations().selectValues }}</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>"]}
|