@cqa-lib/cqa-ui 1.0.99 → 1.0.100
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/esm2020/lib/filters/daterangepicker/daterangepicker.component.mjs +234 -0
- package/esm2020/lib/filters/daterangepicker/daterangepicker.directive.mjs +322 -0
- package/esm2020/lib/filters/dynamic-filter/dynamic-filter.component.mjs +56 -15
- package/esm2020/lib/ui-kit.module.mjs +11 -1
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +615 -22
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +619 -22
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/filters/daterangepicker/daterangepicker.component.d.ts +56 -0
- package/lib/filters/daterangepicker/daterangepicker.directive.d.ts +73 -0
- package/lib/filters/dynamic-filter/dynamic-filter.component.d.ts +11 -2
- package/lib/ui-kit.module.d.ts +38 -36
- package/package.json +4 -1
- package/public-api.d.ts +2 -0
- package/src/lib/filters/daterangepicker/README.md +146 -0
- package/styles.css +1 -1
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ViewChild, forwardRef } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "./daterangepicker.directive";
|
|
6
|
+
export class DaterangepickerComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.disabled = false;
|
|
9
|
+
this.autoApply = false;
|
|
10
|
+
this.alwaysShowCalendars = false;
|
|
11
|
+
this.opens = 'left';
|
|
12
|
+
this.drops = 'down';
|
|
13
|
+
this.datesUpdated = new EventEmitter();
|
|
14
|
+
this.cancelClicked = new EventEmitter();
|
|
15
|
+
this.applyClicked = new EventEmitter();
|
|
16
|
+
this.pickerOptions = {};
|
|
17
|
+
this.onChange = (value) => { };
|
|
18
|
+
this.onTouched = () => { };
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.pickerOptions = {
|
|
22
|
+
startDate: this.startDate ? new Date(this.startDate) : undefined,
|
|
23
|
+
endDate: this.endDate ? new Date(this.endDate) : undefined,
|
|
24
|
+
minDate: this.minDate ? new Date(this.minDate) : undefined,
|
|
25
|
+
maxDate: this.maxDate ? new Date(this.maxDate) : undefined,
|
|
26
|
+
ranges: this.ranges,
|
|
27
|
+
autoApply: this.autoApply,
|
|
28
|
+
alwaysShowCalendars: this.alwaysShowCalendars,
|
|
29
|
+
opens: this.opens,
|
|
30
|
+
drops: this.drops,
|
|
31
|
+
isInvalidDate: this.isInvalidDate,
|
|
32
|
+
locale: {
|
|
33
|
+
format: 'MM/DD/YYYY',
|
|
34
|
+
separator: ' - ',
|
|
35
|
+
applyLabel: 'Apply',
|
|
36
|
+
cancelLabel: 'Cancel',
|
|
37
|
+
fromLabel: 'From',
|
|
38
|
+
toLabel: 'To',
|
|
39
|
+
customRangeLabel: 'Custom',
|
|
40
|
+
weekLabel: 'W',
|
|
41
|
+
daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],
|
|
42
|
+
monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
|
43
|
+
firstDay: 0
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
// Cleanup handled by directive
|
|
49
|
+
}
|
|
50
|
+
onDatesUpdated(event) {
|
|
51
|
+
this.startDate = event.startDate || undefined;
|
|
52
|
+
this.endDate = event.endDate || undefined;
|
|
53
|
+
this.onChange({ start: event.startDate, end: event.endDate });
|
|
54
|
+
this.datesUpdated.emit(event);
|
|
55
|
+
}
|
|
56
|
+
onCancel() {
|
|
57
|
+
this.cancelClicked.emit();
|
|
58
|
+
}
|
|
59
|
+
onApply(event) {
|
|
60
|
+
this.applyClicked.emit(event);
|
|
61
|
+
}
|
|
62
|
+
// ControlValueAccessor implementation
|
|
63
|
+
writeValue(value) {
|
|
64
|
+
if (value) {
|
|
65
|
+
this.startDate = value.start || undefined;
|
|
66
|
+
this.endDate = value.end || undefined;
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
this.startDate = undefined;
|
|
70
|
+
this.endDate = undefined;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
registerOnChange(fn) {
|
|
74
|
+
this.onChange = fn;
|
|
75
|
+
}
|
|
76
|
+
registerOnTouched(fn) {
|
|
77
|
+
this.onTouched = fn;
|
|
78
|
+
}
|
|
79
|
+
setDisabledState(isDisabled) {
|
|
80
|
+
this.disabled = isDisabled;
|
|
81
|
+
}
|
|
82
|
+
openPicker() {
|
|
83
|
+
if (this.disabled || !this.inputRef?.nativeElement)
|
|
84
|
+
return;
|
|
85
|
+
this.inputRef.nativeElement.focus();
|
|
86
|
+
this.inputRef.nativeElement.click();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
DaterangepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DaterangepickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
DaterangepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: DaterangepickerComponent, selector: "cqa-daterangepicker", inputs: { label: "label", placeholder: "placeholder", disabled: "disabled", startDate: "startDate", endDate: "endDate", minDate: "minDate", maxDate: "maxDate", ranges: "ranges", autoApply: "autoApply", alwaysShowCalendars: "alwaysShowCalendars", opens: "opens", drops: "drops", isInvalidDate: "isInvalidDate" }, outputs: { datesUpdated: "datesUpdated", cancelClicked: "cancelClicked", applyClicked: "applyClicked" }, providers: [
|
|
91
|
+
{
|
|
92
|
+
provide: NG_VALUE_ACCESSOR,
|
|
93
|
+
useExisting: forwardRef(() => DaterangepickerComponent),
|
|
94
|
+
multi: true
|
|
95
|
+
}
|
|
96
|
+
], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, static: true }], ngImport: i0, template: `
|
|
97
|
+
<div class="cqa-ui-root">
|
|
98
|
+
<label *ngIf="label" class="form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4] cqa-mb-2">
|
|
99
|
+
{{ label }}
|
|
100
|
+
</label>
|
|
101
|
+
<div class="cqa-daterangepicker-wrapper">
|
|
102
|
+
<input
|
|
103
|
+
#inputRef
|
|
104
|
+
type="text"
|
|
105
|
+
class="cqa-daterangepicker-input"
|
|
106
|
+
[placeholder]="placeholder || 'Start Date - End Date'"
|
|
107
|
+
[readonly]="true"
|
|
108
|
+
[disabled]="disabled"
|
|
109
|
+
cqaDaterangepicker
|
|
110
|
+
[options]="pickerOptions"
|
|
111
|
+
[startDate]="startDate"
|
|
112
|
+
[endDate]="endDate"
|
|
113
|
+
[minDate]="minDate"
|
|
114
|
+
[maxDate]="maxDate"
|
|
115
|
+
(datesUpdated)="onDatesUpdated($event)"
|
|
116
|
+
(cancelClicked)="onCancel()"
|
|
117
|
+
(applyClicked)="onApply($event)"
|
|
118
|
+
/>
|
|
119
|
+
<button
|
|
120
|
+
type="button"
|
|
121
|
+
class="cqa-daterangepicker-icon"
|
|
122
|
+
(click)="openPicker()"
|
|
123
|
+
[disabled]="disabled"
|
|
124
|
+
aria-label="Open date range picker"
|
|
125
|
+
>
|
|
126
|
+
<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
127
|
+
<path d="M5.33398 1.33203V3.9987" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
128
|
+
stroke-linejoin="round" />
|
|
129
|
+
<path d="M10.666 1.33203V3.9987" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
130
|
+
stroke-linejoin="round" />
|
|
131
|
+
<path
|
|
132
|
+
d="M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z"
|
|
133
|
+
stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round" stroke-linejoin="round" />
|
|
134
|
+
<path d="M2 6.66797H14" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
135
|
+
stroke-linejoin="round" />
|
|
136
|
+
</svg>
|
|
137
|
+
</button>
|
|
138
|
+
</div>
|
|
139
|
+
</div>
|
|
140
|
+
`, isInline: true, directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.DaterangepickerDirective, selector: "[cqaDaterangepicker]", inputs: ["options", "startDate", "endDate", "minDate", "maxDate"], outputs: ["datesUpdated", "cancelClicked", "applyClicked"] }] });
|
|
141
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DaterangepickerComponent, decorators: [{
|
|
142
|
+
type: Component,
|
|
143
|
+
args: [{
|
|
144
|
+
selector: 'cqa-daterangepicker',
|
|
145
|
+
template: `
|
|
146
|
+
<div class="cqa-ui-root">
|
|
147
|
+
<label *ngIf="label" class="form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4] cqa-mb-2">
|
|
148
|
+
{{ label }}
|
|
149
|
+
</label>
|
|
150
|
+
<div class="cqa-daterangepicker-wrapper">
|
|
151
|
+
<input
|
|
152
|
+
#inputRef
|
|
153
|
+
type="text"
|
|
154
|
+
class="cqa-daterangepicker-input"
|
|
155
|
+
[placeholder]="placeholder || 'Start Date - End Date'"
|
|
156
|
+
[readonly]="true"
|
|
157
|
+
[disabled]="disabled"
|
|
158
|
+
cqaDaterangepicker
|
|
159
|
+
[options]="pickerOptions"
|
|
160
|
+
[startDate]="startDate"
|
|
161
|
+
[endDate]="endDate"
|
|
162
|
+
[minDate]="minDate"
|
|
163
|
+
[maxDate]="maxDate"
|
|
164
|
+
(datesUpdated)="onDatesUpdated($event)"
|
|
165
|
+
(cancelClicked)="onCancel()"
|
|
166
|
+
(applyClicked)="onApply($event)"
|
|
167
|
+
/>
|
|
168
|
+
<button
|
|
169
|
+
type="button"
|
|
170
|
+
class="cqa-daterangepicker-icon"
|
|
171
|
+
(click)="openPicker()"
|
|
172
|
+
[disabled]="disabled"
|
|
173
|
+
aria-label="Open date range picker"
|
|
174
|
+
>
|
|
175
|
+
<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
176
|
+
<path d="M5.33398 1.33203V3.9987" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
177
|
+
stroke-linejoin="round" />
|
|
178
|
+
<path d="M10.666 1.33203V3.9987" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
179
|
+
stroke-linejoin="round" />
|
|
180
|
+
<path
|
|
181
|
+
d="M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z"
|
|
182
|
+
stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round" stroke-linejoin="round" />
|
|
183
|
+
<path d="M2 6.66797H14" stroke="#0A0A0A" stroke-width="1.33333" stroke-linecap="round"
|
|
184
|
+
stroke-linejoin="round" />
|
|
185
|
+
</svg>
|
|
186
|
+
</button>
|
|
187
|
+
</div>
|
|
188
|
+
</div>
|
|
189
|
+
`,
|
|
190
|
+
providers: [
|
|
191
|
+
{
|
|
192
|
+
provide: NG_VALUE_ACCESSOR,
|
|
193
|
+
useExisting: forwardRef(() => DaterangepickerComponent),
|
|
194
|
+
multi: true
|
|
195
|
+
}
|
|
196
|
+
]
|
|
197
|
+
}]
|
|
198
|
+
}], propDecorators: { label: [{
|
|
199
|
+
type: Input
|
|
200
|
+
}], placeholder: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], disabled: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], startDate: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], endDate: [{
|
|
207
|
+
type: Input
|
|
208
|
+
}], minDate: [{
|
|
209
|
+
type: Input
|
|
210
|
+
}], maxDate: [{
|
|
211
|
+
type: Input
|
|
212
|
+
}], ranges: [{
|
|
213
|
+
type: Input
|
|
214
|
+
}], autoApply: [{
|
|
215
|
+
type: Input
|
|
216
|
+
}], alwaysShowCalendars: [{
|
|
217
|
+
type: Input
|
|
218
|
+
}], opens: [{
|
|
219
|
+
type: Input
|
|
220
|
+
}], drops: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], isInvalidDate: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], datesUpdated: [{
|
|
225
|
+
type: Output
|
|
226
|
+
}], cancelClicked: [{
|
|
227
|
+
type: Output
|
|
228
|
+
}], applyClicked: [{
|
|
229
|
+
type: Output
|
|
230
|
+
}], inputRef: [{
|
|
231
|
+
type: ViewChild,
|
|
232
|
+
args: ['inputRef', { static: true }]
|
|
233
|
+
}] } });
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterangepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/filters/daterangepicker/daterangepicker.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAiC,UAAU,EAAE,MAAM,eAAe,CAAC;AAC7H,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;AA0DzE,MAAM,OAAO,wBAAwB;IAvDrC;QA0DW,aAAQ,GAAG,KAAK,CAAC;QAMjB,cAAS,GAAG,KAAK,CAAC;QAClB,wBAAmB,GAAG,KAAK,CAAC;QAC5B,UAAK,GAAgC,MAAM,CAAC;QAC5C,UAAK,GAA2B,MAAM,CAAC;QAGtC,iBAAY,GAAG,IAAI,YAAY,EAAoD,CAAC;QACpF,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QACzC,iBAAY,GAAG,IAAI,YAAY,EAAoD,CAAC;QAI9F,kBAAa,GAA2B,EAAE,CAAC;QAEnC,aAAQ,GAAG,CAAC,KAAsD,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1E,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;KA6E9B;IA3EC,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS;YAChE,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS;YAC1D,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS;YAC1D,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS;YAC1D,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;YAC7C,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,MAAM,EAAE;gBACN,MAAM,EAAE,YAAY;gBACpB,SAAS,EAAE,KAAK;gBAChB,UAAU,EAAE,OAAO;gBACnB,WAAW,EAAE,QAAQ;gBACrB,SAAS,EAAE,MAAM;gBACjB,OAAO,EAAE,IAAI;gBACb,gBAAgB,EAAE,QAAQ;gBAC1B,SAAS,EAAE,GAAG;gBACd,UAAU,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;gBACtD,UAAU,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC;gBACtI,QAAQ,EAAE,CAAC;aACZ;SACF,CAAC;IACJ,CAAC;IAED,WAAW;QACT,+BAA+B;IACjC,CAAC;IAED,cAAc,CAAC,KAAuD;QACpE,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,IAAI,SAAS,CAAC;QAC9C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,SAAS,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC9D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED,OAAO,CAAC,KAAuD;QAC7D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,sCAAsC;IACtC,UAAU,CAAC,KAAsD;QAC/D,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,IAAI,SAAS,CAAC;YAC1C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,IAAI,SAAS,CAAC;SACvC;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;IACH,CAAC;IAED,gBAAgB,CAAC,EAAoE;QACnF,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,aAAa;YAAE,OAAO;QAC3D,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;;qHApGU,wBAAwB;yGAAxB,wBAAwB,+cARxB;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;YACvD,KAAK,EAAE,IAAI;SACZ;KACF,8IAnDS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CT;2FASU,wBAAwB;kBAvDpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,qBAAqB;oBAC/B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CT;oBACD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yBAAyB,CAAC;4BACvD,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF;8BAEU,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,YAAY;sBAArB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBAEkC,QAAQ;sBAAhD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ElementRef, OnInit, OnDestroy, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DaterangepickerDirective, DateRangePickerOptions } from './daterangepicker.directive';\n\n@Component({\n  selector: 'cqa-daterangepicker',\n  template: `\n    <div class=\"cqa-ui-root\">\n      <label *ngIf=\"label\" class=\"form-label cqa-text-[#374151] cqa-text-[14px] cqa-font-medium cqa-block cqa-leading-[1.4] cqa-mb-2\">\n        {{ label }}\n      </label>\n      <div class=\"cqa-daterangepicker-wrapper\">\n        <input\n          #inputRef\n          type=\"text\"\n          class=\"cqa-daterangepicker-input\"\n          [placeholder]=\"placeholder || 'Start Date - End Date'\"\n          [readonly]=\"true\"\n          [disabled]=\"disabled\"\n          cqaDaterangepicker\n          [options]=\"pickerOptions\"\n          [startDate]=\"startDate\"\n          [endDate]=\"endDate\"\n          [minDate]=\"minDate\"\n          [maxDate]=\"maxDate\"\n          (datesUpdated)=\"onDatesUpdated($event)\"\n          (cancelClicked)=\"onCancel()\"\n          (applyClicked)=\"onApply($event)\"\n        />\n        <button\n          type=\"button\"\n          class=\"cqa-daterangepicker-icon\"\n          (click)=\"openPicker()\"\n          [disabled]=\"disabled\"\n          aria-label=\"Open date range picker\"\n        >\n          <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                      <path d=\"M5.33398 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path d=\"M10.666 1.33203V3.9987\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                      <path\n                        d=\"M12.6667 2.66797H3.33333C2.59695 2.66797 2 3.26492 2 4.0013V13.3346C2 14.071 2.59695 14.668 3.33333 14.668H12.6667C13.403 14.668 14 14.071 14 13.3346V4.0013C14 3.26492 13.403 2.66797 12.6667 2.66797Z\"\n                        stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n                      <path d=\"M2 6.66797H14\" stroke=\"#0A0A0A\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n                        stroke-linejoin=\"round\" />\n                    </svg>\n        </button>\n      </div>\n    </div>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DaterangepickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class DaterangepickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  @Input() label?: string;\n  @Input() placeholder?: string;\n  @Input() disabled = false;\n  @Input() startDate?: Date | string;\n  @Input() endDate?: Date | string;\n  @Input() minDate?: Date | string;\n  @Input() maxDate?: Date | string;\n  @Input() ranges?: any;\n  @Input() autoApply = false;\n  @Input() alwaysShowCalendars = false;\n  @Input() opens: 'left' | 'right' | 'center' = 'left';\n  @Input() drops: 'down' | 'up' | 'auto' = 'down';\n  @Input() isInvalidDate?: (date: Date) => boolean;\n\n  @Output() datesUpdated = new EventEmitter<{ startDate: Date | null; endDate: Date | null }>();\n  @Output() cancelClicked = new EventEmitter<void>();\n  @Output() applyClicked = new EventEmitter<{ startDate: Date | null; endDate: Date | null }>();\n\n  @ViewChild('inputRef', { static: true }) inputRef!: ElementRef<HTMLInputElement>;\n\n  pickerOptions: DateRangePickerOptions = {};\n\n  private onChange = (value: { start: Date | null; end: Date | null } | null) => {};\n  private onTouched = () => {};\n\n  ngOnInit(): void {\n    this.pickerOptions = {\n      startDate: this.startDate ? new Date(this.startDate) : undefined,\n      endDate: this.endDate ? new Date(this.endDate) : undefined,\n      minDate: this.minDate ? new Date(this.minDate) : undefined,\n      maxDate: this.maxDate ? new Date(this.maxDate) : undefined,\n      ranges: this.ranges,\n      autoApply: this.autoApply,\n      alwaysShowCalendars: this.alwaysShowCalendars,\n      opens: this.opens,\n      drops: this.drops,\n      isInvalidDate: this.isInvalidDate,\n      locale: {\n        format: 'MM/DD/YYYY',\n        separator: ' - ',\n        applyLabel: 'Apply',\n        cancelLabel: 'Cancel',\n        fromLabel: 'From',\n        toLabel: 'To',\n        customRangeLabel: 'Custom',\n        weekLabel: 'W',\n        daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n        monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n        firstDay: 0\n      }\n    };\n  }\n\n  ngOnDestroy(): void {\n    // Cleanup handled by directive\n  }\n\n  onDatesUpdated(event: { startDate: Date | null; endDate: Date | null }): void {\n    this.startDate = event.startDate || undefined;\n    this.endDate = event.endDate || undefined;\n    this.onChange({ start: event.startDate, end: event.endDate });\n    this.datesUpdated.emit(event);\n  }\n\n  onCancel(): void {\n    this.cancelClicked.emit();\n  }\n\n  onApply(event: { startDate: Date | null; endDate: Date | null }): void {\n    this.applyClicked.emit(event);\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: { start: Date | null; end: Date | null } | null): void {\n    if (value) {\n      this.startDate = value.start || undefined;\n      this.endDate = value.end || undefined;\n    } else {\n      this.startDate = undefined;\n      this.endDate = undefined;\n    }\n  }\n\n  registerOnChange(fn: (value: { start: Date | null; end: Date | null } | null) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  openPicker(): void {\n    if (this.disabled || !this.inputRef?.nativeElement) return;\n    this.inputRef.nativeElement.focus();\n    this.inputRef.nativeElement.click();\n  }\n}\n\n"]}
|
|
@@ -0,0 +1,322 @@
|
|
|
1
|
+
import { Directive, Input, Output, EventEmitter, forwardRef } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import * as jquery from 'jquery';
|
|
4
|
+
import * as momentImport from 'moment';
|
|
5
|
+
import 'daterangepicker';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
// Normalize module default/namespace interop for both ESM and CJS builds.
|
|
8
|
+
const $ = jquery.default || jquery;
|
|
9
|
+
const moment = momentImport.default || momentImport;
|
|
10
|
+
// Ensure globals are present for the daterangepicker plugin registration.
|
|
11
|
+
if (typeof window !== 'undefined') {
|
|
12
|
+
window.jQuery = window.jQuery || $;
|
|
13
|
+
window.$ = window.$ || $;
|
|
14
|
+
window.moment = window.moment || moment;
|
|
15
|
+
}
|
|
16
|
+
export class DaterangepickerDirective {
|
|
17
|
+
constructor(el) {
|
|
18
|
+
this.el = el;
|
|
19
|
+
this.options = {};
|
|
20
|
+
this.datesUpdated = new EventEmitter();
|
|
21
|
+
this.cancelClicked = new EventEmitter();
|
|
22
|
+
this.applyClicked = new EventEmitter();
|
|
23
|
+
this.onChange = (value) => { };
|
|
24
|
+
this.onTouched = () => { };
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Safely update the input text to avoid "Invalid date" or "undefined" strings.
|
|
28
|
+
*/
|
|
29
|
+
updateInputValue(start, end) {
|
|
30
|
+
if (typeof window.moment === 'undefined')
|
|
31
|
+
return;
|
|
32
|
+
const m = window.moment;
|
|
33
|
+
const format = (this.options?.locale && this.options.locale.format) || 'MM/DD/YYYY';
|
|
34
|
+
const separator = (this.options?.locale && this.options.locale.separator) || ' - ';
|
|
35
|
+
const hasStart = start && m.isMoment(start);
|
|
36
|
+
const hasEnd = end && m.isMoment(end);
|
|
37
|
+
if (hasStart && hasEnd) {
|
|
38
|
+
try {
|
|
39
|
+
const text = `${start.format(format)}${separator}${end.format(format)}`;
|
|
40
|
+
$(this.el.nativeElement).val(text);
|
|
41
|
+
}
|
|
42
|
+
catch { }
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
try {
|
|
46
|
+
$(this.el.nativeElement).val('');
|
|
47
|
+
}
|
|
48
|
+
catch { }
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
ngOnInit() {
|
|
52
|
+
this.initDaterangepicker();
|
|
53
|
+
}
|
|
54
|
+
ngOnChanges(changes) {
|
|
55
|
+
if (this.pickerInstance) {
|
|
56
|
+
if (changes['startDate'] || changes['endDate']) {
|
|
57
|
+
this.updateDates();
|
|
58
|
+
}
|
|
59
|
+
if (changes['minDate'] || changes['maxDate']) {
|
|
60
|
+
this.updateMinMaxDates();
|
|
61
|
+
}
|
|
62
|
+
if (changes['options']) {
|
|
63
|
+
this.destroyPicker();
|
|
64
|
+
this.initDaterangepicker();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
ngOnDestroy() {
|
|
69
|
+
this.destroyPicker();
|
|
70
|
+
}
|
|
71
|
+
initDaterangepicker() {
|
|
72
|
+
if (typeof $ === 'undefined' || typeof $.fn.daterangepicker === 'undefined') {
|
|
73
|
+
console.error('jQuery and daterangepicker must be loaded');
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
// Check if moment.js is available
|
|
77
|
+
if (typeof window.moment === 'undefined') {
|
|
78
|
+
console.error('moment.js must be loaded for daterangepicker to work');
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
// Resolve parent element to scope styles; default to closest .cqa-ui-daterange-picker, fallback to body.
|
|
82
|
+
const parentElCandidate = $(this.el.nativeElement).closest('.cqa-ui-daterange-picker');
|
|
83
|
+
const resolvedParentEl = this.options?.parentEl
|
|
84
|
+
? this.options.parentEl
|
|
85
|
+
: (parentElCandidate && parentElCandidate.length ? parentElCandidate : 'body');
|
|
86
|
+
const baseOptions = {
|
|
87
|
+
opens: 'left',
|
|
88
|
+
drops: 'down',
|
|
89
|
+
autoApply: true,
|
|
90
|
+
autoUpdateInput: false,
|
|
91
|
+
locale: {
|
|
92
|
+
format: 'MM/DD/YYYY',
|
|
93
|
+
separator: ' - ',
|
|
94
|
+
applyLabel: 'Apply',
|
|
95
|
+
cancelLabel: 'Cancel',
|
|
96
|
+
fromLabel: 'From',
|
|
97
|
+
toLabel: 'To',
|
|
98
|
+
customRangeLabel: 'Custom',
|
|
99
|
+
weekLabel: 'W',
|
|
100
|
+
daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],
|
|
101
|
+
monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
|
|
102
|
+
firstDay: 0
|
|
103
|
+
},
|
|
104
|
+
parentEl: resolvedParentEl
|
|
105
|
+
};
|
|
106
|
+
// Merge options but force-disable plugin autoUpdateInput to avoid invalid values.
|
|
107
|
+
const defaultOptions = {
|
|
108
|
+
...baseOptions,
|
|
109
|
+
...this.options,
|
|
110
|
+
locale: {
|
|
111
|
+
...baseOptions.locale,
|
|
112
|
+
...(this.options?.locale || {})
|
|
113
|
+
},
|
|
114
|
+
autoUpdateInput: false
|
|
115
|
+
};
|
|
116
|
+
// Convert Date objects to moment objects for daterangepicker
|
|
117
|
+
const toMoment = (d) => {
|
|
118
|
+
if (!d)
|
|
119
|
+
return null;
|
|
120
|
+
if (typeof d === 'string') {
|
|
121
|
+
const lower = d.trim().toLowerCase();
|
|
122
|
+
if (lower === 'undefined' || lower === 'null' || lower === '')
|
|
123
|
+
return null;
|
|
124
|
+
}
|
|
125
|
+
if (moment.isMoment && moment.isMoment(d))
|
|
126
|
+
return d;
|
|
127
|
+
const date = typeof d === 'string' ? new Date(d) : d;
|
|
128
|
+
if (date instanceof Date && !isNaN(date.getTime())) {
|
|
129
|
+
return moment(date);
|
|
130
|
+
}
|
|
131
|
+
return null;
|
|
132
|
+
};
|
|
133
|
+
const startMoment = toMoment(this.startDate);
|
|
134
|
+
const endMoment = toMoment(this.endDate);
|
|
135
|
+
const minMoment = toMoment(this.minDate);
|
|
136
|
+
const maxMoment = toMoment(this.maxDate);
|
|
137
|
+
if (startMoment)
|
|
138
|
+
defaultOptions.startDate = startMoment;
|
|
139
|
+
if (endMoment)
|
|
140
|
+
defaultOptions.endDate = endMoment;
|
|
141
|
+
if (minMoment)
|
|
142
|
+
defaultOptions.minDate = minMoment;
|
|
143
|
+
if (maxMoment)
|
|
144
|
+
defaultOptions.maxDate = maxMoment;
|
|
145
|
+
// If no initial dates, ensure the input is blank before plugin init.
|
|
146
|
+
if (!startMoment && !endMoment) {
|
|
147
|
+
try {
|
|
148
|
+
$(this.el.nativeElement).val('');
|
|
149
|
+
}
|
|
150
|
+
catch { }
|
|
151
|
+
}
|
|
152
|
+
// Initialize the picker
|
|
153
|
+
$(this.el.nativeElement).daterangepicker(defaultOptions, (start, end, label) => {
|
|
154
|
+
const startDate = start ? start.toDate() : null;
|
|
155
|
+
const endDate = end ? end.toDate() : null;
|
|
156
|
+
this.onChange({ start: startDate, end: endDate });
|
|
157
|
+
this.datesUpdated.emit({ startDate, endDate });
|
|
158
|
+
this.applyClicked.emit({ startDate, endDate });
|
|
159
|
+
this.updateInputValue(start, end);
|
|
160
|
+
});
|
|
161
|
+
this.pickerInstance = $(this.el.nativeElement).data('daterangepicker');
|
|
162
|
+
// Ensure the overlay gets the styling scope class if not already present.
|
|
163
|
+
if (this.pickerInstance?.container) {
|
|
164
|
+
const c = this.pickerInstance.container;
|
|
165
|
+
if (!c.hasClass('cqa-ui-daterange-picker')) {
|
|
166
|
+
c.addClass('cqa-ui-daterange-picker');
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
// Handle cancel event
|
|
170
|
+
$(this.el.nativeElement).on('cancel.daterangepicker', () => {
|
|
171
|
+
this.cancelClicked.emit();
|
|
172
|
+
this.updateInputValue(null, null);
|
|
173
|
+
});
|
|
174
|
+
// Update initial value if provided
|
|
175
|
+
this.updateDates();
|
|
176
|
+
}
|
|
177
|
+
updateDates() {
|
|
178
|
+
if (!this.pickerInstance)
|
|
179
|
+
return;
|
|
180
|
+
if (typeof window.moment === 'undefined')
|
|
181
|
+
return;
|
|
182
|
+
const moment = window.moment;
|
|
183
|
+
// Convert Date objects to moment objects
|
|
184
|
+
const toMoment = (d) => {
|
|
185
|
+
if (!d)
|
|
186
|
+
return null;
|
|
187
|
+
if (typeof d === 'string') {
|
|
188
|
+
const lower = d.trim().toLowerCase();
|
|
189
|
+
if (lower === 'undefined' || lower === 'null' || lower === '')
|
|
190
|
+
return null;
|
|
191
|
+
}
|
|
192
|
+
if (moment.isMoment && moment.isMoment(d))
|
|
193
|
+
return d;
|
|
194
|
+
const date = typeof d === 'string' ? new Date(d) : d;
|
|
195
|
+
if (date instanceof Date && !isNaN(date.getTime())) {
|
|
196
|
+
return moment(date);
|
|
197
|
+
}
|
|
198
|
+
return null;
|
|
199
|
+
};
|
|
200
|
+
const startMoment = toMoment(this.startDate);
|
|
201
|
+
const endMoment = toMoment(this.endDate);
|
|
202
|
+
if (startMoment) {
|
|
203
|
+
this.pickerInstance.setStartDate(startMoment);
|
|
204
|
+
}
|
|
205
|
+
if (endMoment) {
|
|
206
|
+
this.pickerInstance.setEndDate(endMoment);
|
|
207
|
+
}
|
|
208
|
+
// Update input text to reflect current values
|
|
209
|
+
this.updateInputValue(startMoment, endMoment);
|
|
210
|
+
}
|
|
211
|
+
updateMinMaxDates() {
|
|
212
|
+
if (!this.pickerInstance)
|
|
213
|
+
return;
|
|
214
|
+
if (typeof window.moment === 'undefined')
|
|
215
|
+
return;
|
|
216
|
+
const moment = window.moment;
|
|
217
|
+
// Convert Date objects to moment objects
|
|
218
|
+
const toMoment = (d) => {
|
|
219
|
+
if (!d)
|
|
220
|
+
return null;
|
|
221
|
+
if (moment.isMoment && moment.isMoment(d))
|
|
222
|
+
return d;
|
|
223
|
+
const date = typeof d === 'string' ? new Date(d) : d;
|
|
224
|
+
if (date instanceof Date && !isNaN(date.getTime())) {
|
|
225
|
+
return moment(date);
|
|
226
|
+
}
|
|
227
|
+
return null;
|
|
228
|
+
};
|
|
229
|
+
const minMoment = toMoment(this.minDate);
|
|
230
|
+
const maxMoment = toMoment(this.maxDate);
|
|
231
|
+
if (minMoment) {
|
|
232
|
+
this.pickerInstance.setMinDate(minMoment);
|
|
233
|
+
}
|
|
234
|
+
if (maxMoment) {
|
|
235
|
+
this.pickerInstance.setMaxDate(maxMoment);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
destroyPicker() {
|
|
239
|
+
if (this.pickerInstance && typeof $ !== 'undefined') {
|
|
240
|
+
$(this.el.nativeElement).off('cancel.daterangepicker');
|
|
241
|
+
$(this.el.nativeElement).data('daterangepicker')?.remove();
|
|
242
|
+
this.pickerInstance = null;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
// ControlValueAccessor implementation
|
|
246
|
+
writeValue(value) {
|
|
247
|
+
if (value && (value.start || value.end)) {
|
|
248
|
+
// Validate dates before setting
|
|
249
|
+
const isValidDate = (d) => {
|
|
250
|
+
return d !== null && d instanceof Date && !isNaN(d.getTime());
|
|
251
|
+
};
|
|
252
|
+
this.startDate = (value.start && isValidDate(value.start)) ? value.start : undefined;
|
|
253
|
+
this.endDate = (value.end && isValidDate(value.end)) ? value.end : undefined;
|
|
254
|
+
this.updateDates();
|
|
255
|
+
}
|
|
256
|
+
else if (value === null || (value && !value.start && !value.end)) {
|
|
257
|
+
this.startDate = undefined;
|
|
258
|
+
this.endDate = undefined;
|
|
259
|
+
if (this.pickerInstance) {
|
|
260
|
+
try {
|
|
261
|
+
const m = window.moment;
|
|
262
|
+
if (m) {
|
|
263
|
+
// Reset picker internals to a safe value instead of null to avoid "Invalid date"
|
|
264
|
+
this.pickerInstance.setStartDate(m());
|
|
265
|
+
this.pickerInstance.setEndDate(m());
|
|
266
|
+
}
|
|
267
|
+
this.updateInputValue(null, null);
|
|
268
|
+
}
|
|
269
|
+
catch { }
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
registerOnChange(fn) {
|
|
274
|
+
this.onChange = fn;
|
|
275
|
+
}
|
|
276
|
+
registerOnTouched(fn) {
|
|
277
|
+
this.onTouched = fn;
|
|
278
|
+
}
|
|
279
|
+
setDisabledState(isDisabled) {
|
|
280
|
+
if (this.el.nativeElement) {
|
|
281
|
+
this.el.nativeElement.disabled = isDisabled;
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
DaterangepickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DaterangepickerDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
286
|
+
DaterangepickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: DaterangepickerDirective, selector: "[cqaDaterangepicker]", inputs: { options: "options", startDate: "startDate", endDate: "endDate", minDate: "minDate", maxDate: "maxDate" }, outputs: { datesUpdated: "datesUpdated", cancelClicked: "cancelClicked", applyClicked: "applyClicked" }, providers: [
|
|
287
|
+
{
|
|
288
|
+
provide: NG_VALUE_ACCESSOR,
|
|
289
|
+
useExisting: forwardRef(() => DaterangepickerDirective),
|
|
290
|
+
multi: true
|
|
291
|
+
}
|
|
292
|
+
], usesOnChanges: true, ngImport: i0 });
|
|
293
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DaterangepickerDirective, decorators: [{
|
|
294
|
+
type: Directive,
|
|
295
|
+
args: [{
|
|
296
|
+
selector: '[cqaDaterangepicker]',
|
|
297
|
+
providers: [
|
|
298
|
+
{
|
|
299
|
+
provide: NG_VALUE_ACCESSOR,
|
|
300
|
+
useExisting: forwardRef(() => DaterangepickerDirective),
|
|
301
|
+
multi: true
|
|
302
|
+
}
|
|
303
|
+
]
|
|
304
|
+
}]
|
|
305
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { options: [{
|
|
306
|
+
type: Input
|
|
307
|
+
}], startDate: [{
|
|
308
|
+
type: Input
|
|
309
|
+
}], endDate: [{
|
|
310
|
+
type: Input
|
|
311
|
+
}], minDate: [{
|
|
312
|
+
type: Input
|
|
313
|
+
}], maxDate: [{
|
|
314
|
+
type: Input
|
|
315
|
+
}], datesUpdated: [{
|
|
316
|
+
type: Output
|
|
317
|
+
}], cancelClicked: [{
|
|
318
|
+
type: Output
|
|
319
|
+
}], applyClicked: [{
|
|
320
|
+
type: Output
|
|
321
|
+
}] } });
|
|
322
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterangepicker.directive.js","sourceRoot":"","sources":["../../../../../../src/lib/filters/daterangepicker/daterangepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Output, EventEmitter, OnInit, OnDestroy, OnChanges, SimpleChanges, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport * as jquery from 'jquery';\nimport * as momentImport from 'moment';\nimport 'daterangepicker';\n\n// Normalize module default/namespace interop for both ESM and CJS builds.\nconst $: any = (jquery as any).default || (jquery as any);\nconst moment: any = (momentImport as any).default || (momentImport as any);\n\n// Ensure globals are present for the daterangepicker plugin registration.\nif (typeof window !== 'undefined') {\n  (window as any).jQuery = (window as any).jQuery || $;\n  (window as any).$ = (window as any).$ || $;\n  (window as any).moment = (window as any).moment || moment;\n}\n\nexport interface DateRangePickerOptions {\n  startDate?: Date | string;\n  endDate?: Date | string;\n  minDate?: Date | string;\n  maxDate?: Date | string;\n  locale?: any;\n  ranges?: any;\n  opens?: 'left' | 'right' | 'center';\n  drops?: 'down' | 'up' | 'auto';\n  buttonClasses?: string;\n  applyButtonClasses?: string;\n  cancelButtonClasses?: string;\n  autoApply?: boolean;\n  alwaysShowCalendars?: boolean;\n  showDropdowns?: boolean;\n  showWeekNumbers?: boolean;\n  showISOWeekNumbers?: boolean;\n  singleDatePicker?: boolean;\n  timePicker?: boolean;\n  timePicker24Hour?: boolean;\n  timePickerIncrement?: number;\n  timePickerSeconds?: boolean;\n  linkedCalendars?: boolean;\n  autoUpdateInput?: boolean;\n  isInvalidDate?: (date: Date) => boolean;\n  isCustomDate?: (date: Date) => string | boolean;\n  parentEl?: string;\n}\n\n@Directive({\n  selector: '[cqaDaterangepicker]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DaterangepickerDirective),\n      multi: true\n    }\n  ]\n})\nexport class DaterangepickerDirective implements OnInit, OnDestroy, OnChanges, ControlValueAccessor {\n  @Input() options: DateRangePickerOptions = {};\n  @Input() startDate?: Date | string;\n  @Input() endDate?: Date | string;\n  @Input() minDate?: Date | string;\n  @Input() maxDate?: Date | string;\n  @Output() datesUpdated = new EventEmitter<{ startDate: Date | null; endDate: Date | null }>();\n  @Output() cancelClicked = new EventEmitter<void>();\n  @Output() applyClicked = new EventEmitter<{ startDate: Date | null; endDate: Date | null }>();\n\n  private pickerInstance: any;\n  private onChange = (value: any) => {};\n  private onTouched = () => {};\n\n  /**\n   * Safely update the input text to avoid \"Invalid date\" or \"undefined\" strings.\n   */\n  private updateInputValue(start: any, end: any): void {\n    if (typeof (window as any).moment === 'undefined') return;\n    const m = (window as any).moment;\n    const format = (this.options?.locale && this.options.locale.format) || 'MM/DD/YYYY';\n    const separator = (this.options?.locale && this.options.locale.separator) || ' - ';\n\n    const hasStart = start && m.isMoment(start);\n    const hasEnd = end && m.isMoment(end);\n\n    if (hasStart && hasEnd) {\n      try {\n        const text = `${start.format(format)}${separator}${end.format(format)}`;\n        $(this.el.nativeElement).val(text);\n      } catch {}\n    } else {\n      try {\n        $(this.el.nativeElement).val('');\n      } catch {}\n    }\n  }\n\n  constructor(private el: ElementRef) {}\n\n  ngOnInit(): void {\n    this.initDaterangepicker();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.pickerInstance) {\n      if (changes['startDate'] || changes['endDate']) {\n        this.updateDates();\n      }\n      if (changes['minDate'] || changes['maxDate']) {\n        this.updateMinMaxDates();\n      }\n      if (changes['options']) {\n        this.destroyPicker();\n        this.initDaterangepicker();\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroyPicker();\n  }\n\n  private initDaterangepicker(): void {\n    if (typeof $ === 'undefined' || typeof ($.fn as any).daterangepicker === 'undefined') {\n      console.error('jQuery and daterangepicker must be loaded');\n      return;\n    }\n\n    // Check if moment.js is available\n    if (typeof (window as any).moment === 'undefined') {\n      console.error('moment.js must be loaded for daterangepicker to work');\n      return;\n    }\n\n    // Resolve parent element to scope styles; default to closest .cqa-ui-daterange-picker, fallback to body.\n    const parentElCandidate = $(this.el.nativeElement).closest('.cqa-ui-daterange-picker');\n    const resolvedParentEl = this.options?.parentEl\n      ? this.options.parentEl\n      : (parentElCandidate && parentElCandidate.length ? parentElCandidate : 'body');\n\n    const baseOptions: DateRangePickerOptions = {\n      opens: 'left',\n      drops: 'down',\n      autoApply: true,\n      autoUpdateInput: false, // we manage the input ourselves to prevent \"Invalid date\"\n      locale: {\n        format: 'MM/DD/YYYY',\n        separator: ' - ',\n        applyLabel: 'Apply',\n        cancelLabel: 'Cancel',\n        fromLabel: 'From',\n        toLabel: 'To',\n        customRangeLabel: 'Custom',\n        weekLabel: 'W',\n        daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n        monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n        firstDay: 0\n      },\n      parentEl: resolvedParentEl as any\n    };\n\n    // Merge options but force-disable plugin autoUpdateInput to avoid invalid values.\n    const defaultOptions: DateRangePickerOptions = {\n      ...baseOptions,\n      ...this.options,\n      locale: {\n        ...baseOptions.locale,\n        ...(this.options?.locale || {})\n      },\n      autoUpdateInput: false\n    };\n\n    // Convert Date objects to moment objects for daterangepicker\n    const toMoment = (d: Date | string | null | undefined): any => {\n      if (!d) return null;\n      if (typeof d === 'string') {\n        const lower = d.trim().toLowerCase();\n        if (lower === 'undefined' || lower === 'null' || lower === '') return null;\n      }\n      if (moment.isMoment && moment.isMoment(d)) return d;\n      const date = typeof d === 'string' ? new Date(d) : d;\n      if (date instanceof Date && !isNaN(date.getTime())) {\n        return moment(date);\n      }\n      return null;\n    };\n    \n    const startMoment = toMoment(this.startDate);\n    const endMoment = toMoment(this.endDate);\n    const minMoment = toMoment(this.minDate);\n    const maxMoment = toMoment(this.maxDate);\n    \n    if (startMoment) defaultOptions.startDate = startMoment;\n    if (endMoment) defaultOptions.endDate = endMoment;\n    if (minMoment) defaultOptions.minDate = minMoment;\n    if (maxMoment) defaultOptions.maxDate = maxMoment;\n\n    // If no initial dates, ensure the input is blank before plugin init.\n    if (!startMoment && !endMoment) {\n      try { $(this.el.nativeElement).val(''); } catch {}\n    }\n\n    // Initialize the picker\n    $(this.el.nativeElement).daterangepicker(defaultOptions, (start: any, end: any, label: string) => {\n      const startDate = start ? start.toDate() : null;\n      const endDate = end ? end.toDate() : null;\n      \n      this.onChange({ start: startDate, end: endDate });\n      this.datesUpdated.emit({ startDate, endDate });\n      this.applyClicked.emit({ startDate, endDate });\n      this.updateInputValue(start, end);\n    });\n\n    this.pickerInstance = $(this.el.nativeElement).data('daterangepicker');\n\n    // Ensure the overlay gets the styling scope class if not already present.\n    if (this.pickerInstance?.container) {\n      const c = this.pickerInstance.container;\n      if (!c.hasClass('cqa-ui-daterange-picker')) {\n        c.addClass('cqa-ui-daterange-picker');\n      }\n    }\n\n    // Handle cancel event\n    $(this.el.nativeElement).on('cancel.daterangepicker', () => {\n      this.cancelClicked.emit();\n      this.updateInputValue(null, null);\n    });\n\n    // Update initial value if provided\n    this.updateDates();\n  }\n\n  private updateDates(): void {\n    if (!this.pickerInstance) return;\n    if (typeof (window as any).moment === 'undefined') return;\n\n    const moment = (window as any).moment;\n    \n    // Convert Date objects to moment objects\n    const toMoment = (d: Date | string | null | undefined): any => {\n      if (!d) return null;\n      if (typeof d === 'string') {\n        const lower = d.trim().toLowerCase();\n        if (lower === 'undefined' || lower === 'null' || lower === '') return null;\n      }\n      if (moment.isMoment && moment.isMoment(d)) return d;\n      const date = typeof d === 'string' ? new Date(d) : d;\n      if (date instanceof Date && !isNaN(date.getTime())) {\n        return moment(date);\n      }\n      return null;\n    };\n    \n    const startMoment = toMoment(this.startDate);\n    const endMoment = toMoment(this.endDate);\n    \n    if (startMoment) {\n      this.pickerInstance.setStartDate(startMoment);\n    }\n    \n    if (endMoment) {\n      this.pickerInstance.setEndDate(endMoment);\n    }\n    \n    // Update input text to reflect current values\n    this.updateInputValue(startMoment, endMoment);\n  }\n\n  private updateMinMaxDates(): void {\n    if (!this.pickerInstance) return;\n    if (typeof (window as any).moment === 'undefined') return;\n\n    const moment = (window as any).moment;\n    \n    // Convert Date objects to moment objects\n    const toMoment = (d: Date | string | null | undefined): any => {\n      if (!d) return null;\n      if (moment.isMoment && moment.isMoment(d)) return d;\n      const date = typeof d === 'string' ? new Date(d) : d;\n      if (date instanceof Date && !isNaN(date.getTime())) {\n        return moment(date);\n      }\n      return null;\n    };\n    \n    const minMoment = toMoment(this.minDate);\n    const maxMoment = toMoment(this.maxDate);\n    \n    if (minMoment) {\n      this.pickerInstance.setMinDate(minMoment);\n    }\n    if (maxMoment) {\n      this.pickerInstance.setMaxDate(maxMoment);\n    }\n  }\n\n  private destroyPicker(): void {\n    if (this.pickerInstance && typeof $ !== 'undefined') {\n      $(this.el.nativeElement).off('cancel.daterangepicker');\n      $(this.el.nativeElement).data('daterangepicker')?.remove();\n      this.pickerInstance = null;\n    }\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: { start: Date | null; end: Date | null } | null): void {\n    if (value && (value.start || value.end)) {\n      // Validate dates before setting\n      const isValidDate = (d: Date | null): boolean => {\n        return d !== null && d instanceof Date && !isNaN(d.getTime());\n      };\n      \n      this.startDate = (value.start && isValidDate(value.start)) ? value.start : undefined;\n      this.endDate = (value.end && isValidDate(value.end)) ? value.end : undefined;\n      this.updateDates();\n    } else if (value === null || (value && !value.start && !value.end)) {\n      this.startDate = undefined;\n      this.endDate = undefined;\n      if (this.pickerInstance) {\n        try {\n          const m = (window as any).moment;\n          if (m) {\n            // Reset picker internals to a safe value instead of null to avoid \"Invalid date\"\n            this.pickerInstance.setStartDate(m());\n            this.pickerInstance.setEndDate(m());\n          }\n          this.updateInputValue(null, null);\n        } catch {}\n      }\n    }\n  }\n\n  registerOnChange(fn: (value: any) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (this.el.nativeElement) {\n      this.el.nativeElement.disabled = isDisabled;\n    }\n  }\n}\n\n"]}
|