@skyux/datetime 7.0.0-beta.9 → 7.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 (64) hide show
  1. package/documentation.json +1630 -985
  2. package/esm2020/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
  3. package/esm2020/lib/modules/date-pipe/date.pipe.mjs +4 -5
  4. package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +4 -5
  5. package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
  6. package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
  7. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +267 -212
  8. package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +14 -6
  9. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +45 -42
  10. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
  11. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
  12. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
  13. package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
  14. package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
  15. package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
  16. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +11 -18
  17. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +46 -23
  18. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +29 -37
  19. package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
  20. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +227 -217
  21. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +216 -227
  22. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +122 -145
  23. package/esm2020/lib/modules/datepicker/datepicker.module.mjs +5 -5
  24. package/esm2020/lib/modules/datepicker/datepicker.service.mjs +4 -4
  25. package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +5 -6
  26. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +63 -63
  27. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +146 -141
  28. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +126 -136
  29. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +53 -52
  30. package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +55 -54
  31. package/esm2020/lib/modules/shared/sky-datetime-resources.module.mjs +5 -5
  32. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +109 -95
  33. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +109 -103
  34. package/esm2020/lib/modules/timepicker/timepicker.module.mjs +5 -5
  35. package/fesm2015/skyux-datetime.mjs +1716 -1590
  36. package/fesm2015/skyux-datetime.mjs.map +1 -1
  37. package/fesm2020/skyux-datetime.mjs +1694 -1586
  38. package/fesm2020/skyux-datetime.mjs.map +1 -1
  39. package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
  40. package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
  41. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
  42. package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
  43. package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
  44. package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
  45. package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
  46. package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
  47. package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
  48. package/lib/modules/datepicker/date-formatter.d.ts +3 -3
  49. package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
  50. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
  51. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
  52. package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
  53. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
  54. package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
  55. package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
  56. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  57. package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
  58. package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
  59. package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
  60. package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
  61. package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
  62. package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
  63. package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
  64. package/package.json +12 -12
@@ -1,7 +1,7 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
2
- import { SkyAffixAutoFitContext, SkyAffixService, SkyCoreAdapterService, SkyOverlayService, } from '@skyux/core';
3
- import { SkyInputBoxHostService } from '@skyux/forms';
4
- import { SkyThemeService } from '@skyux/theme';
1
+ var _SkyTimepickerComponent_instances, _SkyTimepickerComponent_affixer, _SkyTimepickerComponent_timepickerUnsubscribe, _SkyTimepickerComponent_ngUnsubscribe, _SkyTimepickerComponent_overlay, _SkyTimepickerComponent_overlayKeydownListner, _SkyTimepickerComponent__disabled, _SkyTimepickerComponent__timepickerRef, _SkyTimepickerComponent_affixService, _SkyTimepickerComponent_changeDetector, _SkyTimepickerComponent_coreAdapter, _SkyTimepickerComponent_overlayService, _SkyTimepickerComponent_closePicker, _SkyTimepickerComponent_openPicker, _SkyTimepickerComponent_createAffixer, _SkyTimepickerComponent_destroyAffixer, _SkyTimepickerComponent_createOverlay, _SkyTimepickerComponent_destroyOverlay, _SkyTimepickerComponent_addKeydownListener, _SkyTimepickerComponent_removePickerEventListeners;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
4
+ import { SkyAffixAutoFitContext, } from '@skyux/core';
5
5
  import moment from 'moment';
6
6
  import { Subject, fromEvent } from 'rxjs';
7
7
  import { takeUntil } from 'rxjs/operators';
@@ -21,34 +21,51 @@ let nextId = 0;
21
21
  */
22
22
  export class SkyTimepickerComponent {
23
23
  constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc) {
24
- this.affixService = affixService;
25
- this.changeDetector = changeDetector;
26
- this.coreAdapter = coreAdapter;
27
- this.overlayService = overlayService;
28
24
  this.inputBoxHostService = inputBoxHostService;
25
+ _SkyTimepickerComponent_instances.add(this);
29
26
  /**
30
27
  * Fires when the value in the timepicker input changes.
31
28
  */
32
29
  this.selectedTimeChanged = new EventEmitter();
30
+ this.activeTime = new Date();
31
+ this.hours = [];
33
32
  this.is8601 = false;
33
+ this.isOpen = false;
34
+ this.isVisible = false;
35
+ this.localeFormat = 'h:mm A';
36
+ this.minutes = [];
34
37
  this.timeFormat = 'hh';
35
- this.ngUnsubscribe = new Subject();
38
+ _SkyTimepickerComponent_affixer.set(this, void 0);
39
+ _SkyTimepickerComponent_timepickerUnsubscribe.set(this, new Subject());
40
+ _SkyTimepickerComponent_ngUnsubscribe.set(this, new Subject());
41
+ _SkyTimepickerComponent_overlay.set(this, void 0);
42
+ _SkyTimepickerComponent_overlayKeydownListner.set(this, void 0);
43
+ _SkyTimepickerComponent__disabled.set(this, false);
44
+ _SkyTimepickerComponent__timepickerRef.set(this, void 0);
45
+ _SkyTimepickerComponent_affixService.set(this, void 0);
46
+ _SkyTimepickerComponent_changeDetector.set(this, void 0);
47
+ _SkyTimepickerComponent_coreAdapter.set(this, void 0);
48
+ _SkyTimepickerComponent_overlayService.set(this, void 0);
49
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_affixService, affixService, "f");
50
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_changeDetector, changeDetector, "f");
51
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_coreAdapter, coreAdapter, "f");
52
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_overlayService, overlayService, "f");
36
53
  const uniqueId = nextId++;
37
54
  this.timepickerId = `sky-timepicker-${uniqueId}`;
38
55
  this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;
39
56
  // Update icons when theme changes.
40
57
  themeSvc?.settingsChange
41
- .pipe(takeUntil(this.ngUnsubscribe))
58
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyTimepickerComponent_ngUnsubscribe, "f")))
42
59
  .subscribe(() => {
43
- this.changeDetector.markForCheck();
60
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
44
61
  });
45
62
  }
46
63
  set disabled(value) {
47
- this._disabled = value;
48
- this.changeDetector.markForCheck();
64
+ __classPrivateFieldSet(this, _SkyTimepickerComponent__disabled, value, "f");
65
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
49
66
  }
50
67
  get disabled() {
51
- return this._disabled;
68
+ return __classPrivateFieldGet(this, _SkyTimepickerComponent__disabled, "f");
52
69
  }
53
70
  set selectedHour(setHour) {
54
71
  let hourOffset = 0;
@@ -73,8 +90,7 @@ export class SkyTimepickerComponent {
73
90
  /* istanbul ignore next */
74
91
  return parseInt(moment(this.activeTime).format('h'), 0) || 1;
75
92
  }
76
- /* istanbul ignore else */
77
- if (this.is8601) {
93
+ else {
78
94
  return moment(this.activeTime).hour() + 0;
79
95
  }
80
96
  }
@@ -109,7 +125,7 @@ export class SkyTimepickerComponent {
109
125
  /* istanbul ignore else */
110
126
  if (newTime.local !== 'Invalid date') {
111
127
  this.activeTime = newTime.iso8601;
112
- this.changeDetector.markForCheck();
128
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
113
129
  }
114
130
  }
115
131
  }
@@ -129,26 +145,28 @@ export class SkyTimepickerComponent {
129
145
  }
130
146
  set timepickerRef(value) {
131
147
  if (value) {
132
- this._timepickerRef = value;
148
+ __classPrivateFieldSet(this, _SkyTimepickerComponent__timepickerRef, value, "f");
133
149
  // Wait for the timepicker component to render before guaging dimensions.
134
150
  setTimeout(() => {
135
- this.destroyAffixer();
136
- this.createAffixer();
151
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyAffixer).call(this);
152
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_createAffixer).call(this);
137
153
  setTimeout(() => {
138
- this.coreAdapter.getFocusableChildrenAndApplyFocus(this.timepickerRef, '.sky-timepicker-content', false);
154
+ if (this.timepickerRef) {
155
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_coreAdapter, "f").getFocusableChildrenAndApplyFocus(this.timepickerRef, '.sky-timepicker-content', false);
156
+ }
139
157
  this.isVisible = true;
140
- this.changeDetector.markForCheck();
158
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
141
159
  });
142
160
  });
143
161
  }
144
162
  }
