@netwin/angular-datetime-picker 18.2.0 → 19.0.0-rc.2
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/README.md +1 -27
- package/assets/style/picker.min.css +1 -1
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +7 -13
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +1 -4
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +21 -36
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +1 -2
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +9 -12
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +12 -25
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +1 -2
- package/esm2022/lib/date-time/calendar-body.component.mjs +22 -31
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +13 -29
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +11 -17
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +11 -19
- package/esm2022/lib/date-time/calendar.component.mjs +16 -27
- package/esm2022/lib/date-time/date-time-inline.component.mjs +280 -110
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +4 -11
- package/esm2022/lib/date-time/date-time.module.mjs +12 -36
- package/esm2022/lib/date-time/options-provider.mjs +1 -1
- package/esm2022/lib/date-time/timer-box.component.mjs +6 -16
- package/esm2022/lib/date-time/timer.component.mjs +18 -17
- package/esm2022/lib/types/date-view.mjs +19 -0
- package/esm2022/lib/types/index.mjs +4 -0
- package/esm2022/lib/types/picker-type.mjs +2 -0
- package/esm2022/lib/types/select-mode.mjs +2 -0
- package/esm2022/public_api.mjs +18 -20
- package/fesm2022/netwin-angular-datetime-picker.mjs +1843 -4264
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -1
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +16 -26
- package/lib/date-time/adapter/date-time-format.class.d.ts +8 -12
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +7 -18
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +0 -3
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +6 -17
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +0 -3
- package/lib/date-time/calendar-body.component.d.ts +21 -26
- package/lib/date-time/calendar-month-view.component.d.ts +19 -24
- package/lib/date-time/calendar-multi-year-view.component.d.ts +14 -14
- package/lib/date-time/calendar-year-view.component.d.ts +8 -9
- package/lib/date-time/calendar.component.d.ts +15 -21
- package/lib/date-time/date-time-inline.component.d.ts +164 -74
- package/lib/date-time/date-time-picker-intl.service.d.ts +0 -4
- package/lib/date-time/date-time.module.d.ts +11 -18
- package/lib/date-time/timer-box.component.d.ts +4 -5
- package/lib/date-time/timer.component.d.ts +6 -9
- package/lib/types/date-view.d.ts +17 -0
- package/lib/types/index.d.ts +3 -0
- package/lib/types/picker-type.d.ts +7 -0
- package/lib/types/select-mode.d.ts +8 -0
- package/package.json +1 -1
- package/public_api.d.ts +12 -19
- package/esm2022/lib/date-time/date-time-picker-container.component.mjs +0 -405
- package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +0 -598
- package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +0 -64
- package/esm2022/lib/date-time/date-time-picker.animations.mjs +0 -21
- package/esm2022/lib/date-time/date-time-picker.component.mjs +0 -564
- package/esm2022/lib/date-time/date-time.class.mjs +0 -176
- package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +0 -28
- package/esm2022/lib/dialog/dialog-config.class.mjs +0 -59
- package/esm2022/lib/dialog/dialog-container.component.mjs +0 -232
- package/esm2022/lib/dialog/dialog-ref.class.mjs +0 -134
- package/esm2022/lib/dialog/dialog.module.mjs +0 -26
- package/esm2022/lib/dialog/dialog.service.mjs +0 -228
- package/esm2022/lib/utils/index.mjs +0 -5
- package/esm2022/lib/utils/object.utils.mjs +0 -23
- package/lib/date-time/date-time-picker-container.component.d.ts +0 -130
- package/lib/date-time/date-time-picker-input.directive.d.ts +0 -164
- package/lib/date-time/date-time-picker-trigger.directive.d.ts +0 -23
- package/lib/date-time/date-time-picker.animations.d.ts +0 -8
- package/lib/date-time/date-time-picker.component.d.ts +0 -173
- package/lib/date-time/date-time.class.d.ts +0 -103
- package/lib/date-time/numberedFixLen.pipe.d.ts +0 -10
- package/lib/dialog/dialog-config.class.d.ts +0 -169
- package/lib/dialog/dialog-container.component.d.ts +0 -58
- package/lib/dialog/dialog-ref.class.d.ts +0 -51
- package/lib/dialog/dialog.module.d.ts +0 -11
- package/lib/dialog/dialog.service.d.ts +0 -76
- package/lib/utils/index.d.ts +0 -4
- package/lib/utils/object.utils.d.ts +0 -8
|
@@ -1,43 +1,46 @@
|
|
|
1
|
-
|
|
2
|
-
* date-time-inline.component
|
|
3
|
-
*/
|
|
4
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
5
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
|
|
1
|
+
import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, inject, Input, numberAttribute, Output } from '@angular/core';
|
|
6
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { DateView } from '../types';
|
|
4
|
+
import { DateTimeAdapter } from './adapter/date-time-adapter.class';
|
|
7
5
|
import { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';
|
|
8
|
-
import {
|
|
9
|
-
import { OwlDateTime } from './date-time.class';
|
|
6
|
+
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
|
|
10
7
|
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "./
|
|
12
|
-
import * as i2 from "./
|
|
13
|
-
|
|
8
|
+
import * as i1 from "./timer.component";
|
|
9
|
+
import * as i2 from "./calendar.component";
|
|
10
|
+
const OWL_DATETIME_VALUE_ACCESSOR = {
|
|
14
11
|
provide: NG_VALUE_ACCESSOR,
|
|
15
12
|
useExisting: forwardRef(() => OwlDateTimeInlineComponent),
|
|
16
13
|
multi: true
|
|
17
14
|
};
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
15
|
+
let nextUniqueComponentId = 0;
|
|
16
|
+
export class OwlDateTimeInlineComponent {
|
|
17
|
+
#changeDetector;
|
|
18
|
+
#pickerIntl;
|
|
19
|
+
#dateTimeFormats;
|
|
20
|
+
#dateTimeAdapter;
|
|
21
|
+
get firstDayOfWeek() {
|
|
22
|
+
return this._firstDayOfWeek;
|
|
23
|
+
}
|
|
24
|
+
set firstDayOfWeek(value) {
|
|
25
|
+
value = numberAttribute(value, undefined);
|
|
26
|
+
if (value > 6 || value < 0) {
|
|
27
|
+
this._firstDayOfWeek = undefined;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this._firstDayOfWeek = value;
|
|
25
31
|
}
|
|
26
32
|
}
|
|
27
|
-
get
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this.
|
|
32
|
-
|
|
33
|
-
get selectMode() {
|
|
34
|
-
return this._selectMode;
|
|
35
|
-
}
|
|
36
|
-
set selectMode(mode) {
|
|
37
|
-
if (mode !== 'single' && mode !== 'range' && mode !== 'rangeFrom' && mode !== 'rangeTo') {
|
|
38
|
-
throw Error('OwlDateTime Error: invalid selectMode value!');
|
|
33
|
+
get formatOptions() {
|
|
34
|
+
if (this.pickerType === 'both') {
|
|
35
|
+
return this.#dateTimeFormats.fullPickerInput;
|
|
36
|
+
}
|
|
37
|
+
if (this.pickerType === 'calendar') {
|
|
38
|
+
return this.#dateTimeFormats.datePickerInput;
|
|
39
39
|
}
|
|
40
|
-
this.
|
|
40
|
+
return this.#dateTimeFormats.timePickerInput;
|
|
41
|
+
}
|
|
42
|
+
getValidDate(obj) {
|
|
43
|
+
return this.#dateTimeAdapter.isDateInstance(obj) && this.#dateTimeAdapter.isValid(obj) ? obj : null;
|
|
41
44
|
}
|
|
42
45
|
get startAt() {
|
|
43
46
|
if (this._startAt) {
|
|
@@ -57,7 +60,7 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
57
60
|
}
|
|
58
61
|
}
|
|
59
62
|
set startAt(date) {
|
|
60
|
-
this._startAt = this.getValidDate(this
|
|
63
|
+
this._startAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));
|
|
61
64
|
}
|
|
62
65
|
get endAt() {
|
|
63
66
|
if (this._endAt) {
|
|
@@ -74,33 +77,37 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
74
77
|
}
|
|
75
78
|
}
|
|
76
79
|
set endAt(date) {
|
|
77
|
-
this._endAt = this.getValidDate(this
|
|
80
|
+
this._endAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));
|
|
78
81
|
}
|
|
79
|
-
|
|
80
|
-
|
|
82
|
+
// TODO: remove this getter when `owlDateTimeFilter` is removed
|
|
83
|
+
get dateTimeFilterGetter() {
|
|
84
|
+
return this.dateTimeFilter || this.owlDateTimeFilter;
|
|
81
85
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
get
|
|
86
|
+
/**
|
|
87
|
+
* The minimum valid date.
|
|
88
|
+
*/
|
|
89
|
+
get min() {
|
|
86
90
|
return this._min || null;
|
|
87
91
|
}
|
|
88
|
-
set
|
|
89
|
-
this._min = this.getValidDate(this
|
|
90
|
-
this
|
|
92
|
+
set min(value) {
|
|
93
|
+
this._min = this.getValidDate(this.#dateTimeAdapter.deserialize(value));
|
|
94
|
+
this.#changeDetector.markForCheck();
|
|
91
95
|
}
|
|
92
|
-
|
|
96
|
+
/**
|
|
97
|
+
* The maximum valid date.
|
|
98
|
+
*/
|
|
99
|
+
get max() {
|
|
93
100
|
return this._max || null;
|
|
94
101
|
}
|
|
95
|
-
set
|
|
96
|
-
this._max = this.getValidDate(this
|
|
97
|
-
this
|
|
102
|
+
set max(value) {
|
|
103
|
+
this._max = this.getValidDate(this.#dateTimeAdapter.deserialize(value));
|
|
104
|
+
this.#changeDetector.markForCheck();
|
|
98
105
|
}
|
|
99
106
|
get value() {
|
|
100
107
|
return this._value;
|
|
101
108
|
}
|
|
102
109
|
set value(value) {
|
|
103
|
-
value = this
|
|
110
|
+
value = this.#dateTimeAdapter.deserialize(value);
|
|
104
111
|
value = this.getValidDate(value);
|
|
105
112
|
this._value = value;
|
|
106
113
|
this.selected = value;
|
|
@@ -111,9 +118,9 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
111
118
|
set values(values) {
|
|
112
119
|
if (values && values.length > 0) {
|
|
113
120
|
values = values.map((v) => {
|
|
114
|
-
v = this
|
|
121
|
+
v = this.#dateTimeAdapter.deserialize(v);
|
|
115
122
|
v = this.getValidDate(v);
|
|
116
|
-
return v ? this
|
|
123
|
+
return v ? this.#dateTimeAdapter.clone(v) : null;
|
|
117
124
|
});
|
|
118
125
|
this._values = [...values];
|
|
119
126
|
this.selecteds = [...values];
|
|
@@ -128,59 +135,140 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
128
135
|
}
|
|
129
136
|
set selected(value) {
|
|
130
137
|
this._selected = value;
|
|
131
|
-
this
|
|
138
|
+
this.#changeDetector.markForCheck();
|
|
132
139
|
}
|
|
133
140
|
get selecteds() {
|
|
134
141
|
return this._selecteds;
|
|
135
142
|
}
|
|
136
143
|
set selecteds(values) {
|
|
137
144
|
this._selecteds = values;
|
|
138
|
-
this
|
|
139
|
-
}
|
|
140
|
-
get opened() {
|
|
141
|
-
return true;
|
|
142
|
-
}
|
|
143
|
-
get pickerMode() {
|
|
144
|
-
return 'inline';
|
|
145
|
+
this.#changeDetector.markForCheck();
|
|
145
146
|
}
|
|
147
|
+
/**
|
|
148
|
+
* Returns whether the picker is in single mode
|
|
149
|
+
*/
|
|
146
150
|
get isInSingleMode() {
|
|
147
|
-
return this.
|
|
151
|
+
return this.selectMode === 'single';
|
|
148
152
|
}
|
|
153
|
+
/**
|
|
154
|
+
* Returns whether the picker is in range mode (range, rangeFrom, rangeTo)
|
|
155
|
+
*/
|
|
149
156
|
get isInRangeMode() {
|
|
150
|
-
return this.
|
|
157
|
+
return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
|
|
151
158
|
}
|
|
152
|
-
|
|
153
|
-
|
|
159
|
+
/**
|
|
160
|
+
* The range 'from' label
|
|
161
|
+
*/
|
|
162
|
+
get fromLabel() {
|
|
163
|
+
return this.#pickerIntl.rangeFromLabel;
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* The range 'to' label
|
|
167
|
+
*/
|
|
168
|
+
get toLabel() {
|
|
169
|
+
return this.#pickerIntl.rangeToLabel;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* The range 'from' formatted value
|
|
173
|
+
*/
|
|
174
|
+
get fromFormattedValue() {
|
|
175
|
+
const value = this.selecteds[0];
|
|
176
|
+
return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';
|
|
154
177
|
}
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
178
|
+
/**
|
|
179
|
+
* The range 'to' formatted value
|
|
180
|
+
*/
|
|
181
|
+
get toFormattedValue() {
|
|
182
|
+
const value = this.selecteds[1];
|
|
183
|
+
return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';
|
|
184
|
+
}
|
|
185
|
+
constructor() {
|
|
186
|
+
this.#changeDetector = inject(ChangeDetectorRef);
|
|
187
|
+
this.#pickerIntl = inject(OwlDateTimeIntl);
|
|
188
|
+
this.#dateTimeFormats = inject(OWL_DATE_TIME_FORMATS, { optional: true });
|
|
189
|
+
this.#dateTimeAdapter = inject(DateTimeAdapter, { optional: true });
|
|
190
|
+
/**
|
|
191
|
+
* Whether the timer is in hour12 format
|
|
192
|
+
*/
|
|
193
|
+
this.hour12Timer = false;
|
|
194
|
+
/**
|
|
195
|
+
* The view that the calendar should start in.
|
|
196
|
+
*/
|
|
197
|
+
this.startView = DateView.MONTH;
|
|
198
|
+
/**
|
|
199
|
+
* Whether to should only the year and multi-year views.
|
|
200
|
+
*/
|
|
201
|
+
this.yearOnly = false;
|
|
202
|
+
/**
|
|
203
|
+
* Whether to should only the multi-year view.
|
|
204
|
+
*/
|
|
205
|
+
this.multiyearOnly = false;
|
|
206
|
+
/**
|
|
207
|
+
* Hours to change per step
|
|
208
|
+
*/
|
|
209
|
+
this.stepHour = 1;
|
|
210
|
+
/**
|
|
211
|
+
* Minutes to change per step
|
|
212
|
+
*/
|
|
213
|
+
this.stepMinute = 1;
|
|
214
|
+
/**
|
|
215
|
+
* Seconds to change per step
|
|
216
|
+
*/
|
|
217
|
+
this.stepSecond = 1;
|
|
218
|
+
/**
|
|
219
|
+
* Whether to hide dates in other months at the start or end of the current month.
|
|
220
|
+
*/
|
|
221
|
+
this.hideOtherMonths = false;
|
|
222
|
+
/**
|
|
223
|
+
* Date Time Checker to check if the give dateTime is selectable
|
|
224
|
+
*/
|
|
225
|
+
this.dateTimeChecker = (dateTime) => {
|
|
226
|
+
return (!!dateTime &&
|
|
227
|
+
(!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&
|
|
228
|
+
(!this.min || this.#dateTimeAdapter.compare(dateTime, this.min) >= 0) &&
|
|
229
|
+
(!this.max || this.#dateTimeAdapter.compare(dateTime, this.max) <= 0));
|
|
230
|
+
};
|
|
160
231
|
/**
|
|
161
|
-
* Set the
|
|
162
|
-
* 'both' -- show both calendar and timer
|
|
163
|
-
* 'calendar' -- show only calendar
|
|
164
|
-
* 'timer' -- show only timer
|
|
232
|
+
* Set the {@link PickerType} of the dateTime picker
|
|
165
233
|
*/
|
|
166
|
-
this.
|
|
167
|
-
|
|
168
|
-
|
|
234
|
+
this.pickerType = 'both';
|
|
235
|
+
/**
|
|
236
|
+
* Whether the picker is disabled or not
|
|
237
|
+
*/
|
|
238
|
+
this.disabled = false;
|
|
239
|
+
/**
|
|
240
|
+
* Whether to show the second's timer
|
|
241
|
+
*/
|
|
242
|
+
this.showSecondsTimer = false;
|
|
243
|
+
/**
|
|
244
|
+
* Which select mode to use:
|
|
245
|
+
* - 'single'
|
|
246
|
+
* - 'range'
|
|
247
|
+
* - 'rangeFrom'
|
|
248
|
+
* - 'rangeTo'
|
|
249
|
+
*/
|
|
250
|
+
this.selectMode = 'single';
|
|
251
|
+
/**
|
|
252
|
+
* @deprecated use `dateTimeFilter` instead!
|
|
253
|
+
*/
|
|
254
|
+
this.owlDateTimeFilter = null;
|
|
255
|
+
this.dateTimeFilter = null;
|
|
169
256
|
this._values = [];
|
|
170
257
|
/**
|
|
171
258
|
* Emits selected year in multi-year view
|
|
172
259
|
* This doesn't imply a change on the selected date.
|
|
173
|
-
|
|
260
|
+
*/
|
|
174
261
|
this.yearSelected = new EventEmitter();
|
|
175
262
|
/**
|
|
176
263
|
* Emits selected month in year view
|
|
177
264
|
* This doesn't imply a change on the selected date.
|
|
178
|
-
|
|
265
|
+
*/
|
|
179
266
|
this.monthSelected = new EventEmitter();
|
|
180
267
|
/**
|
|
181
268
|
* Emits selected date
|
|
182
|
-
|
|
269
|
+
*/
|
|
183
270
|
this.dateSelected = new EventEmitter();
|
|
271
|
+
this.activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')
|
|
184
272
|
this._selecteds = [];
|
|
185
273
|
this.onModelChange = () => {
|
|
186
274
|
/* noop */
|
|
@@ -188,18 +276,41 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
188
276
|
this.onModelTouched = () => {
|
|
189
277
|
/* noop */
|
|
190
278
|
};
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
279
|
+
if (!this.#dateTimeAdapter) {
|
|
280
|
+
throw Error(`OwlDateTimePicker: No provider found for DateTimeAdapter. You must import one of the following ` +
|
|
281
|
+
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
282
|
+
`custom implementation.`);
|
|
283
|
+
}
|
|
284
|
+
if (!this.#dateTimeFormats) {
|
|
285
|
+
throw Error(`OwlDateTimePicker: No provider found for OWL_DATE_TIME_FORMATS. You must import one of the following ` +
|
|
286
|
+
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
287
|
+
`custom implementation.`);
|
|
288
|
+
}
|
|
289
|
+
this.id = `owl-dt-picker-${nextUniqueComponentId++}`;
|
|
194
290
|
}
|
|
195
291
|
writeValue(value) {
|
|
196
292
|
if (this.isInSingleMode) {
|
|
197
|
-
this.
|
|
198
|
-
this.
|
|
293
|
+
this.selected = value;
|
|
294
|
+
this.value = this.selected;
|
|
199
295
|
}
|
|
200
296
|
else {
|
|
201
|
-
|
|
202
|
-
this
|
|
297
|
+
// Handle the case where the second selected date is before the first selected date
|
|
298
|
+
// In this case "go back" and treat the value as the first selected date
|
|
299
|
+
if (this.activeSelectedIndex === 1) {
|
|
300
|
+
if (value.getTime() < this.selecteds[0].getTime()) {
|
|
301
|
+
this.activeSelectedIndex = 0;
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
// Set the correct value according to the active selected index
|
|
305
|
+
if (this.activeSelectedIndex === 0) {
|
|
306
|
+
this.selecteds = [value, null];
|
|
307
|
+
}
|
|
308
|
+
else {
|
|
309
|
+
this.selecteds[1] = value;
|
|
310
|
+
}
|
|
311
|
+
// Set the values to the selecteds
|
|
312
|
+
this.values = [...this.selecteds];
|
|
313
|
+
this.activeSelectedIndex = (this.activeSelectedIndex + 1) % 2;
|
|
203
314
|
}
|
|
204
315
|
}
|
|
205
316
|
registerOnChange(fn) {
|
|
@@ -226,59 +337,118 @@ export class OwlDateTimeInlineComponent extends OwlDateTime {
|
|
|
226
337
|
}
|
|
227
338
|
/**
|
|
228
339
|
* Emits the selected year in multi-year view
|
|
229
|
-
|
|
340
|
+
*/
|
|
230
341
|
selectYear(normalizedYear) {
|
|
231
342
|
this.yearSelected.emit(normalizedYear);
|
|
232
343
|
}
|
|
233
344
|
/**
|
|
234
345
|
* Emits selected month in year view
|
|
235
|
-
|
|
346
|
+
*/
|
|
236
347
|
selectMonth(normalizedMonth) {
|
|
348
|
+
this.writeValue(normalizedMonth);
|
|
237
349
|
this.monthSelected.emit(normalizedMonth);
|
|
238
350
|
}
|
|
239
351
|
/**
|
|
240
352
|
* Emits the selected date
|
|
241
|
-
|
|
353
|
+
*/
|
|
242
354
|
selectDate(normalizedDate) {
|
|
355
|
+
this.writeValue(normalizedDate);
|
|
243
356
|
this.dateSelected.emit(normalizedDate);
|
|
244
357
|
}
|
|
245
|
-
|
|
246
|
-
|
|
358
|
+
/**
|
|
359
|
+
* Sets the active "selected" index in range mode.
|
|
360
|
+
* - 0 for 'from'
|
|
361
|
+
* - 1 for 'to'
|
|
362
|
+
*/
|
|
363
|
+
setActiveSelectedIndex(index) {
|
|
364
|
+
if (this.selectMode === 'range' && this.activeSelectedIndex !== index) {
|
|
365
|
+
this.activeSelectedIndex = index;
|
|
366
|
+
const selected = this.selecteds[this.activeSelectedIndex];
|
|
367
|
+
if (this.selecteds && selected) {
|
|
368
|
+
this.value = this.#dateTimeAdapter.clone(selected);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
return;
|
|
372
|
+
}
|
|
373
|
+
/**
|
|
374
|
+
* Handle click on inform radio group
|
|
375
|
+
*/
|
|
376
|
+
handleKeydownOnInfoGroup(event, next, index) {
|
|
377
|
+
let handled = false;
|
|
378
|
+
switch (event.key) {
|
|
379
|
+
// Navigate between the radio group options with arrow keys
|
|
380
|
+
case 'ArrowDown':
|
|
381
|
+
case 'ArrowRight':
|
|
382
|
+
case 'ArrowUp':
|
|
383
|
+
case 'ArrowLeft':
|
|
384
|
+
next.focus();
|
|
385
|
+
this.setActiveSelectedIndex(index === 0 ? 1 : 0);
|
|
386
|
+
handled = true;
|
|
387
|
+
break;
|
|
388
|
+
// Select the active selected index when space is pressed
|
|
389
|
+
case ' ':
|
|
390
|
+
this.setActiveSelectedIndex(index);
|
|
391
|
+
handled = true;
|
|
392
|
+
break;
|
|
393
|
+
}
|
|
394
|
+
if (handled) {
|
|
395
|
+
event.preventDefault();
|
|
396
|
+
event.stopPropagation();
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeInlineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
400
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.10", type: OwlDateTimeInlineComponent, selector: "owl-date-time-inline", inputs: { hour12Timer: ["hour12Timer", "hour12Timer", booleanAttribute], startView: "startView", yearOnly: ["yearOnly", "yearOnly", booleanAttribute], multiyearOnly: ["multiyearOnly", "multiyearOnly", booleanAttribute], stepHour: "stepHour", stepMinute: "stepMinute", stepSecond: "stepSecond", firstDayOfWeek: "firstDayOfWeek", hideOtherMonths: ["hideOtherMonths", "hideOtherMonths", booleanAttribute], pickerType: "pickerType", disabled: ["disabled", "disabled", booleanAttribute], showSecondsTimer: ["showSecondsTimer", "showSecondsTimer", booleanAttribute], selectMode: "selectMode", startAt: "startAt", endAt: "endAt", owlDateTimeFilter: "owlDateTimeFilter", dateTimeFilter: "dateTimeFilter", min: "min", max: "max", value: "value", values: "values" }, outputs: { yearSelected: "yearSelected", monthSelected: "monthSelected", dateSelected: "dateSelected" }, host: { properties: { "class.owl-dt-container-disabled": "disabled" }, classAttribute: "owl-dt-inline owl-dt-container owl-dt-inline-container" }, providers: [OWL_DATETIME_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"owl-dt-container-inner\">\n @if (pickerType === 'both' || pickerType === 'calendar') {\n <owl-date-time-calendar\n [dateFilter]=\"dateTimeFilterGetter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"max\"\n [minDate]=\"min\"\n [multiyearOnly]=\"multiyearOnly\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [startView]=\"startView\"\n [yearOnly]=\"yearOnly\"\n [(pickerMoment)]=\"value\"\n (dateClicked)=\"selectDate($event)\"\n (monthSelected)=\"selectMonth($event)\"\n (selectedChange)=\"select($event)\"\n (yearSelected)=\"selectYear($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-calendar>\n }\n\n @if (pickerType === 'both' || pickerType === 'timer') {\n <owl-date-time-timer\n [hour12Timer]=\"hour12Timer\"\n [maxDateTime]=\"max\"\n [minDateTime]=\"min\"\n [pickerMoment]=\"value\"\n [showSecondsTimer]=\"showSecondsTimer\"\n [stepHour]=\"stepHour\"\n [stepMinute]=\"stepMinute\"\n [stepSecond]=\"stepSecond\"\n (selectedChange)=\"select($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-timer>\n }\n\n @if (isInRangeMode) {\n <div\n class=\"owl-dt-container-info owl-dt-container-row\"\n role=\"radiogroup\">\n <div\n #from\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n </span>\n </div>\n <div\n #to\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n </span>\n </div>\n </div>\n }\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: i1.OwlTimerComponent, selector: "owl-date-time-timer", inputs: ["pickerMoment", "minDateTime", "maxDateTime", "showSecondsTimer", "hour12Timer", "stepHour", "stepMinute", "stepSecond"], outputs: ["selectedChange"], exportAs: ["owlDateTimeTimer"] }, { kind: "component", type: i2.OwlCalendarComponent, selector: "owl-date-time-calendar", inputs: ["minDate", "maxDate", "pickerMoment", "selected", "selecteds", "dateFilter", "firstDayOfWeek", "selectMode", "startView", "yearOnly", "multiyearOnly", "hideOtherMonths"], outputs: ["pickerMomentChange", "dateClicked", "selectedChange", "yearSelected", "monthSelected"], exportAs: ["owlDateTimeCalendar"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
247
401
|
}
|
|
248
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
402
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeInlineComponent, decorators: [{
|
|
249
403
|
type: Component,
|
|
250
404
|
args: [{ selector: 'owl-date-time-inline', host: {
|
|
251
|
-
'[class.owl-dt-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
405
|
+
'[class.owl-dt-container-disabled]': 'disabled',
|
|
406
|
+
'class': 'owl-dt-inline owl-dt-container owl-dt-inline-container'
|
|
407
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, providers: [OWL_DATETIME_VALUE_ACCESSOR], template: "<div class=\"owl-dt-container-inner\">\n @if (pickerType === 'both' || pickerType === 'calendar') {\n <owl-date-time-calendar\n [dateFilter]=\"dateTimeFilterGetter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"max\"\n [minDate]=\"min\"\n [multiyearOnly]=\"multiyearOnly\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [startView]=\"startView\"\n [yearOnly]=\"yearOnly\"\n [(pickerMoment)]=\"value\"\n (dateClicked)=\"selectDate($event)\"\n (monthSelected)=\"selectMonth($event)\"\n (selectedChange)=\"select($event)\"\n (yearSelected)=\"selectYear($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-calendar>\n }\n\n @if (pickerType === 'both' || pickerType === 'timer') {\n <owl-date-time-timer\n [hour12Timer]=\"hour12Timer\"\n [maxDateTime]=\"max\"\n [minDateTime]=\"min\"\n [pickerMoment]=\"value\"\n [showSecondsTimer]=\"showSecondsTimer\"\n [stepHour]=\"stepHour\"\n [stepMinute]=\"stepMinute\"\n [stepSecond]=\"stepSecond\"\n (selectedChange)=\"select($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-timer>\n }\n\n @if (isInRangeMode) {\n <div\n class=\"owl-dt-container-info owl-dt-container-row\"\n role=\"radiogroup\">\n <div\n #from\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n </span>\n </div>\n <div\n #to\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n </span>\n </div>\n </div>\n }\n</div>\n" }]
|
|
408
|
+
}], ctorParameters: () => [], propDecorators: { hour12Timer: [{
|
|
409
|
+
type: Input,
|
|
410
|
+
args: [{ transform: booleanAttribute }]
|
|
411
|
+
}], startView: [{
|
|
412
|
+
type: Input
|
|
413
|
+
}], yearOnly: [{
|
|
414
|
+
type: Input,
|
|
415
|
+
args: [{ transform: booleanAttribute }]
|
|
416
|
+
}], multiyearOnly: [{
|
|
417
|
+
type: Input,
|
|
418
|
+
args: [{ transform: booleanAttribute }]
|
|
419
|
+
}], stepHour: [{
|
|
420
|
+
type: Input
|
|
421
|
+
}], stepMinute: [{
|
|
422
|
+
type: Input
|
|
423
|
+
}], stepSecond: [{
|
|
424
|
+
type: Input
|
|
425
|
+
}], firstDayOfWeek: [{
|
|
426
|
+
type: Input
|
|
427
|
+
}], hideOtherMonths: [{
|
|
428
|
+
type: Input,
|
|
429
|
+
args: [{ transform: booleanAttribute }]
|
|
263
430
|
}], pickerType: [{
|
|
264
431
|
type: Input
|
|
265
432
|
}], disabled: [{
|
|
266
|
-
type: Input
|
|
433
|
+
type: Input,
|
|
434
|
+
args: [{ transform: booleanAttribute }]
|
|
435
|
+
}], showSecondsTimer: [{
|
|
436
|
+
type: Input,
|
|
437
|
+
args: [{ transform: booleanAttribute }]
|
|
267
438
|
}], selectMode: [{
|
|
268
439
|
type: Input
|
|
269
440
|
}], startAt: [{
|
|
270
441
|
type: Input
|
|
271
442
|
}], endAt: [{
|
|
272
443
|
type: Input
|
|
444
|
+
}], owlDateTimeFilter: [{
|
|
445
|
+
type: Input
|
|
273
446
|
}], dateTimeFilter: [{
|
|
274
|
-
type: Input
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
}], maxDateTime: [{
|
|
280
|
-
type: Input,
|
|
281
|
-
args: ['max']
|
|
447
|
+
type: Input
|
|
448
|
+
}], min: [{
|
|
449
|
+
type: Input
|
|
450
|
+
}], max: [{
|
|
451
|
+
type: Input
|
|
282
452
|
}], value: [{
|
|
283
453
|
type: Input
|
|
284
454
|
}], values: [{
|
|
@@ -290,4 +460,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
290
460
|
}], dateSelected: [{
|
|
291
461
|
type: Output
|
|
292
462
|
}] } });
|
|
293
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-inline.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/date-time-inline.component.ts","../../../../../projects/picker/src/lib/date-time/date-time-inline.component.html"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,qBAAqB,EAAsB,MAAM,kCAAkC,CAAC;AAC7F,OAAO,EAAE,6BAA6B,EAAE,MAAM,wCAAwC,CAAC;AACvF,OAAO,EAAE,WAAW,EAAsC,MAAM,mBAAmB,CAAC;;;;AAEpF,MAAM,CAAC,MAAM,2BAA2B,GAAQ;IAC9C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;IACzD,KAAK,EAAE,IAAI;CACZ,CAAC;AAaF,MAAM,OAAO,0BAA8B,SAAQ,WAAc;IAW/D,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAI,UAAU,CAAC,GAAe;QAC5B,IAAI,GAAG,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC;YAC7B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;QACzB,CAAC;IACH,CAAC;IAGD,IACa,QAAQ;QACnB,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IAAa,QAAQ,CAAC,KAAc;QAClC,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAGD,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAI,UAAU,CAAC,IAAgB;QAC7B,IAAI,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,WAAW,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;YACxF,MAAM,KAAK,CAAC,8CAA8C,CAAC,CAAC;QAC9D,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAID,IACI,OAAO;QACT,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,QAAQ,CAAC;QACvB,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,OAAO,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE,CAAC;YAC1E,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,IAAI,OAAO,CAAC,IAAc;QACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5E,CAAC;IAID,IACI,KAAK;QACP,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,KAAK,QAAQ,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,OAAO,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE,CAAC;YAC1E,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,IAAI,KAAK,CAAC,IAAc;QACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,CAAC;IAGD,IACI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,IAAI,cAAc,CAAC,MAAmC;QACpD,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;IAChC,CAAC;IAKD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC;IAC3B,CAAC;IAED,IACI,WAAW,CAAC,KAAe;QAC7B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAKD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC;IAC3B,CAAC;IAED,IACI,WAAW,CAAC,KAAe;QAC7B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAGD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,KAAK,CAAC,KAAe;QACvB,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAChD,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAGD,IACI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAI,MAAM,CAAC,MAAgB;QACzB,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACxB,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBACxC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBACzB,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAClD,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;YAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAuBD,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,KAAe;QAC1B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAGD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,SAAS,CAAC,MAAgB;QAC5B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,WAAW,KAAK,QAAQ,CAAC;IACvC,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,WAAW,KAAK,OAAO,IAAI,IAAI,CAAC,WAAW,KAAK,WAAW,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC;IAC5G,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC;IACd,CAAC;IAUD,YACY,cAAiC,EACZ,eAAmC,EACJ,eAAmC;QAEjG,KAAK,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC;QAJ9B,mBAAc,GAAd,cAAc,CAAmB;QACZ,oBAAe,GAAf,eAAe,CAAoB;QACJ,oBAAe,GAAf,eAAe,CAAoB;QAnOnG;;;;;WAKG;QACK,gBAAW,GAAe,MAAM,CAAC;QAYjC,cAAS,GAAG,KAAK,CAAC;QAUlB,gBAAW,GAAe,QAAQ,CAAC;QA2GnC,YAAO,GAAa,EAAE,CAAC;QAqB/B;;;aAGK;QAEL,iBAAY,GAAG,IAAI,YAAY,EAAK,CAAC;QAErC;;;aAGK;QAEL,kBAAa,GAAG,IAAI,YAAY,EAAK,CAAC;QAEtC;;aAEK;QAEL,iBAAY,GAAG,IAAI,YAAY,EAAK,CAAC;QAY7B,eAAU,GAAa,EAAE,CAAC;QA8B1B,kBAAa,GAA8B,GAAG,EAAE;YACtD,UAAU;QACZ,CAAC,CAAC;QAEM,mBAAc,GAAe,GAAG,EAAE;YACxC,UAAU;QACZ,CAAC,CAAC;IAQF,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,CAAC;IAC/B,CAAC;IAEM,UAAU,CAAC,KAAU;QAC1B,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,KAAK,CAAC;QACtC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;QACjF,CAAC;IACH,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC3B,CAAC;IAEM,gBAAgB,CAAC,UAAmB;QACzC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAEM,MAAM,CAAC,IAAkB;QAC9B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QAC1B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED;;SAEK;IACE,UAAU,CAAC,cAAiB;QACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACzC,CAAC;IAED;;SAEK;IACE,WAAW,CAAC,eAAkB;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC3C,CAAC;IAED;;SAEK;IACE,UAAU,CAAC,cAAiB;QACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACzC,CAAC;8GAvSU,0BAA0B,kGAuOf,qBAAqB;kGAvOhC,0BAA0B,4fAF1B,CAAC,2BAA2B,CAAC,qEAG7B,6BAA6B,qFC1C1C,uDACA;;2FDwCa,0BAA0B;kBAXtC,SAAS;+BACE,sBAAsB,QAG1B;wBACJ,uBAAuB,EAAE,kBAAkB;qBAC5C,mBACgB,uBAAuB,CAAC,MAAM,uBAC1B,KAAK,aACf,CAAC,2BAA2B,CAAC;;0BAwOrC,QAAQ;;0BACR,QAAQ;;0BAAI,MAAM;2BAAC,qBAAqB;yCArO3C,SAAS;sBADR,SAAS;uBAAC,6BAA6B,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAWtD,UAAU;sBADb,KAAK;gBAaO,QAAQ;sBADpB,KAAK;gBAWF,UAAU;sBADb,KAAK;gBAgBF,OAAO;sBADV,KAAK;gBAwBF,KAAK;sBADR,KAAK;gBAqBF,cAAc;sBADjB,KAAK;uBAAC,mBAAmB;gBAiBtB,WAAW;sBADd,KAAK;uBAAC,KAAK;gBAcR,WAAW;sBADd,KAAK;uBAAC,KAAK;gBAQR,KAAK;sBADR,KAAK;gBAcF,MAAM;sBADT,KAAK;gBAyBN,YAAY;sBADX,MAAM;gBAQP,aAAa;sBADZ,MAAM;gBAOP,YAAY;sBADX,MAAM","sourcesContent":["/**\n * date-time-inline.component\n */\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OWL_DATE_TIME_FORMATS, OwlDateTimeFormats } from './adapter/date-time-format.class';\nimport { OwlDateTimeContainerComponent } from './date-time-picker-container.component';\nimport { OwlDateTime, PickerMode, PickerType, SelectMode } from './date-time.class';\n\nexport const OWL_DATETIME_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => OwlDateTimeInlineComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'owl-date-time-inline',\n  templateUrl: './date-time-inline.component.html',\n  styleUrls: ['./date-time-inline.component.scss'],\n  host: {\n    '[class.owl-dt-inline]': 'owlDTInlineClass'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [OWL_DATETIME_VALUE_ACCESSOR]\n})\nexport class OwlDateTimeInlineComponent<T> extends OwlDateTime<T> implements OnInit, ControlValueAccessor {\n  @ViewChild(OwlDateTimeContainerComponent, { static: true })\n  container: OwlDateTimeContainerComponent<T>;\n\n  /**\n   * Set the type of the dateTime picker\n   *      'both' -- show both calendar and timer\n   *      'calendar' -- show only calendar\n   *      'timer' -- show only timer\n   */\n  private _pickerType: PickerType = 'both';\n  @Input()\n  get pickerType(): PickerType {\n    return this._pickerType;\n  }\n\n  set pickerType(val: PickerType) {\n    if (val !== this._pickerType) {\n      this._pickerType = val;\n    }\n  }\n\n  private _disabled = false;\n  @Input()\n  override get disabled(): boolean {\n    return !!this._disabled;\n  }\n\n  override set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  private _selectMode: SelectMode = 'single';\n  @Input()\n  get selectMode() {\n    return this._selectMode;\n  }\n\n  set selectMode(mode: SelectMode) {\n    if (mode !== 'single' && mode !== 'range' && mode !== 'rangeFrom' && mode !== 'rangeTo') {\n      throw Error('OwlDateTime Error: invalid selectMode value!');\n    }\n\n    this._selectMode = mode;\n  }\n\n  /** The date to open the calendar to initially. */\n  private _startAt: T | null;\n  @Input()\n  get startAt(): T | null {\n    if (this._startAt) {\n      return this._startAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[0] || null;\n    } else if (this.selectMode === 'rangeTo') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n\n  set startAt(date: T | null) {\n    this._startAt = this.getValidDate(this.dateTimeAdapter.deserialize(date));\n  }\n\n  /** The date to open for range calendar. */\n  private _endAt: T | null;\n  @Input()\n  get endAt(): T | null {\n    if (this._endAt) {\n      return this._endAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n\n  set endAt(date: T | null) {\n    this._endAt = this.getValidDate(this.dateTimeAdapter.deserialize(date));\n  }\n\n  private _dateTimeFilter: (date: T | null) => boolean;\n  @Input('owlDateTimeFilter')\n  get dateTimeFilter() {\n    return this._dateTimeFilter;\n  }\n\n  set dateTimeFilter(filter: (date: T | null) => boolean) {\n    this._dateTimeFilter = filter;\n  }\n\n  /** The minimum valid date. */\n  private _min: T | null;\n\n  get minDateTime(): T | null {\n    return this._min || null;\n  }\n\n  @Input('min')\n  set minDateTime(value: T | null) {\n    this._min = this.getValidDate(this.dateTimeAdapter.deserialize(value));\n    this.changeDetector.markForCheck();\n  }\n\n  /** The maximum valid date. */\n  private _max: T | null;\n\n  get maxDateTime(): T | null {\n    return this._max || null;\n  }\n\n  @Input('max')\n  set maxDateTime(value: T | null) {\n    this._max = this.getValidDate(this.dateTimeAdapter.deserialize(value));\n    this.changeDetector.markForCheck();\n  }\n\n  private _value: T | null;\n  @Input()\n  get value() {\n    return this._value;\n  }\n\n  set value(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n    this._value = value;\n    this.selected = value;\n  }\n\n  private _values: Array<T> = [];\n  @Input()\n  get values() {\n    return this._values;\n  }\n\n  set values(values: Array<T>) {\n    if (values && values.length > 0) {\n      values = values.map((v) => {\n        v = this.dateTimeAdapter.deserialize(v);\n        v = this.getValidDate(v);\n        return v ? this.dateTimeAdapter.clone(v) : null;\n      });\n      this._values = [...values];\n      this.selecteds = [...values];\n    } else {\n      this._values = [];\n      this.selecteds = [];\n    }\n  }\n\n  /**\n   * Emits selected year in multi-year view\n   * This doesn't imply a change on the selected date.\n   * */\n  @Output()\n  yearSelected = new EventEmitter<T>();\n\n  /**\n   * Emits selected month in year view\n   * This doesn't imply a change on the selected date.\n   * */\n  @Output()\n  monthSelected = new EventEmitter<T>();\n\n  /**\n   * Emits selected date\n   * */\n  @Output()\n  dateSelected = new EventEmitter<T>();\n\n  private _selected: T | null;\n  get selected() {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    this._selected = value;\n    this.changeDetector.markForCheck();\n  }\n\n  private _selecteds: Array<T> = [];\n  get selecteds() {\n    return this._selecteds;\n  }\n\n  set selecteds(values: Array<T>) {\n    this._selecteds = values;\n    this.changeDetector.markForCheck();\n  }\n\n  get opened(): boolean {\n    return true;\n  }\n\n  get pickerMode(): PickerMode {\n    return 'inline';\n  }\n\n  get isInSingleMode(): boolean {\n    return this._selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return this._selectMode === 'range' || this._selectMode === 'rangeFrom' || this._selectMode === 'rangeTo';\n  }\n\n  get owlDTInlineClass(): boolean {\n    return true;\n  }\n\n  private onModelChange: (v: T | Array<T>) => void = () => {\n    /* noop */\n  };\n\n  private onModelTouched: () => void = () => {\n    /* noop */\n  };\n\n  constructor(\n    protected changeDetector: ChangeDetectorRef,\n    @Optional() protected override dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional() @Inject(OWL_DATE_TIME_FORMATS) protected override dateTimeFormats: OwlDateTimeFormats\n  ) {\n    super(dateTimeAdapter, dateTimeFormats);\n  }\n\n  public ngOnInit() {\n    this.container.picker = this;\n  }\n\n  public writeValue(value: any): void {\n    if (this.isInSingleMode) {\n      this.value = value;\n      this.container.pickerMoment = value;\n    } else {\n      this.values = value;\n      this.container.pickerMoment = this._values[this.container.activeSelectedIndex];\n    }\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onModelChange = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    this.onModelTouched = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  public select(date: Array<T> | T): void {\n    if (this.disabled) {\n      return;\n    }\n\n    if (Array.isArray(date)) {\n      this.values = [...date];\n    } else {\n      this.value = date;\n    }\n    this.onModelChange(date);\n    this.onModelTouched();\n  }\n\n  /**\n   * Emits the selected year in multi-year view\n   * */\n  public selectYear(normalizedYear: T): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  /**\n   * Emits selected month in year view\n   * */\n  public selectMonth(normalizedMonth: T): void {\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Emits the selected date\n   * */\n  public selectDate(normalizedDate: T): void {\n    this.dateSelected.emit(normalizedDate);\n  }\n}\n","<owl-date-time-container></owl-date-time-container>\n"]}
|
|
463
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-inline.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/date-time-inline.component.ts","../../../../../projects/picker/src/lib/date-time/date-time-inline.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  numberAttribute,\n  Output,\n  Provider\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateView, PickerType, SelectMode } from '../types';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\n\nconst OWL_DATETIME_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => OwlDateTimeInlineComponent),\n  multi: true\n};\n\nlet nextUniqueComponentId = 0;\n\n@Component({\n  selector: 'owl-date-time-inline',\n  templateUrl: './date-time-inline.component.html',\n  styleUrls: ['./date-time-inline.component.scss'],\n  host: {\n    '[class.owl-dt-container-disabled]': 'disabled',\n    'class': 'owl-dt-inline owl-dt-container owl-dt-inline-container'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [OWL_DATETIME_VALUE_ACCESSOR]\n})\nexport class OwlDateTimeInlineComponent implements ControlValueAccessor {\n  public readonly id: string;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n\n  readonly #pickerIntl = inject(OwlDateTimeIntl);\n\n  readonly #dateTimeFormats = inject(OWL_DATE_TIME_FORMATS, { optional: true });\n\n  readonly #dateTimeAdapter = inject<DateTimeAdapter<Date>>(DateTimeAdapter, { optional: true });\n\n  /**\n   * Whether the timer is in hour12 format\n   */\n  @Input({ transform: booleanAttribute })\n  public hour12Timer = false;\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  public startView: DateView = DateView.MONTH;\n\n  /**\n   * Whether to should only the year and multi-year views.\n   */\n  @Input({ transform: booleanAttribute })\n  public yearOnly = false;\n\n  /**\n   * Whether to should only the multi-year view.\n   */\n  @Input({ transform: booleanAttribute })\n  public multiyearOnly = false;\n\n  /**\n   * Hours to change per step\n   */\n  @Input()\n  public stepHour: number = 1;\n\n  /**\n   * Minutes to change per step\n   */\n  @Input()\n  public stepMinute: number = 1;\n\n  /**\n   * Seconds to change per step\n   */\n  @Input()\n  public stepSecond: number = 1;\n\n  /**\n   * Set the first day of week.\n   * Has to be a number between 0 (Sunday) and 6 (Saturday)\n   */\n  private _firstDayOfWeek: number;\n  @Input()\n  public get firstDayOfWeek(): number {\n    return this._firstDayOfWeek;\n  }\n  public set firstDayOfWeek(value: number) {\n    value = numberAttribute(value, undefined);\n    if (value > 6 || value < 0) {\n      this._firstDayOfWeek = undefined;\n    } else {\n      this._firstDayOfWeek = value;\n    }\n  }\n\n  /**\n   * Whether to hide dates in other months at the start or end of the current month.\n   */\n\n  @Input({ transform: booleanAttribute })\n  public hideOtherMonths: boolean = false;\n\n  protected get formatOptions(): Intl.DateTimeFormatOptions {\n    if (this.pickerType === 'both') {\n      return this.#dateTimeFormats.fullPickerInput;\n    }\n\n    if (this.pickerType === 'calendar') {\n      return this.#dateTimeFormats.datePickerInput;\n    }\n\n    return this.#dateTimeFormats.timePickerInput;\n  }\n\n  /**\n   * Date Time Checker to check if the give dateTime is selectable\n   */\n  public dateTimeChecker = (dateTime: Date): boolean => {\n    return (\n      !!dateTime &&\n      (!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&\n      (!this.min || this.#dateTimeAdapter.compare(dateTime, this.min) >= 0) &&\n      (!this.max || this.#dateTimeAdapter.compare(dateTime, this.max) <= 0)\n    );\n  };\n\n  protected getValidDate(obj: unknown): Date | null {\n    return this.#dateTimeAdapter.isDateInstance(obj) && this.#dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n\n  /**\n   * Set the {@link PickerType} of the dateTime picker\n   */\n  @Input()\n  public pickerType: PickerType = 'both';\n\n  /**\n   * Whether the picker is disabled or not\n   */\n  @Input({ transform: booleanAttribute })\n  public disabled = false;\n\n  /**\n   * Whether to show the second's timer\n   */\n  @Input({ transform: booleanAttribute })\n  public showSecondsTimer = false;\n\n  /**\n   * Which select mode to use:\n   * - 'single'\n   * - 'range'\n   * - 'rangeFrom'\n   * - 'rangeTo'\n   */\n  @Input()\n  public selectMode: SelectMode = 'single';\n\n  /**\n   * The date to open the calendar to initially.\n   */\n  private _startAt: Date | null;\n  @Input()\n  public get startAt(): Date | null {\n    if (this._startAt) {\n      return this._startAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[0] || null;\n    } else if (this.selectMode === 'rangeTo') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n  public set startAt(date: Date | null) {\n    this._startAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));\n  }\n\n  /**\n   * The date to open for range calendar.\n   */\n  private _endAt: Date | null;\n  @Input()\n  public get endAt(): Date | null {\n    if (this._endAt) {\n      return this._endAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n  public set endAt(date: Date | null) {\n    this._endAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));\n  }\n\n  /**\n   * @deprecated use `dateTimeFilter` instead!\n   */\n  @Input()\n  public owlDateTimeFilter: ((date: Date | null) => boolean) | null = null;\n\n  @Input()\n  public dateTimeFilter: ((date: Date | null) => boolean) | null = null;\n\n  // TODO: remove this getter when `owlDateTimeFilter` is removed\n  protected get dateTimeFilterGetter(): ((date: Date | null) => boolean) | null {\n    return this.dateTimeFilter || this.owlDateTimeFilter;\n  }\n\n  private _min: Date | null;\n  /**\n   * The minimum valid date.\n   */\n  @Input()\n  public get min(): Date | null {\n    return this._min || null;\n  }\n  public set min(value: Date | null) {\n    this._min = this.getValidDate(this.#dateTimeAdapter.deserialize(value));\n    this.#changeDetector.markForCheck();\n  }\n\n  private _max: Date | null;\n  /**\n   * The maximum valid date.\n   */\n  @Input()\n  public get max(): Date | null {\n    return this._max || null;\n  }\n  public set max(value: Date | null) {\n    this._max = this.getValidDate(this.#dateTimeAdapter.deserialize(value));\n    this.#changeDetector.markForCheck();\n  }\n\n  private _value: Date | null;\n  @Input()\n  public get value(): Date | null {\n    return this._value;\n  }\n\n  public set value(value: Date | null) {\n    value = this.#dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n    this._value = value;\n    this.selected = value;\n  }\n\n  private _values: Array<Date> = [];\n  @Input()\n  public get values(): Array<Date> | null {\n    return this._values;\n  }\n  public set values(values: Array<Date>) {\n    if (values && values.length > 0) {\n      values = values.map((v) => {\n        v = this.#dateTimeAdapter.deserialize(v);\n        v = this.getValidDate(v);\n        return v ? this.#dateTimeAdapter.clone(v) : null;\n      });\n      this._values = [...values];\n      this.selecteds = [...values];\n    } else {\n      this._values = [];\n      this.selecteds = [];\n    }\n  }\n\n  /**\n   * Emits selected year in multi-year view\n   * This doesn't imply a change on the selected date.\n   */\n  @Output()\n  public readonly yearSelected = new EventEmitter<Date>();\n\n  /**\n   * Emits selected month in year view\n   * This doesn't imply a change on the selected date.\n   */\n  @Output()\n  public readonly monthSelected = new EventEmitter<Date>();\n\n  /**\n   * Emits selected date\n   */\n  @Output()\n  public readonly dateSelected = new EventEmitter<Date>();\n\n  protected activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')\n\n  private _selected: Date | null;\n  protected get selected(): Date | null {\n    return this._selected;\n  }\n  protected set selected(value: Date | null) {\n    this._selected = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  private _selecteds: Array<Date> = [];\n  protected get selecteds(): Array<Date> {\n    return this._selecteds;\n  }\n\n  protected set selecteds(values: Array<Date>) {\n    this._selecteds = values;\n    this.#changeDetector.markForCheck();\n  }\n\n  /**\n   * Returns whether the picker is in single mode\n   */\n  protected get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  /**\n   * Returns whether the picker is in range mode (range, rangeFrom, rangeTo)\n   */\n  protected get isInRangeMode(): boolean {\n    return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';\n  }\n\n  /**\n   * The range 'from' label\n   */\n  protected get fromLabel(): string {\n    return this.#pickerIntl.rangeFromLabel;\n  }\n\n  /**\n   * The range 'to' label\n   */\n  protected get toLabel(): string {\n    return this.#pickerIntl.rangeToLabel;\n  }\n\n  /**\n   * The range 'from' formatted value\n   */\n  protected get fromFormattedValue(): string {\n    const value = this.selecteds[0];\n    return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';\n  }\n\n  /**\n   * The range 'to' formatted value\n   */\n  protected get toFormattedValue(): string {\n    const value = this.selecteds[1];\n    return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';\n  }\n\n  private onModelChange: (v: Date | Array<Date>) => void = () => {\n    /* noop */\n  };\n\n  private onModelTouched: () => void = () => {\n    /* noop */\n  };\n\n  constructor() {\n    if (!this.#dateTimeAdapter) {\n      throw Error(\n        `OwlDateTimePicker: No provider found for DateTimeAdapter. You must import one of the following ` +\n          `modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +\n          `custom implementation.`\n      );\n    }\n\n    if (!this.#dateTimeFormats) {\n      throw Error(\n        `OwlDateTimePicker: No provider found for OWL_DATE_TIME_FORMATS. You must import one of the following ` +\n          `modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +\n          `custom implementation.`\n      );\n    }\n\n    this.id = `owl-dt-picker-${nextUniqueComponentId++}`;\n  }\n\n  public writeValue(value: Date): void {\n    if (this.isInSingleMode) {\n      this.selected = value;\n      this.value = this.selected;\n    } else {\n      // Handle the case where the second selected date is before the first selected date\n      // In this case \"go back\" and treat the value as the first selected date\n      if (this.activeSelectedIndex === 1) {\n        if (value.getTime() < this.selecteds[0].getTime()) {\n          this.activeSelectedIndex = 0;\n        }\n      }\n\n      // Set the correct value according to the active selected index\n      if (this.activeSelectedIndex === 0) {\n        this.selecteds = [value, null];\n      } else {\n        this.selecteds[1] = value;\n      }\n\n      // Set the values to the selecteds\n      this.values = [...this.selecteds];\n      this.activeSelectedIndex = (this.activeSelectedIndex + 1) % 2;\n    }\n  }\n\n  public registerOnChange(fn: (v: Date | Array<Date>) => void): void {\n    this.onModelChange = fn;\n  }\n\n  public registerOnTouched(fn: () => void): void {\n    this.onModelTouched = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  public select(date: Array<Date> | Date): void {\n    if (this.disabled) {\n      return;\n    }\n\n    if (Array.isArray(date)) {\n      this.values = [...date];\n    } else {\n      this.value = date;\n    }\n    this.onModelChange(date);\n    this.onModelTouched();\n  }\n\n  /**\n   * Emits the selected year in multi-year view\n   */\n  public selectYear(normalizedYear: Date): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  /**\n   * Emits selected month in year view\n   */\n  public selectMonth(normalizedMonth: Date): void {\n    this.writeValue(normalizedMonth);\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Emits the selected date\n   */\n  public selectDate(normalizedDate: Date): void {\n    this.writeValue(normalizedDate);\n    this.dateSelected.emit(normalizedDate);\n  }\n\n  /**\n   * Sets the active \"selected\" index in range mode.\n   * - 0 for 'from'\n   * - 1 for 'to'\n   */\n  protected setActiveSelectedIndex(index: number): void {\n    if (this.selectMode === 'range' && this.activeSelectedIndex !== index) {\n      this.activeSelectedIndex = index;\n\n      const selected = this.selecteds[this.activeSelectedIndex];\n      if (this.selecteds && selected) {\n        this.value = this.#dateTimeAdapter.clone(selected);\n      }\n    }\n    return;\n  }\n\n  /**\n   * Handle click on inform radio group\n   */\n  protected handleKeydownOnInfoGroup(event: KeyboardEvent, next: HTMLElement, index: number): void {\n    let handled = false;\n\n    switch (event.key) {\n      // Navigate between the radio group options with arrow keys\n      case 'ArrowDown':\n      case 'ArrowRight':\n      case 'ArrowUp':\n      case 'ArrowLeft':\n        next.focus();\n        this.setActiveSelectedIndex(index === 0 ? 1 : 0);\n        handled = true;\n        break;\n\n      // Select the active selected index when space is pressed\n      case ' ':\n        this.setActiveSelectedIndex(index);\n        handled = true;\n        break;\n    }\n\n    if (handled) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n  }\n}\n","<div class=\"owl-dt-container-inner\">\n  @if (pickerType === 'both' || pickerType === 'calendar') {\n    <owl-date-time-calendar\n      [dateFilter]=\"dateTimeFilterGetter\"\n      [firstDayOfWeek]=\"firstDayOfWeek\"\n      [hideOtherMonths]=\"hideOtherMonths\"\n      [maxDate]=\"max\"\n      [minDate]=\"min\"\n      [multiyearOnly]=\"multiyearOnly\"\n      [selectMode]=\"selectMode\"\n      [selected]=\"selected\"\n      [selecteds]=\"selecteds\"\n      [startView]=\"startView\"\n      [yearOnly]=\"yearOnly\"\n      [(pickerMoment)]=\"value\"\n      (dateClicked)=\"selectDate($event)\"\n      (monthSelected)=\"selectMonth($event)\"\n      (selectedChange)=\"select($event)\"\n      (yearSelected)=\"selectYear($event)\"\n      class=\"owl-dt-container-row\">\n    </owl-date-time-calendar>\n  }\n\n  @if (pickerType === 'both' || pickerType === 'timer') {\n    <owl-date-time-timer\n      [hour12Timer]=\"hour12Timer\"\n      [maxDateTime]=\"max\"\n      [minDateTime]=\"min\"\n      [pickerMoment]=\"value\"\n      [showSecondsTimer]=\"showSecondsTimer\"\n      [stepHour]=\"stepHour\"\n      [stepMinute]=\"stepMinute\"\n      [stepSecond]=\"stepSecond\"\n      (selectedChange)=\"select($event)\"\n      class=\"owl-dt-container-row\">\n    </owl-date-time-timer>\n  }\n\n  @if (isInRangeMode) {\n    <div\n      class=\"owl-dt-container-info owl-dt-container-row\"\n      role=\"radiogroup\">\n      <div\n        #from\n        [attr.aria-checked]=\"activeSelectedIndex === 0\"\n        [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n        [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n        (click)=\"setActiveSelectedIndex(0)\"\n        (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n        class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n        role=\"radio\">\n        <span\n          class=\"owl-dt-control-content owl-dt-container-range-content\"\n          tabindex=\"-1\">\n          <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n          <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n        </span>\n      </div>\n      <div\n        #to\n        [attr.aria-checked]=\"activeSelectedIndex === 1\"\n        [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n        [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n        (click)=\"setActiveSelectedIndex(1)\"\n        (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n        class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n        role=\"radio\">\n        <span\n          class=\"owl-dt-control-content owl-dt-container-range-content\"\n          tabindex=\"-1\">\n          <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n          <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n        </span>\n      </div>\n    </div>\n  }\n</div>\n"]}
|