@netwin/angular-datetime-picker 18.0.0

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 (79) hide show
  1. package/README.md +225 -0
  2. package/assets/style/picker.min.css +1 -0
  3. package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +121 -0
  4. package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
  5. package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +261 -0
  6. package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +10 -0
  7. package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +39 -0
  8. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +235 -0
  9. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +10 -0
  10. package/esm2022/lib/date-time/calendar-body.component.mjs +147 -0
  11. package/esm2022/lib/date-time/calendar-month-view.component.mjs +451 -0
  12. package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +361 -0
  13. package/esm2022/lib/date-time/calendar-year-view.component.mjs +371 -0
  14. package/esm2022/lib/date-time/calendar.component.mjs +383 -0
  15. package/esm2022/lib/date-time/date-time-inline.component.mjs +296 -0
  16. package/esm2022/lib/date-time/date-time-picker-container.component.mjs +420 -0
  17. package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +638 -0
  18. package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
  19. package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +69 -0
  20. package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
  21. package/esm2022/lib/date-time/date-time-picker.component.mjs +580 -0
  22. package/esm2022/lib/date-time/date-time.class.mjs +180 -0
  23. package/esm2022/lib/date-time/date-time.module.mjs +91 -0
  24. package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
  25. package/esm2022/lib/date-time/options-provider.mjs +34 -0
  26. package/esm2022/lib/date-time/timer-box.component.mjs +135 -0
  27. package/esm2022/lib/date-time/timer.component.mjs +292 -0
  28. package/esm2022/lib/dialog/dialog-config.class.mjs +56 -0
  29. package/esm2022/lib/dialog/dialog-container.component.mjs +230 -0
  30. package/esm2022/lib/dialog/dialog-ref.class.mjs +123 -0
  31. package/esm2022/lib/dialog/dialog.module.mjs +34 -0
  32. package/esm2022/lib/dialog/dialog.service.mjs +245 -0
  33. package/esm2022/lib/utils/array.utils.mjs +12 -0
  34. package/esm2022/lib/utils/constants.mjs +55 -0
  35. package/esm2022/lib/utils/date.utils.mjs +49 -0
  36. package/esm2022/lib/utils/index.mjs +5 -0
  37. package/esm2022/lib/utils/object.utils.mjs +26 -0
  38. package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
  39. package/esm2022/public_api.mjs +25 -0
  40. package/fesm2022/netwin-angular-datetime-picker.mjs +5913 -0
  41. package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
  42. package/index.d.ts +5 -0
  43. package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
  44. package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
  45. package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +69 -0
  46. package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
  47. package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
  48. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +64 -0
  49. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
  50. package/lib/date-time/calendar-body.component.d.ts +80 -0
  51. package/lib/date-time/calendar-month-view.component.d.ts +144 -0
  52. package/lib/date-time/calendar-multi-year-view.component.d.ts +111 -0
  53. package/lib/date-time/calendar-year-view.component.d.ts +123 -0
  54. package/lib/date-time/calendar.component.d.ts +155 -0
  55. package/lib/date-time/date-time-inline.component.d.ts +105 -0
  56. package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
  57. package/lib/date-time/date-time-picker-input.directive.d.ts +167 -0
  58. package/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
  59. package/lib/date-time/date-time-picker-trigger.directive.d.ts +24 -0
  60. package/lib/date-time/date-time-picker.animations.d.ts +8 -0
  61. package/lib/date-time/date-time-picker.component.d.ts +177 -0
  62. package/lib/date-time/date-time.class.d.ts +106 -0
  63. package/lib/date-time/date-time.module.d.ts +23 -0
  64. package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
  65. package/lib/date-time/options-provider.d.ts +23 -0
  66. package/lib/date-time/timer-box.component.d.ts +46 -0
  67. package/lib/date-time/timer.component.d.ts +132 -0
  68. package/lib/dialog/dialog-config.class.d.ts +169 -0
  69. package/lib/dialog/dialog-container.component.d.ts +59 -0
  70. package/lib/dialog/dialog-ref.class.d.ts +51 -0
  71. package/lib/dialog/dialog.module.d.ts +11 -0
  72. package/lib/dialog/dialog.service.d.ts +76 -0
  73. package/lib/utils/array.utils.d.ts +5 -0
  74. package/lib/utils/constants.d.ts +19 -0
  75. package/lib/utils/date.utils.d.ts +12 -0
  76. package/lib/utils/index.d.ts +4 -0
  77. package/lib/utils/object.utils.d.ts +11 -0
  78. package/package.json +51 -0
  79. package/public_api.d.ts +24 -0