145
163
  get timepickerRef() {
146
- return this._timepickerRef;
164
+ return __classPrivateFieldGet(this, _SkyTimepickerComponent__timepickerRef, "f");
147
165
  }
148
166
  ngOnInit() {
149
167
  this.setFormat(this.timeFormat);
150
- this.addKeydownListner();
151
- if (this.inputBoxHostService) {
168
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_addKeydownListener).call(this);
169
+ if (this.inputBoxHostService && this.inputTemplateRef) {
152
170
  this.inputBoxHostService.populate({
153
171
  inputTemplate: this.inputTemplateRef,
154
172
  buttonsTemplate: this.triggerButtonTemplateRef,
@@ -156,11 +174,11 @@ export class SkyTimepickerComponent {
156
174
  }
157
175
  }
158
176
  ngOnDestroy() {
159
- this.ngUnsubscribe.next();
160
- this.ngUnsubscribe.complete();
161
- this.removePickerEventListeners();
162
- this.destroyAffixer();
163
- this.destroyOverlay();
177
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_ngUnsubscribe, "f").next();
178
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_ngUnsubscribe, "f").complete();
179
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_removePickerEventListeners).call(this);
180
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyAffixer).call(this);
181
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyOverlay).call(this);
164
182
  }
165
183
  setFormat(format) {
166
184
  let h = 12;
@@ -208,7 +226,7 @@ export class SkyTimepickerComponent {
208
226
  this.minuteMultiplier = data.minuteMultiplier;
209
227
  }
210
228
  onCloseButtonCick() {
211
- this.closePicker();
229
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_closePicker).call(this);
212
230
  }
213
231
  setTime(event) {
214
232
  /* istanbul ignore else */
@@ -229,33 +247,32 @@ export class SkyTimepickerComponent {
229
247
  }
230
248
  }
231
249
  onTriggerButtonClick() {
232
- this.openPicker();
233
- }
234
- closePicker() {
235
- this.destroyAffixer();
236
- this.destroyOverlay();
237
- this.removePickerEventListeners();
238
- this.triggerButtonRef.nativeElement.focus();
239
- this.isOpen = false;
240
- }
241
- openPicker() {
242
- this.isVisible = false;
243
- this.changeDetector.markForCheck();
244
- this.removePickerEventListeners();
245
- this.timepickerUnsubscribe = new Subject();
246
- this.destroyOverlay();
247
- this.createOverlay();
248
- this.isOpen = true;
249
- this.changeDetector.markForCheck();
250
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_openPicker).call(this);
250
251
  }
251
- createAffixer() {
252
- const affixer = this.affixService.createAffixer(this.timepickerRef);
252
+ }
253
+ _SkyTimepickerComponent_affixer = new WeakMap(), _SkyTimepickerComponent_timepickerUnsubscribe = new WeakMap(), _SkyTimepickerComponent_ngUnsubscribe = new WeakMap(), _SkyTimepickerComponent_overlay = new WeakMap(), _SkyTimepickerComponent_overlayKeydownListner = new WeakMap(), _SkyTimepickerComponent__disabled = new WeakMap(), _SkyTimepickerComponent__timepickerRef = new WeakMap(), _SkyTimepickerComponent_affixService = new WeakMap(), _SkyTimepickerComponent_changeDetector = new WeakMap(), _SkyTimepickerComponent_coreAdapter = new WeakMap(), _SkyTimepickerComponent_overlayService = new WeakMap(), _SkyTimepickerComponent_instances = new WeakSet(), _SkyTimepickerComponent_closePicker = function _SkyTimepickerComponent_closePicker() {
254
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyAffixer).call(this);
255
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyOverlay).call(this);
256
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_removePickerEventListeners).call(this);
257
+ this.triggerButtonRef?.nativeElement.focus();
258
+ this.isOpen = false;
259
+ }, _SkyTimepickerComponent_openPicker = function _SkyTimepickerComponent_openPicker() {
260
+ this.isVisible = false;
261
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
262
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_removePickerEventListeners).call(this);
263
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_destroyOverlay).call(this);
264
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_createOverlay).call(this);
265
+ this.isOpen = true;
266
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
267
+ }, _SkyTimepickerComponent_createAffixer = function _SkyTimepickerComponent_createAffixer() {
268
+ if (this.timepickerRef && this.triggerButtonRef) {
269
+ const affixer = __classPrivateFieldGet(this, _SkyTimepickerComponent_affixService, "f").createAffixer(this.timepickerRef);
253
270
  // Hide timepicker when trigger button is scrolled off screen.
254
271
  affixer.placementChange
255
- .pipe(takeUntil(this.timepickerUnsubscribe))
272
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyTimepickerComponent_timepickerUnsubscribe, "f")))
256
273
  .subscribe((change) => {
257
274
  this.isVisible = change.placement !== null;
258
- this.changeDetector.markForCheck();
275
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_changeDetector, "f").markForCheck();
259
276
  });
260
277
  affixer.affixTo(this.triggerButtonRef.nativeElement, {
261
278
  autoFitContext: SkyAffixAutoFitContext.Viewport,
@@ -264,64 +281,61 @@ export class SkyTimepickerComponent {
264
281
  isSticky: true,
265
282
  placement: 'below',
266
283
  });
267
- this.affixer = affixer;
284
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_affixer, affixer, "f");
268
285
  }
269
- destroyAffixer() {
270
- /*istanbul ignore else*/
271
- if (this.affixer) {
272
- this.affixer.destroy();
273
- this.affixer = undefined;
274
- }
286
+ }, _SkyTimepickerComponent_destroyAffixer = function _SkyTimepickerComponent_destroyAffixer() {
287
+ /*istanbul ignore else*/
288
+ if (__classPrivateFieldGet(this, _SkyTimepickerComponent_affixer, "f")) {
289
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_affixer, "f").destroy();
290
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_affixer, undefined, "f");
275
291
  }
276
- createOverlay() {
277
- const overlay = this.overlayService.create({
292
+ }, _SkyTimepickerComponent_createOverlay = function _SkyTimepickerComponent_createOverlay() {
293
+ if (this.timepickerTemplateRef) {
294
+ const overlay = __classPrivateFieldGet(this, _SkyTimepickerComponent_overlayService, "f").create({
278
295
  enableClose: false,
279
296
  enablePointerEvents: false,
280
297
  });
281
298
  overlay.backdropClick
282
- .pipe(takeUntil(this.timepickerUnsubscribe))
299
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyTimepickerComponent_timepickerUnsubscribe, "f")))
283
300
  .subscribe(() => {
284
301
  /* istanbul ignore else */
285
302
  if (this.isOpen) {
286
- this.closePicker();
303
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_closePicker).call(this);
287
304
  }
288
305
  });
289
- this.addKeydownListner();
306
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_addKeydownListener).call(this);
290
307
  overlay.attachTemplate(this.timepickerTemplateRef);
291
- this.overlay = overlay;
292
- }
293
- destroyOverlay() {
294
- /*istanbul ignore else*/
295
- if (this.overlay) {
296
- this.overlayService.close(this.overlay);
297
- this.overlay = undefined;
298
- }
308
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_overlay, overlay, "f");
299
309
  }
300
- addKeydownListner() {
301
- this.overlayKeydownListner = fromEvent(window.document, 'keydown')
302
- .pipe(takeUntil(this.ngUnsubscribe))
303
- .subscribe((event) => {
304
- const key = event.key?.toLowerCase();
305
- /* istanbul ignore else */
306
- if (key === 'escape' && this.isOpen) {
307
- this.closePicker();
308
- }
309
- });
310
+ }, _SkyTimepickerComponent_destroyOverlay = function _SkyTimepickerComponent_destroyOverlay() {
311
+ /*istanbul ignore else*/
312
+ if (__classPrivateFieldGet(this, _SkyTimepickerComponent_overlay, "f")) {
313
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_overlayService, "f").close(__classPrivateFieldGet(this, _SkyTimepickerComponent_overlay, "f"));
314
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_overlay, undefined, "f");
310
315
  }
