@cuby-ui/core 0.0.558 → 0.0.561
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/date-range-calendar/date-range-calendar.component.d.ts +53 -0
- package/components/date-range-calendar/date-range-calendar.interfaces.d.ts +1 -0
- package/components/date-range-calendar/date-range-calendar.module.d.ts +7 -0
- package/components/date-range-calendar/index.d.ts +3 -0
- package/components/filter-bar/components/add-filter-button/add-filter-button.component.d.ts +10 -0
- package/components/filter-bar/components/date-filter/date-filter.component.d.ts +32 -0
- package/components/filter-bar/components/filter-remove-button/filter-remove-button.component.d.ts +8 -0
- package/components/filter-bar/components/index.d.ts +7 -0
- package/components/filter-bar/components/multiselect-filter/multiselect-filter.component.d.ts +16 -0
- package/components/filter-bar/components/range-filter/range-filter.component.d.ts +23 -0
- package/components/filter-bar/components/select-filter/select-filter.component.d.ts +17 -0
- package/components/filter-bar/components/string-filter/string-filter.component.d.ts +17 -0
- package/components/filter-bar/filter-bar.component.d.ts +14 -0
- package/components/filter-bar/filter-bar.interfaces.d.ts +89 -0
- package/components/filter-bar/filter-bar.module.d.ts +7 -0
- package/components/filter-bar/filter-bar.utils.d.ts +3 -0
- package/components/filter-bar/index.d.ts +3 -0
- package/components/index.d.ts +2 -0
- package/components/sidebar/sidebar-header/sidebar-header.component.d.ts +1 -1
- package/components/sidebar/sidebar-navigation-item/sidebar-navigation-item.component.d.ts +1 -1
- package/esm2022/components/date-range-calendar/date-range-calendar.component.mjs +206 -0
- package/esm2022/components/date-range-calendar/date-range-calendar.interfaces.mjs +2 -0
- package/esm2022/components/date-range-calendar/date-range-calendar.module.mjs +16 -0
- package/esm2022/components/date-range-calendar/index.mjs +3 -0
- package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs +25 -0
- package/esm2022/components/filter-bar/components/date-filter/date-filter.component.mjs +147 -0
- package/esm2022/components/filter-bar/components/filter-remove-button/filter-remove-button.component.mjs +20 -0
- package/esm2022/components/filter-bar/components/index.mjs +8 -0
- package/esm2022/components/filter-bar/components/multiselect-filter/multiselect-filter.component.mjs +70 -0
- package/esm2022/components/filter-bar/components/range-filter/range-filter.component.mjs +99 -0
- package/esm2022/components/filter-bar/components/select-filter/select-filter.component.mjs +63 -0
- package/esm2022/components/filter-bar/components/string-filter/string-filter.component.mjs +66 -0
- package/esm2022/components/filter-bar/filter-bar.component.mjs +52 -0
- package/esm2022/components/filter-bar/filter-bar.interfaces.mjs +3 -0
- package/esm2022/components/filter-bar/filter-bar.module.mjs +16 -0
- package/esm2022/components/filter-bar/filter-bar.utils.mjs +114 -0
- package/esm2022/components/filter-bar/index.mjs +3 -0
- package/esm2022/components/index.mjs +3 -1
- package/fesm2022/cuby-ui-core.mjs +828 -18
- package/fesm2022/cuby-ui-core.mjs.map +1 -1
- package/package.json +4 -4
- package/widgets/ui/categories/components/category-item/category-item.component.d.ts +2 -2
- package/widgets/ui/loader/components/stated-loader/stated-loader.component.d.ts +1 -1
- package/widgets/ui/storage-list/components/storage-list-item/storage-list-item.component.d.ts +1 -1
|
@@ -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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5G,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;;;;AAYtC,MAAM,OAAO,6BAA6B;IA6FtC;QA5FA,uEAAuE;QACvD,SAAI,GAAG,KAAK,CAA2B,OAAO,CAAC,CAAC;QAEhE,8BAA8B;QACd,cAAS,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QAErD,4BAA4B;QACZ,YAAO,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QAEnD,sCAAsC;QACtB,iBAAY,GAAG,KAAK,CAAc,IAAI,CAAC,CAAC;QAExD,2CAA2C;QAC3B,kBAAa,GAAG,MAAM,EAA8B,CAAC;QAErE,4CAA4C;QAC5B,iBAAY,GAAG,MAAM,EAAQ,CAAC;QAE9C,oCAAoC;QACpB,cAAS,GAAG,MAAM,EAAQ,CAAC;QAE3C,gCAAgC;QACb,iBAAY,GAAG,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAErD,oDAAoD;QACjC,iBAAY,GAAG,MAAM,CAAc,IAAI,CAAC,CAAC;QAE5D,kDAAkD;QAC/B,eAAU,GAAG,MAAM,CAAc,IAAI,CAAC,CAAC;QAE1D,gDAAgD;QAC7B,oBAAe,GAAG,MAAM,CAAc,IAAI,CAAC,CAAC;QAE/D,sBAAsB;QACH,aAAQ,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAEzE,iCAAiC;QACd,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChD,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAEjC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAChF,CAAC,CAAC,CAAC;QAEH,yBAAyB;QACN,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACjC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YAChC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAE9B,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAC1C,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YAE7C,gFAAgF;YAChF,IAAI,cAAc,GAAG,QAAQ,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAE3C,IAAI,cAAc,GAAG,CAAC,EAAE,CAAC;gBACrB,cAAc,GAAG,CAAC,CAAC;YACvB,CAAC;YAED,MAAM,IAAI,GAA8C,EAAE,CAAC;YAE3D,qCAAqC;YACrC,MAAM,gBAAgB,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAE5D,KAAK,IAAI,CAAC,GAAG,cAAc,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC3C,IAAI,CAAC,IAAI,CAAC;oBACN,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,gBAAgB,GAAG,CAAC,CAAC;oBACrD,cAAc,EAAE,KAAK;iBACxB,CAAC,CAAC;YACP,CAAC;YAED,2BAA2B;YAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC1C,IAAI,CAAC,IAAI,CAAC;oBACN,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;oBAC9B,cAAc,EAAE,IAAI;iBACvB,CAAC,CAAC;YACP,CAAC;YAED,wEAAwE;YACxE,MAAM,aAAa,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;YAEvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC;gBACtC,IAAI,CAAC,IAAI,CAAC;oBACN,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;oBAClC,cAAc,EAAE,KAAK;iBACxB,CAAC,CAAC;YACP,CAAC;YAED,OAAO,IAAI,CAAC;QAChB,CAAC,CAAC,CAAC;QAGC,qGAAqG;QACrG,MAAM,CAAC,GAAG,EAAE;YACR,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,OAAO,EAAE,CAAC;gBAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;gBAC/B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;gBAE3B,IAAI,KAAK,EAAE,CAAC;oBACR,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBAC7B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC9E,CAAC;gBAED,IAAI,GAAG,EAAE,CAAC;oBACN,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBAC7B,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;gBAErC,IAAI,QAAQ,EAAE,CAAC;oBACX,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACnC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;gBACpF,CAAC;YACL,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAES,aAAa;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACpC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACtF,CAAC;IAES,aAAa;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACpC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IACtF,CAAC;IAES,UAAU,CAAC,IAAU;QAC3B,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,OAAO,EAAE,CAAC;YAC1B,0CAA0C;YAC1C,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAE/B,OAAO;QACX,CAAC;QAED,aAAa;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAE9B,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,IAAI,GAAG,CAAC,EAAE,CAAC;YAC3B,wBAAwB;YACxB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;aAAM,CAAC;YACJ,yBAAyB;YACzB,IAAI,IAAI,GAAG,KAAK,EAAE,CAAC;gBACf,8CAA8C;gBAC9C,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAC3B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAChC,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC9B,CAAC;QACL,CAAC;IACL,CAAC;IAES,UAAU,CAAC,IAAU;QAC3B,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,OAAO,EAAE,CAAC;YAC1B,mBAAmB;YACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YAExC,OAAO,QAAQ,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAC/D,CAAC;QAED,aAAa;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAE9B,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC;YACvC,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,CAAC;YACnC,OAAO,IAAI,CAAC;QAChB,CAAC;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAES,SAAS,CAAC,IAAU;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAE9B,IAAI,CAAC,KAAK,IAAI,CAAC,GAAG,EAAE,CAAC;YACjB,OAAO,KAAK,CAAC;QACjB,CAAC;QAED,OAAO,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,GAAG,CAAC;IACtC,CAAC;IAES,YAAY,CAAC,IAAU;QAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAElC,OAAO,KAAK,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACzD,CAAC;IAES,UAAU,CAAC,IAAU;QAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAE9B,OAAO,GAAG,KAAK,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACrD,CAAC;IAES,OAAO,CAAC,IAAU;QACxB,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;IAC5C,CAAC;IAES,KAAK;QACX,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,OAAO,EAAE,CAAC;YAC1B,mBAAmB;YACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YAExC,IAAI,QAAQ,EAAE,CAAC;gBACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrC,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,aAAa;YACb,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAClC,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAE9B,IAAI,KAAK,IAAI,GAAG,EAAE,CAAC;gBACf,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;YAC5C,CAAC;QACL,CAAC;IACL,CAAC;IAES,MAAM;QACZ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAES,YAAY;QAClB,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,OAAO,EAAE,CAAC;YAC1B,OAAO,IAAI,CAAC,eAAe,EAAE,KAAK,IAAI,CAAC;QAC3C,CAAC;QAED,OAAO,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC;IACxC,CAAC;IAEO,SAAS,CAAC,KAAW,EAAE,KAAW;QACtC,OAAO,CACH,KAAK,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE;YAC3C,KAAK,CAAC,QAAQ,EAAE,KAAK,KAAK,CAAC,QAAQ,EAAE;YACrC,KAAK,CAAC,OAAO,EAAE,KAAK,KAAK,CAAC,OAAO,EAAE,CACtC,CAAC;IACN,CAAC;+GApPQ,6BAA6B;mGAA7B,6BAA6B,ssBCf1C,6iEA+DA,m/DDrDc,eAAe,mOAAE,YAAY;;4FAK9B,6BAA6B;kBARzC,SAAS;+BACI,yBAAyB,cACvB,IAAI,WACP,CAAC,eAAe,EAAE,YAAY,CAAC,mBAGvB,uBAAuB,CAAC,MAAM","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=
|
package/esm2022/components/filter-bar/components/add-filter-button/add-filter-button.component.mjs
ADDED
|
@@ -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
|