@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.
Files changed (77) hide show
  1. package/README.md +1 -27
  2. package/assets/style/picker.min.css +1 -1
  3. package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +7 -13
  4. package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +1 -4
  5. package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +21 -36
  6. package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +1 -2
  7. package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +9 -12
  8. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +12 -25
  9. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +1 -2
  10. package/esm2022/lib/date-time/calendar-body.component.mjs +22 -31
  11. package/esm2022/lib/date-time/calendar-month-view.component.mjs +13 -29
  12. package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +11 -17
  13. package/esm2022/lib/date-time/calendar-year-view.component.mjs +11 -19
  14. package/esm2022/lib/date-time/calendar.component.mjs +16 -27
  15. package/esm2022/lib/date-time/date-time-inline.component.mjs +280 -110
  16. package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +4 -11
  17. package/esm2022/lib/date-time/date-time.module.mjs +12 -36
  18. package/esm2022/lib/date-time/options-provider.mjs +1 -1
  19. package/esm2022/lib/date-time/timer-box.component.mjs +6 -16
  20. package/esm2022/lib/date-time/timer.component.mjs +18 -17
  21. package/esm2022/lib/types/date-view.mjs +19 -0
  22. package/esm2022/lib/types/index.mjs +4 -0
  23. package/esm2022/lib/types/picker-type.mjs +2 -0
  24. package/esm2022/lib/types/select-mode.mjs +2 -0
  25. package/esm2022/public_api.mjs +18 -20
  26. package/fesm2022/netwin-angular-datetime-picker.mjs +1843 -4264
  27. package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -1
  28. package/lib/date-time/adapter/date-time-adapter.class.d.ts +16 -26
  29. package/lib/date-time/adapter/date-time-format.class.d.ts +8 -12
  30. package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +7 -18
  31. package/lib/date-time/adapter/native-date-time-format.class.d.ts +0 -3
  32. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +6 -17
  33. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +0 -3
  34. package/lib/date-time/calendar-body.component.d.ts +21 -26
  35. package/lib/date-time/calendar-month-view.component.d.ts +19 -24
  36. package/lib/date-time/calendar-multi-year-view.component.d.ts +14 -14
  37. package/lib/date-time/calendar-year-view.component.d.ts +8 -9
  38. package/lib/date-time/calendar.component.d.ts +15 -21
  39. package/lib/date-time/date-time-inline.component.d.ts +164 -74
  40. package/lib/date-time/date-time-picker-intl.service.d.ts +0 -4
  41. package/lib/date-time/date-time.module.d.ts +11 -18
  42. package/lib/date-time/timer-box.component.d.ts +4 -5
  43. package/lib/date-time/timer.component.d.ts +6 -9
  44. package/lib/types/date-view.d.ts +17 -0
  45. package/lib/types/index.d.ts +3 -0
  46. package/lib/types/picker-type.d.ts +7 -0
  47. package/lib/types/select-mode.d.ts +8 -0
  48. package/package.json +1 -1
  49. package/public_api.d.ts +12 -19
  50. package/esm2022/lib/date-time/date-time-picker-container.component.mjs +0 -405
  51. package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +0 -598
  52. package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +0 -64
  53. package/esm2022/lib/date-time/date-time-picker.animations.mjs +0 -21
  54. package/esm2022/lib/date-time/date-time-picker.component.mjs +0 -564
  55. package/esm2022/lib/date-time/date-time.class.mjs +0 -176
  56. package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +0 -28
  57. package/esm2022/lib/dialog/dialog-config.class.mjs +0 -59
  58. package/esm2022/lib/dialog/dialog-container.component.mjs +0 -232
  59. package/esm2022/lib/dialog/dialog-ref.class.mjs +0 -134
  60. package/esm2022/lib/dialog/dialog.module.mjs +0 -26
  61. package/esm2022/lib/dialog/dialog.service.mjs +0 -228
  62. package/esm2022/lib/utils/index.mjs +0 -5
  63. package/esm2022/lib/utils/object.utils.mjs +0 -23
  64. package/lib/date-time/date-time-picker-container.component.d.ts +0 -130
  65. package/lib/date-time/date-time-picker-input.directive.d.ts +0 -164
  66. package/lib/date-time/date-time-picker-trigger.directive.d.ts +0 -23
  67. package/lib/date-time/date-time-picker.animations.d.ts +0 -8
  68. package/lib/date-time/date-time-picker.component.d.ts +0 -173
  69. package/lib/date-time/date-time.class.d.ts +0 -103
  70. package/lib/date-time/numberedFixLen.pipe.d.ts +0 -10
  71. package/lib/dialog/dialog-config.class.d.ts +0 -169
  72. package/lib/dialog/dialog-container.component.d.ts +0 -58
  73. package/lib/dialog/dialog-ref.class.d.ts +0 -51
  74. package/lib/dialog/dialog.module.d.ts +0 -11
  75. package/lib/dialog/dialog.service.d.ts +0 -76
  76. package/lib/utils/index.d.ts +0 -4
  77. 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 { OwlDateTimeContainerComponent } from './date-time-picker-container.component';
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 "./adapter/date-time-adapter.class";
12
- import * as i2 from "./date-time-picker-container.component";
13
- export const OWL_DATETIME_VALUE_ACCESSOR = {
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
- export class OwlDateTimeInlineComponent extends OwlDateTime {
19
- get pickerType() {
20
- return this._pickerType;
21
- }
22
- set pickerType(val) {
23
- if (val !== this._pickerType) {
24
- this._pickerType = val;
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 disabled() {
28
- return !!this._disabled;
29
- }
30
- set disabled(value) {
31
- this._disabled = coerceBooleanProperty(value);
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._selectMode = mode;
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.dateTimeAdapter.deserialize(date));
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.dateTimeAdapter.deserialize(date));
80
+ this._endAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));
78
81
  }