311
- removePickerEventListeners() {
316
+ }, _SkyTimepickerComponent_addKeydownListener = function _SkyTimepickerComponent_addKeydownListener() {
317
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_overlayKeydownListner, fromEvent(window.document, 'keydown')
318
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyTimepickerComponent_ngUnsubscribe, "f")))
319
+ .subscribe((event) => {
320
+ const key = event.key?.toLowerCase();
312
321
  /* istanbul ignore else */
313
- if (this.timepickerUnsubscribe) {
314
- this.timepickerUnsubscribe.next();
315
- this.timepickerUnsubscribe.complete();
316
- this.timepickerUnsubscribe = undefined;
322
+ if (key === 'escape' && this.isOpen) {
323
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_instances, "m", _SkyTimepickerComponent_closePicker).call(this);
317
324
  }
318
- /* istanbul ignore next */
319
- this.overlayKeydownListner?.unsubscribe();
325
+ }), "f");
326
+ }, _SkyTimepickerComponent_removePickerEventListeners = function _SkyTimepickerComponent_removePickerEventListeners() {
327
+ /* istanbul ignore else */
328
+ if (__classPrivateFieldGet(this, _SkyTimepickerComponent_timepickerUnsubscribe, "f")) {
329
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_timepickerUnsubscribe, "f").next();
330
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_timepickerUnsubscribe, "f").complete();
331
+ __classPrivateFieldSet(this, _SkyTimepickerComponent_timepickerUnsubscribe, new Subject(), "f");
320
332
  }
