@skyux/datetime 8.7.0 → 9.0.0-alpha.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.
- package/esm2022/lib/modules/date-pipe/date-format-utility.mjs +45 -0
- package/{esm2020 → esm2022}/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
- package/esm2022/lib/modules/date-pipe/date.pipe.mjs +67 -0
- package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +4 -4
- package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +518 -0
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker.module.mjs +19 -19
- package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +97 -0
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +54 -0
- package/esm2022/lib/modules/datepicker/date-formatter.mjs +38 -0
- package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +23 -0
- package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +332 -0
- package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +95 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
- package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +487 -0
- package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +534 -0
- package/esm2022/lib/modules/datepicker/datepicker.component.mjs +327 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.module.mjs +35 -35
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/datepicker/daypicker-button.component.mjs +4 -4
- package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +128 -0
- package/esm2022/lib/modules/datepicker/daypicker.component.mjs +224 -0
- package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +412 -0
- package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +80 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/yearpicker.component.mjs +53 -54
- package/{esm2020 → esm2022}/lib/modules/shared/sky-datetime-resources.module.mjs +11 -11
- package/esm2022/lib/modules/timepicker/timepicker.component.mjs +396 -0
- package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +237 -0
- package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker.module.mjs +17 -17
- package/esm2022/testing/datepicker-fixture.mjs +55 -0
- package/esm2022/testing/timepicker-fixture.mjs +52 -0
- package/fesm2022/skyux-datetime-testing.mjs +112 -0
- package/{fesm2020 → fesm2022}/skyux-datetime-testing.mjs.map +1 -1
- package/fesm2022/skyux-datetime.mjs +5030 -0
- package/fesm2022/skyux-datetime.mjs.map +1 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-calendar.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
- package/lib/modules/datepicker/datepicker.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-cell.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
- package/lib/modules/timepicker/timepicker.directive.d.ts +1 -1
- package/package.json +19 -27
- package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +0 -45
- package/esm2020/lib/modules/date-pipe/date.pipe.mjs +0 -70
- package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -50
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -494
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +0 -100
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -53
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +0 -38
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -26
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -333
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -462
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +0 -496
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +0 -319
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +0 -126
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +0 -216
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +0 -392
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +0 -81
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +0 -389
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +0 -236
- package/esm2020/testing/datepicker-fixture.mjs +0 -58
- package/esm2020/testing/timepicker-fixture.mjs +0 -55
- package/fesm2015/skyux-datetime-testing.mjs +0 -117
- package/fesm2015/skyux-datetime-testing.mjs.map +0 -1
- package/fesm2015/skyux-datetime.mjs +0 -4925
- package/fesm2015/skyux-datetime.mjs.map +0 -1
- package/fesm2020/skyux-datetime-testing.mjs +0 -117
- package/fesm2020/skyux-datetime.mjs +0 -4895
- package/fesm2020/skyux-datetime.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-custom-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/fuzzy-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-output.mjs +0 -0
- /package/{esm2020 → esm2022}/skyux-datetime.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/skyux-datetime-testing.mjs +0 -0
@@ -0,0 +1,396 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
2
|
+
import { SKY_STACKING_CONTEXT, SkyAffixAutoFitContext, } from '@skyux/core';
|
3
|
+
import moment from 'moment';
|
4
|
+
import { Subject, fromEvent } from 'rxjs';
|
5
|
+
import { takeUntil } from 'rxjs/operators';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
import * as i1 from "@skyux/core";
|
8
|
+
import * as i2 from "@skyux/forms";
|
9
|
+
import * as i3 from "@skyux/theme";
|
10
|
+
import * as i4 from "@angular/common";
|
11
|
+
import * as i5 from "@skyux/indicators";
|
12
|
+
import * as i6 from "@skyux/i18n";
|
13
|
+
let nextId = 0;
|
14
|
+
/**
|
15
|
+
* Creates a SKY UX-themed replacement for the HTML `input` element with `type="time"`.
|
16
|
+
* The value that users select is driven through the `ngModel` attribute
|
17
|
+
* specified on the `input` element. You must wrap this component around an `input`
|
18
|
+
* with the `skyTimepickerInput` directive.
|
19
|
+
*/
|
20
|
+
export class SkyTimepickerComponent {
|
21
|
+
set disabled(value) {
|
22
|
+
this.#_disabled = value;
|
23
|
+
this.#changeDetector.markForCheck();
|
24
|
+
}
|
25
|
+
get disabled() {
|
26
|
+
return this.#_disabled;
|
27
|
+
}
|
28
|
+
set selectedHour(setHour) {
|
29
|
+
let hourOffset = 0;
|
30
|
+
if (this.selectedMeridies === 'AM' && setHour === 12) {
|
31
|
+
hourOffset = -12;
|
32
|
+
}
|
33
|
+
if (this.selectedMeridies === 'PM' && setHour !== 12) {
|
34
|
+
hourOffset = 12;
|
35
|
+
}
|
36
|
+
if (this.is8601) {
|
37
|
+
hourOffset = 0;
|
38
|
+
}
|
39
|
+
const hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();
|
40
|
+
this.activeTime = moment({
|
41
|
+
hour: hour,
|
42
|
+
minute: moment(this.activeTime).get('minute') + 0,
|
43
|
+
}).toDate();
|
44
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
45
|
+
}
|
46
|
+
get selectedHour() {
|
47
|
+
if (!this.is8601) {
|
48
|
+
/* istanbul ignore next */
|
49
|
+
return parseInt(moment(this.activeTime).format('h'), 0) || 1;
|
50
|
+
}
|
51
|
+
else {
|
52
|
+
return moment(this.activeTime).hour() + 0;
|
53
|
+
}
|
54
|
+
}
|
55
|
+
set selectedMeridies(meridies) {
|
56
|
+
/* istanbul ignore else */
|
57
|
+
if (!this.is8601) {
|
58
|
+
if (meridies.trim() !== this.selectedMeridies) {
|
59
|
+
this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();
|
60
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
61
|
+
}
|
62
|
+
}
|
63
|
+
}
|
64
|
+
get selectedMeridies() {
|
65
|
+
if (this.activeTime) {
|
66
|
+
return moment(this.activeTime).format('A');
|
67
|
+
}
|
68
|
+
return '';
|
69
|
+
}
|
70
|
+
set selectedMinute(minute) {
|
71
|
+
this.activeTime = moment({
|
72
|
+
hour: moment(this.activeTime).get('hour') + 0,
|
73
|
+
minute: minute,
|
74
|
+
}).toDate();
|
75
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
76
|
+
}
|
77
|
+
get selectedMinute() {
|
78
|
+
return moment(this.activeTime).minute() + 0;
|
79
|
+
}
|
80
|
+
set selectedTime(newTime) {
|
81
|
+
if (typeof newTime !== 'undefined') {
|
82
|
+
/* sanity check */
|
83
|
+
/* istanbul ignore else */
|
84
|
+
if (newTime.local !== 'Invalid date') {
|
85
|
+
this.activeTime = newTime.iso8601;
|
86
|
+
this.#changeDetector.markForCheck();
|
87
|
+
}
|
88
|
+
}
|
89
|
+
}
|
90
|
+
get selectedTime() {
|
91
|
+
const time = {
|
92
|
+
hour: moment(this.activeTime).hour(),
|
93
|
+
minute: moment(this.activeTime).minute(),
|
94
|
+
meridie: moment(this.activeTime).format('A'),
|
95
|
+
timezone: parseInt(moment(this.activeTime).format('Z'), 10),
|
96
|
+
iso8601: this.activeTime,
|
97
|
+
local: moment(this.activeTime).format(this.localeFormat),
|
98
|
+
customFormat: typeof this.returnFormat !== 'undefined'
|
99
|
+
? this.returnFormat
|
100
|
+
: this.localeFormat,
|
101
|
+
};
|
102
|
+
return time;
|
103
|
+
}
|
104
|
+
set timepickerRef(value) {
|
105
|
+
if (value) {
|
106
|
+
this.#_timepickerRef = value;
|
107
|
+
// Wait for the timepicker component to render before gauging dimensions.
|
108
|
+
setTimeout(() => {
|
109
|
+
this.#destroyAffixer();
|
110
|
+
this.#createAffixer();
|
111
|
+
setTimeout(() => {
|
112
|
+
if (this.timepickerRef) {
|
113
|
+
this.#coreAdapter.getFocusableChildrenAndApplyFocus(this.timepickerRef, '.sky-timepicker-content', false);
|
114
|
+
}
|
115
|
+
this.isVisible = true;
|
116
|
+
this.#changeDetector.markForCheck();
|
117
|
+
});
|
118
|
+
});
|
119
|
+
}
|
120
|
+
}
|
121
|
+
get timepickerRef() {
|
122
|
+
return this.#_timepickerRef;
|
123
|
+
}
|
124
|
+
#affixer;
|
125
|
+
#timepickerUnsubscribe;
|
126
|
+
#ngUnsubscribe;
|
127
|
+
#overlay;
|
128
|
+
#overlayKeydownListener;
|
129
|
+
#_disabled;
|
130
|
+
#_timepickerRef;
|
131
|
+
#affixService;
|
132
|
+
#changeDetector;
|
133
|
+
#coreAdapter;
|
134
|
+
#overlayService;
|
135
|
+
#zIndex;
|
136
|
+
constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc, stackingContext) {
|
137
|
+
this.inputBoxHostService = inputBoxHostService;
|
138
|
+
/**
|
139
|
+
* Fires when the value in the timepicker input changes.
|
140
|
+
*/
|
141
|
+
this.selectedTimeChanged = new EventEmitter();
|
142
|
+
this.activeTime = new Date();
|
143
|
+
this.hours = [];
|
144
|
+
this.is8601 = false;
|
145
|
+
this.isOpen = false;
|
146
|
+
this.isVisible = false;
|
147
|
+
this.localeFormat = 'h:mm A';
|
148
|
+
this.minutes = [];
|
149
|
+
this.timeFormat = 'hh';
|
150
|
+
this.#timepickerUnsubscribe = new Subject();
|
151
|
+
this.#ngUnsubscribe = new Subject();
|
152
|
+
this.#_disabled = false;
|
153
|
+
this.#affixService = affixService;
|
154
|
+
this.#changeDetector = changeDetector;
|
155
|
+
this.#coreAdapter = coreAdapter;
|
156
|
+
this.#overlayService = overlayService;
|
157
|
+
this.#zIndex = stackingContext?.zIndex;
|
158
|
+
const uniqueId = nextId++;
|
159
|
+
this.timepickerId = `sky-timepicker-${uniqueId}`;
|
160
|
+
this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;
|
161
|
+
// Update icons when theme changes.
|
162
|
+
themeSvc?.settingsChange
|
163
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
164
|
+
.subscribe(() => {
|
165
|
+
this.#changeDetector.markForCheck();
|
166
|
+
});
|
167
|
+
}
|
168
|
+
ngOnInit() {
|
169
|
+
this.setFormat(this.timeFormat);
|
170
|
+
this.#addKeydownListener();
|
171
|
+
if (this.inputBoxHostService && this.inputTemplateRef) {
|
172
|
+
this.inputBoxHostService.populate({
|
173
|
+
inputTemplate: this.inputTemplateRef,
|
174
|
+
buttonsTemplate: this.triggerButtonTemplateRef,
|
175
|
+
});
|
176
|
+
}
|
177
|
+
}
|
178
|
+
ngOnDestroy() {
|
179
|
+
this.#ngUnsubscribe.next();
|
180
|
+
this.#ngUnsubscribe.complete();
|
181
|
+
this.#removePickerEventListeners();
|
182
|
+
this.#destroyAffixer();
|
183
|
+
this.#destroyOverlay();
|
184
|
+
}
|
185
|
+
setFormat(format) {
|
186
|
+
let h = 12;
|
187
|
+
let m = 12;
|
188
|
+
let minuteMultiplier = 5;
|
189
|
+
let localeFormat = 'h:mm A';
|
190
|
+
if (format === 'hh') {
|
191
|
+
h = 12;
|
192
|
+
m = 12;
|
193
|
+
minuteMultiplier = 5;
|
194
|
+
localeFormat = 'h:mm A';
|
195
|
+
this.is8601 = false;
|
196
|
+
}
|
197
|
+
if (format === 'HH') {
|
198
|
+
h = 24;
|
199
|
+
m = 4;
|
200
|
+
minuteMultiplier = 15;
|
201
|
+
localeFormat = 'HH:mm';
|
202
|
+
this.is8601 = true;
|
203
|
+
}
|
204
|
+
const data = {
|
205
|
+
// Create a sparse array with a length equal to the hour.
|
206
|
+
hours: Array(...Array(h)).map((_, i) => {
|
207
|
+
if (format === 'hh') {
|
208
|
+
return ++i;
|
209
|
+
}
|
210
|
+
/* istanbul ignore else */
|
211
|
+
if (format === 'HH') {
|
212
|
+
return i;
|
213
|
+
}
|
214
|
+
/* istanbul ignore next */
|
215
|
+
/* sanity check */
|
216
|
+
return 0;
|
217
|
+
}),
|
218
|
+
// Create a sparse array with a length equal to the minute.
|
219
|
+
minutes: Array(...Array(m)).map(function (_, i) {
|
220
|
+
return i * minuteMultiplier;
|
221
|
+
}),
|
222
|
+
localeFormat: localeFormat,
|
223
|
+
minuteMultiplier: minuteMultiplier,
|
224
|
+
};
|
225
|
+
this.hours = data.hours;
|
226
|
+
this.minutes = data.minutes;
|
227
|
+
this.localeFormat = data.localeFormat;
|
228
|
+
this.minuteMultiplier = data.minuteMultiplier;
|
229
|
+
}
|
230
|
+
onCloseButtonClick() {
|
231
|
+
this.#closePicker();
|
232
|
+
}
|
233
|
+
setTime(event) {
|
234
|
+
/* istanbul ignore else */
|
235
|
+
if (typeof event !== 'undefined') {
|
236
|
+
/* istanbul ignore else */
|
237
|
+
if (event.type === 'click') {
|
238
|
+
event.stopPropagation();
|
239
|
+
if (event.target.name === 'hour') {
|
240
|
+
this.selectedHour = parseInt(event.target.innerHTML, 0);
|
241
|
+
}
|
242
|
+
if (event.target.name === 'minute') {
|
243
|
+
this.selectedMinute = parseInt(event.target.innerHTML, 0);
|
244
|
+
}
|
245
|
+
if (event.target.name === 'meridie') {
|
246
|
+
this.selectedMeridies = event.target.innerHTML;
|
247
|
+
}
|
248
|
+
}
|
249
|
+
}
|
250
|
+
}
|
251
|
+
onTriggerButtonClick() {
|
252
|
+
this.#openPicker();
|
253
|
+
}
|
254
|
+
#closePicker() {
|
255
|
+
this.#destroyAffixer();
|
256
|
+
this.#destroyOverlay();
|
257
|
+
this.#removePickerEventListeners();
|
258
|
+
this.triggerButtonRef?.nativeElement.focus();
|
259
|
+
this.isOpen = false;
|
260
|
+
}
|
261
|
+
#openPicker() {
|
262
|
+
this.isVisible = false;
|
263
|
+
this.#changeDetector.markForCheck();
|
264
|
+
this.#removePickerEventListeners();
|
265
|
+
this.#destroyOverlay();
|
266
|
+
this.#createOverlay();
|
267
|
+
this.isOpen = true;
|
268
|
+
this.#changeDetector.markForCheck();
|
269
|
+
}
|
270
|
+
#createAffixer() {
|
271
|
+
if (this.timepickerRef && this.triggerButtonRef) {
|
272
|
+
const affixer = this.#affixService.createAffixer(this.timepickerRef);
|
273
|
+
// Hide timepicker when trigger button is scrolled off screen.
|
274
|
+
affixer.placementChange
|
275
|
+
.pipe(takeUntil(this.#timepickerUnsubscribe))
|
276
|
+
.subscribe((change) => {
|
277
|
+
this.isVisible = change.placement !== null;
|
278
|
+
this.#changeDetector.markForCheck();
|
279
|
+
});
|
280
|
+
affixer.affixTo(this.triggerButtonRef.nativeElement, {
|
281
|
+
autoFitContext: SkyAffixAutoFitContext.Viewport,
|
282
|
+
enableAutoFit: true,
|
283
|
+
horizontalAlignment: 'right',
|
284
|
+
isSticky: true,
|
285
|
+
placement: 'below',
|
286
|
+
});
|
287
|
+
this.#affixer = affixer;
|
288
|
+
}
|
289
|
+
}
|
290
|
+
#destroyAffixer() {
|
291
|
+
/*istanbul ignore else*/
|
292
|
+
if (this.#affixer) {
|
293
|
+
this.#affixer.destroy();
|
294
|
+
this.#affixer = undefined;
|
295
|
+
}
|
296
|
+
}
|
297
|
+
#createOverlay() {
|
298
|
+
if (this.timepickerTemplateRef) {
|
299
|
+
const overlay = this.#overlayService.create({
|
300
|
+
enableClose: false,
|
301
|
+
enablePointerEvents: false,
|
302
|
+
});
|
303
|
+
if (this.#zIndex) {
|
304
|
+
this.#zIndex
|
305
|
+
.pipe(takeUntil(this.#timepickerUnsubscribe))
|
306
|
+
.subscribe((zIndex) => {
|
307
|
+
overlay.componentRef.instance.zIndex = zIndex.toString(10);
|
308
|
+
});
|
309
|
+
}
|
310
|
+
overlay.backdropClick
|
311
|
+
.pipe(takeUntil(this.#timepickerUnsubscribe))
|
312
|
+
.subscribe(() => {
|
313
|
+
/* istanbul ignore else */
|
314
|
+
if (this.isOpen) {
|
315
|
+
this.#closePicker();
|
316
|
+
}
|
317
|
+
});
|
318
|
+
this.#addKeydownListener();
|
319
|
+
overlay.attachTemplate(this.timepickerTemplateRef);
|
320
|
+
this.#overlay = overlay;
|
321
|
+
}
|
322
|
+
}
|
323
|
+
#destroyOverlay() {
|
324
|
+
/*istanbul ignore else*/
|
325
|
+
if (this.#overlay) {
|
326
|
+
this.#overlayService.close(this.#overlay);
|
327
|
+
this.#overlay = undefined;
|
328
|
+
}
|
329
|
+
}
|
330
|
+
#addKeydownListener() {
|
331
|
+
this.#overlayKeydownListener = fromEvent(window.document, 'keydown')
|
332
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
333
|
+
.subscribe((event) => {
|
334
|
+
const key = event.key?.toLowerCase();
|
335
|
+
/* istanbul ignore else */
|
336
|
+
if (key === 'escape' && this.isOpen) {
|
337
|
+
this.#closePicker();
|
338
|
+
}
|
339
|
+
});
|
340
|
+
}
|
341
|
+
#removePickerEventListeners() {
|
342
|
+
/* istanbul ignore else */
|
343
|
+
if (this.#timepickerUnsubscribe) {
|
344
|
+
this.#timepickerUnsubscribe.next();
|
345
|
+
this.#timepickerUnsubscribe.complete();
|
346
|
+
this.#timepickerUnsubscribe = new Subject();
|
347
|
+
}
|
348
|
+
/* istanbul ignore next */
|
349
|
+
this.#overlayKeydownListener?.unsubscribe();
|
350
|
+
}
|
351
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", 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 }, { token: SKY_STACKING_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
352
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", 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)=\"onCloseButtonClick()\"\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-timepicker-container .sky-timepicker-column ol li button.sky-btn-active:hover,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active{background-color:var(--sky-background-color-input-selected)}.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 }); }
|
353
|
+
}
|
354
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyTimepickerComponent, decorators: [{
|
355
|
+
type: Component,
|
356
|
+
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)=\"onCloseButtonClick()\"\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-timepicker-container .sky-timepicker-column ol li button.sky-btn-active:hover,.sky-theme-modern .sky-timepicker-container .sky-timepicker-column ol .sky-btn-active{background-color:var(--sky-background-color-input-selected)}.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"] }]
|
357
|
+
}], ctorParameters: function () { return [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
|
358
|
+
type: Optional
|
359
|
+
}] }, { type: i3.SkyThemeService, decorators: [{
|
360
|
+
type: Optional
|
361
|
+
}] }, { type: undefined, decorators: [{
|
362
|
+
type: Optional
|
363
|
+
}, {
|
364
|
+
type: Inject,
|
365
|
+
args: [SKY_STACKING_CONTEXT]
|
366
|
+
}] }]; }, propDecorators: { selectedTimeChanged: [{
|
367
|
+
type: Output
|
368
|
+
}], timepickerRef: [{
|
369
|
+
type: ViewChild,
|
370
|
+
args: ['timepickerRef', {
|
371
|
+
read: ElementRef,
|
372
|
+
}]
|
373
|
+
}], timepickerTemplateRef: [{
|
374
|
+
type: ViewChild,
|
375
|
+
args: ['timepickerTemplateRef', {
|
376
|
+
read: TemplateRef,
|
377
|
+
}]
|
378
|
+
}], triggerButtonRef: [{
|
379
|
+
type: ViewChild,
|
380
|
+
args: ['triggerButtonRef', {
|
381
|
+
read: ElementRef,
|
382
|
+
}]
|
383
|
+
}], inputTemplateRef: [{
|
384
|
+
type: ViewChild,
|
385
|
+
args: ['inputTemplateRef', {
|
386
|
+
read: TemplateRef,
|
387
|
+
static: true,
|
388
|
+
}]
|
389
|
+
}], triggerButtonTemplateRef: [{
|
390
|
+
type: ViewChild,
|
391
|
+
args: ['triggerButtonTemplateRef', {
|
392
|
+
read: TemplateRef,
|
393
|
+
static: true,
|
394
|
+
}]
|
395
|
+
}] } });
|
396
|
+
//# 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  Inject,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n  SkyStackingContext,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport moment from 'moment';\nimport { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyTimepickerTimeFormatType } from './timepicker-time-format-type';\nimport { SkyTimepickerTimeOutput } from './timepicker-time-output';\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> =\n    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: SkyTimepickerTimeFormatType = '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 gauging 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  #overlayKeydownListener: 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  #zIndex: Observable<number> | undefined;\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    @Optional()\n    @Inject(SKY_STACKING_CONTEXT)\n    stackingContext?: SkyStackingContext\n  ) {\n    this.#affixService = affixService;\n    this.#changeDetector = changeDetector;\n    this.#coreAdapter = coreAdapter;\n    this.#overlayService = overlayService;\n    this.#zIndex = stackingContext?.zIndex;\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: SkyTimepickerTimeFormatType): 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 onCloseButtonClick(): 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      if (this.#zIndex) {\n        this.#zIndex\n          .pipe(takeUntil(this.#timepickerUnsubscribe))\n          .subscribe((zIndex) => {\n            overlay.componentRef.instance.zIndex = zIndex.toString(10);\n          });\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.#overlayKeydownListener = 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.#overlayKeydownListener?.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)=\"onCloseButtonClick()\"\n        >\n          {{ 'skyux_timepicker_close' | skyLibResources }}\n        </button>\n      </section>\n    </div>\n  </div>\n</ng-template>\n"]}
|