@cuby-ui/core 0.0.557 → 0.0.559

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/components/date-range-calendar/date-range-calendar.component.d.ts +53 -0
  2. package/components/date-range-calendar/date-range-calendar.interfaces.d.ts +1 -0
  3. package/components/date-range-calendar/date-range-calendar.module.d.ts +7 -0
  4. package/components/date-range-calendar/index.d.ts +3 -0
  5. package/components/filter-bar/components/add-filter-button/add-filter-button.component.d.ts +10 -0
  6. package/components/filter-bar/components/date-filter/date-filter.component.d.ts +32 -0
  7. package/components/filter-bar/components/filter-remove-button/filter-remove-button.component.d.ts +8 -0
  8. package/components/filter-bar/components/index.d.ts +7 -0
  9. package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts +16 -0
  10. package/components/filter-bar/components/range-filter/range-filter.component.d.ts +23 -0
  11. package/components/filter-bar/components/select-filter/select-filter.component.d.ts +17 -0
  12. package/components/filter-bar/components/string-filter/string-filter.component.d.ts +17 -0
  13. package/components/filter-bar/filter-bar.component.d.ts +14 -0
  14. package/components/filter-bar/filter-bar.interfaces.d.ts +89 -0
  15. package/components/filter-bar/filter-bar.module.d.ts +7 -0
  16. package/components/filter-bar/filter-bar.utils.d.ts +3 -0
  17. package/components/filter-bar/index.d.ts +3 -0
  18. package/components/index.d.ts +2 -0
  19. package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
  20. package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
  21. package/esm2022/components/date-range-calendar/date-range-calendar.component.mjs +206 -0
  22. package/esm2022/components/date-range-calendar/date-range-calendar.interfaces.mjs +2 -0
  23. package/esm2022/components/date-range-calendar/date-range-calendar.module.mjs +16 -0
  24. package/esm2022/components/date-range-calendar/index.mjs +3 -0
  25. package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs +25 -0
  26. package/esm2022/components/filter-bar/components/date-filter/date-filter.component.mjs +147 -0
  27. package/esm2022/components/filter-bar/components/filter-remove-button/filter-remove-button.component.mjs +20 -0
  28. package/esm2022/components/filter-bar/components/index.mjs +8 -0
  29. package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs +70 -0
  30. package/esm2022/components/filter-bar/components/range-filter/range-filter.component.mjs +99 -0
  31. package/esm2022/components/filter-bar/components/select-filter/select-filter.component.mjs +63 -0
  32. package/esm2022/components/filter-bar/components/string-filter/string-filter.component.mjs +66 -0
  33. package/esm2022/components/filter-bar/filter-bar.component.mjs +52 -0
  34. package/esm2022/components/filter-bar/filter-bar.interfaces.mjs +3 -0
  35. package/esm2022/components/filter-bar/filter-bar.module.mjs +16 -0
  36. package/esm2022/components/filter-bar/filter-bar.utils.mjs +114 -0
  37. package/esm2022/components/filter-bar/index.mjs +3 -0
  38. package/esm2022/components/index.mjs +3 -1
  39. package/esm2022/components/input-number/input-number.component.mjs +2 -2
  40. package/esm2022/components/input-password/input-password.component.mjs +2 -2
  41. package/esm2022/components/input-text/input-text.component.mjs +2 -2
  42. package/esm2022/components/input-time/input-time.component.mjs +2 -2
  43. package/esm2022/components/textarea/textarea.component.mjs +2 -2
  44. package/fesm2022/cuby-ui-core.mjs +834 -24
  45. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  46. package/package.json +4 -4
  47. package/styles/mixins/inputs.scss +10 -0
  48. package/widgets/ui/categories/components/category-item/category-item.component.d.ts +2 -2
  49. package/widgets/ui/loader/components/stated-loader/stated-loader.component.d.ts +1 -1
  50. package/widgets/ui/storage-list/components/storage-list-item/storage-list-item.component.d.ts +1 -1