321
- }
322
- SkyTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTimepickerComponent, deps: [{ token: i1.SkyAffixService }, { token: i0.ChangeDetectorRef }, { token: i1.SkyCoreAdapterService }, { token: i1.SkyOverlayService }, { token: i2.SkyInputBoxHostService, optional: true }, { token: i3.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
323
- SkyTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyTimepickerComponent, selector: "sky-timepicker", outputs: { selectedTimeChanged: "selectedTimeChanged" }, viewQueries: [{ propertyName: "timepickerRef", first: true, predicate: ["timepickerRef"], descendants: true, read: ElementRef }, { propertyName: "timepickerTemplateRef", first: true, predicate: ["timepickerTemplateRef"], descendants: true, read: TemplateRef }, { propertyName: "triggerButtonRef", first: true, predicate: ["triggerButtonRef"], descendants: true, read: ElementRef }, { propertyName: "inputTemplateRef", first: true, predicate: ["inputTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButtonTemplateRef", first: true, predicate: ["triggerButtonTemplateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"sky-timepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"clock\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n <div\n class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"timepickerId\"\n [class.sky-timepicker-hidden]=\"!isVisible\"\n #timepickerRef\n >\n <div class=\"sky-timepicker-content\">\n <section\n class=\"sky-timepicker-column\"\n [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n >\n <ol>\n <li *ngFor=\"let hour of hours\">\n <button\n name=\"hour\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n (click)=\"setTime($event)\"\n >\n {{ hour }}\n </button>\n </li>\n </ol>\n </section>\n <section class=\"sky-timepicker-column\">\n <ol>\n <li *ngFor=\"let minute of minutes\">\n <button\n name=\"minute\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n (click)=\"setTime($event)\"\n >\n {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n </button>\n </li>\n </ol>\n </section>\n <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n <ol>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n (click)=\"setTime($event)\"\n >\n AM\n </button>\n </li>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n (click)=\"setTime($event)\"\n >\n PM\n </button>\n </li>\n </ol>\n </section>\n </div>\n <div class=\"sky-timepicker-footer\">\n <section class=\"sky-timepicker-column\">\n <button\n class=\"sky-btn sky-btn-primary\"\n type=\"button\"\n (click)=\"onCloseButtonCick()\"\n >\n {{ 'skyux_timepicker_close' | skyLibResources }}\n </button>\n </section>\n </div>\n </div>\n</ng-template>\n", styles: [".sky-timepicker-container{position:fixed;font-size:15px;padding:5px;background-color:#eeeeef;border-radius:5px}.sky-timepicker-container :last-child ol{display:flex;flex-direction:column;height:100%}.sky-timepicker-container :last-child ol li{border-bottom:1px solid #e2e3e4;flex:1}.sky-timepicker-column{margin:5px}.sky-timepicker-column ol{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;column-gap:1px;columns:2;list-style-type:none;margin:0;padding:0}.sky-timepicker-column ol li{text-align:center;cursor:pointer;margin:0}.sky-timepicker-column ol li button{cursor:pointer}.sky-timepicker-column ol li button:focus{outline:thin dotted;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.sky-timepicker-column ol li button:hover{background-color:#eeeeef}.sky-timepicker-column ol li button:active{background-color:#e2e3e4}.sky-timepicker-column ol li button.sky-btn-active:hover{background-color:#c1e8fb}.sky-timepicker-column ol .sky-btn-active{background-color:#c1e8fb;box-shadow:inset 0 0 0 2px #00b4f1;border-radius:3px}.sky-timepicker-column.sky-timepicker-24hour ol{columns:4}.sky-timepicker-column.sky-timepicker-24hour ol li{border-bottom-width:0}.sky-timepicker-content{display:flex}.sky-timepicker-content button{background-color:#fff;border-width:0;padding:5px 15px;width:100%;height:100%}.sky-timepicker-footer{margin:0;padding:0 5px}.sky-timepicker-footer .sky-timepicker-column{margin-left:0;margin-right:0;width:100%}.sky-timepicker-hidden{visibility:hidden}.sky-timepicker-clock-icon-modern,.sky-theme-modern .sky-timepicker-clock-icon-default{display:none}.sky-theme-modern .sky-timepicker-clock-icon-modern{display:inline}.sky-theme-modern .sky-timepicker-container{background-color:#fff;border:solid 1px #cdcfd2;border-radius:6px;font-size:16px}.sky-theme-modern .sky-timepicker-container:focus-within{border:solid 2px #1870B8;padding:4px}.sky-theme-modern .sky-timepicker-container:last-child ol li{border-bottom:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-default{border-width:1px;border-color:transparent;padding:4px 6px;outline:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover:not(.sky-btn-active){background-color:transparent}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover{box-shadow:inset 0 0 0 1px #00b4f1;border-radius:6px}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:focus{outline:none;border-radius:6px;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container:not(:focus-within){border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol{border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol button{background-color:transparent;color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol .sky-btn-active{background-color:#009cd1}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i6.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
324
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTimepickerComponent, decorators: [{
333
+ /* istanbul ignore next */
334
+ __classPrivateFieldGet(this, _SkyTimepickerComponent_overlayKeydownListner, "f")?.unsubscribe();
335
+ };
336
+ SkyTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyTimepickerComponent, deps: [{ token: i1.SkyAffixService }, { token: i0.ChangeDetectorRef }, { token: i1.SkyCoreAdapterService }, { token: i1.SkyOverlayService }, { token: i2.SkyInputBoxHostService, optional: true }, { token: i3.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
337
+ SkyTimepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyTimepickerComponent, selector: "sky-timepicker", outputs: { selectedTimeChanged: "selectedTimeChanged" }, viewQueries: [{ propertyName: "timepickerRef", first: true, predicate: ["timepickerRef"], descendants: true, read: ElementRef }, { propertyName: "timepickerTemplateRef", first: true, predicate: ["timepickerTemplateRef"], descendants: true, read: TemplateRef }, { propertyName: "triggerButtonRef", first: true, predicate: ["triggerButtonRef"], descendants: true, read: ElementRef }, { propertyName: "inputTemplateRef", first: true, predicate: ["inputTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButtonTemplateRef", first: true, predicate: ["triggerButtonTemplateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"sky-timepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"clock\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n <div\n class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"timepickerId\"\n [class.sky-timepicker-hidden]=\"!isVisible\"\n #timepickerRef\n >\n <div class=\"sky-timepicker-content\">\n <section\n class=\"sky-timepicker-column\"\n [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n >\n <ol>\n <li *ngFor=\"let hour of hours\">\n <button\n name=\"hour\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n (click)=\"setTime($event)\"\n >\n {{ hour }}\n </button>\n </li>\n </ol>\n </section>\n <section class=\"sky-timepicker-column\">\n <ol>\n <li *ngFor=\"let minute of minutes\">\n <button\n name=\"minute\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n (click)=\"setTime($event)\"\n >\n {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n </button>\n </li>\n </ol>\n </section>\n <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n <ol>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n (click)=\"setTime($event)\"\n >\n AM\n </button>\n </li>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n (click)=\"setTime($event)\"\n >\n PM\n </button>\n </li>\n </ol>\n </section>\n </div>\n <div class=\"sky-timepicker-footer\">\n <section class=\"sky-timepicker-column\">\n <button\n class=\"sky-btn sky-btn-primary\"\n type=\"button\"\n (click)=\"onCloseButtonCick()\"\n >\n {{ 'skyux_timepicker_close' | skyLibResources }}\n </button>\n </section>\n </div>\n </div>\n</ng-template>\n", styles: [".sky-timepicker-container{position:fixed;font-size:15px;padding:5px;background-color:#eeeeef;border-radius:5px}.sky-timepicker-container :last-child ol{display:flex;flex-direction:column;height:100%}.sky-timepicker-container :last-child ol li{border-bottom:1px solid #e2e3e4;flex:1}.sky-timepicker-column{margin:5px}.sky-timepicker-column ol{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;column-gap:1px;columns:2;list-style-type:none;margin:0;padding:0}.sky-timepicker-column ol li{text-align:center;cursor:pointer;margin:0}.sky-timepicker-column ol li button{cursor:pointer}.sky-timepicker-column ol li button:focus{outline:thin dotted;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.sky-timepicker-column ol li button:hover{background-color:#eeeeef}.sky-timepicker-column ol li button:active{background-color:#e2e3e4}.sky-timepicker-column ol li button.sky-btn-active:hover{background-color:#c1e8fb}.sky-timepicker-column ol .sky-btn-active{background-color:#c1e8fb;box-shadow:inset 0 0 0 2px #00b4f1;border-radius:3px}.sky-timepicker-column.sky-timepicker-24hour ol{columns:4}.sky-timepicker-column.sky-timepicker-24hour ol li{border-bottom-width:0}.sky-timepicker-content{display:flex}.sky-timepicker-content button{background-color:#fff;border-width:0;padding:5px 15px;width:100%;height:100%}.sky-timepicker-footer{margin:0;padding:0 5px}.sky-timepicker-footer .sky-timepicker-column{margin-left:0;margin-right:0;width:100%}.sky-timepicker-hidden{visibility:hidden}.sky-timepicker-clock-icon-modern,.sky-theme-modern .sky-timepicker-clock-icon-default{display:none}.sky-theme-modern .sky-timepicker-clock-icon-modern{display:inline}.sky-theme-modern .sky-timepicker-container{background-color:#fff;border:solid 1px #cdcfd2;border-radius:6px;font-size:16px}.sky-theme-modern .sky-timepicker-container:focus-within{border:solid 2px #1870B8;padding:4px}.sky-theme-modern .sky-timepicker-container:last-child ol li{border-bottom:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-default{border-width:1px;border-color:transparent;padding:4px 6px;outline:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover:not(.sky-btn-active){background-color:transparent}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover{box-shadow:inset 0 0 0 1px #00b4f1;border-radius:6px}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:focus{outline:none;border-radius:6px;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container:not(:focus-within){border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol{border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol button{background-color:transparent;color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol .sky-btn-active{background-color:#009cd1}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "pipe", type: i6.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
338
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyTimepickerComponent, decorators: [{
325
339
  type: Component,
326
340
  args: [{ selector: 'sky-timepicker', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sky-timepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"clock\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n <div\n class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"timepickerId\"\n [class.sky-timepicker-hidden]=\"!isVisible\"\n #timepickerRef\n >\n <div class=\"sky-timepicker-content\">\n <section\n class=\"sky-timepicker-column\"\n [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n >\n <ol>\n <li *ngFor=\"let hour of hours\">\n <button\n name=\"hour\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n (click)=\"setTime($event)\"\n >\n {{ hour }}\n </button>\n </li>\n </ol>\n </section>\n <section class=\"sky-timepicker-column\">\n <ol>\n <li *ngFor=\"let minute of minutes\">\n <button\n name=\"minute\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n (click)=\"setTime($event)\"\n >\n {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n </button>\n </li>\n </ol>\n </section>\n <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n <ol>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n (click)=\"setTime($event)\"\n >\n AM\n </button>\n </li>\n <li>\n <button\n name=\"meridie\"\n type=\"button\"\n [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n (click)=\"setTime($event)\"\n >\n PM\n </button>\n </li>\n </ol>\n </section>\n </div>\n <div class=\"sky-timepicker-footer\">\n <section class=\"sky-timepicker-column\">\n <button\n class=\"sky-btn sky-btn-primary\"\n type=\"button\"\n (click)=\"onCloseButtonCick()\"\n >\n {{ 'skyux_timepicker_close' | skyLibResources }}\n </button>\n </section>\n </div>\n </div>\n</ng-template>\n", styles: [".sky-timepicker-container{position:fixed;font-size:15px;padding:5px;background-color:#eeeeef;border-radius:5px}.sky-timepicker-container :last-child ol{display:flex;flex-direction:column;height:100%}.sky-timepicker-container :last-child ol li{border-bottom:1px solid #e2e3e4;flex:1}.sky-timepicker-column{margin:5px}.sky-timepicker-column ol{border-top:1px solid #e2e3e4;border-right:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;column-gap:1px;columns:2;list-style-type:none;margin:0;padding:0}.sky-timepicker-column ol li{text-align:center;cursor:pointer;margin:0}.sky-timepicker-column ol li button{cursor:pointer}.sky-timepicker-column ol li button:focus{outline:thin dotted;outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.sky-timepicker-column ol li button:hover{background-color:#eeeeef}.sky-timepicker-column ol li button:active{background-color:#e2e3e4}.sky-timepicker-column ol li button.sky-btn-active:hover{background-color:#c1e8fb}.sky-timepicker-column ol .sky-btn-active{background-color:#c1e8fb;box-shadow:inset 0 0 0 2px #00b4f1;border-radius:3px}.sky-timepicker-column.sky-timepicker-24hour ol{columns:4}.sky-timepicker-column.sky-timepicker-24hour ol li{border-bottom-width:0}.sky-timepicker-content{display:flex}.sky-timepicker-content button{background-color:#fff;border-width:0;padding:5px 15px;width:100%;height:100%}.sky-timepicker-footer{margin:0;padding:0 5px}.sky-timepicker-footer .sky-timepicker-column{margin-left:0;margin-right:0;width:100%}.sky-timepicker-hidden{visibility:hidden}.sky-timepicker-clock-icon-modern,.sky-theme-modern .sky-timepicker-clock-icon-default{display:none}.sky-theme-modern .sky-timepicker-clock-icon-modern{display:inline}.sky-theme-modern .sky-timepicker-container{background-color:#fff;border:solid 1px #cdcfd2;border-radius:6px;font-size:16px}.sky-theme-modern .sky-timepicker-container:focus-within{border:solid 2px #1870B8;padding:4px}.sky-theme-modern .sky-timepicker-container:last-child ol li{border-bottom:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-default{border-width:1px;border-color:transparent;padding:4px 6px;outline:none}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover:not(.sky-btn-active){background-color:transparent}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:hover{box-shadow:inset 0 0 0 1px #00b4f1;border-radius:6px}.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:active,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol button:focus{outline:none;border-radius:6px;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container{color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-container:not(:focus-within){border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol{border-color:#686c73}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol button{background-color:transparent;color:#fbfcfe}.sky-theme-modern.sky-theme-mode-dark .sky-timepicker-column ol .sky-btn-active{background-color:#009cd1}\n"] }]
327
341
  }], ctorParameters: function () { return [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
@@ -358,4 +372,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
358
372
  static: true,
359
373
  }]
360
374
  }] } });
361
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EAGZ,QAAQ,EACR,MAAM,EACN,WAAW,EACX,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,sBAAsB,EACtB,eAAe,EAEf,qBAAqB,EAErB,iBAAiB,GAClB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;AAI3C,IAAI,MAAM,GAAG,CAAC,CAAC;AAEf;;;;;GAKG;AAQH,MAAM,OAAO,sBAAsB;IAkMjC,YACU,YAA6B,EAC7B,cAAiC,EACjC,WAAkC,EAClC,cAAiC,EACtB,mBAA4C,EACnD,QAA0B;QAL9B,iBAAY,GAAZ,YAAY,CAAiB;QAC7B,mBAAc,GAAd,cAAc,CAAmB;QACjC,gBAAW,GAAX,WAAW,CAAuB;QAClC,mBAAc,GAAd,cAAc,CAAmB;QACtB,wBAAmB,GAAnB,mBAAmB,CAAyB;QAtMjE;;WAEG;QAEI,wBAAmB,GAA0C,IAAI,YAAY,EAA2B,CAAC;QAuGzG,WAAM,GAAG,KAAK,CAAC;QAcf,eAAU,GAAG,IAAI,CAAC;QA8DjB,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QAkB1C,MAAM,QAAQ,GAAG,MAAM,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,kBAAkB,QAAQ,EAAE,CAAC;QACjD,IAAI,CAAC,eAAe,GAAG,yBAAyB,QAAQ,EAAE,CAAC;QAE3D,mCAAmC;QACnC,QAAQ,EAAE,cAAc;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IA7MD,IAAW,QAAQ,CAAC,KAAc;QAChC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAW,YAAY,CAAC,OAAe;QACrC,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI,IAAI,OAAO,KAAK,EAAE,EAAE;YACpD,UAAU,GAAG,CAAC,EAAE,CAAC;SAClB;QACD,IAAI,IAAI,CAAC,gBAAgB,KAAK,IAAI,IAAI,OAAO,KAAK,EAAE,EAAE;YACpD,UAAU,GAAG,EAAE,CAAC;SACjB;QACD,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,UAAU,GAAG,CAAC,CAAC;SAChB;QACD,MAAM,IAAI,GAAG,MAAM,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;QAEvE,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YACvB,IAAI,EAAE,IAAI;YACV,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC;SAClD,CAAC,CAAC,MAAM,EAAE,CAAC;QACZ,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED,IAAW,YAAY;QACrB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,0BAA0B;YAC1B,OAAO,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;SAC9D;QACD,0BAA0B;QAC1B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,OAAO,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC3C;IACH,CAAC;IAED,IAAW,gBAAgB,CAAC,QAAgB;QAC1C,0BAA0B;QAC1B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,QAAQ,CAAC,IAAI,EAAE,KAAK,IAAI,CAAC,gBAAgB,EAAE;gBAC7C,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC;gBACpE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClD;SACF;IACH,CAAC;IAED,IAAW,gBAAgB;QACzB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAC5C;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAW,cAAc,CAAC,MAAc;QACtC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YACvB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC;YAC7C,MAAM,EAAE,MAAM;SACf,CAAC,CAAC,MAAM,EAAE,CAAC;QACZ,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC9C,CAAC;IAED,IAAW,YAAY,CAAC,OAAgC;QACtD,IAAI,OAAO,OAAO,KAAK,WAAW,EAAE;YAClC,kBAAkB;YAClB,0BAA0B;YAC1B,IAAI,OAAO,CAAC,KAAK,KAAK,cAAc,EAAE;gBACpC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC;gBAClC,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;aACpC;SACF;IACH,CAAC;IAED,IAAW,YAAY;QACrB,MAAM,IAAI,GAA4B;YACpC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE;YACpC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE;YACxC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;YAC5C,QAAQ,EAAE,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YAC3D,OAAO,EAAE,IAAI,CAAC,UAAU;YACxB,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC;YACxD,YAAY,EACV,OAAO,IAAI,CAAC,YAAY,KAAK,WAAW;gBACtC,CAAC,CAAC,IAAI,CAAC,YAAY;gBACnB,CAAC,CAAC,IAAI,CAAC,YAAY;SACxB,CAAC;QAEF,OAAO,IAAI,CAAC;IACd,CAAC;IA0BD,IAGY,aAAa,CAAC,KAAiB;QACzC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAE5B,yEAAyE;YACzE,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,aAAa,EAAE,CAAC;gBAErB,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,WAAW,CAAC,iCAAiC,CAChD,IAAI,CAAC,aAAa,EAClB,yBAAyB,EACzB,KAAK,CACN,CAAC;oBAEF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBACtB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;gBACrC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,IAAY,aAAa;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IA0DM,QAAQ;QACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;gBAChC,aAAa,EAAE,IAAI,CAAC,gBAAgB;gBACpC,eAAe,EAAE,IAAI,CAAC,wBAAwB;aAC/C,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,SAAS,CAAC,MAAc;QAC7B,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,IAAI,gBAAgB,GAAG,CAAC,CAAC;QACzB,IAAI,YAAY,GAAG,QAAQ,CAAC;QAC5B,IAAI,MAAM,KAAK,IAAI,EAAE;YACnB,CAAC,GAAG,EAAE,CAAC;YACP,CAAC,GAAG,EAAE,CAAC;YACP,gBAAgB,GAAG,CAAC,CAAC;YACrB,YAAY,GAAG,QAAQ,CAAC;YACxB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;QACD,IAAI,MAAM,KAAK,IAAI,EAAE;YACnB,CAAC,GAAG,EAAE,CAAC;YACP,CAAC,GAAG,CAAC,CAAC;YACN,gBAAgB,GAAG,EAAE,CAAC;YACtB,YAAY,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACpB;QAED,MAAM,IAAI,GAKN;YACF,yDAAyD;YACzD,KAAK,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACrC,IAAI,MAAM,KAAK,IAAI,EAAE;oBACnB,OAAO,EAAE,CAAC,CAAC;iBACZ;gBACD,0BAA0B;gBAC1B,IAAI,MAAM,KAAK,IAAI,EAAE;oBACnB,OAAO,CAAC,CAAC;iBACV;gBACD,0BAA0B;gBAC1B,kBAAkB;gBAClB,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;YACF,2DAA2D;YAC3D,OAAO,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;gBAC5C,OAAO,CAAC,GAAG,gBAAgB,CAAC;YAC9B,CAAC,CAAC;YACF,YAAY,EAAE,YAAY;YAC1B,gBAAgB,EAAE,gBAAgB;SACnC,CAAC;QAEF,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;QACtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC;IAChD,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEM,OAAO,CAAC,KAAU;QACvB,0BAA0B;QAC1B,IAAI,OAAO,KAAK,KAAK,WAAW,EAAE;YAChC,0BAA0B;YAC1B,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;gBAC1B,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;oBAChC,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;iBACzD;gBACD,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE;oBAClC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;iBAC3D;gBACD,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;oBACnC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC;iBAChD;aACF;SACF;IACH,CAAC;IAEM,oBAAoB;QACzB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC5C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QAEnC,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,qBAAqB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAEO,aAAa;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAEpE,8DAA8D;QAC9D,OAAO,CAAC,eAAe;aACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;aAC3C,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,KAAK,IAAI,CAAC;YAC3C,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;QAEL,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE;YACnD,cAAc,EAAE,sBAAsB,CAAC,QAAQ;YAC/C,aAAa,EAAE,IAAI;YACnB,mBAAmB,EAAE,OAAO;YAC5B,QAAQ,EAAE,IAAI;YACd,SAAS,EAAE,OAAO;SACnB,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAEO,cAAc;QACpB,wBAAwB;QACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;IACH,CAAC;IAEO,aAAa;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;YACzC,WAAW,EAAE,KAAK;YAClB,mBAAmB,EAAE,KAAK;SAC3B,CAAC,CAAC;QAEH,OAAO,CAAC,aAAa;aAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;aAC3C,SAAS,CAAC,GAAG,EAAE;YACd,0BAA0B;YAC1B,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAEnD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAEO,cAAc;QACpB,wBAAwB;QACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;SAC1B;IACH,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,CAAC;aAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,EAAE,WAAW,EAAE,CAAC;YACrC,0BAA0B;YAC1B,IAAI,GAAG,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,EAAE;gBACnC,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,0BAA0B;QAChC,0BAA0B;QAC1B,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;YAClC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,EAAE,CAAC;YACtC,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;SACxC;QACD,0BAA0B;QAC1B,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;IAC5C,CAAC;;mHAhaU,sBAAsB;uGAAtB,sBAAsB,0MAiIzB,UAAU,yHA8BV,WAAW,+GAKX,UAAU,+GAKV,WAAW,6IAMX,WAAW,2CC7NrB,smHAsHA;2FDxEa,sBAAsB;kBAPlC,SAAS;+BACE,gBAAgB,iBAGX,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAyM5C,QAAQ;;0BACR,QAAQ;4CAnMJ,mBAAmB;sBADzB,MAAM;gBA+HK,aAAa;sBAHxB,SAAS;uBAAC,eAAe,EAAE;wBAC1B,IAAI,EAAE,UAAU;qBACjB;gBA+BO,qBAAqB;sBAH5B,SAAS;uBAAC,uBAAuB,EAAE;wBAClC,IAAI,EAAE,WAAW;qBAClB;gBAMO,gBAAgB;sBAHvB,SAAS;uBAAC,kBAAkB,EAAE;wBAC7B,IAAI,EAAE,UAAU;qBACjB;gBAOO,gBAAgB;sBAJvB,SAAS;uBAAC,kBAAkB,EAAE;wBAC7B,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACb;gBAOO,wBAAwB;sBAJ/B,SAAS;uBAAC,0BAA0B,EAAE;wBACrC,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACb","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport moment from 'moment';\nimport { Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTimepickerTimeOutput } from './timepicker.interface';\n\nlet nextId = 0;\n\n/**\n * Creates a SKY UX-themed replacement for the HTML `input` element with `type=\"time\"`.\n * The value that users select is driven through the `ngModel` attribute\n * specified on the `input` element. You must wrap this component around an `input`\n * with the `skyTimepickerInput` directive.\n */\n@Component({\n  selector: 'sky-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyTimepickerComponent implements OnInit, OnDestroy {\n  /**\n   * Fires when the value in the timepicker input changes.\n   */\n  @Output()\n  public selectedTimeChanged: EventEmitter<SkyTimepickerTimeOutput> = new EventEmitter<SkyTimepickerTimeOutput>();\n\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this.changeDetector.markForCheck();\n  }\n\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  public set selectedHour(setHour: number) {\n    let hourOffset = 0;\n    if (this.selectedMeridies === 'AM' && setHour === 12) {\n      hourOffset = -12;\n    }\n    if (this.selectedMeridies === 'PM' && setHour !== 12) {\n      hourOffset = 12;\n    }\n    if (this.is8601) {\n      hourOffset = 0;\n    }\n    const hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();\n\n    this.activeTime = moment({\n      hour: hour,\n      minute: moment(this.activeTime).get('minute') + 0,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedHour(): number {\n    if (!this.is8601) {\n      /* istanbul ignore next */\n      return parseInt(moment(this.activeTime).format('h'), 0) || 1;\n    }\n    /* istanbul ignore else */\n    if (this.is8601) {\n      return moment(this.activeTime).hour() + 0;\n    }\n  }\n\n  public set selectedMeridies(meridies: string) {\n    /* istanbul ignore else */\n    if (!this.is8601) {\n      if (meridies.trim() !== this.selectedMeridies) {\n        this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();\n        this.selectedTimeChanged.emit(this.selectedTime);\n      }\n    }\n  }\n\n  public get selectedMeridies(): string {\n    if (this.activeTime) {\n      return moment(this.activeTime).format('A');\n    }\n    return '';\n  }\n\n  public set selectedMinute(minute: number) {\n    this.activeTime = moment({\n      hour: moment(this.activeTime).get('hour') + 0,\n      minute: minute,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedMinute(): number {\n    return moment(this.activeTime).minute() + 0;\n  }\n\n  public set selectedTime(newTime: SkyTimepickerTimeOutput) {\n    if (typeof newTime !== 'undefined') {\n      /* sanity check */\n      /* istanbul ignore else */\n      if (newTime.local !== 'Invalid date') {\n        this.activeTime = newTime.iso8601;\n        this.changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get selectedTime(): SkyTimepickerTimeOutput {\n    const time: SkyTimepickerTimeOutput = {\n      hour: moment(this.activeTime).hour(),\n      minute: moment(this.activeTime).minute(),\n      meridie: moment(this.activeTime).format('A'),\n      timezone: parseInt(moment(this.activeTime).format('Z'), 10),\n      iso8601: this.activeTime,\n      local: moment(this.activeTime).format(this.localeFormat),\n      customFormat:\n        typeof this.returnFormat !== 'undefined'\n          ? this.returnFormat\n          : this.localeFormat,\n    };\n\n    return time;\n  }\n\n  public activeTime: Date;\n\n  public hours: Array<number>;\n\n  public is8601 = false;\n\n  public isOpen: boolean;\n\n  public isVisible: boolean;\n\n  public localeFormat: string;\n\n  public minutes: Array<number>;\n\n  public minuteMultiplier: number;\n\n  public returnFormat: string;\n\n  public timeFormat = 'hh';\n\n  public timepickerId: string;\n\n  public triggerButtonId: string;\n\n  @ViewChild('timepickerRef', {\n    read: ElementRef,\n  })\n  private set timepickerRef(value: ElementRef) {\n    if (value) {\n      this._timepickerRef = value;\n\n      // Wait for the timepicker component to render before guaging dimensions.\n      setTimeout(() => {\n        this.destroyAffixer();\n        this.createAffixer();\n\n        setTimeout(() => {\n          this.coreAdapter.getFocusableChildrenAndApplyFocus(\n            this.timepickerRef,\n            '.sky-timepicker-content',\n            false\n          );\n\n          this.isVisible = true;\n          this.changeDetector.markForCheck();\n        });\n      });\n    }\n  }\n\n  private get timepickerRef(): ElementRef {\n    return this._timepickerRef;\n  }\n\n  @ViewChild('timepickerTemplateRef', {\n    read: TemplateRef,\n  })\n  private timepickerTemplateRef: TemplateRef<unknown>;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef,\n  })\n  private triggerButtonRef: ElementRef;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private inputTemplateRef: TemplateRef<unknown>;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private triggerButtonTemplateRef: TemplateRef<unknown>;\n\n  private affixer: SkyAffixer;\n\n  private timepickerUnsubscribe: Subject<void>;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private overlay: SkyOverlayInstance;\n\n  private overlayKeydownListner: Subscription;\n\n  private _disabled: boolean;\n\n  private _timepickerRef: ElementRef;\n\n  constructor(\n    private affixService: SkyAffixService,\n    private changeDetector: ChangeDetectorRef,\n    private coreAdapter: SkyCoreAdapterService,\n    private overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    const uniqueId = nextId++;\n    this.timepickerId = `sky-timepicker-${uniqueId}`;\n    this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    this.setFormat(this.timeFormat);\n    this.addKeydownListner();\n\n    if (this.inputBoxHostService) {\n      this.inputBoxHostService.populate({\n        inputTemplate: this.inputTemplateRef,\n        buttonsTemplate: this.triggerButtonTemplateRef,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.removePickerEventListeners();\n    this.destroyAffixer();\n    this.destroyOverlay();\n  }\n\n  public setFormat(format: string): void {\n    let h = 12;\n    let m = 12;\n    let minuteMultiplier = 5;\n    let localeFormat = 'h:mm A';\n    if (format === 'hh') {\n      h = 12;\n      m = 12;\n      minuteMultiplier = 5;\n      localeFormat = 'h:mm A';\n      this.is8601 = false;\n    }\n    if (format === 'HH') {\n      h = 24;\n      m = 4;\n      minuteMultiplier = 15;\n      localeFormat = 'HH:mm';\n      this.is8601 = true;\n    }\n\n    const data: {\n      hours: number[];\n      minutes: number[];\n      localeFormat: string;\n      minuteMultiplier: number;\n    } = {\n      // Create a sparse array with a length equal to the hour.\n      hours: Array(...Array(h)).map((_, i) => {\n        if (format === 'hh') {\n          return ++i;\n        }\n        /* istanbul ignore else */\n        if (format === 'HH') {\n          return i;\n        }\n        /* istanbul ignore next */\n        /* sanity check */\n        return 0;\n      }),\n      // Create a sparse array with a length equal to the minute.\n      minutes: Array(...Array(m)).map(function (_, i) {\n        return i * minuteMultiplier;\n      }),\n      localeFormat: localeFormat,\n      minuteMultiplier: minuteMultiplier,\n    };\n\n    this.hours = data.hours;\n    this.minutes = data.minutes;\n    this.localeFormat = data.localeFormat;\n    this.minuteMultiplier = data.minuteMultiplier;\n  }\n\n  public onCloseButtonCick(): void {\n    this.closePicker();\n  }\n\n  public setTime(event: any): void {\n    /* istanbul ignore else */\n    if (typeof event !== 'undefined') {\n      /* istanbul ignore else */\n      if (event.type === 'click') {\n        event.stopPropagation();\n        if (event.target.name === 'hour') {\n          this.selectedHour = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'minute') {\n          this.selectedMinute = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'meridie') {\n          this.selectedMeridies = event.target.innerHTML;\n        }\n      }\n    }\n  }\n\n  public onTriggerButtonClick(): void {\n    this.openPicker();\n  }\n\n  private closePicker() {\n    this.destroyAffixer();\n    this.destroyOverlay();\n    this.removePickerEventListeners();\n    this.triggerButtonRef.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  private openPicker(): void {\n    this.isVisible = false;\n    this.changeDetector.markForCheck();\n\n    this.removePickerEventListeners();\n    this.timepickerUnsubscribe = new Subject<void>();\n    this.destroyOverlay();\n    this.createOverlay();\n\n    this.isOpen = true;\n    this.changeDetector.markForCheck();\n  }\n\n  private createAffixer(): void {\n    const affixer = this.affixService.createAffixer(this.timepickerRef);\n\n    // Hide timepicker when trigger button is scrolled off screen.\n    affixer.placementChange\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = change.placement !== null;\n        this.changeDetector.markForCheck();\n      });\n\n    affixer.affixTo(this.triggerButtonRef.nativeElement, {\n      autoFitContext: SkyAffixAutoFitContext.Viewport,\n      enableAutoFit: true,\n      horizontalAlignment: 'right',\n      isSticky: true,\n      placement: 'below',\n    });\n\n    this.affixer = affixer;\n  }\n\n  private destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.affixer) {\n      this.affixer.destroy();\n      this.affixer = undefined;\n    }\n  }\n\n  private createOverlay(): void {\n    const overlay = this.overlayService.create({\n      enableClose: false,\n      enablePointerEvents: false,\n    });\n\n    overlay.backdropClick\n      .pipe(takeUntil(this.timepickerUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.isOpen) {\n          this.closePicker();\n        }\n      });\n\n    this.addKeydownListner();\n\n    overlay.attachTemplate(this.timepickerTemplateRef);\n\n    this.overlay = overlay;\n  }\n\n  private destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.overlay) {\n      this.overlayService.close(this.overlay);\n      this.overlay = undefined;\n    }\n  }\n\n  private addKeydownListner(): void {\n    this.overlayKeydownListner = fromEvent(window.document, 'keydown')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((event: KeyboardEvent) => {\n        const key = event.key?.toLowerCase();\n        /* istanbul ignore else */\n        if (key === 'escape' && this.isOpen) {\n          this.closePicker();\n        }\n      });\n  }\n\n  private removePickerEventListeners(): void {\n    /* istanbul ignore else */\n    if (this.timepickerUnsubscribe) {\n      this.timepickerUnsubscribe.next();\n      this.timepickerUnsubscribe.complete();\n      this.timepickerUnsubscribe = undefined;\n    }\n    /* istanbul ignore next */\n    this.overlayKeydownListner?.unsubscribe();\n  }\n}\n","<div class=\"sky-timepicker\">\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div class=\"sky-input-group\">\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div class=\"sky-input-group-btn\">\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n      <sky-icon\n        *skyThemeIf=\"'modern'\"\n        icon=\"clock\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n  <div\n    class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"timepickerId\"\n    [class.sky-timepicker-hidden]=\"!isVisible\"\n    #timepickerRef\n  >\n    <div class=\"sky-timepicker-content\">\n      <section\n        class=\"sky-timepicker-column\"\n        [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n      >\n        <ol>\n          <li *ngFor=\"let hour of hours\">\n            <button\n              name=\"hour\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ hour }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section class=\"sky-timepicker-column\">\n        <ol>\n          <li *ngFor=\"let minute of minutes\">\n            <button\n              name=\"minute\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n        <ol>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n              (click)=\"setTime($event)\"\n            >\n              AM\n            </button>\n          </li>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n              (click)=\"setTime($event)\"\n            >\n              PM\n            </button>\n          </li>\n        </ol>\n      </section>\n    </div>\n    <div class=\"sky-timepicker-footer\">\n      <section class=\"sky-timepicker-column\">\n        <button\n          class=\"sky-btn sky-btn-primary\"\n          type=\"button\"\n          (click)=\"onCloseButtonCick()\"\n        >\n          {{ 'skyux_timepicker_close' | skyLibResources }}\n        </button>\n      </section>\n    </div>\n  </div>\n</ng-template>\n"]}
375
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport moment from 'moment';\nimport { Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTimepickerTimeOutput } from './timepicker.interface';\n\nlet nextId = 0;\n\n/**\n * Creates a SKY UX-themed replacement for the HTML `input` element with `type=\"time\"`.\n * The value that users select is driven through the `ngModel` attribute\n * specified on the `input` element. You must wrap this component around an `input`\n * with the `skyTimepickerInput` directive.\n */\n@Component({\n  selector: 'sky-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyTimepickerComponent implements OnInit, OnDestroy {\n  /**\n   * Fires when the value in the timepicker input changes.\n   */\n  @Output()\n  public selectedTimeChanged: EventEmitter<SkyTimepickerTimeOutput> = new EventEmitter<SkyTimepickerTimeOutput>();\n\n  public set disabled(value: boolean) {\n    this.#_disabled = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public set selectedHour(setHour: number) {\n    let hourOffset = 0;\n    if (this.selectedMeridies === 'AM' && setHour === 12) {\n      hourOffset = -12;\n    }\n    if (this.selectedMeridies === 'PM' && setHour !== 12) {\n      hourOffset = 12;\n    }\n    if (this.is8601) {\n      hourOffset = 0;\n    }\n    const hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();\n\n    this.activeTime = moment({\n      hour: hour,\n      minute: moment(this.activeTime).get('minute') + 0,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedHour(): number {\n    if (!this.is8601) {\n      /* istanbul ignore next */\n      return parseInt(moment(this.activeTime).format('h'), 0) || 1;\n    } else {\n      return moment(this.activeTime).hour() + 0;\n    }\n  }\n\n  public set selectedMeridies(meridies: string) {\n    /* istanbul ignore else */\n    if (!this.is8601) {\n      if (meridies.trim() !== this.selectedMeridies) {\n        this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();\n        this.selectedTimeChanged.emit(this.selectedTime);\n      }\n    }\n  }\n\n  public get selectedMeridies(): string {\n    if (this.activeTime) {\n      return moment(this.activeTime).format('A');\n    }\n    return '';\n  }\n\n  public set selectedMinute(minute: number) {\n    this.activeTime = moment({\n      hour: moment(this.activeTime).get('hour') + 0,\n      minute: minute,\n    }).toDate();\n    this.selectedTimeChanged.emit(this.selectedTime);\n  }\n\n  public get selectedMinute(): number {\n    return moment(this.activeTime).minute() + 0;\n  }\n\n  public set selectedTime(newTime: SkyTimepickerTimeOutput | undefined) {\n    if (typeof newTime !== 'undefined') {\n      /* sanity check */\n      /* istanbul ignore else */\n      if (newTime.local !== 'Invalid date') {\n        this.activeTime = newTime.iso8601;\n        this.#changeDetector.markForCheck();\n      }\n    }\n  }\n\n  public get selectedTime(): SkyTimepickerTimeOutput | undefined {\n    const time: SkyTimepickerTimeOutput = {\n      hour: moment(this.activeTime).hour(),\n      minute: moment(this.activeTime).minute(),\n      meridie: moment(this.activeTime).format('A'),\n      timezone: parseInt(moment(this.activeTime).format('Z'), 10),\n      iso8601: this.activeTime,\n      local: moment(this.activeTime).format(this.localeFormat),\n      customFormat:\n        typeof this.returnFormat !== 'undefined'\n          ? this.returnFormat\n          : this.localeFormat,\n    };\n\n    return time;\n  }\n\n  public activeTime: Date = new Date();\n\n  public hours: Array<number> = [];\n\n  public is8601 = false;\n\n  public isOpen = false;\n\n  public isVisible = false;\n\n  public localeFormat = 'h:mm A';\n\n  public minutes: Array<number> = [];\n\n  public minuteMultiplier: number | undefined;\n\n  public returnFormat: string | undefined;\n\n  public timeFormat = 'hh';\n\n  public timepickerId: string;\n\n  public triggerButtonId: string;\n\n  @ViewChild('timepickerRef', {\n    read: ElementRef,\n  })\n  public set timepickerRef(value: ElementRef | undefined) {\n    if (value) {\n      this.#_timepickerRef = value;\n\n      // Wait for the timepicker component to render before guaging dimensions.\n      setTimeout(() => {\n        this.#destroyAffixer();\n        this.#createAffixer();\n\n        setTimeout(() => {\n          if (this.timepickerRef) {\n            this.#coreAdapter.getFocusableChildrenAndApplyFocus(\n              this.timepickerRef,\n              '.sky-timepicker-content',\n              false\n            );\n          }\n\n          this.isVisible = true;\n          this.#changeDetector.markForCheck();\n        });\n      });\n    }\n  }\n\n  public get timepickerRef(): ElementRef | undefined {\n    return this.#_timepickerRef;\n  }\n\n  @ViewChild('timepickerTemplateRef', {\n    read: TemplateRef,\n  })\n  public timepickerTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef,\n  })\n  public triggerButtonRef: ElementRef | undefined;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public inputTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public triggerButtonTemplateRef: TemplateRef<unknown> | undefined;\n\n  #affixer: SkyAffixer | undefined;\n\n  #timepickerUnsubscribe = new Subject<void>();\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #overlayKeydownListner: Subscription | undefined;\n\n  #_disabled = false;\n\n  #_timepickerRef: ElementRef | undefined;\n\n  #affixService: SkyAffixService;\n  #changeDetector: ChangeDetectorRef;\n  #coreAdapter: SkyCoreAdapterService;\n  #overlayService: SkyOverlayService;\n\n  constructor(\n    affixService: SkyAffixService,\n    changeDetector: ChangeDetectorRef,\n    coreAdapter: SkyCoreAdapterService,\n    overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#affixService = affixService;\n    this.#changeDetector = changeDetector;\n    this.#coreAdapter = coreAdapter;\n    this.#overlayService = overlayService;\n\n    const uniqueId = nextId++;\n    this.timepickerId = `sky-timepicker-${uniqueId}`;\n    this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    this.setFormat(this.timeFormat);\n    this.#addKeydownListener();\n\n    if (this.inputBoxHostService && this.inputTemplateRef) {\n      this.inputBoxHostService.populate({\n        inputTemplate: this.inputTemplateRef,\n        buttonsTemplate: this.triggerButtonTemplateRef,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#removePickerEventListeners();\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n  }\n\n  public setFormat(format: string): void {\n    let h = 12;\n    let m = 12;\n    let minuteMultiplier = 5;\n    let localeFormat = 'h:mm A';\n    if (format === 'hh') {\n      h = 12;\n      m = 12;\n      minuteMultiplier = 5;\n      localeFormat = 'h:mm A';\n      this.is8601 = false;\n    }\n    if (format === 'HH') {\n      h = 24;\n      m = 4;\n      minuteMultiplier = 15;\n      localeFormat = 'HH:mm';\n      this.is8601 = true;\n    }\n\n    const data: {\n      hours: number[];\n      minutes: number[];\n      localeFormat: string;\n      minuteMultiplier: number;\n    } = {\n      // Create a sparse array with a length equal to the hour.\n      hours: Array(...Array(h)).map((_, i) => {\n        if (format === 'hh') {\n          return ++i;\n        }\n        /* istanbul ignore else */\n        if (format === 'HH') {\n          return i;\n        }\n        /* istanbul ignore next */\n        /* sanity check */\n        return 0;\n      }),\n      // Create a sparse array with a length equal to the minute.\n      minutes: Array(...Array(m)).map(function (_, i) {\n        return i * minuteMultiplier;\n      }),\n      localeFormat: localeFormat,\n      minuteMultiplier: minuteMultiplier,\n    };\n\n    this.hours = data.hours;\n    this.minutes = data.minutes;\n    this.localeFormat = data.localeFormat;\n    this.minuteMultiplier = data.minuteMultiplier;\n  }\n\n  public onCloseButtonCick(): void {\n    this.#closePicker();\n  }\n\n  public setTime(event: any): void {\n    /* istanbul ignore else */\n    if (typeof event !== 'undefined') {\n      /* istanbul ignore else */\n      if (event.type === 'click') {\n        event.stopPropagation();\n        if (event.target.name === 'hour') {\n          this.selectedHour = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'minute') {\n          this.selectedMinute = parseInt(event.target.innerHTML, 0);\n        }\n        if (event.target.name === 'meridie') {\n          this.selectedMeridies = event.target.innerHTML;\n        }\n      }\n    }\n  }\n\n  public onTriggerButtonClick(): void {\n    this.#openPicker();\n  }\n\n  #closePicker() {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    this.#removePickerEventListeners();\n    this.triggerButtonRef?.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  #openPicker(): void {\n    this.isVisible = false;\n    this.#changeDetector.markForCheck();\n\n    this.#removePickerEventListeners();\n    this.#destroyOverlay();\n    this.#createOverlay();\n\n    this.isOpen = true;\n    this.#changeDetector.markForCheck();\n  }\n\n  #createAffixer(): void {\n    if (this.timepickerRef && this.triggerButtonRef) {\n      const affixer = this.#affixService.createAffixer(this.timepickerRef);\n\n      // Hide timepicker when trigger button is scrolled off screen.\n      affixer.placementChange\n        .pipe(takeUntil(this.#timepickerUnsubscribe))\n        .subscribe((change) => {\n          this.isVisible = change.placement !== null;\n          this.#changeDetector.markForCheck();\n        });\n\n      affixer.affixTo(this.triggerButtonRef.nativeElement, {\n        autoFitContext: SkyAffixAutoFitContext.Viewport,\n        enableAutoFit: true,\n        horizontalAlignment: 'right',\n        isSticky: true,\n        placement: 'below',\n      });\n\n      this.#affixer = affixer;\n    }\n  }\n\n  #destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.#affixer) {\n      this.#affixer.destroy();\n      this.#affixer = undefined;\n    }\n  }\n\n  #createOverlay(): void {\n    if (this.timepickerTemplateRef) {\n      const overlay = this.#overlayService.create({\n        enableClose: false,\n        enablePointerEvents: false,\n      });\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#timepickerUnsubscribe))\n        .subscribe(() => {\n          /* istanbul ignore else */\n          if (this.isOpen) {\n            this.#closePicker();\n          }\n        });\n\n      this.#addKeydownListener();\n\n      overlay.attachTemplate(this.timepickerTemplateRef);\n\n      this.#overlay = overlay;\n    }\n  }\n\n  #destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  #addKeydownListener(): void {\n    this.#overlayKeydownListner = fromEvent<KeyboardEvent>(\n      window.document,\n      'keydown'\n    )\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        const key = event.key?.toLowerCase();\n        /* istanbul ignore else */\n        if (key === 'escape' && this.isOpen) {\n          this.#closePicker();\n        }\n      });\n  }\n\n  #removePickerEventListeners(): void {\n    /* istanbul ignore else */\n    if (this.#timepickerUnsubscribe) {\n      this.#timepickerUnsubscribe.next();\n      this.#timepickerUnsubscribe.complete();\n      this.#timepickerUnsubscribe = new Subject<void>();\n    }\n    /* istanbul ignore next */\n    this.#overlayKeydownListner?.unsubscribe();\n  }\n}\n","<div class=\"sky-timepicker\">\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div class=\"sky-input-group\">\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div class=\"sky-input-group-btn\">\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-timepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? timepickerId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_timepicker_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\" icon=\"clock-o\" size=\"lg\"></sky-icon>\n      <sky-icon\n        *skyThemeIf=\"'modern'\"\n        icon=\"clock\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #timepickerTemplateRef>\n  <div\n    class=\"sky-timepicker-container sky-shadow sky-box sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"timepickerId\"\n    [class.sky-timepicker-hidden]=\"!isVisible\"\n    #timepickerRef\n  >\n    <div class=\"sky-timepicker-content\">\n      <section\n        class=\"sky-timepicker-column\"\n        [ngClass]=\"{ 'sky-timepicker-24hour': is8601 }\"\n      >\n        <ol>\n          <li *ngFor=\"let hour of hours\">\n            <button\n              name=\"hour\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedHour === hour }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ hour }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section class=\"sky-timepicker-column\">\n        <ol>\n          <li *ngFor=\"let minute of minutes\">\n            <button\n              name=\"minute\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMinute === minute }\"\n              (click)=\"setTime($event)\"\n            >\n              {{ '00'.substring(0, 2 - minute.toString().length) + minute }}\n            </button>\n          </li>\n        </ol>\n      </section>\n      <section *ngIf=\"!is8601\" class=\"sky-timepicker-column\">\n        <ol>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'AM' }\"\n              (click)=\"setTime($event)\"\n            >\n              AM\n            </button>\n          </li>\n          <li>\n            <button\n              name=\"meridie\"\n              type=\"button\"\n              [ngClass]=\"{ 'sky-btn-active': selectedMeridies === 'PM' }\"\n              (click)=\"setTime($event)\"\n            >\n              PM\n            </button>\n          </li>\n        </ol>\n      </section>\n    </div>\n    <div class=\"sky-timepicker-footer\">\n      <section class=\"sky-timepicker-column\">\n        <button\n          class=\"sky-btn sky-btn-primary\"\n          type=\"button\"\n          (click)=\"onCloseButtonCick()\"\n        >\n          {{ 'skyux_timepicker_close' | skyLibResources }}\n        </button>\n      </section>\n    </div>\n  </div>\n</ng-template>\n"]}