@skyux/datetime 5.9.4 → 6.0.0-beta.10
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/documentation.json +709 -790
- package/esm2020/index.mjs +31 -0
- package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +46 -0
- package/esm2020/lib/modules/date-pipe/date-pipe.module.mjs +21 -0
- package/esm2020/lib/modules/date-pipe/date.pipe.mjs +65 -0
- package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +437 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +47 -0
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +97 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculation.mjs +2 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +2 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +2 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +118 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +23 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +2 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +53 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +2 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +147 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range-relative-value.mjs +249 -0
- package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +2 -0
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +38 -0
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +33 -0
- package/esm2020/lib/modules/datepicker/datepicker-calendar-change.mjs +2 -0
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +310 -0
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +104 -0
- package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +21 -0
- package/esm2020/lib/modules/datepicker/datepicker-custom-date.mjs +2 -0
- package/esm2020/lib/modules/datepicker/datepicker-date.mjs +2 -0
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +464 -0
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +488 -0
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +328 -0
- package/esm2020/lib/modules/datepicker/datepicker.module.mjs +95 -0
- package/esm2020/lib/modules/datepicker/datepicker.service.mjs +21 -0
- package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +22 -0
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +126 -0
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +211 -0
- package/esm2020/lib/modules/datepicker/fuzzy-date.mjs +2 -0
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +402 -0
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +80 -0
- package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +86 -0
- package/esm2020/lib/modules/shared/sky-datetime-resources.module.mjs +131 -0
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +361 -0
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +226 -0
- package/esm2020/lib/modules/timepicker/timepicker.interface.mjs +2 -0
- package/esm2020/lib/modules/timepicker/timepicker.module.mjs +46 -0
- package/esm2020/skyux-datetime.mjs +5 -0
- package/esm2020/testing/datepicker-fixture.mjs +53 -0
- package/esm2020/testing/public-api.mjs +3 -0
- package/esm2020/testing/skyux-datetime-testing.mjs +5 -0
- package/esm2020/testing/timepicker-fixture.mjs +50 -0
- package/fesm2015/{skyux-datetime-testing.js → skyux-datetime-testing.mjs} +1 -2
- package/fesm2015/skyux-datetime-testing.mjs.map +1 -0
- package/fesm2015/skyux-datetime.mjs +4752 -0
- package/fesm2015/skyux-datetime.mjs.map +1 -0
- package/{esm2015/testing/datepicker-fixture.js → fesm2020/skyux-datetime-testing.mjs} +57 -3
- package/fesm2020/skyux-datetime-testing.mjs.map +1 -0
- package/{fesm2015/skyux-datetime.js → fesm2020/skyux-datetime.mjs} +196 -218
- package/fesm2020/skyux-datetime.mjs.map +1 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +2 -6
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +11 -0
- package/package.json +42 -18
- package/testing/package.json +5 -5
- package/bundles/skyux-datetime-testing.umd.js +0 -143
- package/bundles/skyux-datetime.umd.js +0 -5488
- package/esm2015/index.js +0 -31
- package/esm2015/index.js.map +0 -1
- package/esm2015/lib/modules/date-pipe/date-format-utility.js +0 -46
- package/esm2015/lib/modules/date-pipe/date-format-utility.js.map +0 -1
- package/esm2015/lib/modules/date-pipe/date-pipe.module.js +0 -21
- package/esm2015/lib/modules/date-pipe/date-pipe.module.js.map +0 -1
- package/esm2015/lib/modules/date-pipe/date.pipe.js +0 -65
- package/esm2015/lib/modules/date-pipe/date.pipe.js.map +0 -1
- package/esm2015/lib/modules/date-pipe/fuzzy-date.pipe.js +0 -47
- package/esm2015/lib/modules/date-pipe/fuzzy-date.pipe.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/date-range-picker.component.js +0 -453
- package/esm2015/lib/modules/date-range-picker/date-range-picker.component.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/date-range-picker.module.js +0 -47
- package/esm2015/lib/modules/date-range-picker/date-range-picker.module.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/date-range.service.js +0 -97
- package/esm2015/lib/modules/date-range-picker/date-range.service.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculation.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculation.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-config.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-config.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-id.js +0 -118
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-id.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-type.js +0 -23
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-type.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-validate-function.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator-validate-function.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator.js +0 -56
- package/esm2015/lib/modules/date-range-picker/types/date-range-calculator.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-default-calculator-config.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range-default-calculator-config.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-default-calculator-configs.js +0 -147
- package/esm2015/lib/modules/date-range-picker/types/date-range-default-calculator-configs.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range-relative-value.js +0 -249
- package/esm2015/lib/modules/date-range-picker/types/date-range-relative-value.js.map +0 -1
- package/esm2015/lib/modules/date-range-picker/types/date-range.js +0 -2
- package/esm2015/lib/modules/date-range-picker/types/date-range.js.map +0 -1
- package/esm2015/lib/modules/datepicker/date-formatter.js +0 -38
- package/esm2015/lib/modules/datepicker/date-formatter.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-adapter.service.js +0 -33
- package/esm2015/lib/modules/datepicker/datepicker-adapter.service.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-calendar-change.js +0 -2
- package/esm2015/lib/modules/datepicker/datepicker-calendar-change.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-calendar-inner.component.js +0 -315
- package/esm2015/lib/modules/datepicker/datepicker-calendar-inner.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-calendar.component.js +0 -109
- package/esm2015/lib/modules/datepicker/datepicker-calendar.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-config.service.js +0 -21
- package/esm2015/lib/modules/datepicker/datepicker-config.service.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-custom-date.js +0 -2
- package/esm2015/lib/modules/datepicker/datepicker-custom-date.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-date.js +0 -2
- package/esm2015/lib/modules/datepicker/datepicker-date.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-input-fuzzy.directive.js +0 -467
- package/esm2015/lib/modules/datepicker/datepicker-input-fuzzy.directive.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker-input.directive.js +0 -446
- package/esm2015/lib/modules/datepicker/datepicker-input.directive.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker.component.js +0 -333
- package/esm2015/lib/modules/datepicker/datepicker.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker.module.js +0 -95
- package/esm2015/lib/modules/datepicker/datepicker.module.js.map +0 -1
- package/esm2015/lib/modules/datepicker/datepicker.service.js +0 -21
- package/esm2015/lib/modules/datepicker/datepicker.service.js.map +0 -1
- package/esm2015/lib/modules/datepicker/daypicker-button.component.js +0 -26
- package/esm2015/lib/modules/datepicker/daypicker-button.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/daypicker-cell.component.js +0 -130
- package/esm2015/lib/modules/datepicker/daypicker-cell.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/daypicker.component.js +0 -215
- package/esm2015/lib/modules/datepicker/daypicker.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/fuzzy-date.js +0 -2
- package/esm2015/lib/modules/datepicker/fuzzy-date.js.map +0 -1
- package/esm2015/lib/modules/datepicker/fuzzy-date.service.js +0 -403
- package/esm2015/lib/modules/datepicker/fuzzy-date.service.js.map +0 -1
- package/esm2015/lib/modules/datepicker/monthpicker.component.js +0 -84
- package/esm2015/lib/modules/datepicker/monthpicker.component.js.map +0 -1
- package/esm2015/lib/modules/datepicker/yearpicker.component.js +0 -90
- package/esm2015/lib/modules/datepicker/yearpicker.component.js.map +0 -1
- package/esm2015/lib/modules/shared/sky-datetime-resources.module.js +0 -131
- package/esm2015/lib/modules/shared/sky-datetime-resources.module.js.map +0 -1
- package/esm2015/lib/modules/timepicker/timepicker.component.js +0 -367
- package/esm2015/lib/modules/timepicker/timepicker.component.js.map +0 -1
- package/esm2015/lib/modules/timepicker/timepicker.directive.js +0 -228
- package/esm2015/lib/modules/timepicker/timepicker.directive.js.map +0 -1
- package/esm2015/lib/modules/timepicker/timepicker.interface.js +0 -2
- package/esm2015/lib/modules/timepicker/timepicker.interface.js.map +0 -1
- package/esm2015/lib/modules/timepicker/timepicker.module.js +0 -46
- package/esm2015/lib/modules/timepicker/timepicker.module.js.map +0 -1
- package/esm2015/skyux-datetime.js +0 -5
- package/esm2015/skyux-datetime.js.map +0 -1
- package/esm2015/testing/datepicker-fixture.js.map +0 -1
- package/esm2015/testing/public-api.js +0 -3
- package/esm2015/testing/public-api.js.map +0 -1
- package/esm2015/testing/skyux-datetime-testing.js +0 -5
- package/esm2015/testing/skyux-datetime-testing.js.map +0 -1
- package/esm2015/testing/timepicker-fixture.js +0 -50
- package/esm2015/testing/timepicker-fixture.js.map +0 -1
- package/fesm2015/skyux-datetime-testing.js.map +0 -1
- package/fesm2015/skyux-datetime.js.map +0 -1
|
@@ -0,0 +1,361 @@
|
|
|
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';
|
|
5
|
+
import moment from 'moment';
|
|
6
|
+
import { Subject, fromEvent } from 'rxjs';
|
|
7
|
+
import { takeUntil } from 'rxjs/operators';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@skyux/core";
|
|
10
|
+
import * as i2 from "@skyux/forms";
|
|
11
|
+
import * as i3 from "@skyux/theme";
|
|
12
|
+
import * as i4 from "@skyux/indicators";
|
|
13
|
+
import * as i5 from "@angular/common";
|
|
14
|
+
import * as i6 from "@skyux/i18n";
|
|
15
|
+
let nextId = 0;
|
|
16
|
+
/**
|
|
17
|
+
* Creates a SKY UX-themed replacement for the HTML `input` element with `type="time"`.
|
|
18
|
+
* The value that users select is driven through the `ngModel` attribute
|
|
19
|
+
* specified on the `input` element. You must wrap this component around an `input`
|
|
20
|
+
* with the `skyTimepickerInput` directive.
|
|
21
|
+
*/
|
|
22
|
+
export class SkyTimepickerComponent {
|
|
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
|
+
this.inputBoxHostService = inputBoxHostService;
|
|
29
|
+
/**
|
|
30
|
+
* Fires when the value in the timepicker input changes.
|
|
31
|
+
*/
|
|
32
|
+
this.selectedTimeChanged = new EventEmitter();
|
|
33
|
+
this.is8601 = false;
|
|
34
|
+
this.timeFormat = 'hh';
|
|
35
|
+
this.ngUnsubscribe = new Subject();
|
|
36
|
+
const uniqueId = nextId++;
|
|
37
|
+
this.timepickerId = `sky-timepicker-${uniqueId}`;
|
|
38
|
+
this.triggerButtonId = `sky-timepicker-button-${uniqueId}`;
|
|
39
|
+
// Update icons when theme changes.
|
|
40
|
+
themeSvc?.settingsChange
|
|
41
|
+
.pipe(takeUntil(this.ngUnsubscribe))
|
|
42
|
+
.subscribe(() => {
|
|
43
|
+
this.changeDetector.markForCheck();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
set disabled(value) {
|
|
47
|
+
this._disabled = value;
|
|
48
|
+
this.changeDetector.markForCheck();
|
|
49
|
+
}
|
|
50
|
+
get disabled() {
|
|
51
|
+
return this._disabled;
|
|
52
|
+
}
|
|
53
|
+
set selectedHour(setHour) {
|
|
54
|
+
let hourOffset = 0;
|
|
55
|
+
if (this.selectedMeridies === 'AM' && setHour === 12) {
|
|
56
|
+
hourOffset = -12;
|
|
57
|
+
}
|
|
58
|
+
if (this.selectedMeridies === 'PM' && setHour !== 12) {
|
|
59
|
+
hourOffset = 12;
|
|
60
|
+
}
|
|
61
|
+
if (this.is8601) {
|
|
62
|
+
hourOffset = 0;
|
|
63
|
+
}
|
|
64
|
+
const hour = moment({ hour: setHour }).add(hourOffset, 'hours').hour();
|
|
65
|
+
this.activeTime = moment({
|
|
66
|
+
hour: hour,
|
|
67
|
+
minute: moment(this.activeTime).get('minute') + 0,
|
|
68
|
+
}).toDate();
|
|
69
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
|
70
|
+
}
|
|
71
|
+
get selectedHour() {
|
|
72
|
+
if (!this.is8601) {
|
|
73
|
+
/* istanbul ignore next */
|
|
74
|
+
return parseInt(moment(this.activeTime).format('h'), 0) || 1;
|
|
75
|
+
}
|
|
76
|
+
/* istanbul ignore else */
|
|
77
|
+
if (this.is8601) {
|
|
78
|
+
return moment(this.activeTime).hour() + 0;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
set selectedMeridies(meridies) {
|
|
82
|
+
/* istanbul ignore else */
|
|
83
|
+
if (!this.is8601) {
|
|
84
|
+
if (meridies.trim() !== this.selectedMeridies) {
|
|
85
|
+
this.activeTime = moment(this.activeTime).add(12, 'hours').toDate();
|
|
86
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
get selectedMeridies() {
|
|
91
|
+
if (this.activeTime) {
|
|
92
|
+
return moment(this.activeTime).format('A');
|
|
93
|
+
}
|
|
94
|
+
return '';
|
|
95
|
+
}
|
|
96
|
+
set selectedMinute(minute) {
|
|
97
|
+
this.activeTime = moment({
|
|
98
|
+
hour: moment(this.activeTime).get('hour') + 0,
|
|
99
|
+
minute: minute,
|
|
100
|
+
}).toDate();
|
|
101
|
+
this.selectedTimeChanged.emit(this.selectedTime);
|
|
102
|
+
}
|
|
103
|
+
get selectedMinute() {
|
|
104
|
+
return moment(this.activeTime).minute() + 0;
|
|
105
|
+
}
|
|
106
|
+
set selectedTime(newTime) {
|
|
107
|
+
if (typeof newTime !== 'undefined') {
|
|
108
|
+
/* sanity check */
|
|
109
|
+
/* istanbul ignore else */
|
|
110
|
+
if (newTime.local !== 'Invalid date') {
|
|
111
|
+
this.activeTime = newTime.iso8601;
|
|
112
|
+
this.changeDetector.markForCheck();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
get selectedTime() {
|
|
117
|
+
const time = {
|
|
118
|
+
hour: moment(this.activeTime).hour(),
|
|
119
|
+
minute: moment(this.activeTime).minute(),
|
|
120
|
+
meridie: moment(this.activeTime).format('A'),
|
|
121
|
+
timezone: parseInt(moment(this.activeTime).format('Z'), 10),
|
|
122
|
+
iso8601: this.activeTime,
|
|
123
|
+
local: moment(this.activeTime).format(this.localeFormat),
|
|
124
|
+
customFormat: typeof this.returnFormat !== 'undefined'
|
|
125
|
+
? this.returnFormat
|
|
126
|
+
: this.localeFormat,
|
|
127
|
+
};
|
|
128
|
+
return time;
|
|
129
|
+
}
|
|
130
|
+
set timepickerRef(value) {
|
|
131
|
+
if (value) {
|
|
132
|
+
this._timepickerRef = value;
|
|
133
|
+
// Wait for the timepicker component to render before guaging dimensions.
|
|
134
|
+
setTimeout(() => {
|
|
135
|
+
this.destroyAffixer();
|
|
136
|
+
this.createAffixer();
|
|
137
|
+
setTimeout(() => {
|
|
138
|
+
this.coreAdapter.getFocusableChildrenAndApplyFocus(this.timepickerRef, '.sky-timepicker-content', false);
|
|
139
|
+
this.isVisible = true;
|
|
140
|
+
this.changeDetector.markForCheck();
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
get timepickerRef() {
|
|
146
|
+
return this._timepickerRef;
|
|
147
|
+
}
|
|
148
|
+
ngOnInit() {
|
|
149
|
+
this.setFormat(this.timeFormat);
|
|
150
|
+
this.addKeydownListner();
|
|
151
|
+
if (this.inputBoxHostService) {
|
|
152
|
+
this.inputBoxHostService.populate({
|
|
153
|
+
inputTemplate: this.inputTemplateRef,
|
|
154
|
+
buttonsTemplate: this.triggerButtonTemplateRef,
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
ngOnDestroy() {
|
|
159
|
+
this.ngUnsubscribe.next();
|
|
160
|
+
this.ngUnsubscribe.complete();
|
|
161
|
+
this.removePickerEventListeners();
|
|
162
|
+
this.destroyAffixer();
|
|
163
|
+
this.destroyOverlay();
|
|
164
|
+
}
|
|
165
|
+
setFormat(format) {
|
|
166
|
+
let h = 12;
|
|
167
|
+
let m = 12;
|
|
168
|
+
let minuteMultiplier = 5;
|
|
169
|
+
let localeFormat = 'h:mm A';
|
|
170
|
+
if (format === 'hh') {
|
|
171
|
+
h = 12;
|
|
172
|
+
m = 12;
|
|
173
|
+
minuteMultiplier = 5;
|
|
174
|
+
localeFormat = 'h:mm A';
|
|
175
|
+
this.is8601 = false;
|
|
176
|
+
}
|
|
177
|
+
if (format === 'HH') {
|
|
178
|
+
h = 24;
|
|
179
|
+
m = 4;
|
|
180
|
+
minuteMultiplier = 15;
|
|
181
|
+
localeFormat = 'HH:mm';
|
|
182
|
+
this.is8601 = true;
|
|
183
|
+
}
|
|
184
|
+
const data = {
|
|
185
|
+
// Create a sparse array with a length equal to the hour.
|
|
186
|
+
hours: Array(...Array(h)).map((_, i) => {
|
|
187
|
+
if (format === 'hh') {
|
|
188
|
+
return ++i;
|
|
189
|
+
}
|
|
190
|
+
/* istanbul ignore else */
|
|
191
|
+
if (format === 'HH') {
|
|
192
|
+
return i;
|
|
193
|
+
}
|
|
194
|
+
/* istanbul ignore next */
|
|
195
|
+
/* sanity check */
|
|
196
|
+
return 0;
|
|
197
|
+
}),
|
|
198
|
+
// Create a sparse array with a length equal to the minute.
|
|
199
|
+
minutes: Array(...Array(m)).map(function (_, i) {
|
|
200
|
+
return i * minuteMultiplier;
|
|
201
|
+
}),
|
|
202
|
+
localeFormat: localeFormat,
|
|
203
|
+
minuteMultiplier: minuteMultiplier,
|
|
204
|
+
};
|
|
205
|
+
this.hours = data.hours;
|
|
206
|
+
this.minutes = data.minutes;
|
|
207
|
+
this.localeFormat = data.localeFormat;
|
|
208
|
+
this.minuteMultiplier = data.minuteMultiplier;
|
|
209
|
+
}
|
|
210
|
+
onCloseButtonCick() {
|
|
211
|
+
this.closePicker();
|
|
212
|
+
}
|
|
213
|
+
setTime(event) {
|
|
214
|
+
/* istanbul ignore else */
|
|
215
|
+
if (typeof event !== 'undefined') {
|
|
216
|
+
/* istanbul ignore else */
|
|
217
|
+
if (event.type === 'click') {
|
|
218
|
+
event.stopPropagation();
|
|
219
|
+
if (event.target.name === 'hour') {
|
|
220
|
+
this.selectedHour = parseInt(event.target.innerHTML, 0);
|
|
221
|
+
}
|
|
222
|
+
if (event.target.name === 'minute') {
|
|
223
|
+
this.selectedMinute = parseInt(event.target.innerHTML, 0);
|
|
224
|
+
}
|
|
225
|
+
if (event.target.name === 'meridie') {
|
|
226
|
+
this.selectedMeridies = event.target.innerHTML;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
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
|
+
}
|
|
251
|
+
createAffixer() {
|
|
252
|
+
const affixer = this.affixService.createAffixer(this.timepickerRef);
|
|
253
|
+
// Hide timepicker when trigger button is scrolled off screen.
|
|
254
|
+
affixer.placementChange
|
|
255
|
+
.pipe(takeUntil(this.timepickerUnsubscribe))
|
|
256
|
+
.subscribe((change) => {
|
|
257
|
+
this.isVisible = change.placement !== null;
|
|
258
|
+
this.changeDetector.markForCheck();
|
|
259
|
+
});
|
|
260
|
+
affixer.affixTo(this.triggerButtonRef.nativeElement, {
|
|
261
|
+
autoFitContext: SkyAffixAutoFitContext.Viewport,
|
|
262
|
+
enableAutoFit: true,
|
|
263
|
+
horizontalAlignment: 'right',
|
|
264
|
+
isSticky: true,
|
|
265
|
+
placement: 'below',
|
|
266
|
+
});
|
|
267
|
+
this.affixer = affixer;
|
|
268
|
+
}
|
|
269
|
+
destroyAffixer() {
|
|
270
|
+
/*istanbul ignore else*/
|
|
271
|
+
if (this.affixer) {
|
|
272
|
+
this.affixer.destroy();
|
|
273
|
+
this.affixer = undefined;
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
createOverlay() {
|
|
277
|
+
const overlay = this.overlayService.create({
|
|
278
|
+
enableClose: false,
|
|
279
|
+
enablePointerEvents: false,
|
|
280
|
+
});
|
|
281
|
+
overlay.backdropClick
|
|
282
|
+
.pipe(takeUntil(this.timepickerUnsubscribe))
|
|
283
|
+
.subscribe(() => {
|
|
284
|
+
/* istanbul ignore else */
|
|
285
|
+
if (this.isOpen) {
|
|
286
|
+
this.closePicker();
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
this.addKeydownListner();
|
|
290
|
+
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
|
+
}
|
|
299
|
+
}
|
|
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
|
+
}
|
|
311
|
+
removePickerEventListeners() {
|
|
312
|
+
/* istanbul ignore else */
|
|
313
|
+
if (this.timepickerUnsubscribe) {
|
|
314
|
+
this.timepickerUnsubscribe.next();
|
|
315
|
+
this.timepickerUnsubscribe.complete();
|
|
316
|
+
this.timepickerUnsubscribe = undefined;
|
|
317
|
+
}
|
|
318
|
+
/* istanbul ignore next */
|
|
319
|
+
this.overlayKeydownListner?.unsubscribe();
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
SkyTimepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", 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: "12.0.0", version: "13.3.2", 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"], components: [{ type: i4.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "skyLibResources": i6.SkyLibResourcesPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
324
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: SkyTimepickerComponent, decorators: [{
|
|
325
|
+
type: Component,
|
|
326
|
+
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
|
+
}], ctorParameters: function () { return [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
|
|
328
|
+
type: Optional
|
|
329
|
+
}] }, { type: i3.SkyThemeService, decorators: [{
|
|
330
|
+
type: Optional
|
|
331
|
+
}] }]; }, propDecorators: { selectedTimeChanged: [{
|
|
332
|
+
type: Output
|
|
333
|
+
}], timepickerRef: [{
|
|
334
|
+
type: ViewChild,
|
|
335
|
+
args: ['timepickerRef', {
|
|
336
|
+
read: ElementRef,
|
|
337
|
+
}]
|
|
338
|
+
}], timepickerTemplateRef: [{
|
|
339
|
+
type: ViewChild,
|
|
340
|
+
args: ['timepickerTemplateRef', {
|
|
341
|
+
read: TemplateRef,
|
|
342
|
+
}]
|
|
343
|
+
}], triggerButtonRef: [{
|
|
344
|
+
type: ViewChild,
|
|
345
|
+
args: ['triggerButtonRef', {
|
|
346
|
+
read: ElementRef,
|
|
347
|
+
}]
|
|
348
|
+
}], inputTemplateRef: [{
|
|
349
|
+
type: ViewChild,
|
|
350
|
+
args: ['inputTemplateRef', {
|
|
351
|
+
read: TemplateRef,
|
|
352
|
+
static: true,
|
|
353
|
+
}]
|
|
354
|
+
}], triggerButtonTemplateRef: [{
|
|
355
|
+
type: ViewChild,
|
|
356
|
+
args: ['triggerButtonTemplateRef', {
|
|
357
|
+
read: TemplateRef,
|
|
358
|
+
static: true,
|
|
359
|
+
}]
|
|
360
|
+
}] } });
|
|
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":"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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    }\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"]}
|