@@ -0,0 +1,420 @@
1
+ /**
2
+ * date-time-picker-container.component
3
+ */
4
+ import { ChangeDetectionStrategy, Component, Optional, ViewChild } from '@angular/core';
5
+ import { OwlCalendarComponent } from './calendar.component';
6
+ import { OwlTimerComponent } from './timer.component';
7
+ import { Subject } from 'rxjs';
8
+ import { owlDateTimePickerAnimations } from './date-time-picker.animations';
9
+ import { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, SPACE, UP_ARROW } from '@angular/cdk/keycodes';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "./date-time-picker-intl.service";
12
+ import * as i2 from "./adapter/date-time-adapter.class";
13
+ import * as i3 from "@angular/common";
14
+ import * as i4 from "@angular/cdk/a11y";
15
+ import * as i5 from "./timer.component";
16
+ import * as i6 from "./calendar.component";
17
+ export class OwlDateTimeContainerComponent {
18
+ get hidePickerStream() {
19
+ return this.hidePicker$.asObservable();
20
+ }
21
+ get confirmSelectedStream() {
22
+ return this.confirmSelected$.asObservable();
23
+ }
24
+ get beforePickerOpenedStream() {
25
+ return this.beforePickerOpened$.asObservable();
26
+ }
27
+ get pickerOpenedStream() {
28
+ return this.pickerOpened$.asObservable();
29
+ }
30
+ get pickerMoment() {
31
+ return this._clamPickerMoment;
32
+ }
33
+ set pickerMoment(value) {
34
+ if (value) {
35
+ this._clamPickerMoment = this.dateTimeAdapter.clampDate(value, this.picker.minDateTime, this.picker.maxDateTime);
36
+ }
37
+ this.cdRef.markForCheck();
38
+ }
39
+ get pickerType() {
40
+ return this.picker.pickerType;
41
+ }
42
+ get cancelLabel() {
43
+ return this.pickerIntl.cancelBtnLabel;
44
+ }
45
+ get setLabel() {
46
+ return this.pickerIntl.setBtnLabel;
47
+ }
48
+ /**
49
+ * The range 'from' label
50
+ * */
51
+ get fromLabel() {
52
+ return this.pickerIntl.rangeFromLabel;
53
+ }
54
+ /**
55
+ * The range 'to' label
56
+ * */
57
+ get toLabel() {
58
+ return this.pickerIntl.rangeToLabel;
59
+ }
60
+ /**
61
+ * The range 'from' formatted value
62
+ * */
63
+ get fromFormattedValue() {
64
+ const value = this.picker.selecteds[0];
65
+ return value
66
+ ? this.dateTimeAdapter.format(value, this.picker.formatString)
67
+ : '';
68
+ }
69
+ /**
70
+ * The range 'to' formatted value
71
+ * */
72
+ get toFormattedValue() {
73
+ const value = this.picker.selecteds[1];
74
+ return value
75
+ ? this.dateTimeAdapter.format(value, this.picker.formatString)
76
+ : '';
77
+ }
78
+ /**
79
+ * Cases in which the control buttons show in the picker
80
+ * 1) picker mode is 'dialog'
81
+ * 2) picker type is NOT 'calendar' and the picker mode is NOT 'inline'
82
+ * */
83
+ get showControlButtons() {
84
+ return (this.picker.pickerMode === 'dialog' ||
85
+ (this.picker.pickerType !== 'calendar' &&
86
+ this.picker.pickerMode !== 'inline'));
87
+ }
88
+ get containerElm() {
89
+ return this.elmRef.nativeElement;
90
+ }
91
+ get owlDTContainerClass() {
92
+ return true;
93
+ }
94
+ get owlDTPopupContainerClass() {
95
+ return this.picker.pickerMode === 'popup';
96
+ }
97
+ get owlDTDialogContainerClass() {
98
+ return this.picker.pickerMode === 'dialog';
99
+ }
100
+ get owlDTInlineContainerClass() {
101
+ return this.picker.pickerMode === 'inline';
102
+ }
103
+ get owlDTContainerDisabledClass() {
104
+ return this.picker.disabled;
105
+ }
106
+ get owlDTContainerId() {
107
+ return this.picker.id;
108
+ }
109
+ get owlDTContainerAnimation() {
110
+ return this.picker.pickerMode === 'inline' ? '' : 'enter';
111
+ }
112
+ constructor(cdRef, elmRef, pickerIntl, dateTimeAdapter) {
113
+ this.cdRef = cdRef;
114
+ this.elmRef = elmRef;
115
+ this.pickerIntl = pickerIntl;
116
+ this.dateTimeAdapter = dateTimeAdapter;
117
+ this.activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')
118
+ /**
119
+ * Stream emits when try to hide picker
120
+ * */
121
+ this.hidePicker$ = new Subject();
122
+ /**
123
+ * Stream emits when try to confirm the selected value
124
+ * */
125
+ this.confirmSelected$ = new Subject();
126
+ this.beforePickerOpened$ = new Subject();
127
+ this.pickerOpened$ = new Subject();
128
+ }
129
+ ngOnInit() {
130
+ if (this.picker.selectMode === 'range') {
131
+ if (this.picker.selecteds[0]) {
132
+ this.retainStartTime = this.dateTimeAdapter.clone(this.picker.selecteds[0]);
133
+ }
134
+ if (this.picker.selecteds[1]) {
135
+ this.retainEndTime = this.dateTimeAdapter.clone(this.picker.selecteds[1]);
136
+ }
137
+ }
138
+ }
139
+ ngAfterContentInit() {
140
+ this.initPicker();
141
+ }
142
+ ngAfterViewInit() {
143
+ this.focusPicker();
144
+ }
145
+ handleContainerAnimationStart(event) {
146
+ const toState = event.toState;
147
+ if (toState === 'enter') {
148
+ this.beforePickerOpened$.next(null);
149
+ }
150
+ }
151
+ handleContainerAnimationDone(event) {
152
+ const toState = event.toState;
153
+ if (toState === 'enter') {
154
+ this.pickerOpened$.next(null);
155
+ }
156
+ }
157
+ dateSelected(date) {
158
+ let result;
159
+ if (this.picker.isInSingleMode) {
160
+ result = this.dateSelectedInSingleMode(date);
161
+ if (result) {
162
+ this.pickerMoment = result;
163
+ this.picker.select(result);
164
+ }
165
+ else {
166
+ // we close the picker when result is null and pickerType is calendar.
167
+ if (this.pickerType === 'calendar') {
168
+ this.hidePicker$.next(null);
169
+ }
170
+ }
171
+ return;
172
+ }
173
+ if (this.picker.isInRangeMode) {
174
+ result = this.dateSelectedInRangeMode(date);
175
+ if (result) {
176
+ this.pickerMoment = result[this.activeSelectedIndex];
177
+ this.picker.select(result);
178
+ }
179
+ }
180
+ }
181
+ timeSelected(time) {
182
+ this.pickerMoment = this.dateTimeAdapter.clone(time);
183
+ if (!this.picker.dateTimeChecker(this.pickerMoment)) {
184
+ return;
185
+ }
186
+ if (this.picker.isInSingleMode) {
187
+ this.picker.select(this.pickerMoment);
188
+ return;
189
+ }
190
+ if (this.picker.isInRangeMode) {
191
+ const selecteds = [...this.picker.selecteds];
192
+ // check if the 'from' is after 'to' or 'to'is before 'from'
193
+ // In this case, we set both the 'from' and 'to' the same value
194
+ if ((this.activeSelectedIndex === 0 &&
195
+ selecteds[1] &&
196
+ this.dateTimeAdapter.compare(this.pickerMoment, selecteds[1]) === 1) ||
197
+ (this.activeSelectedIndex === 1 &&
198
+ selecteds[0] &&
199
+ this.dateTimeAdapter.compare(this.pickerMoment, selecteds[0]) === -1)) {
200
+ selecteds[0] = this.pickerMoment;
201
+ selecteds[1] = this.pickerMoment;
202
+ }
203
+ else {
204
+ selecteds[this.activeSelectedIndex] = this.pickerMoment;
205
+ }
206
+ if (selecteds[0]) {
207
+ this.retainStartTime = this.dateTimeAdapter.clone(selecteds[0]);
208
+ }
209
+ if (selecteds[1]) {
210
+ this.retainEndTime = this.dateTimeAdapter.clone(selecteds[1]);
211
+ }
212
+ this.picker.select(selecteds);
213
+ }
214
+ }
215
+ /**
216
+ * Handle click on cancel button
217
+ */
218
+ onCancelClicked(event) {
219
+ this.hidePicker$.next(null);
220
+ event.preventDefault();
221
+ return;
222
+ }
223
+ /**
224
+ * Handle click on set button
225
+ */
226
+ onSetClicked(event) {
227
+ if (!this.picker.dateTimeChecker(this.pickerMoment)) {
228
+ this.hidePicker$.next(null);
229
+ event.preventDefault();
230
+ return;
231
+ }
232
+ this.confirmSelected$.next(event);
233
+ event.preventDefault();
234
+ return;
235
+ }
236
+ /**
237
+ * Handle click on inform radio group
238
+ */
239
+ handleClickOnInfoGroup(event, index) {
240
+ this.setActiveSelectedIndex(index);
241
+ event.preventDefault();
242
+ event.stopPropagation();
243
+ }
244
+ /**
245
+ * Handle click on inform radio group
246
+ */
247
+ handleKeydownOnInfoGroup(event, next, index) {
248
+ switch (event.keyCode) {
249
+ case DOWN_ARROW:
250
+ case RIGHT_ARROW:
251
+ case UP_ARROW:
252
+ case LEFT_ARROW:
253
+ next.focus();
254
+ this.setActiveSelectedIndex(index === 0 ? 1 : 0);
255
+ event.preventDefault();
256
+ event.stopPropagation();
257
+ break;
258
+ case SPACE:
259
+ this.setActiveSelectedIndex(index);
260
+ event.preventDefault();
261
+ event.stopPropagation();
262
+ break;
263
+ default:
264
+ return;
265
+ }
266
+ }
267
+ /**
268
+ * Set the value of activeSelectedIndex
269
+ */
270
+ setActiveSelectedIndex(index) {
271
+ if (this.picker.selectMode === 'range' &&
272
+ this.activeSelectedIndex !== index) {
273
+ this.activeSelectedIndex = index;
274
+ const selected = this.picker.selecteds[this.activeSelectedIndex];
275
+ if (this.picker.selecteds && selected) {
276
+ this.pickerMoment = this.dateTimeAdapter.clone(selected);
277
+ }
278
+ }
279
+ return;
280
+ }
281
+ initPicker() {
282
+ this.pickerMoment = this.picker.startAt || this.dateTimeAdapter.now();
283
+ this.activeSelectedIndex = this.picker.selectMode === 'rangeTo' ? 1 : 0;
284
+ }
285
+ /**
286
+ * Select calendar date in single mode,
287
+ * it returns null when date is not selected.
288
+ */
289
+ dateSelectedInSingleMode(date) {
290
+ if (this.dateTimeAdapter.isSameDay(date, this.picker.selected)) {
291
+ return null;
292
+ }
293
+ return this.updateAndCheckCalendarDate(date);
294
+ }
295
+ /**
296
+ * Select dates in range Mode
297
+ */
298
+ dateSelectedInRangeMode(date) {
299
+ let from = this.picker.selecteds[0];
300
+ let to = this.picker.selecteds[1];
301
+ const result = this.updateAndCheckCalendarDate(date);
302
+ if (!result) {
303
+ return null;
304
+ }
305
+ // if the given calendar day is after or equal to 'from',
306
+ // set ths given date as 'to'
307
+ // otherwise, set it as 'from' and set 'to' to null
308
+ if (this.picker.selectMode === 'range') {
309
+ if (this.picker.selecteds &&
310
+ this.picker.selecteds.length &&
311
+ !to &&
312
+ from &&
313
+ this.dateTimeAdapter.differenceInCalendarDays(result, from) >= 0) {
314
+ if (this.picker.endAt && !this.retainEndTime) {
315
+ to = this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(result), this.dateTimeAdapter.getMonth(result), this.dateTimeAdapter.getDate(result), this.dateTimeAdapter.getHours(this.picker.endAt), this.dateTimeAdapter.getMinutes(this.picker.endAt), this.dateTimeAdapter.getSeconds(this.picker.endAt));
316
+ }
317
+ else if (this.retainEndTime) {
318
+ to = this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(result), this.dateTimeAdapter.getMonth(result), this.dateTimeAdapter.getDate(result), this.dateTimeAdapter.getHours(this.retainEndTime), this.dateTimeAdapter.getMinutes(this.retainEndTime), this.dateTimeAdapter.getSeconds(this.retainEndTime));
319
+ }
320
+ else {
321
+ to = result;
322
+ }
323
+ this.activeSelectedIndex = 1;
324
+ }
325
+ else {
326
+ if (this.picker.startAt && !this.retainStartTime) {
327
+ from = this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(result), this.dateTimeAdapter.getMonth(result), this.dateTimeAdapter.getDate(result), this.dateTimeAdapter.getHours(this.picker.startAt), this.dateTimeAdapter.getMinutes(this.picker.startAt), this.dateTimeAdapter.getSeconds(this.picker.startAt));
328
+ }
329
+ else if (this.retainStartTime) {
330
+ from = this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(result), this.dateTimeAdapter.getMonth(result), this.dateTimeAdapter.getDate(result), this.dateTimeAdapter.getHours(this.retainStartTime), this.dateTimeAdapter.getMinutes(this.retainStartTime), this.dateTimeAdapter.getSeconds(this.retainStartTime));
331
+ }
332
+ else {
333
+ from = result;
334
+ }
335
+ to = null;
336
+ this.activeSelectedIndex = 0;
337
+ }
338
+ }
339
+ else if (this.picker.selectMode === 'rangeFrom') {
340
+ from = result;
341
+ // if the from value is after the to value, set the to value as null
342
+ if (to && this.dateTimeAdapter.compare(from, to) > 0) {
343
+ to = null;
344
+ }
345
+ }
346
+ else if (this.picker.selectMode === 'rangeTo') {
347
+ to = result;
348
+ // if the from value is after the to value, set the from value as null
349
+ if (from && this.dateTimeAdapter.compare(from, to) > 0) {
350
+ from = null;
351
+ }
352
+ }
353
+ return [from, to];
354
+ }
355
+ /**
356
+ * Update the given calendar date's time and check if it is valid
357
+ * Because the calendar date has 00:00:00 as default time, if the picker type is 'both',
358
+ * we need to update the given calendar date's time before selecting it.
359
+ * if it is valid, return the updated dateTime
360
+ * if it is not valid, return null
361
+ */
362
+ updateAndCheckCalendarDate(date) {
363
+ let result;
364
+ // if the picker is 'both', update the calendar date's time value
365
+ if (this.picker.pickerType === 'both') {
366
+ result = this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(date), this.dateTimeAdapter.getMonth(date), this.dateTimeAdapter.getDate(date), this.dateTimeAdapter.getHours(this.pickerMoment), this.dateTimeAdapter.getMinutes(this.pickerMoment), this.dateTimeAdapter.getSeconds(this.pickerMoment));
367
+ result = this.dateTimeAdapter.clampDate(result, this.picker.minDateTime, this.picker.maxDateTime);
368
+ }
369
+ else {
370
+ result = this.dateTimeAdapter.clone(date);
371
+ }
372
+ // check the updated dateTime
373
+ return this.picker.dateTimeChecker(result) ? result : null;
374
+ }
375
+ /**
376
+ * Focus to the picker
377
+ * */
378
+ focusPicker() {
379
+ if (this.picker.pickerMode === 'inline') {
380
+ return;
381
+ }
382
+ if (this.calendar) {
383
+ this.calendar.focusActiveCell();
384
+ }
385
+ else if (this.timer) {
386
+ this.timer.focus();
387
+ }
388
+ }
389
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDateTimeContainerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.OwlDateTimeIntl }, { token: i2.DateTimeAdapter, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
390
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: OwlDateTimeContainerComponent, selector: "owl-date-time-container", host: { listeners: { "@transformPicker.start": "handleContainerAnimationStart($event)", "@transformPicker.done": "handleContainerAnimationDone($event)" }, properties: { "class.owl-dt-container": "owlDTContainerClass", "class.owl-dt-popup-container": "owlDTPopupContainerClass", "class.owl-dt-dialog-container": "owlDTDialogContainerClass", "class.owl-dt-inline-container": "owlDTInlineContainerClass", "class.owl-dt-container-disabled": "owlDTContainerDisabledClass", "attr.id": "owlDTContainerId", "@transformPicker": "owlDTContainerAnimation" } }, viewQueries: [{ propertyName: "calendar", first: true, predicate: OwlCalendarComponent, descendants: true }, { propertyName: "timer", first: true, predicate: OwlTimerComponent, descendants: true }], exportAs: ["owlDateTimeContainer"], ngImport: i0, template: "<div [cdkTrapFocus]=\"picker.pickerMode !== 'inline'\"\n [@fadeInPicker]=\"picker.pickerMode === 'inline'? '' : 'enter'\"\n class=\"owl-dt-container-inner\">\n\n <owl-date-time-calendar\n *ngIf=\"pickerType === 'both' || pickerType === 'calendar'\"\n class=\"owl-dt-container-row\"\n [firstDayOfWeek]=\"picker.firstDayOfWeek\"\n [(pickerMoment)]=\"pickerMoment\"\n [selected]=\"picker.selected\"\n [selecteds]=\"picker.selecteds\"\n [selectMode]=\"picker.selectMode\"\n [minDate]=\"picker.minDateTime\"\n [maxDate]=\"picker.maxDateTime\"\n [dateFilter]=\"picker.dateTimeFilter\"\n [startView]=\"picker.startView\"\n [yearOnly]=\"picker.yearOnly\"\n [multiyearOnly]=\"picker.multiyearOnly\"\n [hideOtherMonths]=\"picker.hideOtherMonths\"\n (yearSelected)=\"picker.selectYear($event)\"\n (monthSelected)=\"picker.selectMonth($event)\"\n (dateClicked)=\"picker.selectDate($event)\"\n (selectedChange)=\"dateSelected($event)\"></owl-date-time-calendar>\n\n <owl-date-time-timer\n *ngIf=\"pickerType === 'both' || pickerType === 'timer'\"\n class=\"owl-dt-container-row\"\n [pickerMoment]=\"pickerMoment\"\n [minDateTime]=\"picker.minDateTime\"\n [maxDateTime]=\"picker.maxDateTime\"\n [showSecondsTimer]=\"picker.showSecondsTimer\"\n [hour12Timer]=\"picker.hour12Timer\"\n [stepHour]=\"picker.stepHour\"\n [stepMinute]=\"picker.stepMinute\"\n [stepSecond]=\"picker.stepSecond\"\n (selectedChange)=\"timeSelected($event)\"></owl-date-time-timer>\n\n <div *ngIf=\"picker.isInRangeMode\"\n role=\"radiogroup\"\n class=\"owl-dt-container-info owl-dt-container-row\">\n <div role=\"radio\" [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 0}\"\n (click)=\"handleClickOnInfoGroup($event, 0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\" #from>\n <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 role=\"radio\" [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 1}\"\n (click)=\"handleClickOnInfoGroup($event, 1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\" #to>\n <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 *ngIf=\"showControlButtons\" class=\"owl-dt-container-buttons owl-dt-container-row\">\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n type=\"button\" tabindex=\"0\"\n (click)=\"onCancelClicked($event)\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n {{cancelLabel}}\n </span>\n </button>\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n type=\"button\" tabindex=\"0\"\n (click)=\"onSetClicked($event)\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n {{setLabel}}\n </span>\n </button>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i5.OwlTimerComponent, selector: "owl-date-time-timer", inputs: ["pickerMoment", "minDateTime", "maxDateTime", "showSecondsTimer", "hour12Timer", "stepHour", "stepMinute", "stepSecond"], outputs: ["selectedChange"], exportAs: ["owlDateTimeTimer"] }, { kind: "component", type: i6.OwlCalendarComponent, selector: "owl-date-time-calendar", inputs: ["minDate", "maxDate", "pickerMoment", "selected", "selecteds", "dateFilter", "firstDayOfWeek", "selectMode", "startView", "yearOnly", "multiyearOnly", "hideOtherMonths"], outputs: ["pickerMomentChange", "dateClicked", "selectedChange", "userSelection", "yearSelected", "monthSelected"], exportAs: ["owlDateTimeCalendar"] }], animations: [
391
+ owlDateTimePickerAnimations.transformPicker,
392
+ owlDateTimePickerAnimations.fadeInPicker
393
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
394
+ }
395
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlDateTimeContainerComponent, decorators: [{
396
+ type: Component,
397
+ args: [{ exportAs: 'owlDateTimeContainer', selector: 'owl-date-time-container', changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, animations: [
398
+ owlDateTimePickerAnimations.transformPicker,
399
+ owlDateTimePickerAnimations.fadeInPicker
400
+ ], host: {
401
+ '(@transformPicker.start)': 'handleContainerAnimationStart($event)',
402
+ '(@transformPicker.done)': 'handleContainerAnimationDone($event)',
403
+ '[class.owl-dt-container]': 'owlDTContainerClass',
404
+ '[class.owl-dt-popup-container]': 'owlDTPopupContainerClass',
405
+ '[class.owl-dt-dialog-container]': 'owlDTDialogContainerClass',
406
+ '[class.owl-dt-inline-container]': 'owlDTInlineContainerClass',
407
+ '[class.owl-dt-container-disabled]': 'owlDTContainerDisabledClass',
408
+ '[attr.id]': 'owlDTContainerId',
409
+ '[@transformPicker]': 'owlDTContainerAnimation',
410
+ }, template: "<div [cdkTrapFocus]=\"picker.pickerMode !== 'inline'\"\n [@fadeInPicker]=\"picker.pickerMode === 'inline'? '' : 'enter'\"\n class=\"owl-dt-container-inner\">\n\n <owl-date-time-calendar\n *ngIf=\"pickerType === 'both' || pickerType === 'calendar'\"\n class=\"owl-dt-container-row\"\n [firstDayOfWeek]=\"picker.firstDayOfWeek\"\n [(pickerMoment)]=\"pickerMoment\"\n [selected]=\"picker.selected\"\n [selecteds]=\"picker.selecteds\"\n [selectMode]=\"picker.selectMode\"\n [minDate]=\"picker.minDateTime\"\n [maxDate]=\"picker.maxDateTime\"\n [dateFilter]=\"picker.dateTimeFilter\"\n [startView]=\"picker.startView\"\n [yearOnly]=\"picker.yearOnly\"\n [multiyearOnly]=\"picker.multiyearOnly\"\n [hideOtherMonths]=\"picker.hideOtherMonths\"\n (yearSelected)=\"picker.selectYear($event)\"\n (monthSelected)=\"picker.selectMonth($event)\"\n (dateClicked)=\"picker.selectDate($event)\"\n (selectedChange)=\"dateSelected($event)\"></owl-date-time-calendar>\n\n <owl-date-time-timer\n *ngIf=\"pickerType === 'both' || pickerType === 'timer'\"\n class=\"owl-dt-container-row\"\n [pickerMoment]=\"pickerMoment\"\n [minDateTime]=\"picker.minDateTime\"\n [maxDateTime]=\"picker.maxDateTime\"\n [showSecondsTimer]=\"picker.showSecondsTimer\"\n [hour12Timer]=\"picker.hour12Timer\"\n [stepHour]=\"picker.stepHour\"\n [stepMinute]=\"picker.stepMinute\"\n [stepSecond]=\"picker.stepSecond\"\n (selectedChange)=\"timeSelected($event)\"></owl-date-time-timer>\n\n <div *ngIf=\"picker.isInRangeMode\"\n role=\"radiogroup\"\n class=\"owl-dt-container-info owl-dt-container-row\">\n <div role=\"radio\" [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 0}\"\n (click)=\"handleClickOnInfoGroup($event, 0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\" #from>\n <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 role=\"radio\" [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 1}\"\n (click)=\"handleClickOnInfoGroup($event, 1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\" #to>\n <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 *ngIf=\"showControlButtons\" class=\"owl-dt-container-buttons owl-dt-container-row\">\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n type=\"button\" tabindex=\"0\"\n (click)=\"onCancelClicked($event)\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n {{cancelLabel}}\n </span>\n </button>\n <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n type=\"button\" tabindex=\"0\"\n (click)=\"onSetClicked($event)\">\n <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n {{setLabel}}\n </span>\n </button>\n </div>\n</div>\n" }]
411
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.OwlDateTimeIntl }, { type: i2.DateTimeAdapter, decorators: [{
412
+ type: Optional
413
+ }] }], propDecorators: { calendar: [{
414
+ type: ViewChild,
415
+ args: [OwlCalendarComponent]
416
+ }], timer: [{
417
+ type: ViewChild,
418
+ args: [OwlTimerComponent]
419
+ }] } });
420
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker-container.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/date-time-picker-container.component.ts","../../../../../projects/picker/src/lib/date-time/date-time-picker-container.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * date-time-picker-container.component\n */\n\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    OnInit,\n    Optional,\n    ViewChild\n} from '@angular/core';\nimport { AnimationEvent } from '@angular/animations';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { OwlCalendarComponent } from './calendar.component';\nimport { OwlTimerComponent } from './timer.component';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OwlDateTime, PickerType } from './date-time.class';\nimport { Observable, Subject } from 'rxjs';\nimport { owlDateTimePickerAnimations } from './date-time-picker.animations';\nimport {\n    DOWN_ARROW,\n    LEFT_ARROW,\n    RIGHT_ARROW,\n    SPACE,\n    UP_ARROW\n} from '@angular/cdk/keycodes';\n\n@Component({\n    exportAs: 'owlDateTimeContainer',\n    selector: 'owl-date-time-container',\n    templateUrl: './date-time-picker-container.component.html',\n    styleUrls: ['./date-time-picker-container.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    animations: [\n        owlDateTimePickerAnimations.transformPicker,\n        owlDateTimePickerAnimations.fadeInPicker\n    ],\n    host: {\n        '(@transformPicker.start)': 'handleContainerAnimationStart($event)',\n        '(@transformPicker.done)': 'handleContainerAnimationDone($event)',\n        '[class.owl-dt-container]': 'owlDTContainerClass',\n        '[class.owl-dt-popup-container]': 'owlDTPopupContainerClass',\n        '[class.owl-dt-dialog-container]': 'owlDTDialogContainerClass',\n        '[class.owl-dt-inline-container]': 'owlDTInlineContainerClass',\n        '[class.owl-dt-container-disabled]': 'owlDTContainerDisabledClass',\n        '[attr.id]': 'owlDTContainerId',\n        '[@transformPicker]': 'owlDTContainerAnimation',\n    }\n})\nexport class OwlDateTimeContainerComponent<T>\n    implements OnInit, AfterContentInit, AfterViewInit {\n    @ViewChild(OwlCalendarComponent)\n    calendar: OwlCalendarComponent<T>;\n    @ViewChild(OwlTimerComponent)\n    timer: OwlTimerComponent<T>;\n\n    public picker: OwlDateTime<T>;\n    public activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')\n\n    // retain start and end time\n    private retainStartTime: T;\n    private retainEndTime: T;\n\n    /**\n     * Stream emits when try to hide picker\n     * */\n    private hidePicker$ = new Subject<any>();\n\n    get hidePickerStream(): Observable<any> {\n        return this.hidePicker$.asObservable();\n    }\n\n    /**\n     * Stream emits when try to confirm the selected value\n     * */\n    private confirmSelected$ = new Subject<any>();\n\n    get confirmSelectedStream(): Observable<any> {\n        return this.confirmSelected$.asObservable();\n    }\n\n    private beforePickerOpened$ = new Subject<any>();\n\n    get beforePickerOpenedStream(): Observable<any> {\n        return this.beforePickerOpened$.asObservable();\n    }\n\n    private pickerOpened$ = new Subject<any>();\n\n    get pickerOpenedStream(): Observable<any> {\n        return this.pickerOpened$.asObservable();\n    }\n\n    /**\n     * The current picker moment. This determines which time period is shown and which date is\n     * highlighted when using keyboard navigation.\n     */\n    private _clamPickerMoment: T;\n\n    get pickerMoment() {\n        return this._clamPickerMoment;\n    }\n\n    set pickerMoment(value: T) {\n        if (value) {\n            this._clamPickerMoment = this.dateTimeAdapter.clampDate(\n                value,\n                this.picker.minDateTime,\n                this.picker.maxDateTime\n            );\n        }\n        this.cdRef.markForCheck();\n    }\n\n    get pickerType(): PickerType {\n        return this.picker.pickerType;\n    }\n\n    get cancelLabel(): string {\n        return this.pickerIntl.cancelBtnLabel;\n    }\n\n    get setLabel(): string {\n        return this.pickerIntl.setBtnLabel;\n    }\n\n    /**\n     * The range 'from' label\n     * */\n    get fromLabel(): string {\n        return this.pickerIntl.rangeFromLabel;\n    }\n\n    /**\n     * The range 'to' label\n     * */\n    get toLabel(): string {\n        return this.pickerIntl.rangeToLabel;\n    }\n\n    /**\n     * The range 'from' formatted value\n     * */\n    get fromFormattedValue(): string {\n        const value = this.picker.selecteds[0];\n        return value\n            ? this.dateTimeAdapter.format(value, this.picker.formatString)\n            : '';\n    }\n\n    /**\n     * The range 'to' formatted value\n     * */\n    get toFormattedValue(): string {\n        const value = this.picker.selecteds[1];\n        return value\n            ? this.dateTimeAdapter.format(value, this.picker.formatString)\n            : '';\n    }\n\n    /**\n     * Cases in which the control buttons show in the picker\n     * 1) picker mode is 'dialog'\n     * 2) picker type is NOT 'calendar' and the picker mode is NOT 'inline'\n     * */\n    get showControlButtons(): boolean {\n        return (\n            this.picker.pickerMode === 'dialog' ||\n            (this.picker.pickerType !== 'calendar' &&\n                this.picker.pickerMode !== 'inline')\n        );\n    }\n\n    get containerElm(): HTMLElement {\n        return this.elmRef.nativeElement;\n    }\n\n    get owlDTContainerClass(): boolean {\n        return true;\n    }\n\n    get owlDTPopupContainerClass(): boolean {\n        return this.picker.pickerMode === 'popup';\n    }\n\n    get owlDTDialogContainerClass(): boolean {\n        return this.picker.pickerMode === 'dialog';\n    }\n\n    get owlDTInlineContainerClass(): boolean {\n        return this.picker.pickerMode === 'inline';\n    }\n\n    get owlDTContainerDisabledClass(): boolean {\n        return this.picker.disabled;\n    }\n\n    get owlDTContainerId(): string {\n        return this.picker.id;\n    }\n\n    get owlDTContainerAnimation(): any {\n        return this.picker.pickerMode === 'inline' ? '' : 'enter';\n    }\n\n    constructor( private cdRef: ChangeDetectorRef,\n                  private elmRef: ElementRef,\n                  private pickerIntl: OwlDateTimeIntl,\n                 @Optional() private dateTimeAdapter: DateTimeAdapter<T> ) {\n    }\n\n    public ngOnInit() {\n        if (this.picker.selectMode === 'range') {\n            if (this.picker.selecteds[0]) {\n                this.retainStartTime = this.dateTimeAdapter.clone(this.picker.selecteds[0]);\n            }\n            if (this.picker.selecteds[1]) {\n                this.retainEndTime = this.dateTimeAdapter.clone(this.picker.selecteds[1]);\n            }\n        }\n    }\n\n    public ngAfterContentInit(): void {\n        this.initPicker();\n    }\n\n    public ngAfterViewInit(): void {\n        this.focusPicker();\n    }\n\n    public handleContainerAnimationStart(event: AnimationEvent): void {\n        const toState = event.toState;\n        if (toState === 'enter') {\n            this.beforePickerOpened$.next(null);\n        }\n    }\n    public handleContainerAnimationDone(event: AnimationEvent): void {\n        const toState = event.toState;\n        if (toState === 'enter') {\n            this.pickerOpened$.next(null);\n        }\n    }\n\n    public dateSelected(date: T): void {\n        let result;\n\n        if (this.picker.isInSingleMode) {\n            result = this.dateSelectedInSingleMode(date);\n            if (result) {\n                this.pickerMoment = result;\n                this.picker.select(result);\n            } else {\n                // we close the picker when result is null and pickerType is calendar.\n                if (this.pickerType === 'calendar') {\n                    this.hidePicker$.next(null);\n                }\n            }\n            return;\n        }\n\n        if (this.picker.isInRangeMode) {\n            result = this.dateSelectedInRangeMode(date);\n            if (result) {\n                this.pickerMoment = result[this.activeSelectedIndex];\n                this.picker.select(result);\n            }\n        }\n    }\n\n    public timeSelected(time: T): void {\n        this.pickerMoment = this.dateTimeAdapter.clone(time);\n\n        if (!this.picker.dateTimeChecker(this.pickerMoment)) {\n            return;\n        }\n\n        if (this.picker.isInSingleMode) {\n            this.picker.select(this.pickerMoment);\n            return;\n        }\n\n        if (this.picker.isInRangeMode) {\n            const selecteds = [...this.picker.selecteds];\n\n            // check if the 'from' is after 'to' or 'to'is before 'from'\n            // In this case, we set both the 'from' and 'to' the same value\n            if (\n                (this.activeSelectedIndex === 0 &&\n                    selecteds[1] &&\n                    this.dateTimeAdapter.compare(\n                        this.pickerMoment,\n                        selecteds[1]\n                    ) === 1) ||\n                (this.activeSelectedIndex === 1 &&\n                    selecteds[0] &&\n                    this.dateTimeAdapter.compare(\n                        this.pickerMoment,\n                        selecteds[0]\n                    ) === -1)\n            ) {\n                selecteds[0] = this.pickerMoment;\n                selecteds[1] = this.pickerMoment;\n            } else {\n                selecteds[this.activeSelectedIndex] = this.pickerMoment;\n            }\n\n            if (selecteds[0]) {\n                this.retainStartTime = this.dateTimeAdapter.clone(selecteds[0]);\n            }\n            if (selecteds[1]) {\n                this.retainEndTime = this.dateTimeAdapter.clone(selecteds[1]);\n            }\n            this.picker.select(selecteds);\n        }\n    }\n\n    /**\n     * Handle click on cancel button\n     */\n    public onCancelClicked(event: any): void {\n        this.hidePicker$.next(null);\n        event.preventDefault();\n        return;\n    }\n\n    /**\n     * Handle click on set button\n     */\n    public onSetClicked(event: any): void {\n        if (!this.picker.dateTimeChecker(this.pickerMoment)) {\n            this.hidePicker$.next(null);\n            event.preventDefault();\n            return;\n        }\n\n        this.confirmSelected$.next(event);\n        event.preventDefault();\n        return;\n    }\n\n    /**\n     * Handle click on inform radio group\n     */\n    public handleClickOnInfoGroup(event: any, index: number): void {\n        this.setActiveSelectedIndex(index);\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    /**\n     * Handle click on inform radio group\n     */\n    public handleKeydownOnInfoGroup(\n        event: any,\n        next: any,\n        index: number\n    ): void {\n        switch (event.keyCode) {\n            case DOWN_ARROW:\n            case RIGHT_ARROW:\n            case UP_ARROW:\n            case LEFT_ARROW:\n                next.focus();\n                this.setActiveSelectedIndex(index === 0 ? 1 : 0);\n                event.preventDefault();\n                event.stopPropagation();\n                break;\n\n            case SPACE:\n                this.setActiveSelectedIndex(index);\n                event.preventDefault();\n                event.stopPropagation();\n                break;\n\n            default:\n                return;\n        }\n    }\n\n    /**\n     * Set the value of activeSelectedIndex\n     */\n    private setActiveSelectedIndex(index: number): void {\n        if (\n            this.picker.selectMode === 'range' &&\n            this.activeSelectedIndex !== index\n        ) {\n            this.activeSelectedIndex = index;\n\n            const selected = this.picker.selecteds[this.activeSelectedIndex];\n            if (this.picker.selecteds && selected) {\n                this.pickerMoment = this.dateTimeAdapter.clone(selected);\n            }\n        }\n        return;\n    }\n\n    private initPicker(): void {\n        this.pickerMoment = this.picker.startAt || this.dateTimeAdapter.now();\n        this.activeSelectedIndex = this.picker.selectMode === 'rangeTo' ? 1 : 0;\n    }\n\n    /**\n     * Select calendar date in single mode,\n     * it returns null when date is not selected.\n     */\n    private dateSelectedInSingleMode(date: T): T | null {\n        if (this.dateTimeAdapter.isSameDay(date, this.picker.selected)) {\n            return null;\n        }\n\n        return this.updateAndCheckCalendarDate(date);\n    }\n\n    /**\n     * Select dates in range Mode\n     */\n    private dateSelectedInRangeMode(date: T): T[] | null {\n        let from = this.picker.selecteds[0];\n        let to = this.picker.selecteds[1];\n\n        const result = this.updateAndCheckCalendarDate(date);\n\n        if (!result) {\n            return null;\n        }\n\n        // if the given calendar day is after or equal to 'from',\n        // set ths given date as 'to'\n        // otherwise, set it as 'from' and set 'to' to null\n        if (this.picker.selectMode === 'range') {\n            if (\n                this.picker.selecteds &&\n                this.picker.selecteds.length &&\n                !to &&\n                from &&\n                this.dateTimeAdapter.differenceInCalendarDays(result, from) >= 0\n            ) {\n                if (this.picker.endAt && !this.retainEndTime) {\n                    to = this.dateTimeAdapter.createDate(\n                        this.dateTimeAdapter.getYear(result),\n                        this.dateTimeAdapter.getMonth(result),\n                        this.dateTimeAdapter.getDate(result),\n                        this.dateTimeAdapter.getHours(this.picker.endAt),\n                        this.dateTimeAdapter.getMinutes(this.picker.endAt),\n                        this.dateTimeAdapter.getSeconds(this.picker.endAt));\n                } else if (this.retainEndTime) {\n                    to = this.dateTimeAdapter.createDate(\n                        this.dateTimeAdapter.getYear(result),\n                        this.dateTimeAdapter.getMonth(result),\n                        this.dateTimeAdapter.getDate(result),\n                        this.dateTimeAdapter.getHours(this.retainEndTime),\n                        this.dateTimeAdapter.getMinutes(this.retainEndTime),\n                        this.dateTimeAdapter.getSeconds(this.retainEndTime));\n                } else {\n                    to = result;\n                }\n                this.activeSelectedIndex = 1;\n            } else {\n                if (this.picker.startAt && !this.retainStartTime) {\n                    from = this.dateTimeAdapter.createDate(\n                        this.dateTimeAdapter.getYear(result),\n                        this.dateTimeAdapter.getMonth(result),\n                        this.dateTimeAdapter.getDate(result),\n                        this.dateTimeAdapter.getHours(this.picker.startAt),\n                        this.dateTimeAdapter.getMinutes(this.picker.startAt),\n                        this.dateTimeAdapter.getSeconds(this.picker.startAt)\n                    );\n                } else if (this.retainStartTime) {\n                    from = this.dateTimeAdapter.createDate(\n                        this.dateTimeAdapter.getYear(result),\n                        this.dateTimeAdapter.getMonth(result),\n                        this.dateTimeAdapter.getDate(result),\n                        this.dateTimeAdapter.getHours(this.retainStartTime),\n                        this.dateTimeAdapter.getMinutes(this.retainStartTime),\n                        this.dateTimeAdapter.getSeconds(this.retainStartTime));\n                } else {\n                    from = result;\n                }\n                to = null;\n                this.activeSelectedIndex = 0;\n            }\n        } else if (this.picker.selectMode === 'rangeFrom') {\n            from = result;\n\n            // if the from value is after the to value, set the to value as null\n            if (to && this.dateTimeAdapter.compare(from, to) > 0) {\n                to = null;\n            }\n        } else if (this.picker.selectMode === 'rangeTo') {\n            to = result;\n\n            // if the from value is after the to value, set the from value as null\n            if (from && this.dateTimeAdapter.compare(from, to) > 0) {\n                from = null;\n            }\n        }\n\n        return [from, to];\n    }\n\n    /**\n     * Update the given calendar date's time and check if it is valid\n     * Because the calendar date has 00:00:00 as default time, if the picker type is 'both',\n     * we need to update the given calendar date's time before selecting it.\n     * if it is valid, return the updated dateTime\n     * if it is not valid, return null\n     */\n    private updateAndCheckCalendarDate(date: T): T {\n        let result;\n\n        // if the picker is 'both', update the calendar date's time value\n        if (this.picker.pickerType === 'both') {\n            result = this.dateTimeAdapter.createDate(\n                this.dateTimeAdapter.getYear(date),\n                this.dateTimeAdapter.getMonth(date),\n                this.dateTimeAdapter.getDate(date),\n                this.dateTimeAdapter.getHours(this.pickerMoment),\n                this.dateTimeAdapter.getMinutes(this.pickerMoment),\n                this.dateTimeAdapter.getSeconds(this.pickerMoment)\n            );\n            result = this.dateTimeAdapter.clampDate(\n                result,\n                this.picker.minDateTime,\n                this.picker.maxDateTime\n            );\n        } else {\n            result = this.dateTimeAdapter.clone(date);\n        }\n\n        // check the updated dateTime\n        return this.picker.dateTimeChecker(result) ? result : null;\n    }\n\n    /**\n     * Focus to the picker\n     * */\n    private focusPicker(): void {\n        if (this.picker.pickerMode === 'inline') {\n            return;\n        }\n\n        if (this.calendar) {\n            this.calendar.focusActiveCell();\n        } else if (this.timer) {\n            this.timer.focus();\n        }\n    }\n}\n","<div [cdkTrapFocus]=\"picker.pickerMode !== 'inline'\"\n     [@fadeInPicker]=\"picker.pickerMode === 'inline'? '' : 'enter'\"\n     class=\"owl-dt-container-inner\">\n\n    <owl-date-time-calendar\n            *ngIf=\"pickerType === 'both' || pickerType === 'calendar'\"\n            class=\"owl-dt-container-row\"\n            [firstDayOfWeek]=\"picker.firstDayOfWeek\"\n            [(pickerMoment)]=\"pickerMoment\"\n            [selected]=\"picker.selected\"\n            [selecteds]=\"picker.selecteds\"\n            [selectMode]=\"picker.selectMode\"\n            [minDate]=\"picker.minDateTime\"\n            [maxDate]=\"picker.maxDateTime\"\n            [dateFilter]=\"picker.dateTimeFilter\"\n            [startView]=\"picker.startView\"\n            [yearOnly]=\"picker.yearOnly\"\n            [multiyearOnly]=\"picker.multiyearOnly\"\n            [hideOtherMonths]=\"picker.hideOtherMonths\"\n            (yearSelected)=\"picker.selectYear($event)\"\n            (monthSelected)=\"picker.selectMonth($event)\"\n            (dateClicked)=\"picker.selectDate($event)\"\n            (selectedChange)=\"dateSelected($event)\"></owl-date-time-calendar>\n\n    <owl-date-time-timer\n            *ngIf=\"pickerType === 'both' || pickerType === 'timer'\"\n            class=\"owl-dt-container-row\"\n            [pickerMoment]=\"pickerMoment\"\n            [minDateTime]=\"picker.minDateTime\"\n            [maxDateTime]=\"picker.maxDateTime\"\n            [showSecondsTimer]=\"picker.showSecondsTimer\"\n            [hour12Timer]=\"picker.hour12Timer\"\n            [stepHour]=\"picker.stepHour\"\n            [stepMinute]=\"picker.stepMinute\"\n            [stepSecond]=\"picker.stepSecond\"\n            (selectedChange)=\"timeSelected($event)\"></owl-date-time-timer>\n\n    <div *ngIf=\"picker.isInRangeMode\"\n         role=\"radiogroup\"\n         class=\"owl-dt-container-info owl-dt-container-row\">\n        <div role=\"radio\" [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n             [attr.aria-checked]=\"activeSelectedIndex === 0\"\n             class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n             [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 0}\"\n             (click)=\"handleClickOnInfoGroup($event, 0)\"\n             (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\" #from>\n            <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 role=\"radio\" [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n             [attr.aria-checked]=\"activeSelectedIndex === 1\"\n             class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n             [ngClass]=\"{'owl-dt-container-info-active': activeSelectedIndex === 1}\"\n             (click)=\"handleClickOnInfoGroup($event, 1)\"\n             (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\" #to>\n            <span class=\"owl-dt-control-content owl-dt-container-range-content\" 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 *ngIf=\"showControlButtons\" class=\"owl-dt-container-buttons owl-dt-container-row\">\n        <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n                type=\"button\" tabindex=\"0\"\n                (click)=\"onCancelClicked($event)\">\n            <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n                {{cancelLabel}}\n            </span>\n        </button>\n        <button class=\"owl-dt-control owl-dt-control-button owl-dt-container-control-button\"\n                type=\"button\" tabindex=\"0\"\n                (click)=\"onSetClicked($event)\">\n            <span class=\"owl-dt-control-content owl-dt-control-button-content\" tabindex=\"-1\">\n                {{setLabel}}\n            </span>\n        </button>\n    </div>\n</div>\n"]}