79
- get dateTimeFilter() {
80
- return this._dateTimeFilter;
82
+ // TODO: remove this getter when `owlDateTimeFilter` is removed
83
+ get dateTimeFilterGetter() {
84
+ return this.dateTimeFilter || this.owlDateTimeFilter;
81
85
  }
82
- set dateTimeFilter(filter) {
83
- this._dateTimeFilter = filter;
84
- }
85
- get minDateTime() {
86
+ /**
87
+ * The minimum valid date.
88
+ */
89
+ get min() {
86
90
  return this._min || null;
87
91
  }
88
- set minDateTime(value) {
89
- this._min = this.getValidDate(this.dateTimeAdapter.deserialize(value));
90
- this.changeDetector.markForCheck();
92
+ set min(value) {
93
+ this._min = this.getValidDate(this.#dateTimeAdapter.deserialize(value));
94
+ this.#changeDetector.markForCheck();
91
95
  }
92
- get maxDateTime() {
96
+ /**
97
+ * The maximum valid date.
98
+ */
99
+ get max() {
93
100
  return this._max || null;
94
101
  }
95
- set maxDateTime(value) {
96
- this._max = this.getValidDate(this.dateTimeAdapter.deserialize(value));
97
- this.changeDetector.markForCheck();
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.dateTimeAdapter.deserialize(value);
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.dateTimeAdapter.deserialize(v);
121
+ v = this.#dateTimeAdapter.deserialize(v);
115
122
  v = this.getValidDate(v);
116
- return v ? this.dateTimeAdapter.clone(v) : null;
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.changeDetector.markForCheck();
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.changeDetector.markForCheck();
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._selectMode === 'single';
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._selectMode === 'range' || this._selectMode === 'rangeFrom' || this._selectMode === 'rangeTo';
157
+ return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
151
158
  }
152
- get owlDTInlineClass() {
153
- return true;
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
- constructor(changeDetector, dateTimeAdapter, dateTimeFormats) {
156
- super(dateTimeAdapter, dateTimeFormats);
157
- this.changeDetector = changeDetector;
158
- this.dateTimeAdapter = dateTimeAdapter;
159
- this.dateTimeFormats = dateTimeFormats;
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 type of the dateTime picker
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._pickerType = 'both';
167
- this._disabled = false;
168
- this._selectMode = 'single';
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
- ngOnInit() {
193
- this.container.picker = this;
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.value = value;
198
- this.container.pickerMoment = value;
293
+ this.selected = value;
294
+ this.value = this.selected;
199
295
  }
200
296
  else {
201
- this.values = value;
202
- this.container.pickerMoment = this._values[this.container.activeSelectedIndex];
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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: OwlDateTimeInlineComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
246
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: OwlDateTimeInlineComponent, selector: "owl-date-time-inline", inputs: { pickerType: "pickerType", disabled: "disabled", selectMode: "selectMode", startAt: "startAt", endAt: "endAt", dateTimeFilter: ["owlDateTimeFilter", "dateTimeFilter"], minDateTime: ["min", "minDateTime"], maxDateTime: ["max", "maxDateTime"], value: "value", values: "values" }, outputs: { yearSelected: "yearSelected", monthSelected: "monthSelected", dateSelected: "dateSelected" }, host: { properties: { "class.owl-dt-inline": "owlDTInlineClass" } }, providers: [OWL_DATETIME_VALUE_ACCESSOR], viewQueries: [{ propertyName: "container", first: true, predicate: OwlDateTimeContainerComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<owl-date-time-container></owl-date-time-container>\n", styles: [""], dependencies: [{ kind: "component", type: i2.OwlDateTimeContainerComponent, selector: "owl-date-time-container", exportAs: ["owlDateTimeContainer"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
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.8", ngImport: i0, type: OwlDateTimeInlineComponent, decorators: [{
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-inline]': 'owlDTInlineClass'
252
- }, changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, providers: [OWL_DATETIME_VALUE_ACCESSOR], template: "<owl-date-time-container></owl-date-time-container>\n" }]
253
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.DateTimeAdapter, decorators: [{
254
- type: Optional
255
- }] }, { type: undefined, decorators: [{
256
- type: Optional
257
- }, {
258
- type: Inject,
259
- args: [OWL_DATE_TIME_FORMATS]
260
- }] }], propDecorators: { container: [{
261
- type: ViewChild,
262
- args: [OwlDateTimeContainerComponent, { static: true }]
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
- args: ['owlDateTimeFilter']
276
- }], minDateTime: [{
277
- type: Input,
278
- args: ['min']
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":"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","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"]}