@cuby-ui/core 0.0.562 → 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.
Files changed (22) hide show
  1. package/components/filter-bar/components/add-filter-button/add-filter-button.component.d.ts +2 -1
  2. package/components/filter-bar/components/date-filter/date-filter.component.d.ts +3 -2
  3. package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts +3 -2
  4. package/components/filter-bar/components/range-filter/range-filter.component.d.ts +3 -2
  5. package/components/filter-bar/components/select-filter/select-filter.component.d.ts +3 -2
  6. package/components/filter-bar/components/string-filter/string-filter.component.d.ts +3 -2
  7. package/components/filter-bar/filter-bar.component.d.ts +3 -2
  8. package/components/filter-bar/filter-bar.interfaces.d.ts +10 -0
  9. package/components/filter-bar/index.d.ts +2 -1
  10. package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs +4 -4
  11. package/esm2022/components/filter-bar/components/date-filter/date-filter.component.mjs +3 -2
  12. package/esm2022/components/filter-bar/components/filter-remove-button/filter-remove-button.component.mjs +3 -4
  13. package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs +5 -6
  14. package/esm2022/components/filter-bar/components/range-filter/range-filter.component.mjs +5 -6
  15. package/esm2022/components/filter-bar/components/select-filter/select-filter.component.mjs +5 -6
  16. package/esm2022/components/filter-bar/components/string-filter/string-filter.component.mjs +5 -6
  17. package/esm2022/components/filter-bar/filter-bar.component.mjs +5 -3
  18. package/esm2022/components/filter-bar/filter-bar.interfaces.mjs +10 -2
  19. package/esm2022/components/filter-bar/index.mjs +2 -1
  20. package/fesm2022/cuby-ui-core.mjs +38 -24
  21. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  22. 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 {};
