@skyux/datetime 7.0.0-beta.11 → 7.0.0-beta.13
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 +1532 -991
- package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +262 -204
- package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +11 -3
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +42 -38
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
- package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
- package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +7 -14
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +43 -20
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +28 -35
- package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +1 -1
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +223 -209
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +212 -220
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +117 -138
- package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +3 -3
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +61 -59
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +143 -137
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +123 -132
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +51 -49
- package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +52 -50
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +104 -88
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +105 -98
- package/fesm2015/skyux-datetime.mjs +1642 -1516
- package/fesm2015/skyux-datetime.mjs.map +1 -1
- package/fesm2020/skyux-datetime.mjs +1618 -1510
- package/fesm2020/skyux-datetime.mjs.map +1 -1
- package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
- package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
- package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
- package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
- package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
- package/lib/modules/datepicker/date-formatter.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
- package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
- package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
- package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
- package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
- package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
- package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
- package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
- package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
- package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
- package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
- package/package.json +8 -8
@@ -1,8 +1,9 @@
|
|
1
|
+
var _SkyTimepickerInputDirective_instances, _SkyTimepickerInputDirective__timeFormat, _SkyTimepickerInputDirective_modelValue_get, _SkyTimepickerInputDirective_modelValue_set, _SkyTimepickerInputDirective_control, _SkyTimepickerInputDirective__disabled, _SkyTimepickerInputDirective__modelValue, _SkyTimepickerInputDirective__skyTimepickerInput, _SkyTimepickerInputDirective_renderer, _SkyTimepickerInputDirective_elRef, _SkyTimepickerInputDirective_resourcesService, _SkyTimepickerInputDirective_changeDetector, _SkyTimepickerInputDirective_setInputValue, _SkyTimepickerInputDirective_formatter, _SkyTimepickerInputDirective_updateTimepickerInput, _SkyTimepickerInputDirective__onChange, _SkyTimepickerInputDirective__onTouched, _SkyTimepickerInputDirective__validatorChange;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { ChangeDetectorRef, Directive, ElementRef, HostListener, Input, Renderer2, forwardRef, } from '@angular/core';
|
2
4
|
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
3
5
|
import { SkyLibResourcesService } from '@skyux/i18n';
|
4
6
|
import moment from 'moment';
|
5
|
-
import { SkyTimepickerComponent } from './timepicker.component';
|
6
7
|
import * as i0 from "@angular/core";
|
7
8
|
import * as i1 from "@skyux/i18n";
|
8
9
|
const SKY_TIMEPICKER_VALUE_ACCESSOR = {
|
@@ -17,18 +18,31 @@ const SKY_TIMEPICKER_VALIDATOR = {
|
|
17
18
|
};
|
18
19
|
export class SkyTimepickerInputDirective {
|
19
20
|
constructor(renderer, elRef, resourcesService, changeDetector) {
|
20
|
-
this
|
21
|
-
this
|
22
|
-
this
|
23
|
-
this
|
24
|
-
this
|
25
|
-
|
26
|
-
this
|
21
|
+
_SkyTimepickerInputDirective_instances.add(this);
|
22
|
+
_SkyTimepickerInputDirective__timeFormat.set(this, 'hh');
|
23
|
+
_SkyTimepickerInputDirective_control.set(this, void 0);
|
24
|
+
_SkyTimepickerInputDirective__disabled.set(this, false);
|
25
|
+
_SkyTimepickerInputDirective__modelValue.set(this, void 0);
|
26
|
+
_SkyTimepickerInputDirective__skyTimepickerInput.set(this, void 0);
|
27
|
+
_SkyTimepickerInputDirective_renderer.set(this, void 0);
|
28
|
+
_SkyTimepickerInputDirective_elRef.set(this, void 0);
|
29
|
+
_SkyTimepickerInputDirective_resourcesService.set(this, void 0);
|
30
|
+
_SkyTimepickerInputDirective_changeDetector.set(this, void 0);
|
31
|
+
/* istanbul ignore next */
|
32
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any
|
33
|
+
_SkyTimepickerInputDirective__onChange.set(this, (_) => { });
|
34
|
+
/* istanbul ignore next */
|
27
35
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
28
|
-
this
|
36
|
+
_SkyTimepickerInputDirective__onTouched.set(this, () => { });
|
37
|
+
/* istanbul ignore next */
|
29
38
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
30
|
-
this
|
39
|
+
_SkyTimepickerInputDirective__validatorChange.set(this, () => { });
|
40
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_renderer, renderer, "f");
|
41
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_elRef, elRef, "f");
|
42
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_resourcesService, resourcesService, "f");
|
43
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_changeDetector, changeDetector, "f");
|
31
44
|
}
|
45
|
+
// TODO: In a future breaking change - grab the parent component through dependency injection and remove this setter.
|
32
46
|
/**
|
33
47
|
* Creates the timepicker input field and picker. Place this attribute on an `input` element,
|
34
48
|
* and wrap the input in a `sky-timepicker` component.
|
@@ -36,70 +50,59 @@ export class SkyTimepickerInputDirective {
|
|
36
50
|
* @required
|
37
51
|
*/
|
38
52
|
get skyTimepickerInput() {
|
39
|
-
return this
|
53
|
+
return __classPrivateFieldGet(this, _SkyTimepickerInputDirective__skyTimepickerInput, "f");
|
40
54
|
}
|
41
55
|
set skyTimepickerInput(value) {
|
42
|
-
this
|
43
|
-
this.
|
56
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__skyTimepickerInput, value, "f");
|
57
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "m", _SkyTimepickerInputDirective_updateTimepickerInput).call(this);
|
44
58
|
}
|
59
|
+
// TODO: In a future breaking change - make this more specific than "string"
|
45
60
|
/**
|
46
61
|
* Specifies the 12-hour `hh` or 24-hour `HH` time format for the input.
|
47
62
|
* @default "hh"
|
48
63
|
*/
|
49
64
|
set timeFormat(value) {
|
50
|
-
this
|
65
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__timeFormat, value || 'hh', "f");
|
51
66
|
}
|
52
67
|
get timeFormat() {
|
53
|
-
return this
|
68
|
+
return __classPrivateFieldGet(this, _SkyTimepickerInputDirective__timeFormat, "f");
|
54
69
|
}
|
55
70
|
/**
|
56
71
|
* Indicates whether to disable the timepicker.
|
57
72
|
* @default false
|
58
73
|
*/
|
59
74
|
get disabled() {
|
60
|
-
return this
|
75
|
+
return __classPrivateFieldGet(this, _SkyTimepickerInputDirective__disabled, "f");
|
61
76
|
}
|
62
77
|
set disabled(value) {
|
63
|
-
this
|
64
|
-
this.
|
65
|
-
this.
|
66
|
-
}
|
67
|
-
get modelValue() {
|
68
|
-
return this._modelValue;
|
69
|
-
}
|
70
|
-
set modelValue(value) {
|
71
|
-
if (value !== this._modelValue) {
|
72
|
-
this._modelValue = value;
|
73
|
-
this.updateTimepickerInput();
|
74
|
-
this.setInputValue(value);
|
75
|
-
this._validatorChange();
|
76
|
-
this._onChange(value);
|
77
|
-
}
|
78
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__disabled, value || false, "f");
|
79
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "m", _SkyTimepickerInputDirective_updateTimepickerInput).call(this);
|
80
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_renderer, "f").setProperty(__classPrivateFieldGet(this, _SkyTimepickerInputDirective_elRef, "f").nativeElement, 'disabled', value);
|
78
81
|
}
|
79
82
|
ngOnInit() {
|
80
|
-
this.
|
83
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_renderer, "f").addClass(__classPrivateFieldGet(this, _SkyTimepickerInputDirective_elRef, "f").nativeElement, 'sky-form-control');
|
81
84
|
this.pickerChangedSubscription =
|
82
|
-
this.skyTimepickerInput
|
85
|
+
this.skyTimepickerInput?.selectedTimeChanged.subscribe((newTime) => {
|
83
86
|
this.writeValue(newTime);
|
84
|
-
this.
|
87
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective__onTouched, "f").call(this);
|
85
88
|
});
|
86
89
|
/* istanbul ignore else */
|
87
|
-
if (!this.
|
88
|
-
this
|
90
|
+
if (!__classPrivateFieldGet(this, _SkyTimepickerInputDirective_elRef, "f").nativeElement.getAttribute('aria-label')) {
|
91
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_resourcesService, "f")
|
89
92
|
.getString('skyux_timepicker_input_default_label')
|
90
93
|
.subscribe((value) => {
|
91
|
-
this.
|
94
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_renderer, "f").setAttribute(__classPrivateFieldGet(this, _SkyTimepickerInputDirective_elRef, "f").nativeElement, 'aria-label', value);
|
92
95
|
});
|
93
96
|
}
|
94
97
|
}
|
95
98
|
ngAfterContentInit() {
|
96
99
|
// Watch for the control to be added and initialize the value immediately.
|
97
100
|
/* istanbul ignore else */
|
98
|
-
if (this
|
99
|
-
this.
|
101
|
+
if (__classPrivateFieldGet(this, _SkyTimepickerInputDirective_control, "f") && __classPrivateFieldGet(this, _SkyTimepickerInputDirective_control, "f").parent) {
|
102
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_control, "f").setValue(__classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "a", _SkyTimepickerInputDirective_modelValue_get), {
|
100
103
|
emitEvent: false,
|
101
104
|
});
|
102
|
-
this.
|
105
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_changeDetector, "f").markForCheck();
|
103
106
|
}
|
104
107
|
}
|
105
108
|
ngOnDestroy() {
|
@@ -109,38 +112,40 @@ export class SkyTimepickerInputDirective {
|
|
109
112
|
}
|
110
113
|
}
|
111
114
|
ngOnChanges() {
|
112
|
-
this.skyTimepickerInput
|
113
|
-
|
115
|
+
if (this.skyTimepickerInput) {
|
116
|
+
this.skyTimepickerInput.setFormat(this.timeFormat);
|
117
|
+
this.skyTimepickerInput.returnFormat = this.returnFormat;
|
118
|
+
}
|
114
119
|
}
|
115
120
|
onChange(event) {
|
116
121
|
this.writeValue(event.target.value);
|
117
122
|
}
|
118
123
|
/* istanbul ignore next */
|
119
124
|
onBlur() {
|
120
|
-
this.
|
125
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective__onTouched, "f").call(this);
|
121
126
|
}
|
122
127
|
registerOnChange(fn) {
|
123
|
-
this
|
128
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__onChange, fn, "f");
|
124
129
|
}
|
125
130
|
registerOnTouched(fn) {
|
126
|
-
this
|
131
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__onTouched, fn, "f");
|
127
132
|
}
|
128
133
|
registerOnValidatorChange(fn) {
|
129
|
-
this
|
134
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__validatorChange, fn, "f");
|
130
135
|
}
|
131
136
|
setDisabledState(isDisabled) {
|
132
137
|
this.disabled = isDisabled;
|
133
138
|
}
|
134
139
|
writeValue(value) {
|
135
|
-
this
|
140
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_instances, __classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "m", _SkyTimepickerInputDirective_formatter).call(this, value), "a", _SkyTimepickerInputDirective_modelValue_set);
|
136
141
|
}
|
137
142
|
validate(control) {
|
138
|
-
if (!this
|
139
|
-
this
|
143
|
+
if (!__classPrivateFieldGet(this, _SkyTimepickerInputDirective_control, "f")) {
|
144
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective_control, control, "f");
|
140
145
|
}
|
141
146
|
const value = control.value;
|
142
147
|
if (!value) {
|
143
|
-
return
|
148
|
+
return null;
|
144
149
|
}
|
145
150
|
/* istanbul ignore next */
|
146
151
|
if (value.local === 'Invalid date') {
|
@@ -150,59 +155,61 @@ export class SkyTimepickerInputDirective {
|
|
150
155
|
},
|
151
156
|
};
|
152
157
|
}
|
153
|
-
return
|
154
|
-
}
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
158
|
+
return null;
|
159
|
+
}
|
160
|
+
}
|
161
|
+
_SkyTimepickerInputDirective__timeFormat = new WeakMap(), _SkyTimepickerInputDirective_control = new WeakMap(), _SkyTimepickerInputDirective__disabled = new WeakMap(), _SkyTimepickerInputDirective__modelValue = new WeakMap(), _SkyTimepickerInputDirective__skyTimepickerInput = new WeakMap(), _SkyTimepickerInputDirective_renderer = new WeakMap(), _SkyTimepickerInputDirective_elRef = new WeakMap(), _SkyTimepickerInputDirective_resourcesService = new WeakMap(), _SkyTimepickerInputDirective_changeDetector = new WeakMap(), _SkyTimepickerInputDirective__onChange = new WeakMap(), _SkyTimepickerInputDirective__onTouched = new WeakMap(), _SkyTimepickerInputDirective__validatorChange = new WeakMap(), _SkyTimepickerInputDirective_instances = new WeakSet(), _SkyTimepickerInputDirective_modelValue_get = function _SkyTimepickerInputDirective_modelValue_get() {
|
162
|
+
return __classPrivateFieldGet(this, _SkyTimepickerInputDirective__modelValue, "f");
|
163
|
+
}, _SkyTimepickerInputDirective_modelValue_set = function _SkyTimepickerInputDirective_modelValue_set(value) {
|
164
|
+
if (value !== __classPrivateFieldGet(this, _SkyTimepickerInputDirective__modelValue, "f")) {
|
165
|
+
__classPrivateFieldSet(this, _SkyTimepickerInputDirective__modelValue, value, "f");
|
166
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "m", _SkyTimepickerInputDirective_updateTimepickerInput).call(this);
|
167
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "m", _SkyTimepickerInputDirective_setInputValue).call(this, value);
|
168
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective__validatorChange, "f").call(this);
|
169
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective__onChange, "f").call(this, value);
|
170
|
+
}
|
171
|
+
}, _SkyTimepickerInputDirective_setInputValue = function _SkyTimepickerInputDirective_setInputValue(value) {
|
172
|
+
let formattedValue = '';
|
173
|
+
if (value) {
|
174
|
+
const output = moment(value).format(value.customFormat);
|
175
|
+
/* istanbul ignore else */
|
176
|
+
if (output !== 'Invalid date') {
|
177
|
+
formattedValue = output;
|
163
178
|
}
|
164
|
-
this.renderer.setProperty(this.elRef.nativeElement, 'value', formattedValue);
|
165
179
|
}
|
166
|
-
|
167
|
-
|
168
|
-
|
180
|
+
__classPrivateFieldGet(this, _SkyTimepickerInputDirective_renderer, "f").setProperty(__classPrivateFieldGet(this, _SkyTimepickerInputDirective_elRef, "f").nativeElement, 'value', formattedValue);
|
181
|
+
}, _SkyTimepickerInputDirective_formatter = function _SkyTimepickerInputDirective_formatter(time) {
|
182
|
+
if (time && typeof time !== 'string' && 'local' in time) {
|
183
|
+
return time;
|
184
|
+
}
|
185
|
+
if (typeof time === 'string') {
|
186
|
+
if (time.length === 0) {
|
187
|
+
return '';
|
169
188
|
}
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
}
|
174
|
-
let currentFormat;
|
175
|
-
if (this.timeFormat === 'hh') {
|
176
|
-
currentFormat = 'h:mm A';
|
177
|
-
}
|
178
|
-
if (this.timeFormat === 'HH') {
|
179
|
-
currentFormat = 'H:mm';
|
180
|
-
}
|
181
|
-
if (typeof this.returnFormat === 'undefined') {
|
182
|
-
this.returnFormat = currentFormat;
|
183
|
-
}
|
184
|
-
const formatTime = {
|
185
|
-
hour: moment(time, currentFormat).hour(),
|
186
|
-
minute: moment(time, currentFormat).minute(),
|
187
|
-
meridie: moment(time, currentFormat).format('A'),
|
188
|
-
timezone: parseInt(moment(time, currentFormat).format('Z'), 10),
|
189
|
-
iso8601: moment(time, currentFormat).toDate(),
|
190
|
-
local: moment(time, currentFormat).format(currentFormat),
|
191
|
-
customFormat: this.returnFormat,
|
192
|
-
};
|
193
|
-
return formatTime;
|
189
|
+
const currentFormat = this.timeFormat === 'HH' ? 'H:mm' : 'h:mm A';
|
190
|
+
if (typeof this.returnFormat === 'undefined') {
|
191
|
+
this.returnFormat = currentFormat;
|
194
192
|
}
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
193
|
+
const formatTime = {
|
194
|
+
hour: moment(time, currentFormat).hour(),
|
195
|
+
minute: moment(time, currentFormat).minute(),
|
196
|
+
meridie: moment(time, currentFormat).format('A'),
|
197
|
+
timezone: parseInt(moment(time, currentFormat).format('Z'), 10),
|
198
|
+
iso8601: moment(time, currentFormat).toDate(),
|
199
|
+
local: moment(time, currentFormat).format(currentFormat),
|
200
|
+
customFormat: this.returnFormat,
|
201
|
+
};
|
202
|
+
return formatTime;
|
203
|
+
}
|
204
|
+
}, _SkyTimepickerInputDirective_updateTimepickerInput = function _SkyTimepickerInputDirective_updateTimepickerInput() {
|
205
|
+
if (this.skyTimepickerInput) {
|
206
|
+
this.skyTimepickerInput.disabled = this.disabled;
|
207
|
+
/* istanbul ignore else */
|
208
|
+
if (this.skyTimepickerInput.selectedTime !== __classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "a", _SkyTimepickerInputDirective_modelValue_get)) {
|
209
|
+
this.skyTimepickerInput.selectedTime = __classPrivateFieldGet(this, _SkyTimepickerInputDirective_instances, "a", _SkyTimepickerInputDirective_modelValue_get);
|
203
210
|
}
|
204
211
|
}
|
205
|
-
}
|
212
|
+
};
|
206
213
|
SkyTimepickerInputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTimepickerInputDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.SkyLibResourcesService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
207
214
|
SkyTimepickerInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: SkyTimepickerInputDirective, selector: "[skyTimepickerInput]", inputs: { skyTimepickerInput: "skyTimepickerInput", timeFormat: "timeFormat", returnFormat: "returnFormat", disabled: "disabled" }, host: { listeners: { "change": "onChange($event)", "blur": "onBlur()" } }, providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR], usesOnChanges: true, ngImport: i0 });
|
208
215
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyTimepickerInputDirective, decorators: [{
|
@@ -226,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
226
233
|
type: HostListener,
|
227
234
|
args: ['blur']
|
228
235
|
}] } });
|
229
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  Validator,\n} from '@angular/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport moment from 'moment';\nimport { Subscription } from 'rxjs';\n\nimport { SkyTimepickerComponent } from './timepicker.component';\nimport { SkyTimepickerTimeOutput } from './timepicker.interface';\n\nconst SKY_TIMEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_TIMEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyTimepickerInput]',\n  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],\n})\nexport class SkyTimepickerInputDirective\n  implements\n    OnInit,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    OnChanges,\n    AfterContentInit\n{\n  public pickerChangedSubscription: Subscription;\n  private _timeFormat = 'hh';\n\n  /**\n   * Creates the timepicker input field and picker. Place this attribute on an `input` element,\n   * and wrap the input in a `sky-timepicker` component.\n   * This attribute must be set to the instance of the `sky-timepicker`.\n   * @required\n   */\n  @Input()\n  public get skyTimepickerInput(): SkyTimepickerComponent {\n    return this._skyTimepickerInput;\n  }\n\n  public set skyTimepickerInput(value: SkyTimepickerComponent) {\n    this._skyTimepickerInput = value;\n    this.updateTimepickerInput();\n  }\n\n  /**\n   * Specifies the 12-hour `hh` or 24-hour `HH` time format for the input.\n   * @default \"hh\"\n   */\n  @Input()\n  public set timeFormat(value: string) {\n    this._timeFormat = value;\n  }\n\n  public get timeFormat(): string {\n    return this._timeFormat || 'hh';\n  }\n\n  /**\n   * Specifies a custom time format. For examples,\n   * see the [moment.js](https://momentjs.com/docs/#/displaying/format/) docs.\n   */\n  @Input()\n  public returnFormat: string;\n\n  /**\n   * Indicates whether to disable the timepicker.\n   * @default false\n   */\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled || false;\n  }\n\n  public set disabled(value: boolean) {\n    this._disabled = value;\n\n    this.updateTimepickerInput();\n\n    this.renderer.setProperty(this.elRef.nativeElement, 'disabled', value);\n  }\n\n  private get modelValue(): SkyTimepickerTimeOutput {\n    return this._modelValue;\n  }\n\n  private set modelValue(value: SkyTimepickerTimeOutput) {\n    if (value !== this._modelValue) {\n      this._modelValue = value;\n      this.updateTimepickerInput();\n      this.setInputValue(value);\n      this._validatorChange();\n      this._onChange(value);\n    }\n  }\n\n  private control: AbstractControl;\n\n  private _disabled: boolean;\n  private _modelValue: SkyTimepickerTimeOutput;\n  private _skyTimepickerInput: SkyTimepickerComponent;\n\n  constructor(\n    private renderer: Renderer2,\n    private elRef: ElementRef,\n    private resourcesService: SkyLibResourcesService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit() {\n    this.renderer.addClass(this.elRef.nativeElement, 'sky-form-control');\n    this.pickerChangedSubscription =\n      this.skyTimepickerInput.selectedTimeChanged.subscribe(\n        (newTime: string) => {\n          this.writeValue(newTime);\n          this._onTouched();\n        }\n      );\n\n    /* istanbul ignore else */\n    if (!this.elRef.nativeElement.getAttribute('aria-label')) {\n      this.resourcesService\n        .getString('skyux_timepicker_input_default_label')\n        .subscribe((value: string) => {\n          this.renderer.setAttribute(\n            this.elRef.nativeElement,\n            'aria-label',\n            value\n          );\n        });\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    // Watch for the control to be added and initialize the value immediately.\n    /* istanbul ignore else */\n    if (this.control && this.control.parent) {\n      this.control.setValue(this.modelValue, {\n        emitEvent: false,\n      });\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy() {\n    /* istanbul ignore else */\n    if (this.pickerChangedSubscription) {\n      this.pickerChangedSubscription.unsubscribe();\n    }\n  }\n\n  public ngOnChanges() {\n    this.skyTimepickerInput.setFormat(this.timeFormat);\n    this.skyTimepickerInput.returnFormat = this.returnFormat;\n  }\n\n  @HostListener('change', ['$event'])\n  public onChange(event: any) {\n    this.writeValue(event.target.value);\n  }\n\n  /* istanbul ignore next */\n  @HostListener('blur')\n  public onBlur() {\n    this._onTouched();\n  }\n\n  public registerOnChange(fn: (value: any) => any): void {\n    this._onChange = fn;\n  }\n  public registerOnTouched(fn: () => any): void {\n    this._onTouched = fn;\n  }\n  public registerOnValidatorChange(fn: () => void): void {\n    this._validatorChange = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  public writeValue(value: any) {\n    this.modelValue = this.formatter(value);\n  }\n\n  public validate(control: AbstractControl): { [key: string]: any } {\n    if (!this.control) {\n      this.control = control;\n    }\n\n    const value = control.value;\n    if (!value) {\n      return undefined;\n    }\n\n    /* istanbul ignore next */\n    if (value.local === 'Invalid date') {\n      return {\n        skyTime: {\n          invalid: control.value,\n        },\n      };\n    }\n\n    return undefined;\n  }\n\n  private setInputValue(value: SkyTimepickerTimeOutput): void {\n    let formattedValue = '';\n    if (value) {\n      const output = moment(value).format(value.customFormat);\n      /* istanbul ignore else */\n      if (output !== 'Invalid date') {\n        formattedValue = output;\n      }\n    }\n\n    this.renderer.setProperty(\n      this.elRef.nativeElement,\n      'value',\n      formattedValue\n    );\n  }\n\n  private formatter(time: any) {\n    if (time && typeof time !== 'string' && 'local' in time) {\n      return time;\n    }\n    if (typeof time === 'string') {\n      if (time.length === 0) {\n        return '';\n      }\n      let currentFormat: string;\n      if (this.timeFormat === 'hh') {\n        currentFormat = 'h:mm A';\n      }\n      if (this.timeFormat === 'HH') {\n        currentFormat = 'H:mm';\n      }\n      if (typeof this.returnFormat === 'undefined') {\n        this.returnFormat = currentFormat;\n      }\n      const formatTime: SkyTimepickerTimeOutput = {\n        hour: moment(time, currentFormat).hour(),\n        minute: moment(time, currentFormat).minute(),\n        meridie: moment(time, currentFormat).format('A'),\n        timezone: parseInt(moment(time, currentFormat).format('Z'), 10),\n        iso8601: moment(time, currentFormat).toDate(),\n        local: moment(time, currentFormat).format(currentFormat),\n        customFormat: this.returnFormat,\n      };\n      return formatTime;\n    }\n  }\n\n  private updateTimepickerInput(): void {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.disabled = this.disabled;\n\n      /* istanbul ignore else */\n      if (this.skyTimepickerInput.selectedTime !== this.modelValue) {\n        this.skyTimepickerInput.selectedTime = this.modelValue;\n      }\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _onChange = (_: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _onTouched = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _validatorChange = () => {};\n}\n"]}
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport moment from 'moment';\nimport { Subscription } from 'rxjs';\n\nimport { SkyTimepickerComponent } from './timepicker.component';\nimport { SkyTimepickerTimeOutput } from './timepicker.interface';\n\nconst SKY_TIMEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_TIMEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyTimepickerInput]',\n  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],\n})\nexport class SkyTimepickerInputDirective\n  implements\n    OnInit,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    OnChanges,\n    AfterContentInit\n{\n  public pickerChangedSubscription: Subscription | undefined;\n  #_timeFormat = 'hh';\n\n  // TODO: In a future breaking change - grab the parent component through dependency injection and remove this setter.\n  /**\n   * Creates the timepicker input field and picker. Place this attribute on an `input` element,\n   * and wrap the input in a `sky-timepicker` component.\n   * This attribute must be set to the instance of the `sky-timepicker`.\n   * @required\n   */\n  @Input()\n  public get skyTimepickerInput(): SkyTimepickerComponent | undefined {\n    return this.#_skyTimepickerInput;\n  }\n\n  public set skyTimepickerInput(value: SkyTimepickerComponent | undefined) {\n    this.#_skyTimepickerInput = value;\n    this.#updateTimepickerInput();\n  }\n\n  // TODO: In a future breaking change - make this more specific than \"string\"\n  /**\n   * Specifies the 12-hour `hh` or 24-hour `HH` time format for the input.\n   * @default \"hh\"\n   */\n  @Input()\n  public set timeFormat(value: string | undefined) {\n    this.#_timeFormat = value || 'hh';\n  }\n\n  public get timeFormat(): string {\n    return this.#_timeFormat;\n  }\n\n  /**\n   * Specifies a custom time format. For examples,\n   * see the [moment.js](https://momentjs.com/docs/#/displaying/format/) docs.\n   */\n  @Input()\n  public returnFormat: string | undefined;\n\n  /**\n   * Indicates whether to disable the timepicker.\n   * @default false\n   */\n  @Input()\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value || false;\n\n    this.#updateTimepickerInput();\n\n    this.#renderer.setProperty(this.#elRef.nativeElement, 'disabled', value);\n  }\n\n  get #modelValue(): SkyTimepickerTimeOutput | undefined {\n    return this.#_modelValue;\n  }\n\n  set #modelValue(value: SkyTimepickerTimeOutput | undefined) {\n    if (value !== this.#_modelValue) {\n      this.#_modelValue = value;\n      this.#updateTimepickerInput();\n      this.#setInputValue(value);\n      this.#_validatorChange();\n      this.#_onChange(value);\n    }\n  }\n\n  #control: AbstractControl | undefined;\n\n  #_disabled = false;\n  #_modelValue: SkyTimepickerTimeOutput | undefined;\n  #_skyTimepickerInput: SkyTimepickerComponent | undefined;\n\n  #renderer: Renderer2;\n  #elRef: ElementRef;\n  #resourcesService: SkyLibResourcesService;\n  #changeDetector: ChangeDetectorRef;\n\n  constructor(\n    renderer: Renderer2,\n    elRef: ElementRef,\n    resourcesService: SkyLibResourcesService,\n    changeDetector: ChangeDetectorRef\n  ) {\n    this.#renderer = renderer;\n    this.#elRef = elRef;\n    this.#resourcesService = resourcesService;\n    this.#changeDetector = changeDetector;\n  }\n\n  public ngOnInit() {\n    this.#renderer.addClass(this.#elRef.nativeElement, 'sky-form-control');\n    this.pickerChangedSubscription =\n      this.skyTimepickerInput?.selectedTimeChanged.subscribe(\n        (newTime: string) => {\n          this.writeValue(newTime);\n          this.#_onTouched();\n        }\n      );\n\n    /* istanbul ignore else */\n    if (!this.#elRef.nativeElement.getAttribute('aria-label')) {\n      this.#resourcesService\n        .getString('skyux_timepicker_input_default_label')\n        .subscribe((value: string) => {\n          this.#renderer.setAttribute(\n            this.#elRef.nativeElement,\n            'aria-label',\n            value\n          );\n        });\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    // Watch for the control to be added and initialize the value immediately.\n    /* istanbul ignore else */\n    if (this.#control && this.#control.parent) {\n      this.#control.setValue(this.#modelValue, {\n        emitEvent: false,\n      });\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy() {\n    /* istanbul ignore else */\n    if (this.pickerChangedSubscription) {\n      this.pickerChangedSubscription.unsubscribe();\n    }\n  }\n\n  public ngOnChanges() {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.setFormat(this.timeFormat);\n      this.skyTimepickerInput.returnFormat = this.returnFormat;\n    }\n  }\n\n  @HostListener('change', ['$event'])\n  public onChange(event: any) {\n    this.writeValue(event.target.value);\n  }\n\n  /* istanbul ignore next */\n  @HostListener('blur')\n  public onBlur() {\n    this.#_onTouched();\n  }\n\n  public registerOnChange(fn: (value: any) => any): void {\n    this.#_onChange = fn;\n  }\n  public registerOnTouched(fn: () => any): void {\n    this.#_onTouched = fn;\n  }\n  public registerOnValidatorChange(fn: () => void): void {\n    this.#_validatorChange = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  public writeValue(value: any) {\n    this.#modelValue = this.#formatter(value);\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    const value = control.value;\n    if (!value) {\n      return null;\n    }\n\n    /* istanbul ignore next */\n    if (value.local === 'Invalid date') {\n      return {\n        skyTime: {\n          invalid: control.value,\n        },\n      };\n    }\n\n    return null;\n  }\n\n  #setInputValue(value: SkyTimepickerTimeOutput | undefined): void {\n    let formattedValue = '';\n    if (value) {\n      const output = moment(value).format(value.customFormat);\n      /* istanbul ignore else */\n      if (output !== 'Invalid date') {\n        formattedValue = output;\n      }\n    }\n\n    this.#renderer.setProperty(\n      this.#elRef.nativeElement,\n      'value',\n      formattedValue\n    );\n  }\n\n  #formatter(time: any) {\n    if (time && typeof time !== 'string' && 'local' in time) {\n      return time;\n    }\n    if (typeof time === 'string') {\n      if (time.length === 0) {\n        return '';\n      }\n      const currentFormat = this.timeFormat === 'HH' ? 'H:mm' : 'h:mm A';\n\n      if (typeof this.returnFormat === 'undefined') {\n        this.returnFormat = currentFormat;\n      }\n\n      const formatTime: SkyTimepickerTimeOutput = {\n        hour: moment(time, currentFormat).hour(),\n        minute: moment(time, currentFormat).minute(),\n        meridie: moment(time, currentFormat).format('A'),\n        timezone: parseInt(moment(time, currentFormat).format('Z'), 10),\n        iso8601: moment(time, currentFormat).toDate(),\n        local: moment(time, currentFormat).format(currentFormat),\n        customFormat: this.returnFormat,\n      };\n      return formatTime;\n    }\n  }\n\n  #updateTimepickerInput(): void {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.disabled = this.disabled;\n\n      /* istanbul ignore else */\n      if (this.skyTimepickerInput.selectedTime !== this.#modelValue) {\n        this.skyTimepickerInput.selectedTime = this.#modelValue;\n      }\n    }\n  }\n\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any\n  #_onChange = (_: any): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_onTouched = (): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_validatorChange = (): void => {};\n}\n"]}
|