@@ -0,0 +1,206 @@
1
+ import { ChangeDetectionStrategy, Component, computed, effect, input, output, signal } from '@angular/core';
2
+ import { CuiButtonModule } from '../button';
3
+ import { CuiSvgModule } from '../svg';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../button/button.component";
6
+ import * as i2 from "../svg/svg.component";
7
+ export class CuiDateRangeCalendarComponent {
8
+ constructor() {
9
+ /** Selection mode: 'range' for date range, 'single' for single date */
10
+ this.mode = input('range');
11
+ /** Start date of the range */
12
+ this.startDate = input(null);
13
+ /** End date of the range */
14
+ this.endDate = input(null);
15
+ /** Selected date (for single mode) */
16
+ this.selectedDate = input(null);
17
+ /** Emitted when a date range is applied */
18
+ this.rangeSelected = output();
19
+ /** Emitted when a single date is applied */
20
+ this.dateSelected = output();
21
+ /** Emitted when the user cancels */
22
+ this.cancelled = output();
23
+ /** Currently displayed month */
24
+ this.currentMonth = signal(new Date());
25
+ /** Temporary start date (during range selection) */
26
+ this.tmpStartDate = signal(null);
27
+ /** Temporary end date (during range selection) */
28
+ this.tmpEndDate = signal(null);
29
+ /** Temporary selected date (for single mode) */
30
+ this.tmpSelectedDate = signal(null);
31
+ /** Week day labels */
32
+ this.weekDays = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
33
+ /** Current month display name */
34
+ this.currentMonthName = computed(() => {
35
+ const date = this.currentMonth();
36
+ return date.toLocaleDateString('en-US', { month: 'long', year: 'numeric' });
37
+ });
38
+ /** Calendar days grid */
39
+ this.calendarDays = computed(() => {
40
+ const date = this.currentMonth();
41
+ const year = date.getFullYear();
42
+ const month = date.getMonth();
43
+ const firstDay = new Date(year, month, 1);
44
+ const lastDay = new Date(year, month + 1, 0);
45
+ // Get the day of the week for the first day (0 = Sunday, convert so Monday = 0)
46
+ let startDayOfWeek = firstDay.getDay() - 1;
47
+ if (startDayOfWeek < 0) {
48
+ startDayOfWeek = 6;
49
+ }
50
+ const days = [];
51
+ // Add previous month's trailing days
52
+ const prevMonthLastDay = new Date(year, month, 0).getDate();
53
+ for (let i = startDayOfWeek - 1; i >= 0; i--) {
54
+ days.push({
55
+ date: new Date(year, month - 1, prevMonthLastDay - i),
56
+ isCurrentMonth: false
57
+ });
58
+ }
59
+ // Add current month's days
60
+ for (let i = 1; i <= lastDay.getDate(); i++) {
61
+ days.push({
62
+ date: new Date(year, month, i),
63
+ isCurrentMonth: true
64
+ });
65
+ }
66
+ // Add next month's leading days to fill the grid (6 rows x 7 days = 42)
67
+ const remainingDays = 42 - days.length;
68
+ for (let i = 1; i <= remainingDays; i++) {
69
+ days.push({
70
+ date: new Date(year, month + 1, i),
71
+ isCurrentMonth: false
72
+ });
73
+ }
74
+ return days;
75
+ });
76
+ // Initialize temporary values from inputs via effect (signal inputs are not resolved in constructor)
77
+ effect(() => {
78
+ if (this.mode() === 'range') {
79
+ const start = this.startDate();
80
+ const end = this.endDate();
81
+ if (start) {
82
+ this.tmpStartDate.set(start);
83
+ this.currentMonth.set(new Date(start.getFullYear(), start.getMonth(), 1));
84
+ }
85
+ if (end) {
86
+ this.tmpEndDate.set(end);
87
+ }
88
+ }
89
+ else {
90
+ const selected = this.selectedDate();
91
+ if (selected) {
92
+ this.tmpSelectedDate.set(selected);
93
+ this.currentMonth.set(new Date(selected.getFullYear(), selected.getMonth(), 1));
94
+ }
95
+ }
96
+ });
97
+ }
98
+ goToPrevMonth() {
99
+ const current = this.currentMonth();
100
+ this.currentMonth.set(new Date(current.getFullYear(), current.getMonth() - 1, 1));
101
+ }
102
+ goToNextMonth() {
103
+ const current = this.currentMonth();
104
+ this.currentMonth.set(new Date(current.getFullYear(), current.getMonth() + 1, 1));
105
+ }
106
+ selectDate(date) {
107
+ if (this.mode() !== 'range') {
108
+ // Single date mode - just select the date
109
+ this.tmpSelectedDate.set(date);
110
+ return;
111
+ }
112
+ // Range mode
113
+ const start = this.tmpStartDate();
114
+ const end = this.tmpEndDate();
115
+ if (!start || (start && end)) {
116
+ // Start a new selection
117
+ this.tmpStartDate.set(date);
118
+ this.tmpEndDate.set(null);
119
+ }
120
+ else {
121
+ // Complete the selection
122
+ if (date < start) {
123
+ // If selected date is before start, swap them
124
+ this.tmpEndDate.set(start);
125
+ this.tmpStartDate.set(date);
126
+ }
127
+ else {
128
+ this.tmpEndDate.set(date);
129
+ }
130
+ }
131
+ }
132
+ isSelected(date) {
133
+ if (this.mode() !== 'range') {
134
+ // Single date mode
135
+ const selected = this.tmpSelectedDate();
136
+ return selected !== null && this.isSameDay(date, selected);
137
+ }
138
+ // Range mode
139
+ const start = this.tmpStartDate();
140
+ const end = this.tmpEndDate();
141
+ if (start && this.isSameDay(date, start)) {
142
+ return true;
143
+ }
144
+ if (end && this.isSameDay(date, end)) {
145
+ return true;
146
+ }
147
+ return false;
148
+ }
149
+ isInRange(date) {
150
+ const start = this.tmpStartDate();
151
+ const end = this.tmpEndDate();
152
+ if (!start || !end) {
153
+ return false;
154
+ }
155
+ return date > start && date < end;
156
+ }
157
+ isRangeStart(date) {
158
+ const start = this.tmpStartDate();
159
+ return start !== null && this.isSameDay(date, start);
160
+ }
161
+ isRangeEnd(date) {
162
+ const end = this.tmpEndDate();
163
+ return end !== null && this.isSameDay(date, end);
164
+ }
165
+ isToday(date) {
166
+ return this.isSameDay(date, new Date());
167
+ }
168
+ apply() {
169
+ if (this.mode() !== 'range') {
170
+ // Single date mode
171
+ const selected = this.tmpSelectedDate();
172
+ if (selected) {
173
+ this.dateSelected.emit(selected);
174
+ }
175
+ }
176
+ else {
177
+ // Range mode
178
+ const start = this.tmpStartDate();
179
+ const end = this.tmpEndDate();
180
+ if (start && end) {
181
+ this.rangeSelected.emit({ start, end });
182
+ }
183
+ }
184
+ }
185
+ cancel() {
186
+ this.cancelled.emit();
187
+ }
188
+ hasSelection() {
189
+ if (this.mode() !== 'range') {
190
+ return this.tmpSelectedDate() !== null;
191
+ }
192
+ return this.tmpStartDate() !== null;
193
+ }
194
+ isSameDay(date1, date2) {
195
+ return (date1.getFullYear() === date2.getFullYear() &&
196
+ date1.getMonth() === date2.getMonth() &&
197
+ date1.getDate() === date2.getDate());
198
+ }
199
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
200
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiDateRangeCalendarComponent, isStandalone: true, selector: "cui-date-range-calendar", inputs: { mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, startDate: { classPropertyName: "startDate", publicName: "startDate", isSignal: true, isRequired: false, transformFunction: null }, endDate: { classPropertyName: "endDate", publicName: "endDate", isSignal: true, isRequired: false, transformFunction: null }, selectedDate: { classPropertyName: "selectedDate", publicName: "selectedDate", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { rangeSelected: "rangeSelected", dateSelected: "dateSelected", cancelled: "cancelled" }, ngImport: i0, template: "<div class=\"cui-calendar\">\n <div class=\"cui-calendar__header\">\n <button\n type=\"button\"\n class=\"cui-calendar__nav-btn\"\n (click)=\"goToPrevMonth()\"\n >\n <cui-svg icon=\"cuiIconChevronLeft\" />\n </button>\n <span class=\"cui-calendar__month-name\">{{ currentMonthName() }}</span>\n <button\n type=\"button\"\n class=\"cui-calendar__nav-btn\"\n (click)=\"goToNextMonth()\"\n >\n <cui-svg icon=\"cuiIconChevronRight\" />\n </button>\n </div>\n\n <div class=\"cui-calendar__weekdays\">\n @for (day of weekDays; track day) {\n <div class=\"cui-calendar__weekday\">{{ day }}</div>\n }\n </div>\n\n <div class=\"cui-calendar__days\">\n @for (day of calendarDays(); track day.date.getTime()) {\n <button\n type=\"button\"\n class=\"cui-calendar__day\"\n [class.cui-calendar__day--other-month]=\"!day.isCurrentMonth\"\n [class.cui-calendar__day--selected]=\"isSelected(day.date)\"\n [class.cui-calendar__day--in-range]=\"isInRange(day.date)\"\n [class.cui-calendar__day--range-start]=\"isRangeStart(day.date)\"\n [class.cui-calendar__day--range-end]=\"isRangeEnd(day.date)\"\n [class.cui-calendar__day--today]=\"isToday(day.date)\"\n (click)=\"selectDate(day.date)\"\n >\n {{ day.date.getDate() }}\n </button>\n }\n </div>\n\n <div class=\"cui-calendar__footer\">\n <button\n type=\"button\"\n cuiButton\n appearance=\"secondary\"\n (click)=\"cancel()\"\n >\n Cancel\n </button>\n <button\n type=\"button\"\n cuiButton\n appearance=\"action\"\n [disabled]=\"!hasSelection()\"\n (click)=\"apply()\"\n >\n Apply\n </button>\n </div>\n</div>\n", styles: [".cui-calendar{display:flex;flex-direction:column;padding:12px;min-width:280px}.cui-calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cui-calendar__nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s}.cui-calendar__nav-btn:hover{background:var(--cui-base-100)}.cui-calendar__month-name{font-weight:500;font-size:14px;line-height:20px;color:var(--cui-base-900)}.cui-calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.cui-calendar__weekday{font-weight:500;font-size:12px;line-height:14px;display:flex;align-items:center;justify-content:center;height:32px;color:var(--cui-base-500)}.cui-calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cui-calendar__day{font-weight:400;font-size:13px;line-height:16px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s;color:var(--cui-base-900)}.cui-calendar__day:hover{background:var(--cui-base-100)}.cui-calendar__day--other-month{color:var(--cui-base-400)}.cui-calendar__day--today{font-weight:600;border:1px solid var(--cui-base-300)}.cui-calendar__day--selected{background:var(--cui-light-blue-600);color:var(--cui-base-0)}.cui-calendar__day--selected:hover{background:var(--cui-light-blue-700)}.cui-calendar__day--in-range{background:var(--cui-lavender-bg);border-radius:0}.cui-calendar__day--in-range:hover{background:var(--cui-base-200)}.cui-calendar__day--range-start{border-radius:6px 0 0 6px}.cui-calendar__day--range-end{border-radius:0 6px 6px 0}.cui-calendar__day--range-start.cui-calendar__day--range-end{border-radius:6px}.cui-calendar__footer{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--cui-base-200)}\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: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i2.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
201
+ }
202
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarComponent, decorators: [{
203
+ type: Component,
204
+ args: [{ selector: 'cui-date-range-calendar', standalone: true, imports: [CuiButtonModule, CuiSvgModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cui-calendar\">\n <div class=\"cui-calendar__header\">\n <button\n type=\"button\"\n class=\"cui-calendar__nav-btn\"\n (click)=\"goToPrevMonth()\"\n >\n <cui-svg icon=\"cuiIconChevronLeft\" />\n </button>\n <span class=\"cui-calendar__month-name\">{{ currentMonthName() }}</span>\n <button\n type=\"button\"\n class=\"cui-calendar__nav-btn\"\n (click)=\"goToNextMonth()\"\n >\n <cui-svg icon=\"cuiIconChevronRight\" />\n </button>\n </div>\n\n <div class=\"cui-calendar__weekdays\">\n @for (day of weekDays; track day) {\n <div class=\"cui-calendar__weekday\">{{ day }}</div>\n }\n </div>\n\n <div class=\"cui-calendar__days\">\n @for (day of calendarDays(); track day.date.getTime()) {\n <button\n type=\"button\"\n class=\"cui-calendar__day\"\n [class.cui-calendar__day--other-month]=\"!day.isCurrentMonth\"\n [class.cui-calendar__day--selected]=\"isSelected(day.date)\"\n [class.cui-calendar__day--in-range]=\"isInRange(day.date)\"\n [class.cui-calendar__day--range-start]=\"isRangeStart(day.date)\"\n [class.cui-calendar__day--range-end]=\"isRangeEnd(day.date)\"\n [class.cui-calendar__day--today]=\"isToday(day.date)\"\n (click)=\"selectDate(day.date)\"\n >\n {{ day.date.getDate() }}\n </button>\n }\n </div>\n\n <div class=\"cui-calendar__footer\">\n <button\n type=\"button\"\n cuiButton\n appearance=\"secondary\"\n (click)=\"cancel()\"\n >\n Cancel\n </button>\n <button\n type=\"button\"\n cuiButton\n appearance=\"action\"\n [disabled]=\"!hasSelection()\"\n (click)=\"apply()\"\n >\n Apply\n </button>\n </div>\n</div>\n", styles: [".cui-calendar{display:flex;flex-direction:column;padding:12px;min-width:280px}.cui-calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cui-calendar__nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s}.cui-calendar__nav-btn:hover{background:var(--cui-base-100)}.cui-calendar__month-name{font-weight:500;font-size:14px;line-height:20px;color:var(--cui-base-900)}.cui-calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.cui-calendar__weekday{font-weight:500;font-size:12px;line-height:14px;display:flex;align-items:center;justify-content:center;height:32px;color:var(--cui-base-500)}.cui-calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cui-calendar__day{font-weight:400;font-size:13px;line-height:16px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s;color:var(--cui-base-900)}.cui-calendar__day:hover{background:var(--cui-base-100)}.cui-calendar__day--other-month{color:var(--cui-base-400)}.cui-calendar__day--today{font-weight:600;border:1px solid var(--cui-base-300)}.cui-calendar__day--selected{background:var(--cui-light-blue-600);color:var(--cui-base-0)}.cui-calendar__day--selected:hover{background:var(--cui-light-blue-700)}.cui-calendar__day--in-range{background:var(--cui-lavender-bg);border-radius:0}.cui-calendar__day--in-range:hover{background:var(--cui-base-200)}.cui-calendar__day--range-start{border-radius:6px 0 0 6px}.cui-calendar__day--range-end{border-radius:0 6px 6px 0}.cui-calendar__day--range-start.cui-calendar__day--range-end{border-radius:6px}.cui-calendar__footer{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--cui-base-200)}\n"] }]
205
+ }], ctorParameters: () => [] });
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-calendar.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/date-range-calendar/date-range-calendar.component.ts","../../../../../projects/core/components/date-range-calendar/date-range-calendar.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, output, signal } from '@angular/core';\n\nimport { CuiButtonModule } from '../button';\nimport { CuiSvgModule } from '../svg';\n\nimport type { CuiDateRangeCalendarMode } from './date-range-calendar.interfaces';\n\n@Component({\n    selector: 'cui-date-range-calendar',\n    standalone: true,\n    imports: [CuiButtonModule, CuiSvgModule],\n    templateUrl: './date-range-calendar.template.html',\n    styleUrls: ['./date-range-calendar.style.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiDateRangeCalendarComponent {\n    /** Selection mode: 'range' for date range, 'single' for single date */\n    public readonly mode = input<CuiDateRangeCalendarMode>('range');\n\n    /** Start date of the range */\n    public readonly startDate = input<Date | null>(null);\n\n    /** End date of the range */\n    public readonly endDate = input<Date | null>(null);\n\n    /** Selected date (for single mode) */\n    public readonly selectedDate = input<Date | null>(null);\n\n    /** Emitted when a date range is applied */\n    public readonly rangeSelected = output<{ start: Date; end: Date }>();\n\n    /** Emitted when a single date is applied */\n    public readonly dateSelected = output<Date>();\n\n    /** Emitted when the user cancels */\n    public readonly cancelled = output<void>();\n\n    /** Currently displayed month */\n    protected readonly currentMonth = signal(new Date());\n\n    /** Temporary start date (during range selection) */\n    protected readonly tmpStartDate = signal<Date | null>(null);\n\n    /** Temporary end date (during range selection) */\n    protected readonly tmpEndDate = signal<Date | null>(null);\n\n    /** Temporary selected date (for single mode) */\n    protected readonly tmpSelectedDate = signal<Date | null>(null);\n\n    /** Week day labels */\n    protected readonly weekDays = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];\n\n    /** Current month display name */\n    protected readonly currentMonthName = computed(() => {\n        const date = this.currentMonth();\n\n        return date.toLocaleDateString('en-US', { month: 'long', year: 'numeric' });\n    });\n\n    /** Calendar days grid */\n    protected readonly calendarDays = computed(() => {\n        const date = this.currentMonth();\n        const year = date.getFullYear();\n        const month = date.getMonth();\n\n        const firstDay = new Date(year, month, 1);\n        const lastDay = new Date(year, month + 1, 0);\n\n        // Get the day of the week for the first day (0 = Sunday, convert so Monday = 0)\n        let startDayOfWeek = firstDay.getDay() - 1;\n\n        if (startDayOfWeek < 0) {\n            startDayOfWeek = 6;\n        }\n\n        const days: { date: Date; isCurrentMonth: boolean }[] = [];\n\n        // Add previous month's trailing days\n        const prevMonthLastDay = new Date(year, month, 0).getDate();\n\n        for (let i = startDayOfWeek - 1; i >= 0; i--) {\n            days.push({\n                date: new Date(year, month - 1, prevMonthLastDay - i),\n                isCurrentMonth: false\n            });\n        }\n\n        // Add current month's days\n        for (let i = 1; i <= lastDay.getDate(); i++) {\n            days.push({\n                date: new Date(year, month, i),\n                isCurrentMonth: true\n            });\n        }\n\n        // Add next month's leading days to fill the grid (6 rows x 7 days = 42)\n        const remainingDays = 42 - days.length;\n\n        for (let i = 1; i <= remainingDays; i++) {\n            days.push({\n                date: new Date(year, month + 1, i),\n                isCurrentMonth: false\n            });\n        }\n\n        return days;\n    });\n\n    constructor() {\n        // Initialize temporary values from inputs via effect (signal inputs are not resolved in constructor)\n        effect(() => {\n            if (this.mode() === 'range') {\n                const start = this.startDate();\n                const end = this.endDate();\n\n                if (start) {\n                    this.tmpStartDate.set(start);\n                    this.currentMonth.set(new Date(start.getFullYear(), start.getMonth(), 1));\n                }\n\n                if (end) {\n                    this.tmpEndDate.set(end);\n                }\n            } else {\n                const selected = this.selectedDate();\n\n                if (selected) {\n                    this.tmpSelectedDate.set(selected);\n                    this.currentMonth.set(new Date(selected.getFullYear(), selected.getMonth(), 1));\n                }\n            }\n        });\n    }\n\n    protected goToPrevMonth(): void {\n        const current = this.currentMonth();\n        this.currentMonth.set(new Date(current.getFullYear(), current.getMonth() - 1, 1));\n    }\n\n    protected goToNextMonth(): void {\n        const current = this.currentMonth();\n        this.currentMonth.set(new Date(current.getFullYear(), current.getMonth() + 1, 1));\n    }\n\n    protected selectDate(date: Date): void {\n        if (this.mode() !== 'range') {\n            // Single date mode - just select the date\n            this.tmpSelectedDate.set(date);\n\n            return;\n        }\n\n        // Range mode\n        const start = this.tmpStartDate();\n        const end = this.tmpEndDate();\n\n        if (!start || (start && end)) {\n            // Start a new selection\n            this.tmpStartDate.set(date);\n            this.tmpEndDate.set(null);\n        } else {\n            // Complete the selection\n            if (date < start) {\n                // If selected date is before start, swap them\n                this.tmpEndDate.set(start);\n                this.tmpStartDate.set(date);\n            } else {\n                this.tmpEndDate.set(date);\n            }\n        }\n    }\n\n    protected isSelected(date: Date): boolean {\n        if (this.mode() !== 'range') {\n            // Single date mode\n            const selected = this.tmpSelectedDate();\n\n            return selected !== null && this.isSameDay(date, selected);\n        }\n\n        // Range mode\n        const start = this.tmpStartDate();\n        const end = this.tmpEndDate();\n\n        if (start && this.isSameDay(date, start)) {\n            return true;\n        }\n\n        if (end && this.isSameDay(date, end)) {\n            return true;\n        }\n\n        return false;\n    }\n\n    protected isInRange(date: Date): boolean {\n        const start = this.tmpStartDate();\n        const end = this.tmpEndDate();\n\n        if (!start || !end) {\n            return false;\n        }\n\n        return date > start && date < end;\n    }\n\n    protected isRangeStart(date: Date): boolean {\n        const start = this.tmpStartDate();\n\n        return start !== null && this.isSameDay(date, start);\n    }\n\n    protected isRangeEnd(date: Date): boolean {\n        const end = this.tmpEndDate();\n\n        return end !== null && this.isSameDay(date, end);\n    }\n\n    protected isToday(date: Date): boolean {\n        return this.isSameDay(date, new Date());\n    }\n\n    protected apply(): void {\n        if (this.mode() !== 'range') {\n            // Single date mode\n            const selected = this.tmpSelectedDate();\n\n            if (selected) {\n                this.dateSelected.emit(selected);\n            }\n        } else {\n            // Range mode\n            const start = this.tmpStartDate();\n            const end = this.tmpEndDate();\n\n            if (start && end) {\n                this.rangeSelected.emit({ start, end });\n            }\n        }\n    }\n\n    protected cancel(): void {\n        this.cancelled.emit();\n    }\n\n    protected hasSelection(): boolean {\n        if (this.mode() !== 'range') {\n            return this.tmpSelectedDate() !== null;\n        }\n\n        return this.tmpStartDate() !== null;\n    }\n\n    private isSameDay(date1: Date, date2: Date): boolean {\n        return (\n            date1.getFullYear() === date2.getFullYear() &&\n            date1.getMonth() === date2.getMonth() &&\n            date1.getDate() === date2.getDate()\n        );\n    }\n}\n","<div class=\"cui-calendar\">\n    <div class=\"cui-calendar__header\">\n        <button\n            type=\"button\"\n            class=\"cui-calendar__nav-btn\"\n            (click)=\"goToPrevMonth()\"\n        >\n            <cui-svg icon=\"cuiIconChevronLeft\" />\n        </button>\n        <span class=\"cui-calendar__month-name\">{{ currentMonthName() }}</span>\n        <button\n            type=\"button\"\n            class=\"cui-calendar__nav-btn\"\n            (click)=\"goToNextMonth()\"\n        >\n            <cui-svg icon=\"cuiIconChevronRight\" />\n        </button>\n    </div>\n\n    <div class=\"cui-calendar__weekdays\">\n        @for (day of weekDays; track day) {\n            <div class=\"cui-calendar__weekday\">{{ day }}</div>\n        }\n    </div>\n\n    <div class=\"cui-calendar__days\">\n        @for (day of calendarDays(); track day.date.getTime()) {\n            <button\n                type=\"button\"\n                class=\"cui-calendar__day\"\n                [class.cui-calendar__day--other-month]=\"!day.isCurrentMonth\"\n                [class.cui-calendar__day--selected]=\"isSelected(day.date)\"\n                [class.cui-calendar__day--in-range]=\"isInRange(day.date)\"\n                [class.cui-calendar__day--range-start]=\"isRangeStart(day.date)\"\n                [class.cui-calendar__day--range-end]=\"isRangeEnd(day.date)\"\n                [class.cui-calendar__day--today]=\"isToday(day.date)\"\n                (click)=\"selectDate(day.date)\"\n            >\n                {{ day.date.getDate() }}\n            </button>\n        }\n    </div>\n\n    <div class=\"cui-calendar__footer\">\n        <button\n            type=\"button\"\n            cuiButton\n            appearance=\"secondary\"\n            (click)=\"cancel()\"\n        >\n            Cancel\n        </button>\n        <button\n            type=\"button\"\n            cuiButton\n            appearance=\"action\"\n            [disabled]=\"!hasSelection()\"\n            (click)=\"apply()\"\n        >\n            Apply\n        </button>\n    </div>\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1jYWxlbmRhci5pbnRlcmZhY2VzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2RhdGUtcmFuZ2UtY2FsZW5kYXIvZGF0ZS1yYW5nZS1jYWxlbmRhci5pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBDdWlEYXRlUmFuZ2VDYWxlbmRhck1vZGUgPSAnc2luZ2xlJyB8ICdyYW5nZSc7XG4iXX0=
@@ -0,0 +1,16 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CuiDateRangeCalendarComponent } from './date-range-calendar.component';
3
+ import * as i0 from "@angular/core";
4
+ export class CuiDateRangeCalendarModule {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarModule, imports: [CuiDateRangeCalendarComponent], exports: [CuiDateRangeCalendarComponent] }); }
7
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarModule, imports: [CuiDateRangeCalendarComponent] }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateRangeCalendarModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ imports: [CuiDateRangeCalendarComponent],
13
+ exports: [CuiDateRangeCalendarComponent]
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1jYWxlbmRhci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGF0ZS1yYW5nZS1jYWxlbmRhci9kYXRlLXJhbmdlLWNhbGVuZGFyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQU1oRixNQUFNLE9BQU8sMEJBQTBCOytHQUExQiwwQkFBMEI7Z0hBQTFCLDBCQUEwQixZQUh6Qiw2QkFBNkIsYUFDN0IsNkJBQTZCO2dIQUU5QiwwQkFBMEIsWUFIekIsNkJBQTZCOzs0RkFHOUIsMEJBQTBCO2tCQUp0QyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLDZCQUE2QixDQUFDO29CQUN4QyxPQUFPLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztpQkFDM0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3VpRGF0ZVJhbmdlQ2FsZW5kYXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtcmFuZ2UtY2FsZW5kYXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ3VpRGF0ZVJhbmdlQ2FsZW5kYXJDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtDdWlEYXRlUmFuZ2VDYWxlbmRhckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQ3VpRGF0ZVJhbmdlQ2FsZW5kYXJNb2R1bGUge30iXX0=
@@ -0,0 +1,3 @@
1
+ export { CuiDateRangeCalendarComponent } from './date-range-calendar.component';
2
+ export { CuiDateRangeCalendarModule } from './date-range-calendar.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZGF0ZS1yYW5nZS1jYWxlbmRhci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEN1aURhdGVSYW5nZUNhbGVuZGFyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXJhbmdlLWNhbGVuZGFyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDdWlEYXRlUmFuZ2VDYWxlbmRhck1vZHVsZSB9IGZyb20gJy4vZGF0ZS1yYW5nZS1jYWxlbmRhci5tb2R1bGUnO1xuZXhwb3J0IHR5cGUgeyBDdWlEYXRlUmFuZ2VDYWxlbmRhck1vZGUgfSBmcm9tICcuL2RhdGUtcmFuZ2UtY2FsZW5kYXIuaW50ZXJmYWNlcyc7XG4iXX0=
@@ -0,0 +1,25 @@
1
+ import { ChangeDetectionStrategy, Component, input, output } from '@angular/core';
2
+ import { TranslocoPipe } from '@jsverse/transloco';
3
+ import { CuiButtonModule } from '../../../../components/button';
4
+ import { CuiDropdownDirective } from '../../../../components/dropdown';
5
+ import { CuiSvgModule } from '../../../../components/svg';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../button/button.component";
8
+ import * as i2 from "../../../svg/svg.component";
9
+ export class CuiAddFilterButtonComponent {
10
+ constructor() {
11
+ this.availableFields = input.required();
12
+ this.fieldSelected = output();
13
+ }
14
+ selectField(field, dropdown) {
15
+ this.fieldSelected.emit(field);
16
+ dropdown.close();
17
+ }
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 }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiAddFilterButtonComponent, decorators: [{
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"] }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLWZpbHRlci1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9hZGQtZmlsdGVyLWJ1dHRvbi9hZGQtZmlsdGVyLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2FkZC1maWx0ZXItYnV0dG9uL2FkZC1maWx0ZXItYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7O0FBVzFELE1BQU0sT0FBTywyQkFBMkI7SUFSeEM7UUFTb0Isb0JBQWUsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFvQixDQUFDO1FBRXJELGtCQUFhLEdBQUcsTUFBTSxFQUFrQixDQUFDO0tBTTVEO0lBSmEsV0FBVyxDQUFDLEtBQXFCLEVBQUUsUUFBOEI7UUFDdkUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3JCLENBQUM7K0dBUlEsMkJBQTJCO21HQUEzQiwyQkFBMkIsK1JDaEJ4Qyw0NkJBOEJNLHN5QkRuQlEsZUFBZSxvT0FBRSxvQkFBb0IsbUpBQUUsWUFBWSxtS0FBRSxhQUFhOzs0RkFLbkUsMkJBQTJCO2tCQVJ2QyxTQUFTOytCQUNJLHVCQUF1QixjQUNyQixJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsb0JBQW9CLEVBQUUsWUFBWSxFQUFFLGFBQWEsQ0FBQyxtQkFHNUQsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbG9jb1BpcGUgfSBmcm9tICdAanN2ZXJzZS90cmFuc2xvY28nO1xuXG5pbXBvcnQgeyBDdWlCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQgeyBDdWlEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvZHJvcGRvd24nO1xuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9zdmcnO1xuaW1wb3J0IHR5cGUgeyBDdWlGaWx0ZXJGaWVsZCB9IGZyb20gJy4uLy4uL2ZpbHRlci1iYXIuaW50ZXJmYWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnY3VpLWFkZC1maWx0ZXItYnV0dG9uJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDdWlCdXR0b25Nb2R1bGUsIEN1aURyb3Bkb3duRGlyZWN0aXZlLCBDdWlTdmdNb2R1bGUsIFRyYW5zbG9jb1BpcGVdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9hZGQtZmlsdGVyLWJ1dHRvbi50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9hZGQtZmlsdGVyLWJ1dHRvbi5zdHlsZS5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQ3VpQWRkRmlsdGVyQnV0dG9uQ29tcG9uZW50IHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgYXZhaWxhYmxlRmllbGRzID0gaW5wdXQucmVxdWlyZWQ8Q3VpRmlsdGVyRmllbGRbXT4oKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBmaWVsZFNlbGVjdGVkID0gb3V0cHV0PEN1aUZpbHRlckZpZWxkPigpO1xuXG4gICAgcHJvdGVjdGVkIHNlbGVjdEZpZWxkKGZpZWxkOiBDdWlGaWx0ZXJGaWVsZCwgZHJvcGRvd246IEN1aURyb3Bkb3duRGlyZWN0aXZlKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZmllbGRTZWxlY3RlZC5lbWl0KGZpZWxkKTtcbiAgICAgICAgZHJvcGRvd24uY2xvc2UoKTtcbiAgICB9XG59IiwiPGRpdiBjbGFzcz1cImN1aS1hZGQtZmlsdGVyXCI+XG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fYnRuXCJcbiAgICAgICAgY3VpQnV0dG9uXG4gICAgICAgIHNpemU9XCJ4eHNcIlxuICAgICAgICBhcHBlYXJhbmNlPVwib3V0bGluZWRcIlxuICAgICAgICBbY3VpRHJvcGRvd25dPVwiZHJvcGRvd25UcGxcIlxuICAgICAgICAjZHJvcGRvd249XCJjdWlEcm9wZG93blwiXG4gICAgPlxuICAgICAgICA8Y3VpLXN2Z1xuICAgICAgICAgICAgaWNvbj1cImN1aUljb25QbHVzU21cIlxuICAgICAgICAgICAgW3dpZHRoXT1cIjE2XCJcbiAgICAgICAgICAgIGNvbG9yPVwidmFyKC0tY3VpLWluZm8pXCJcbiAgICAgICAgLz5cbiAgICAgICAge3sgJ0FERF9GSUxURVInIHwgdHJhbnNsb2NvIH19XG4gICAgPC9idXR0b24+XG4gICAgPG5nLXRlbXBsYXRlICNkcm9wZG93blRwbD5cbiAgICAgICAgPGRpdiBjbGFzcz1cImN1aS1hZGQtZmlsdGVyX19kcm9wZG93blwiPlxuICAgICAgICAgICAgQGZvciAoZmllbGQgb2YgYXZhaWxhYmxlRmllbGRzKCk7IHRyYWNrIGZpZWxkLmlkKSB7XG4gICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJjdWktYWRkLWZpbHRlcl9fZHJvcGRvd24taXRlbVwiXG4gICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJzZWxlY3RGaWVsZChmaWVsZCwgZHJvcGRvd24pXCJcbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHt7IGZpZWxkLmxhYmVsIHwgdHJhbnNsb2NvIH19XG4gICAgICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgICAgICB9XG4gICAgICAgIDwvZGl2PlxuICAgIDwvbmctdGVtcGxhdGU+XG48L2Rpdj4iXX0=
@@ -0,0 +1,147 @@
1
+ import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
2
+ import { CuiButtonModule } from '../../../../components/button';
3
+ import { CuiDateRangeCalendarComponent } from '../../../date-range-calendar';
4
+ import { CuiDropdownDirective } from '../../../../components/dropdown';
5
+ import { CuiSvgModule } from '../../../../components/svg';
6
+ import { CuiFilterRemoveButtonComponent } from '../filter-remove-button/filter-remove-button.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../../svg/svg.component";
9
+ const DEFAULT_OPERATOR_LABELS = {
10
+ on: 'On',
11
+ before: 'Before',
12
+ after: 'After',
13
+ between: 'Between'
14
+ };
15
+ export class CuiDateFilterComponent {
16
+ constructor() {
17
+ this.filter = input.required();
18
+ this.removed = output();
19
+ this.changed = output();
20
+ this.operatorOptions = computed(() => {
21
+ const field = this.filter().field;
22
+ const operators = field.dateOperators ?? ['on', 'before', 'after', 'between'];
23
+ return operators.map((op) => ({
24
+ value: op,
25
+ label: field.operatorLabels?.[op] ?? DEFAULT_OPERATOR_LABELS[op]
26
+ }));
27
+ });
28
+ this.currentOperator = computed(() => {
29
+ const f = this.filter();
30
+ return f.value.type === 'date' ? f.value.operator : 'on';
31
+ });
32
+ this.operatorLabel = computed(() => {
33
+ const options = this.operatorOptions();
34
+ const op = options.find((o) => o.value === this.currentOperator());
35
+ return op?.label ?? '';
36
+ });
37
+ this.dateLabel = computed(() => {
38
+ const f = this.filter();
39
+ if (f.value.type !== 'date') {
40
+ return '';
41
+ }
42
+ const dateValue = f.value;
43
+ if (dateValue.operator === 'between') {
44
+ if (dateValue.rangeStart && dateValue.rangeEnd) {
45
+ return `${this.formatDate(dateValue.rangeStart)} - ${this.formatDate(dateValue.rangeEnd)}`;
46
+ }
47
+ return '';
48
+ }
49
+ return dateValue.value ? this.formatDate(dateValue.value) : '';
50
+ });
51
+ this.hasValue = computed(() => {
52
+ const f = this.filter();
53
+ if (f.value.type !== 'date') {
54
+ return false;
55
+ }
56
+ if (f.value.operator === 'between') {
57
+ return !!f.value.rangeStart && !!f.value.rangeEnd;
58
+ }
59
+ return !!f.value.value;
60
+ });
61
+ this.rangeStart = computed(() => {
62
+ const f = this.filter();
63
+ return f.value.type === 'date' && f.value.rangeStart ? new Date(f.value.rangeStart) : null;
64
+ });
65
+ this.rangeEnd = computed(() => {
66
+ const f = this.filter();
67
+ return f.value.type === 'date' && f.value.rangeEnd ? new Date(f.value.rangeEnd) : null;
68
+ });
69
+ this.selectedDate = computed(() => {
70
+ const f = this.filter();
71
+ return f.value.type === 'date' && f.value.value ? new Date(f.value.value) : null;
72
+ });
73
+ this.calendarMode = computed(() => (this.currentOperator() === 'between' ? 'range' : 'single'));
74
+ }
75
+ onRemove() {
76
+ this.removed.emit(this.filter().id);
77
+ }
78
+ selectOperator(operator, dropdown) {
79
+ const f = this.filter();
80
+ if (f.value.type !== 'date') {
81
+ return;
82
+ }
83
+ const isBetween = operator === 'between';
84
+ const updated = {
85
+ ...f,
86
+ value: {
87
+ type: 'date',
88
+ operator,
89
+ value: isBetween ? null : f.value.value,
90
+ rangeStart: isBetween ? f.value.rangeStart : null,
91
+ rangeEnd: isBetween ? f.value.rangeEnd : null
92
+ }
93
+ };
94
+ this.changed.emit(updated);
95
+ dropdown.close();
96
+ }
97
+ onRangeSelected(range, dropdown) {
98
+ const f = this.filter();
99
+ if (f.value.type !== 'date') {
100
+ return;
101
+ }
102
+ this.changed.emit({
103
+ ...f,
104
+ value: {
105
+ type: 'date',
106
+ operator: 'between',
107
+ value: null,
108
+ rangeStart: range.start,
109
+ rangeEnd: range.end
110
+ }
111
+ });
112
+ dropdown.close();
113
+ }
114
+ onSingleDateSelected(date, dropdown) {
115
+ const f = this.filter();
116
+ if (f.value.type !== 'date') {
117
+ return;
118
+ }
119
+ this.changed.emit({
120
+ ...f,
121
+ value: {
122
+ type: 'date',
123
+ operator: f.value.operator,
124
+ value: date,
125
+ rangeStart: null,
126
+ rangeEnd: null
127
+ }
128
+ });
129
+ dropdown.close();
130
+ }
131
+ formatDate(date) {
132
+ return date.toLocaleDateString();
133
+ }
134
+ 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
+ }
137
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiDateFilterComponent, decorators: [{
138
+ type: Component,
139
+ args: [{ selector: 'cui-date-filter', standalone: true, imports: [
140
+ CuiButtonModule,
141
+ CuiDateRangeCalendarComponent,
142
+ CuiDropdownDirective,
143
+ CuiFilterRemoveButtonComponent,
144
+ CuiSvgModule
145
+ ], 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
+ //# 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"]}
@@ -0,0 +1,20 @@
1
+ import { ChangeDetectionStrategy, Component, input, output } from '@angular/core';
2
+ import { CuiSvgModule } from '../../../../components/svg';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../../svg/svg.component";
5
+ export class CuiFilterRemoveButtonComponent {
6
+ constructor() {
7
+ this.label = input.required();
8
+ this.removed = output();
9
+ }
10
+ onRemove() {
11
+ this.removed.emit();
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterRemoveButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
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 }); }
15
+ }
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiFilterRemoveButtonComponent, decorators: [{
17
+ type: Component,
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"] }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLXJlbW92ZS1idXR0b24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2ZpbHRlci1iYXIvY29tcG9uZW50cy9maWx0ZXItcmVtb3ZlLWJ1dHRvbi9maWx0ZXItcmVtb3ZlLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2ZpbHRlci1yZW1vdmUtYnV0dG9uL2ZpbHRlci1yZW1vdmUtYnV0dG9uLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBVTFELE1BQU0sT0FBTyw4QkFBOEI7SUFSM0M7UUFTb0IsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUVqQyxZQUFPLEdBQUcsTUFBTSxFQUFRLENBQUM7S0FLNUM7SUFIVSxRQUFRO1FBQ1gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN4QixDQUFDOytHQVBRLDhCQUE4QjttR0FBOUIsOEJBQThCLHdQQ1ozQyx5UUFVQSxtakJESGMsWUFBWTs7NEZBS2IsOEJBQThCO2tCQVIxQyxTQUFTOytCQUNJLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsbUJBR04sdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQ3VpU3ZnTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vY29tcG9uZW50cy9zdmcnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2N1aS1maWx0ZXItcmVtb3ZlLWJ1dHRvbicsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ3VpU3ZnTW9kdWxlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZmlsdGVyLXJlbW92ZS1idXR0b24udGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLXJlbW92ZS1idXR0b24uc3R5bGUuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEN1aUZpbHRlclJlbW92ZUJ1dHRvbkNvbXBvbmVudCB7XG4gICAgcHVibGljIHJlYWRvbmx5IGxhYmVsID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IHJlbW92ZWQgPSBvdXRwdXQ8dm9pZD4oKTtcblxuICAgIHB1YmxpYyBvblJlbW92ZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZW1vdmVkLmVtaXQoKTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgY2xhc3M9XCJmaWx0ZXItcmVtb3ZlLWJ1dHRvblwiXG4+XG4gICAgPGN1aS1zdmdcbiAgICAgICAgaWNvbj1cImN1aUljb25WZWN0b3JcIlxuICAgICAgICAoY2xpY2spPVwib25SZW1vdmUoKTsgJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCJcbiAgICAvPlxuICAgIDxzcGFuIGNsYXNzPVwiZmlsdGVyLXJlbW92ZS1idXR0b25fX2xhYmVsXCI+e3sgbGFiZWwoKSB9fTo8L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ export { CuiStringFilterComponent } from './string-filter/string-filter.component';
2
+ export { CuiRangeFilterComponent } from './range-filter/range-filter.component';
3
+ export { CuiSelectFilterComponent } from './select-filter/select-filter.component';
4
+ export { CuiMultiSelectFilterComponent } from './multiselect-filter/multiselect-filter.component';
5
+ export { CuiAddFilterButtonComponent } from './add-filter-button/add-filter-button.component';
6
+ export { CuiFilterRemoveButtonComponent } from './filter-remove-button/filter-remove-button.component';
7
+ export { CuiDateFilterComponent } from './date-filter/date-filter.component';
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvZmlsdGVyLWJhci9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ25GLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ25GLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLHVEQUF1RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpU3RyaW5nRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9zdHJpbmctZmlsdGVyL3N0cmluZy1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IEN1aVJhbmdlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9yYW5nZS1maWx0ZXIvcmFuZ2UtZmlsdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDdWlTZWxlY3RGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC1maWx0ZXIvc2VsZWN0LWZpbHRlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgQ3VpTXVsdGlTZWxlY3RGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuL211bHRpc2VsZWN0LWZpbHRlci9tdWx0aXNlbGVjdC1maWx0ZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IEN1aUFkZEZpbHRlckJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYWRkLWZpbHRlci1idXR0b24vYWRkLWZpbHRlci1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCB7IEN1aUZpbHRlclJlbW92ZUJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vZmlsdGVyLXJlbW92ZS1idXR0b24vZmlsdGVyLXJlbW92ZS1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCB7IEN1aURhdGVGaWx0ZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtZmlsdGVyL2RhdGUtZmlsdGVyLmNvbXBvbmVudCc7Il19