@@ -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';
@@ -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 {{ 'ADD_FILTER' | transloco }}\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 | transloco }}\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"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
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, TranslocoPipe], 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 {{ 'ADD_FILTER' | transloco }}\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 | transloco }}\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"] }]
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWZpbHRlci1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9hZGQtZmlsdGVyLWJ1dHRvbi9hZGQtZmlsdGVyLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2FkZC1maWx0ZXItYnV0dG9uL2FkZC1maWx0ZXItYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7O0FBVzFELE1BQU0sT0FBTywyQkFBMkI7SUFSeEM7UUFTb0Isb0JBQWUsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFvQixDQUFDO1FBRXJELGtCQUFhLEdBQUcsTUFBTSxFQUFrQixDQUFDO0tBTTVEO0lBSmEsV0FBVyxDQUFDLEtBQXFCLEVBQUUsUUFBOEI7UUFDdkUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3JCLENBQUM7K0dBUlEsMkJBQTJCO21HQUEzQiwyQkFBMkIsK1JDaEJ4Qyw0NkJBOEJNLHN5QkRuQlEsZUFBZSxvT0FBRSxvQkFBb0IsbUpBQUUsWUFBWSxtS0FBRSxhQUFhOzs0RkFLbkUsMkJBQTJCO2tCQVJ2QyxTQUFTOytCQUNJLHVCQUF1QixjQUNyQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLEVBQUUsWUFBWSxFQUFFLGFBQWEsQ0FBQyxtQkFHNUQsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbG9jb1BpcGUgfSBmcm9tICdAanN2ZXJzZS90cmFuc2xvY28nO1xuXG5pbXBvcnQgeyBDdWlCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQgeyBDdWlEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvZHJvcGRvd24nO1xuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9zdmcnO1xuaW1wb3J0IHR5cGUgeyBDdWlGaWx0ZXJGaWVsZCB9IGZyb20gJy4uLy4uL2ZpbHRlci1iYXIuaW50ZXJmYWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnY3VpLWFkZC1maWx0ZXItYnV0dG9uJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDdWlCdXR0b25Nb2R1bGUsIEN1aURyb3Bkb3duRGlyZWN0aXZlLCBDdWlTdmdNb2R1bGUsIFRyYW5zbG9jb1BpcGVdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9hZGQtZmlsdGVyLWJ1dHRvbi50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9hZGQtZmlsdGVyLWJ1dHRvbi5zdHlsZS5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpQWRkRmlsdGVyQnV0dG9uQ29tcG9uZW50IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgYXZhaWxhYmxlRmllbGRzID0gaW5wdXQucmVxdWlyZWQ8Q3VpRmlsdGVyRmllbGRbXT4oKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBmaWVsZFNlbGVjdGVkID0gb3V0cHV0PEN1aUZpbHRlckZpZWxkPigpO1xuXG4gICAgcHJvdGVjdGVkIHNlbGVjdEZpZWxkKGZpZWxkOiBDdWlGaWx0ZXJGaWVsZCwgZHJvcGRvd246IEN1aURyb3Bkb3duRGlyZWN0aXZlKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZmllbGRTZWxlY3RlZC5lbWl0KGZpZWxkKTtcbiAgICAgICAgZHJvcGRvd24uY2xvc2UoKTtcbiAgICB9XG59IiwiPGRpdiBjbGFzcz1cImN1aS1hZGQtZmlsdGVyXCI+XG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fYnRuXCJcbiAgICAgICAgY3VpQnV0dG9uXG4gICAgICAgIHNpemU9XCJ4eHNcIlxuICAgICAgICBhcHBlYXJhbmNlPVwib3V0bGluZWRcIlxuICAgICAgICBbY3VpRHJvcGRvd25dPVwiZHJvcGRvd25UcGxcIlxuICAgICAgICAjZHJvcGRvd249XCJjdWlEcm9wZG93blwiXG4gICAgPlxuICAgICAgICA8Y3VpLXN2Z1xuICAgICAgICAgICAgaWNvbj1cImN1aUljb25QbHVzU21cIlxuICAgICAgICAgICAgW3dpZHRoXT1cIjE2XCJcbiAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWluZm8pXCJcbiAgICAgICAgLz5cbiAgICAgICAge3sgJ0FERF9GSUxURVInIHwgdHJhbnNsb2NvIH19XG4gICAgPC9idXR0b24+XG4gICAgPG5nLXRlbXBsYXRlICNkcm9wZG93blRwbD5cbiAgICAgICAgPGRpdiBjbGFzcz1cImN1aS1hZGQtZmlsdGVyX19kcm9wZG93blwiPlxuICAgICAgICAgICAgQGZvciAoZmllbGQgb2YgYXZhaWxhYmxlRmllbGRzKCk7IHRyYWNrIGZpZWxkLmlkKSB7XG4gICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fZHJvcGRvd24taXRlbVwiXG4gICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJzZWxlY3RGaWVsZChmaWVsZCwgZHJvcGRvd24pXCJcbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHt7IGZpZWxkLmxhYmVsIHwgdHJhbnNsb2NvIH19XG4gICAgICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgICAgICB9XG4gICAgICAgIDwvZGl2PlxuICAgIDwvbmctdGVtcGxhdGU+XG48L2Rpdj4iXX0=
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"]}
@@ -1,5 +1,4 @@
1
1
  import { ChangeDetectionStrategy, Component, input, output } from '@angular/core';
2
- import { TranslocoPipe } from '@jsverse/transloco';
3
2
  import { CuiSvgModule } from '../../../../components/svg';
4
3
  import * as i0 from "@angular/core";
5
4
  import * as i1 from "../../../svg/svg.component";
@@ -12,10 +11,10 @@ export class CuiFilterRemoveButtonComponent {
12
11
  this.removed.emit();
13
12
  }
14
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterRemoveButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
15
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: CuiFilterRemoveButtonComponent, isStandalone: true, selector: "cui-filter-remove-button", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed" }, ngImport: i0, template: "<button\n type=\"button\"\n class=\"filter-remove-button\"\n>\n <cui-svg\n icon=\"cuiIconVector\"\n (click)=\"onRemove(); $event.stopPropagation()\"\n />\n <span class=\"filter-remove-button__label\">{{ label() | transloco }}:</span>\n</button>\n", styles: [":host{display:contents}.filter-remove-button{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-start;padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-left-radius:8px;border-bottom-left-radius:8px;cursor:pointer}.filter-remove-button:hover,.filter-remove-button:focus{outline:none}.filter-remove-button__label{font-weight:500;font-size:12px;line-height:14px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "pipe", type: TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: CuiFilterRemoveButtonComponent, isStandalone: true, selector: "cui-filter-remove-button", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { removed: "removed" }, ngImport: i0, template: "<button\n type=\"button\"\n class=\"filter-remove-button\"\n>\n <cui-svg\n icon=\"cuiIconVector\"\n (click)=\"onRemove(); $event.stopPropagation()\"\n />\n <span class=\"filter-remove-button__label\">{{ label() }}:</span>\n</button>\n", styles: [":host{display:contents}.filter-remove-button{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-start;padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-left-radius:8px;border-bottom-left-radius:8px;cursor:pointer}.filter-remove-button:hover,.filter-remove-button:focus{outline:none}.filter-remove-button__label{font-weight:500;font-size:12px;line-height:14px}\n"], dependencies: [{ kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i1.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
16
15
  }
17
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterRemoveButtonComponent, decorators: [{
18
17
  type: Component,
19
- args: [{ selector: 'cui-filter-remove-button', standalone: true, imports: [CuiSvgModule, TranslocoPipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n type=\"button\"\n class=\"filter-remove-button\"\n>\n <cui-svg\n icon=\"cuiIconVector\"\n (click)=\"onRemove(); $event.stopPropagation()\"\n />\n <span class=\"filter-remove-button__label\">{{ label() | transloco }}:</span>\n</button>\n", styles: [":host{display:contents}.filter-remove-button{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-start;padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-left-radius:8px;border-bottom-left-radius:8px;cursor:pointer}.filter-remove-button:hover,.filter-remove-button:focus{outline:none}.filter-remove-button__label{font-weight:500;font-size:12px;line-height:14px}\n"] }]
18
+ args: [{ selector: 'cui-filter-remove-button', standalone: true, imports: [CuiSvgModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n type=\"button\"\n class=\"filter-remove-button\"\n>\n <cui-svg\n icon=\"cuiIconVector\"\n (click)=\"onRemove(); $event.stopPropagation()\"\n />\n <span class=\"filter-remove-button__label\">{{ label() }}:</span>\n</button>\n", styles: [":host{display:contents}.filter-remove-button{display:flex;flex-direction:row;gap:4px;align-items:center;justify-content:flex-start;padding-right:6px;padding-left:6px;font-weight:500;font-size:12px;line-height:14px;height:28px;background:transparent;border:1px solid var(--cui-base-200);border-top-left-radius:8px;border-bottom-left-radius:8px;cursor:pointer}.filter-remove-button:hover,.filter-remove-button:focus{outline:none}.filter-remove-button__label{font-weight:500;font-size:12px;line-height:14px}\n"] }]
20
19
  }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXJlbW92ZS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9maWx0ZXItcmVtb3ZlLWJ1dHRvbi9maWx0ZXItcmVtb3ZlLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2ZpbHRlci1yZW1vdmUtYnV0dG9uL2ZpbHRlci1yZW1vdmUtYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVuRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQVUxRCxNQUFNLE9BQU8sOEJBQThCO0lBUjNDO1FBU29CLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFFakMsWUFBTyxHQUFHLE1BQU0sRUFBUSxDQUFDO0tBSzVDO0lBSFUsUUFBUTtRQUNYLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDeEIsQ0FBQzsrR0FQUSw4QkFBOEI7bUdBQTlCLDhCQUE4Qix3UENiM0MscVJBVUEsbWpCREZjLFlBQVksbUtBQUUsYUFBYTs7NEZBSzVCLDhCQUE4QjtrQkFSMUMsU0FBUzsrQkFDSSwwQkFBMEIsY0FDeEIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQyxtQkFHckIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbG9jb1BpcGUgfSBmcm9tICdAanN2ZXJzZS90cmFuc2xvY28nO1xuXG5pbXBvcnQgeyBDdWlTdmdNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21wb25lbnRzL3N2Zyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnY3VpLWZpbHRlci1yZW1vdmUtYnV0dG9uJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDdWlTdmdNb2R1bGUsIFRyYW5zbG9jb1BpcGVdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maWx0ZXItcmVtb3ZlLWJ1dHRvbi50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9maWx0ZXItcmVtb3ZlLWJ1dHRvbi5zdHlsZS5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpRmlsdGVyUmVtb3ZlQnV0dG9uQ29tcG9uZW50IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgbGFiZWwgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG5cbiAgICBwdWJsaWMgcmVhZG9ubHkgcmVtb3ZlZCA9IG91dHB1dDx2b2lkPigpO1xuXG4gICAgcHVibGljIG9uUmVtb3ZlKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnJlbW92ZWQuZW1pdCgpO1xuICAgIH1cbn1cbiIsIjxidXR0b25cbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBjbGFzcz1cImZpbHRlci1yZW1vdmUtYnV0dG9uXCJcbj5cbiAgICA8Y3VpLXN2Z1xuICAgICAgICBpY29uPVwiY3VpSWNvblZlY3RvclwiXG4gICAgICAgIChjbGljayk9XCJvblJlbW92ZSgpOyAkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcIlxuICAgIC8+XG4gICAgPHNwYW4gY2xhc3M9XCJmaWx0ZXItcmVtb3ZlLWJ1dHRvbl9fbGFiZWxcIj57eyBsYWJlbCgpIHwgdHJhbnNsb2NvIH19Ojwvc3Bhbj5cbjwvYnV0dG9uPlxuIl19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXJlbW92ZS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9maWx0ZXItcmVtb3ZlLWJ1dHRvbi9maWx0ZXItcmVtb3ZlLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2ZpbHRlci1yZW1vdmUtYnV0dG9uL2ZpbHRlci1yZW1vdmUtYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBVTFELE1BQU0sT0FBTyw4QkFBOEI7SUFSM0M7UUFTb0IsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUVqQyxZQUFPLEdBQUcsTUFBTSxFQUFRLENBQUM7S0FLNUM7SUFIVSxRQUFRO1FBQ1gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN4QixDQUFDOytHQVBRLDhCQUE4QjttR0FBOUIsOEJBQThCLHdQQ1ozQyx5UUFVQSxtakJESGMsWUFBWTs7NEZBS2IsOEJBQThCO2tCQVIxQyxTQUFTOytCQUNJLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsbUJBR04sdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9zdmcnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1maWx0ZXItcmVtb3ZlLWJ1dHRvbicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ3VpU3ZnTW9kdWxlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLXJlbW92ZS1idXR0b24udGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLXJlbW92ZS1idXR0b24uc3R5bGUuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEN1aUZpbHRlclJlbW92ZUJ1dHRvbkNvbXBvbmVudCB7XG4gICAgcHVibGljIHJlYWRvbmx5IGxhYmVsID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHJlbW92ZWQgPSBvdXRwdXQ8dm9pZD4oKTtcblxuICAgIHB1YmxpYyBvblJlbW92ZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZW1vdmVkLmVtaXQoKTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgY2xhc3M9XCJmaWx0ZXItcmVtb3ZlLWJ1dHRvblwiXG4+XG4gICAgPGN1aS1zdmdcbiAgICAgICAgaWNvbj1cImN1aUljb25WZWN0b3JcIlxuICAgICAgICAoY2xpY2spPVwib25SZW1vdmUoKTsgJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCJcbiAgICAvPlxuICAgIDxzcGFuIGNsYXNzPVwiZmlsdGVyLXJlbW92ZS1idXR0b25fX2xhYmVsXCI+e3sgbGFiZWwoKSB9fTo8L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
@@ -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 | 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 }); }
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
- 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"] }]
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,{"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>"]}
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>"]}