@netwin/angular-datetime-picker 19.0.0-rc.3 → 19.0.0-rc.5
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/README.md +27 -1
- package/assets/style/picker.min.css +1 -1
- package/fesm2022/netwin-angular-datetime-picker.mjs +4178 -1486
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -1
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +19 -9
- package/lib/date-time/adapter/date-time-format.class.d.ts +12 -8
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +16 -5
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +3 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +15 -4
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +3 -0
- package/lib/date-time/calendar-body.component.d.ts +18 -13
- package/lib/date-time/calendar-month-view.component.d.ts +17 -12
- package/lib/date-time/calendar-multi-year-view.component.d.ts +12 -12
- package/lib/date-time/calendar-year-view.component.d.ts +7 -6
- package/lib/date-time/calendar.component.d.ts +37 -17
- package/lib/date-time/date-time-inline.component.d.ts +79 -156
- package/lib/date-time/date-time-picker-container.component.d.ts +131 -0
- package/lib/date-time/date-time-picker-input.directive.d.ts +172 -0
- package/lib/date-time/date-time-picker-intl.service.d.ts +6 -0
- package/lib/date-time/date-time-picker-trigger.directive.d.ts +23 -0
- package/lib/date-time/date-time-picker.animations.d.ts +8 -0
- package/lib/date-time/date-time-picker.component.d.ts +171 -0
- package/lib/date-time/date-time.class.d.ts +103 -0
- package/lib/date-time/date-time.module.d.ts +17 -11
- package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
- package/lib/date-time/timer-box.component.d.ts +4 -3
- package/lib/date-time/timer.component.d.ts +19 -16
- package/lib/dialog/dialog-config.class.d.ts +169 -0
- package/lib/dialog/dialog-container.component.d.ts +69 -0
- package/lib/dialog/dialog-ref.class.d.ts +51 -0
- package/lib/dialog/dialog.module.d.ts +11 -0
- package/lib/dialog/dialog.service.d.ts +76 -0
- package/lib/utils/index.d.ts +4 -0
- package/lib/utils/object.utils.d.ts +8 -0
- package/package.json +5 -7
- package/public_api.d.ts +16 -12
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +0 -114
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +0 -4
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +0 -238
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +0 -15
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +0 -42
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +0 -215
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +0 -15
- package/esm2022/lib/date-time/calendar-body.component.mjs +0 -137
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +0 -420
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +0 -360
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +0 -354
- package/esm2022/lib/date-time/calendar.component.mjs +0 -357
- package/esm2022/lib/date-time/date-time-inline.component.mjs +0 -463
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +0 -55
- package/esm2022/lib/date-time/date-time.module.mjs +0 -59
- package/esm2022/lib/date-time/options-provider.mjs +0 -34
- package/esm2022/lib/date-time/timer-box.component.mjs +0 -130
- package/esm2022/lib/date-time/timer.component.mjs +0 -280
- package/esm2022/lib/types/date-view.mjs +0 -19
- package/esm2022/lib/types/index.mjs +0 -4
- package/esm2022/lib/types/picker-type.mjs +0 -2
- package/esm2022/lib/types/select-mode.mjs +0 -2
- package/esm2022/lib/utils/array.utils.mjs +0 -5
- package/esm2022/lib/utils/constants.mjs +0 -31
- package/esm2022/lib/utils/date.utils.mjs +0 -46
- package/esm2022/netwin-angular-datetime-picker.mjs +0 -5
- package/esm2022/public_api.mjs +0 -23
- package/lib/types/date-view.d.ts +0 -17
- package/lib/types/index.d.ts +0 -3
- package/lib/types/picker-type.d.ts +0 -7
- package/lib/types/select-mode.d.ts +0 -8
|
@@ -1,463 +0,0 @@
|
|
|
1
|
-
import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, inject, Input, numberAttribute, Output } from '@angular/core';
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { DateView } from '../types';
|
|
4
|
-
import { DateTimeAdapter } from './adapter/date-time-adapter.class';
|
|
5
|
-
import { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';
|
|
6
|
-
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "./timer.component";
|
|
9
|
-
import * as i2 from "./calendar.component";
|
|
10
|
-
const OWL_DATETIME_VALUE_ACCESSOR = {
|
|
11
|
-
provide: NG_VALUE_ACCESSOR,
|
|
12
|
-
useExisting: forwardRef(() => OwlDateTimeInlineComponent),
|
|
13
|
-
multi: true
|
|
14
|
-
};
|
|
15
|
-
let nextUniqueComponentId = 0;
|
|
16
|
-
export class OwlDateTimeInlineComponent {
|
|
17
|
-
#changeDetector;
|
|
18
|
-
#pickerIntl;
|
|
19
|
-
#dateTimeFormats;
|
|
20
|
-
#dateTimeAdapter;
|
|
21
|
-
get firstDayOfWeek() {
|
|
22
|
-
return this._firstDayOfWeek;
|
|
23
|
-
}
|
|
24
|
-
set firstDayOfWeek(value) {
|
|
25
|
-
value = numberAttribute(value, undefined);
|
|
26
|
-
if (value > 6 || value < 0) {
|
|
27
|
-
this._firstDayOfWeek = undefined;
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
this._firstDayOfWeek = value;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
get formatOptions() {
|
|
34
|
-
if (this.pickerType === 'both') {
|
|
35
|
-
return this.#dateTimeFormats.fullPickerInput;
|
|
36
|
-
}
|
|
37
|
-
if (this.pickerType === 'calendar') {
|
|
38
|
-
return this.#dateTimeFormats.datePickerInput;
|
|
39
|
-
}
|
|
40
|
-
return this.#dateTimeFormats.timePickerInput;
|
|
41
|
-
}
|
|
42
|
-
getValidDate(obj) {
|
|
43
|
-
return this.#dateTimeAdapter.isDateInstance(obj) && this.#dateTimeAdapter.isValid(obj) ? obj : null;
|
|
44
|
-
}
|
|
45
|
-
get startAt() {
|
|
46
|
-
if (this._startAt) {
|
|
47
|
-
return this._startAt;
|
|
48
|
-
}
|
|
49
|
-
if (this.selectMode === 'single') {
|
|
50
|
-
return this.value || null;
|
|
51
|
-
}
|
|
52
|
-
else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {
|
|
53
|
-
return this.values[0] || null;
|
|
54
|
-
}
|
|
55
|
-
else if (this.selectMode === 'rangeTo') {
|
|
56
|
-
return this.values[1] || null;
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
return null;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
set startAt(date) {
|
|
63
|
-
this._startAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));
|
|
64
|
-
}
|
|
65
|
-
get endAt() {
|
|
66
|
-
if (this._endAt) {
|
|
67
|
-
return this._endAt;
|
|
68
|
-
}
|
|
69
|
-
if (this.selectMode === 'single') {
|
|
70
|
-
return this.value || null;
|
|
71
|
-
}
|
|
72
|
-
else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {
|
|
73
|
-
return this.values[1] || null;
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
return null;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
set endAt(date) {
|
|
80
|
-
this._endAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));
|
|
81
|
-
}
|
|
82
|
-
// TODO: remove this getter when `owlDateTimeFilter` is removed
|
|
83
|
-
get dateTimeFilterGetter() {
|
|
84
|
-
return this.dateTimeFilter || this.owlDateTimeFilter;
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* The minimum valid date.
|
|
88
|
-
*/
|
|
89
|
-
get min() {
|
|
90
|
-
return this._min || null;
|
|
91
|
-
}
|
|
92
|
-
set min(value) {
|
|
93
|
-
this._min = this.getValidDate(this.#dateTimeAdapter.deserialize(value));
|
|
94
|
-
this.#changeDetector.markForCheck();
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* The maximum valid date.
|
|
98
|
-
*/
|
|
99
|
-
get max() {
|
|
100
|
-
return this._max || null;
|
|
101
|
-
}
|
|
102
|
-
set max(value) {
|
|
103
|
-
this._max = this.getValidDate(this.#dateTimeAdapter.deserialize(value));
|
|
104
|
-
this.#changeDetector.markForCheck();
|
|
105
|
-
}
|
|
106
|
-
get value() {
|
|
107
|
-
return this._value;
|
|
108
|
-
}
|
|
109
|
-
set value(value) {
|
|
110
|
-
value = this.#dateTimeAdapter.deserialize(value);
|
|
111
|
-
value = this.getValidDate(value);
|
|
112
|
-
this._value = value;
|
|
113
|
-
this.selected = value;
|
|
114
|
-
}
|
|
115
|
-
get values() {
|
|
116
|
-
return this._values;
|
|
117
|
-
}
|
|
118
|
-
set values(values) {
|
|
119
|
-
if (values && values.length > 0) {
|
|
120
|
-
values = values.map((v) => {
|
|
121
|
-
v = this.#dateTimeAdapter.deserialize(v);
|
|
122
|
-
v = this.getValidDate(v);
|
|
123
|
-
return v ? this.#dateTimeAdapter.clone(v) : null;
|
|
124
|
-
});
|
|
125
|
-
this._values = [...values];
|
|
126
|
-
this.selecteds = [...values];
|
|
127
|
-
}
|
|
128
|
-
else {
|
|
129
|
-
this._values = [];
|
|
130
|
-
this.selecteds = [];
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
get selected() {
|
|
134
|
-
return this._selected;
|
|
135
|
-
}
|
|
136
|
-
set selected(value) {
|
|
137
|
-
this._selected = value;
|
|
138
|
-
this.#changeDetector.markForCheck();
|
|
139
|
-
}
|
|
140
|
-
get selecteds() {
|
|
141
|
-
return this._selecteds;
|
|
142
|
-
}
|
|
143
|
-
set selecteds(values) {
|
|
144
|
-
this._selecteds = values;
|
|
145
|
-
this.#changeDetector.markForCheck();
|
|
146
|
-
}
|
|
147
|
-
/**
|
|
148
|
-
* Returns whether the picker is in single mode
|
|
149
|
-
*/
|
|
150
|
-
get isInSingleMode() {
|
|
151
|
-
return this.selectMode === 'single';
|
|
152
|
-
}
|
|
153
|
-
/**
|
|
154
|
-
* Returns whether the picker is in range mode (range, rangeFrom, rangeTo)
|
|
155
|
-
*/
|
|
156
|
-
get isInRangeMode() {
|
|
157
|
-
return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* The range 'from' label
|
|
161
|
-
*/
|
|
162
|
-
get fromLabel() {
|
|
163
|
-
return this.#pickerIntl.rangeFromLabel;
|
|
164
|
-
}
|
|
165
|
-
/**
|
|
166
|
-
* The range 'to' label
|
|
167
|
-
*/
|
|
168
|
-
get toLabel() {
|
|
169
|
-
return this.#pickerIntl.rangeToLabel;
|
|
170
|
-
}
|
|
171
|
-
/**
|
|
172
|
-
* The range 'from' formatted value
|
|
173
|
-
*/
|
|
174
|
-
get fromFormattedValue() {
|
|
175
|
-
const value = this.selecteds[0];
|
|
176
|
-
return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';
|
|
177
|
-
}
|
|
178
|
-
/**
|
|
179
|
-
* The range 'to' formatted value
|
|
180
|
-
*/
|
|
181
|
-
get toFormattedValue() {
|
|
182
|
-
const value = this.selecteds[1];
|
|
183
|
-
return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';
|
|
184
|
-
}
|
|
185
|
-
constructor() {
|
|
186
|
-
this.#changeDetector = inject(ChangeDetectorRef);
|
|
187
|
-
this.#pickerIntl = inject(OwlDateTimeIntl);
|
|
188
|
-
this.#dateTimeFormats = inject(OWL_DATE_TIME_FORMATS, { optional: true });
|
|
189
|
-
this.#dateTimeAdapter = inject(DateTimeAdapter, { optional: true });
|
|
190
|
-
/**
|
|
191
|
-
* Whether the timer is in hour12 format
|
|
192
|
-
*/
|
|
193
|
-
this.hour12Timer = false;
|
|
194
|
-
/**
|
|
195
|
-
* The view that the calendar should start in.
|
|
196
|
-
*/
|
|
197
|
-
this.startView = DateView.MONTH;
|
|
198
|
-
/**
|
|
199
|
-
* Whether to should only the year and multi-year views.
|
|
200
|
-
*/
|
|
201
|
-
this.yearOnly = false;
|
|
202
|
-
/**
|
|
203
|
-
* Whether to should only the multi-year view.
|
|
204
|
-
*/
|
|
205
|
-
this.multiyearOnly = false;
|
|
206
|
-
/**
|
|
207
|
-
* Hours to change per step
|
|
208
|
-
*/
|
|
209
|
-
this.stepHour = 1;
|
|
210
|
-
/**
|
|
211
|
-
* Minutes to change per step
|
|
212
|
-
*/
|
|
213
|
-
this.stepMinute = 1;
|
|
214
|
-
/**
|
|
215
|
-
* Seconds to change per step
|
|
216
|
-
*/
|
|
217
|
-
this.stepSecond = 1;
|
|
218
|
-
/**
|
|
219
|
-
* Whether to hide dates in other months at the start or end of the current month.
|
|
220
|
-
*/
|
|
221
|
-
this.hideOtherMonths = false;
|
|
222
|
-
/**
|
|
223
|
-
* Date Time Checker to check if the give dateTime is selectable
|
|
224
|
-
*/
|
|
225
|
-
this.dateTimeChecker = (dateTime) => {
|
|
226
|
-
return (!!dateTime &&
|
|
227
|
-
(!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&
|
|
228
|
-
(!this.min || this.#dateTimeAdapter.compare(dateTime, this.min) >= 0) &&
|
|
229
|
-
(!this.max || this.#dateTimeAdapter.compare(dateTime, this.max) <= 0));
|
|
230
|
-
};
|
|
231
|
-
/**
|
|
232
|
-
* Set the {@link PickerType} of the dateTime picker
|
|
233
|
-
*/
|
|
234
|
-
this.pickerType = 'both';
|
|
235
|
-
/**
|
|
236
|
-
* Whether the picker is disabled or not
|
|
237
|
-
*/
|
|
238
|
-
this.disabled = false;
|
|
239
|
-
/**
|
|
240
|
-
* Whether to show the second's timer
|
|
241
|
-
*/
|
|
242
|
-
this.showSecondsTimer = false;
|
|
243
|
-
/**
|
|
244
|
-
* Which select mode to use:
|
|
245
|
-
* - 'single'
|
|
246
|
-
* - 'range'
|
|
247
|
-
* - 'rangeFrom'
|
|
248
|
-
* - 'rangeTo'
|
|
249
|
-
*/
|
|
250
|
-
this.selectMode = 'single';
|
|
251
|
-
/**
|
|
252
|
-
* @deprecated use `dateTimeFilter` instead!
|
|
253
|
-
*/
|
|
254
|
-
this.owlDateTimeFilter = null;
|
|
255
|
-
this.dateTimeFilter = null;
|
|
256
|
-
this._values = [];
|
|
257
|
-
/**
|
|
258
|
-
* Emits selected year in multi-year view
|
|
259
|
-
* This doesn't imply a change on the selected date.
|
|
260
|
-
*/
|
|
261
|
-
this.yearSelected = new EventEmitter();
|
|
262
|
-
/**
|
|
263
|
-
* Emits selected month in year view
|
|
264
|
-
* This doesn't imply a change on the selected date.
|
|
265
|
-
*/
|
|
266
|
-
this.monthSelected = new EventEmitter();
|
|
267
|
-
/**
|
|
268
|
-
* Emits selected date
|
|
269
|
-
*/
|
|
270
|
-
this.dateSelected = new EventEmitter();
|
|
271
|
-
this.activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')
|
|
272
|
-
this._selecteds = [];
|
|
273
|
-
this.onModelChange = () => {
|
|
274
|
-
/* noop */
|
|
275
|
-
};
|
|
276
|
-
this.onModelTouched = () => {
|
|
277
|
-
/* noop */
|
|
278
|
-
};
|
|
279
|
-
if (!this.#dateTimeAdapter) {
|
|
280
|
-
throw Error(`OwlDateTimePicker: No provider found for DateTimeAdapter. You must import one of the following ` +
|
|
281
|
-
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
282
|
-
`custom implementation.`);
|
|
283
|
-
}
|
|
284
|
-
if (!this.#dateTimeFormats) {
|
|
285
|
-
throw Error(`OwlDateTimePicker: No provider found for OWL_DATE_TIME_FORMATS. You must import one of the following ` +
|
|
286
|
-
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
287
|
-
`custom implementation.`);
|
|
288
|
-
}
|
|
289
|
-
this.id = `owl-dt-picker-${nextUniqueComponentId++}`;
|
|
290
|
-
}
|
|
291
|
-
writeValue(value) {
|
|
292
|
-
if (this.isInSingleMode) {
|
|
293
|
-
this.selected = value;
|
|
294
|
-
this.value = this.selected;
|
|
295
|
-
}
|
|
296
|
-
else {
|
|
297
|
-
// Handle the case where the second selected date is before the first selected date
|
|
298
|
-
// In this case "go back" and treat the value as the first selected date
|
|
299
|
-
if (this.activeSelectedIndex === 1) {
|
|
300
|
-
if (this.selecteds[0] && value.getTime() < this.selecteds[0].getTime()) {
|
|
301
|
-
this.activeSelectedIndex = 0;
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
// Set the correct value according to the active selected index
|
|
305
|
-
if (this.activeSelectedIndex === 0) {
|
|
306
|
-
this.selecteds = [value, null];
|
|
307
|
-
}
|
|
308
|
-
else {
|
|
309
|
-
this.selecteds[1] = value;
|
|
310
|
-
}
|
|
311
|
-
// Set the values to the selecteds
|
|
312
|
-
this.values = [...this.selecteds];
|
|
313
|
-
this.activeSelectedIndex = (this.activeSelectedIndex + 1) % 2;
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
registerOnChange(fn) {
|
|
317
|
-
this.onModelChange = fn;
|
|
318
|
-
}
|
|
319
|
-
registerOnTouched(fn) {
|
|
320
|
-
this.onModelTouched = fn;
|
|
321
|
-
}
|
|
322
|
-
setDisabledState(isDisabled) {
|
|
323
|
-
this.disabled = isDisabled;
|
|
324
|
-
}
|
|
325
|
-
select(date) {
|
|
326
|
-
if (this.disabled) {
|
|
327
|
-
return;
|
|
328
|
-
}
|
|
329
|
-
if (Array.isArray(date)) {
|
|
330
|
-
this.values = [...date];
|
|
331
|
-
}
|
|
332
|
-
else {
|
|
333
|
-
this.value = date;
|
|
334
|
-
}
|
|
335
|
-
this.onModelChange(date);
|
|
336
|
-
this.onModelTouched();
|
|
337
|
-
}
|
|
338
|
-
/**
|
|
339
|
-
* Emits the selected year in multi-year view
|
|
340
|
-
*/
|
|
341
|
-
selectYear(normalizedYear) {
|
|
342
|
-
this.yearSelected.emit(normalizedYear);
|
|
343
|
-
}
|
|
344
|
-
/**
|
|
345
|
-
* Emits selected month in year view
|
|
346
|
-
*/
|
|
347
|
-
selectMonth(normalizedMonth) {
|
|
348
|
-
this.writeValue(normalizedMonth);
|
|
349
|
-
this.monthSelected.emit(normalizedMonth);
|
|
350
|
-
}
|
|
351
|
-
/**
|
|
352
|
-
* Emits the selected date
|
|
353
|
-
*/
|
|
354
|
-
selectDate(normalizedDate) {
|
|
355
|
-
this.writeValue(normalizedDate);
|
|
356
|
-
this.dateSelected.emit(normalizedDate);
|
|
357
|
-
}
|
|
358
|
-
/**
|
|
359
|
-
* Sets the active "selected" index in range mode.
|
|
360
|
-
* - 0 for 'from'
|
|
361
|
-
* - 1 for 'to'
|
|
362
|
-
*/
|
|
363
|
-
setActiveSelectedIndex(index) {
|
|
364
|
-
if (this.selectMode === 'range' && this.activeSelectedIndex !== index) {
|
|
365
|
-
this.activeSelectedIndex = index;
|
|
366
|
-
const selected = this.selecteds[this.activeSelectedIndex];
|
|
367
|
-
if (this.selecteds && selected) {
|
|
368
|
-
this.value = this.#dateTimeAdapter.clone(selected);
|
|
369
|
-
}
|
|
370
|
-
}
|
|
371
|
-
return;
|
|
372
|
-
}
|
|
373
|
-
/**
|
|
374
|
-
* Handle click on inform radio group
|
|
375
|
-
*/
|
|
376
|
-
handleKeydownOnInfoGroup(event, next, index) {
|
|
377
|
-
let handled = false;
|
|
378
|
-
switch (event.key) {
|
|
379
|
-
// Navigate between the radio group options with arrow keys
|
|
380
|
-
case 'ArrowDown':
|
|
381
|
-
case 'ArrowRight':
|
|
382
|
-
case 'ArrowUp':
|
|
383
|
-
case 'ArrowLeft':
|
|
384
|
-
next.focus();
|
|
385
|
-
this.setActiveSelectedIndex(index === 0 ? 1 : 0);
|
|
386
|
-
handled = true;
|
|
387
|
-
break;
|
|
388
|
-
// Select the active selected index when space is pressed
|
|
389
|
-
case ' ':
|
|
390
|
-
this.setActiveSelectedIndex(index);
|
|
391
|
-
handled = true;
|
|
392
|
-
break;
|
|
393
|
-
}
|
|
394
|
-
if (handled) {
|
|
395
|
-
event.preventDefault();
|
|
396
|
-
event.stopPropagation();
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeInlineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
400
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.10", type: OwlDateTimeInlineComponent, selector: "owl-date-time-inline", inputs: { hour12Timer: ["hour12Timer", "hour12Timer", booleanAttribute], startView: "startView", yearOnly: ["yearOnly", "yearOnly", booleanAttribute], multiyearOnly: ["multiyearOnly", "multiyearOnly", booleanAttribute], stepHour: "stepHour", stepMinute: "stepMinute", stepSecond: "stepSecond", firstDayOfWeek: "firstDayOfWeek", hideOtherMonths: ["hideOtherMonths", "hideOtherMonths", booleanAttribute], pickerType: "pickerType", disabled: ["disabled", "disabled", booleanAttribute], showSecondsTimer: ["showSecondsTimer", "showSecondsTimer", booleanAttribute], selectMode: "selectMode", startAt: "startAt", endAt: "endAt", owlDateTimeFilter: "owlDateTimeFilter", dateTimeFilter: "dateTimeFilter", min: "min", max: "max", value: "value", values: "values" }, outputs: { yearSelected: "yearSelected", monthSelected: "monthSelected", dateSelected: "dateSelected" }, host: { properties: { "class.owl-dt-container-disabled": "disabled" }, classAttribute: "owl-dt-inline owl-dt-container owl-dt-inline-container" }, providers: [OWL_DATETIME_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"owl-dt-container-inner\">\n @if (pickerType === 'both' || pickerType === 'calendar') {\n <owl-date-time-calendar\n [dateFilter]=\"dateTimeFilterGetter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"max\"\n [minDate]=\"min\"\n [multiyearOnly]=\"multiyearOnly\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [startView]=\"startView\"\n [yearOnly]=\"yearOnly\"\n [(pickerMoment)]=\"value\"\n (dateClicked)=\"selectDate($event)\"\n (monthSelected)=\"selectMonth($event)\"\n (selectedChange)=\"select($event)\"\n (yearSelected)=\"selectYear($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-calendar>\n }\n\n @if (pickerType === 'both' || pickerType === 'timer') {\n <owl-date-time-timer\n [hour12Timer]=\"hour12Timer\"\n [maxDateTime]=\"max\"\n [minDateTime]=\"min\"\n [pickerMoment]=\"value\"\n [showSecondsTimer]=\"showSecondsTimer\"\n [stepHour]=\"stepHour\"\n [stepMinute]=\"stepMinute\"\n [stepSecond]=\"stepSecond\"\n (selectedChange)=\"select($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-timer>\n }\n\n @if (isInRangeMode) {\n <div\n class=\"owl-dt-container-info owl-dt-container-row\"\n role=\"radiogroup\">\n <div\n #from\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n </span>\n </div>\n <div\n #to\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n </span>\n </div>\n </div>\n }\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: i1.OwlTimerComponent, selector: "owl-date-time-timer", inputs: ["pickerMoment", "minDateTime", "maxDateTime", "showSecondsTimer", "hour12Timer", "stepHour", "stepMinute", "stepSecond"], outputs: ["selectedChange"], exportAs: ["owlDateTimeTimer"] }, { kind: "component", type: i2.OwlCalendarComponent, selector: "owl-date-time-calendar", inputs: ["minDate", "maxDate", "pickerMoment", "selected", "selecteds", "dateFilter", "firstDayOfWeek", "selectMode", "startView", "yearOnly", "multiyearOnly", "hideOtherMonths"], outputs: ["pickerMomentChange", "dateClicked", "selectedChange", "yearSelected", "monthSelected"], exportAs: ["owlDateTimeCalendar"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
401
|
-
}
|
|
402
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeInlineComponent, decorators: [{
|
|
403
|
-
type: Component,
|
|
404
|
-
args: [{ selector: 'owl-date-time-inline', host: {
|
|
405
|
-
'[class.owl-dt-container-disabled]': 'disabled',
|
|
406
|
-
'class': 'owl-dt-inline owl-dt-container owl-dt-inline-container'
|
|
407
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, providers: [OWL_DATETIME_VALUE_ACCESSOR], template: "<div class=\"owl-dt-container-inner\">\n @if (pickerType === 'both' || pickerType === 'calendar') {\n <owl-date-time-calendar\n [dateFilter]=\"dateTimeFilterGetter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"max\"\n [minDate]=\"min\"\n [multiyearOnly]=\"multiyearOnly\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n [startView]=\"startView\"\n [yearOnly]=\"yearOnly\"\n [(pickerMoment)]=\"value\"\n (dateClicked)=\"selectDate($event)\"\n (monthSelected)=\"selectMonth($event)\"\n (selectedChange)=\"select($event)\"\n (yearSelected)=\"selectYear($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-calendar>\n }\n\n @if (pickerType === 'both' || pickerType === 'timer') {\n <owl-date-time-timer\n [hour12Timer]=\"hour12Timer\"\n [maxDateTime]=\"max\"\n [minDateTime]=\"min\"\n [pickerMoment]=\"value\"\n [showSecondsTimer]=\"showSecondsTimer\"\n [stepHour]=\"stepHour\"\n [stepMinute]=\"stepMinute\"\n [stepSecond]=\"stepSecond\"\n (selectedChange)=\"select($event)\"\n class=\"owl-dt-container-row\">\n </owl-date-time-timer>\n }\n\n @if (isInRangeMode) {\n <div\n class=\"owl-dt-container-info owl-dt-container-row\"\n role=\"radiogroup\">\n <div\n #from\n [attr.aria-checked]=\"activeSelectedIndex === 0\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(0)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n </span>\n </div>\n <div\n #to\n [attr.aria-checked]=\"activeSelectedIndex === 1\"\n [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n (click)=\"setActiveSelectedIndex(1)\"\n (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n role=\"radio\">\n <span\n class=\"owl-dt-control-content owl-dt-container-range-content\"\n tabindex=\"-1\">\n <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n </span>\n </div>\n </div>\n }\n</div>\n" }]
|
|
408
|
-
}], ctorParameters: () => [], propDecorators: { hour12Timer: [{
|
|
409
|
-
type: Input,
|
|
410
|
-
args: [{ transform: booleanAttribute }]
|
|
411
|
-
}], startView: [{
|
|
412
|
-
type: Input
|
|
413
|
-
}], yearOnly: [{
|
|
414
|
-
type: Input,
|
|
415
|
-
args: [{ transform: booleanAttribute }]
|
|
416
|
-
}], multiyearOnly: [{
|
|
417
|
-
type: Input,
|
|
418
|
-
args: [{ transform: booleanAttribute }]
|
|
419
|
-
}], stepHour: [{
|
|
420
|
-
type: Input
|
|
421
|
-
}], stepMinute: [{
|
|
422
|
-
type: Input
|
|
423
|
-
}], stepSecond: [{
|
|
424
|
-
type: Input
|
|
425
|
-
}], firstDayOfWeek: [{
|
|
426
|
-
type: Input
|
|
427
|
-
}], hideOtherMonths: [{
|
|
428
|
-
type: Input,
|
|
429
|
-
args: [{ transform: booleanAttribute }]
|
|
430
|
-
}], pickerType: [{
|
|
431
|
-
type: Input
|
|
432
|
-
}], disabled: [{
|
|
433
|
-
type: Input,
|
|
434
|
-
args: [{ transform: booleanAttribute }]
|
|
435
|
-
}], showSecondsTimer: [{
|
|
436
|
-
type: Input,
|
|
437
|
-
args: [{ transform: booleanAttribute }]
|
|
438
|
-
}], selectMode: [{
|
|
439
|
-
type: Input
|
|
440
|
-
}], startAt: [{
|
|
441
|
-
type: Input
|
|
442
|
-
}], endAt: [{
|
|
443
|
-
type: Input
|
|
444
|
-
}], owlDateTimeFilter: [{
|
|
445
|
-
type: Input
|
|
446
|
-
}], dateTimeFilter: [{
|
|
447
|
-
type: Input
|
|
448
|
-
}], min: [{
|
|
449
|
-
type: Input
|
|
450
|
-
}], max: [{
|
|
451
|
-
type: Input
|
|
452
|
-
}], value: [{
|
|
453
|
-
type: Input
|
|
454
|
-
}], values: [{
|
|
455
|
-
type: Input
|
|
456
|
-
}], yearSelected: [{
|
|
457
|
-
type: Output
|
|
458
|
-
}], monthSelected: [{
|
|
459
|
-
type: Output
|
|
460
|
-
}], dateSelected: [{
|
|
461
|
-
type: Output
|
|
462
|
-
}] } });
|
|
463
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-inline.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/date-time-inline.component.ts","../../../../../projects/picker/src/lib/date-time/date-time-inline.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  numberAttribute,\n  Output,\n  Provider\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateView, PickerType, SelectMode } from '../types';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\n\nconst OWL_DATETIME_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => OwlDateTimeInlineComponent),\n  multi: true\n};\n\nlet nextUniqueComponentId = 0;\n\n@Component({\n  selector: 'owl-date-time-inline',\n  templateUrl: './date-time-inline.component.html',\n  styleUrls: ['./date-time-inline.component.scss'],\n  host: {\n    '[class.owl-dt-container-disabled]': 'disabled',\n    'class': 'owl-dt-inline owl-dt-container owl-dt-inline-container'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [OWL_DATETIME_VALUE_ACCESSOR]\n})\nexport class OwlDateTimeInlineComponent implements ControlValueAccessor {\n  public readonly id: string;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n\n  readonly #pickerIntl = inject(OwlDateTimeIntl);\n\n  readonly #dateTimeFormats = inject(OWL_DATE_TIME_FORMATS, { optional: true });\n\n  readonly #dateTimeAdapter = inject<DateTimeAdapter<Date>>(DateTimeAdapter, { optional: true });\n\n  /**\n   * Whether the timer is in hour12 format\n   */\n  @Input({ transform: booleanAttribute })\n  public hour12Timer = false;\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  public startView: DateView = DateView.MONTH;\n\n  /**\n   * Whether to should only the year and multi-year views.\n   */\n  @Input({ transform: booleanAttribute })\n  public yearOnly = false;\n\n  /**\n   * Whether to should only the multi-year view.\n   */\n  @Input({ transform: booleanAttribute })\n  public multiyearOnly = false;\n\n  /**\n   * Hours to change per step\n   */\n  @Input()\n  public stepHour: number = 1;\n\n  /**\n   * Minutes to change per step\n   */\n  @Input()\n  public stepMinute: number = 1;\n\n  /**\n   * Seconds to change per step\n   */\n  @Input()\n  public stepSecond: number = 1;\n\n  /**\n   * Set the first day of week.\n   * Has to be a number between 0 (Sunday) and 6 (Saturday)\n   */\n  private _firstDayOfWeek: number;\n  @Input()\n  public get firstDayOfWeek(): number {\n    return this._firstDayOfWeek;\n  }\n  public set firstDayOfWeek(value: number) {\n    value = numberAttribute(value, undefined);\n    if (value > 6 || value < 0) {\n      this._firstDayOfWeek = undefined;\n    } else {\n      this._firstDayOfWeek = value;\n    }\n  }\n\n  /**\n   * Whether to hide dates in other months at the start or end of the current month.\n   */\n\n  @Input({ transform: booleanAttribute })\n  public hideOtherMonths: boolean = false;\n\n  protected get formatOptions(): Intl.DateTimeFormatOptions {\n    if (this.pickerType === 'both') {\n      return this.#dateTimeFormats.fullPickerInput;\n    }\n\n    if (this.pickerType === 'calendar') {\n      return this.#dateTimeFormats.datePickerInput;\n    }\n\n    return this.#dateTimeFormats.timePickerInput;\n  }\n\n  /**\n   * Date Time Checker to check if the give dateTime is selectable\n   */\n  public dateTimeChecker = (dateTime: Date): boolean => {\n    return (\n      !!dateTime &&\n      (!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&\n      (!this.min || this.#dateTimeAdapter.compare(dateTime, this.min) >= 0) &&\n      (!this.max || this.#dateTimeAdapter.compare(dateTime, this.max) <= 0)\n    );\n  };\n\n  protected getValidDate(obj: unknown): Date | null {\n    return this.#dateTimeAdapter.isDateInstance(obj) && this.#dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n\n  /**\n   * Set the {@link PickerType} of the dateTime picker\n   */\n  @Input()\n  public pickerType: PickerType = 'both';\n\n  /**\n   * Whether the picker is disabled or not\n   */\n  @Input({ transform: booleanAttribute })\n  public disabled = false;\n\n  /**\n   * Whether to show the second's timer\n   */\n  @Input({ transform: booleanAttribute })\n  public showSecondsTimer = false;\n\n  /**\n   * Which select mode to use:\n   * - 'single'\n   * - 'range'\n   * - 'rangeFrom'\n   * - 'rangeTo'\n   */\n  @Input()\n  public selectMode: SelectMode = 'single';\n\n  /**\n   * The date to open the calendar to initially.\n   */\n  private _startAt: Date | null;\n  @Input()\n  public get startAt(): Date | null {\n    if (this._startAt) {\n      return this._startAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[0] || null;\n    } else if (this.selectMode === 'rangeTo') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n  public set startAt(date: Date | null) {\n    this._startAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));\n  }\n\n  /**\n   * The date to open for range calendar.\n   */\n  private _endAt: Date | null;\n  @Input()\n  public get endAt(): Date | null {\n    if (this._endAt) {\n      return this._endAt;\n    }\n\n    if (this.selectMode === 'single') {\n      return this.value || null;\n    } else if (this.selectMode === 'range' || this.selectMode === 'rangeFrom') {\n      return this.values[1] || null;\n    } else {\n      return null;\n    }\n  }\n  public set endAt(date: Date | null) {\n    this._endAt = this.getValidDate(this.#dateTimeAdapter.deserialize(date));\n  }\n\n  /**\n   * @deprecated use `dateTimeFilter` instead!\n   */\n  @Input()\n  public owlDateTimeFilter: ((date: Date | null) => boolean) | null = null;\n\n  @Input()\n  public dateTimeFilter: ((date: Date | null) => boolean) | null = null;\n\n  // TODO: remove this getter when `owlDateTimeFilter` is removed\n  protected get dateTimeFilterGetter(): ((date: Date | null) => boolean) | null {\n    return this.dateTimeFilter || this.owlDateTimeFilter;\n  }\n\n  private _min: Date | null;\n  /**\n   * The minimum valid date.\n   */\n  @Input()\n  public get min(): Date | null {\n    return this._min || null;\n  }\n  public set min(value: Date | null) {\n    this._min = this.getValidDate(this.#dateTimeAdapter.deserialize(value));\n    this.#changeDetector.markForCheck();\n  }\n\n  private _max: Date | null;\n  /**\n   * The maximum valid date.\n   */\n  @Input()\n  public get max(): Date | null {\n    return this._max || null;\n  }\n  public set max(value: Date | null) {\n    this._max = this.getValidDate(this.#dateTimeAdapter.deserialize(value));\n    this.#changeDetector.markForCheck();\n  }\n\n  private _value: Date | null;\n  @Input()\n  public get value(): Date | null {\n    return this._value;\n  }\n\n  public set value(value: Date | null) {\n    value = this.#dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n    this._value = value;\n    this.selected = value;\n  }\n\n  private _values: Array<Date> = [];\n  @Input()\n  public get values(): Array<Date> | null {\n    return this._values;\n  }\n  public set values(values: Array<Date>) {\n    if (values && values.length > 0) {\n      values = values.map((v) => {\n        v = this.#dateTimeAdapter.deserialize(v);\n        v = this.getValidDate(v);\n        return v ? this.#dateTimeAdapter.clone(v) : null;\n      });\n      this._values = [...values];\n      this.selecteds = [...values];\n    } else {\n      this._values = [];\n      this.selecteds = [];\n    }\n  }\n\n  /**\n   * Emits selected year in multi-year view\n   * This doesn't imply a change on the selected date.\n   */\n  @Output()\n  public readonly yearSelected = new EventEmitter<Date>();\n\n  /**\n   * Emits selected month in year view\n   * This doesn't imply a change on the selected date.\n   */\n  @Output()\n  public readonly monthSelected = new EventEmitter<Date>();\n\n  /**\n   * Emits selected date\n   */\n  @Output()\n  public readonly dateSelected = new EventEmitter<Date>();\n\n  protected activeSelectedIndex = 0; // The current active SelectedIndex in range select mode (0: 'from', 1: 'to')\n\n  private _selected: Date | null;\n  protected get selected(): Date | null {\n    return this._selected;\n  }\n  protected set selected(value: Date | null) {\n    this._selected = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  private _selecteds: Array<Date> = [];\n  protected get selecteds(): Array<Date> {\n    return this._selecteds;\n  }\n\n  protected set selecteds(values: Array<Date>) {\n    this._selecteds = values;\n    this.#changeDetector.markForCheck();\n  }\n\n  /**\n   * Returns whether the picker is in single mode\n   */\n  protected get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  /**\n   * Returns whether the picker is in range mode (range, rangeFrom, rangeTo)\n   */\n  protected get isInRangeMode(): boolean {\n    return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';\n  }\n\n  /**\n   * The range 'from' label\n   */\n  protected get fromLabel(): string {\n    return this.#pickerIntl.rangeFromLabel;\n  }\n\n  /**\n   * The range 'to' label\n   */\n  protected get toLabel(): string {\n    return this.#pickerIntl.rangeToLabel;\n  }\n\n  /**\n   * The range 'from' formatted value\n   */\n  protected get fromFormattedValue(): string {\n    const value = this.selecteds[0];\n    return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';\n  }\n\n  /**\n   * The range 'to' formatted value\n   */\n  protected get toFormattedValue(): string {\n    const value = this.selecteds[1];\n    return value ? this.#dateTimeAdapter.format(value, this.formatOptions) : '';\n  }\n\n  private onModelChange: (v: Date | Array<Date>) => void = () => {\n    /* noop */\n  };\n\n  private onModelTouched: () => void = () => {\n    /* noop */\n  };\n\n  constructor() {\n    if (!this.#dateTimeAdapter) {\n      throw Error(\n        `OwlDateTimePicker: No provider found for DateTimeAdapter. You must import one of the following ` +\n          `modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +\n          `custom implementation.`\n      );\n    }\n\n    if (!this.#dateTimeFormats) {\n      throw Error(\n        `OwlDateTimePicker: No provider found for OWL_DATE_TIME_FORMATS. You must import one of the following ` +\n          `modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +\n          `custom implementation.`\n      );\n    }\n\n    this.id = `owl-dt-picker-${nextUniqueComponentId++}`;\n  }\n\n  public writeValue(value: Date): void {\n    if (this.isInSingleMode) {\n      this.selected = value;\n      this.value = this.selected;\n    } else {\n      // Handle the case where the second selected date is before the first selected date\n      // In this case \"go back\" and treat the value as the first selected date\n      if (this.activeSelectedIndex === 1) {\n        if (this.selecteds[0] && value.getTime() < this.selecteds[0].getTime()) {\n          this.activeSelectedIndex = 0;\n        }\n      }\n\n      // Set the correct value according to the active selected index\n      if (this.activeSelectedIndex === 0) {\n        this.selecteds = [value, null];\n      } else {\n        this.selecteds[1] = value;\n      }\n\n      // Set the values to the selecteds\n      this.values = [...this.selecteds];\n      this.activeSelectedIndex = (this.activeSelectedIndex + 1) % 2;\n    }\n  }\n\n  public registerOnChange(fn: (v: Date | Array<Date>) => void): void {\n    this.onModelChange = fn;\n  }\n\n  public registerOnTouched(fn: () => void): void {\n    this.onModelTouched = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  public select(date: Array<Date> | Date): void {\n    if (this.disabled) {\n      return;\n    }\n\n    if (Array.isArray(date)) {\n      this.values = [...date];\n    } else {\n      this.value = date;\n    }\n    this.onModelChange(date);\n    this.onModelTouched();\n  }\n\n  /**\n   * Emits the selected year in multi-year view\n   */\n  public selectYear(normalizedYear: Date): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  /**\n   * Emits selected month in year view\n   */\n  public selectMonth(normalizedMonth: Date): void {\n    this.writeValue(normalizedMonth);\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Emits the selected date\n   */\n  public selectDate(normalizedDate: Date): void {\n    this.writeValue(normalizedDate);\n    this.dateSelected.emit(normalizedDate);\n  }\n\n  /**\n   * Sets the active \"selected\" index in range mode.\n   * - 0 for 'from'\n   * - 1 for 'to'\n   */\n  protected setActiveSelectedIndex(index: number): void {\n    if (this.selectMode === 'range' && this.activeSelectedIndex !== index) {\n      this.activeSelectedIndex = index;\n\n      const selected = this.selecteds[this.activeSelectedIndex];\n      if (this.selecteds && selected) {\n        this.value = this.#dateTimeAdapter.clone(selected);\n      }\n    }\n    return;\n  }\n\n  /**\n   * Handle click on inform radio group\n   */\n  protected handleKeydownOnInfoGroup(event: KeyboardEvent, next: HTMLElement, index: number): void {\n    let handled = false;\n\n    switch (event.key) {\n      // Navigate between the radio group options with arrow keys\n      case 'ArrowDown':\n      case 'ArrowRight':\n      case 'ArrowUp':\n      case 'ArrowLeft':\n        next.focus();\n        this.setActiveSelectedIndex(index === 0 ? 1 : 0);\n        handled = true;\n        break;\n\n      // Select the active selected index when space is pressed\n      case ' ':\n        this.setActiveSelectedIndex(index);\n        handled = true;\n        break;\n    }\n\n    if (handled) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n  }\n}\n","<div class=\"owl-dt-container-inner\">\n  @if (pickerType === 'both' || pickerType === 'calendar') {\n    <owl-date-time-calendar\n      [dateFilter]=\"dateTimeFilterGetter\"\n      [firstDayOfWeek]=\"firstDayOfWeek\"\n      [hideOtherMonths]=\"hideOtherMonths\"\n      [maxDate]=\"max\"\n      [minDate]=\"min\"\n      [multiyearOnly]=\"multiyearOnly\"\n      [selectMode]=\"selectMode\"\n      [selected]=\"selected\"\n      [selecteds]=\"selecteds\"\n      [startView]=\"startView\"\n      [yearOnly]=\"yearOnly\"\n      [(pickerMoment)]=\"value\"\n      (dateClicked)=\"selectDate($event)\"\n      (monthSelected)=\"selectMonth($event)\"\n      (selectedChange)=\"select($event)\"\n      (yearSelected)=\"selectYear($event)\"\n      class=\"owl-dt-container-row\">\n    </owl-date-time-calendar>\n  }\n\n  @if (pickerType === 'both' || pickerType === 'timer') {\n    <owl-date-time-timer\n      [hour12Timer]=\"hour12Timer\"\n      [maxDateTime]=\"max\"\n      [minDateTime]=\"min\"\n      [pickerMoment]=\"value\"\n      [showSecondsTimer]=\"showSecondsTimer\"\n      [stepHour]=\"stepHour\"\n      [stepMinute]=\"stepMinute\"\n      [stepSecond]=\"stepSecond\"\n      (selectedChange)=\"select($event)\"\n      class=\"owl-dt-container-row\">\n    </owl-date-time-timer>\n  }\n\n  @if (isInRangeMode) {\n    <div\n      class=\"owl-dt-container-info owl-dt-container-row\"\n      role=\"radiogroup\">\n      <div\n        #from\n        [attr.aria-checked]=\"activeSelectedIndex === 0\"\n        [class.owl-dt-container-info-active]=\"activeSelectedIndex === 0\"\n        [tabindex]=\"activeSelectedIndex === 0 ? 0 : -1\"\n        (click)=\"setActiveSelectedIndex(0)\"\n        (keydown)=\"handleKeydownOnInfoGroup($event, to, 0)\"\n        class=\"owl-dt-control owl-dt-container-range owl-dt-container-from\"\n        role=\"radio\">\n        <span\n          class=\"owl-dt-control-content owl-dt-container-range-content\"\n          tabindex=\"-1\">\n          <span class=\"owl-dt-container-info-label\">{{ fromLabel }}:</span>\n          <span class=\"owl-dt-container-info-value\">{{ fromFormattedValue }}</span>\n        </span>\n      </div>\n      <div\n        #to\n        [attr.aria-checked]=\"activeSelectedIndex === 1\"\n        [class.owl-dt-container-info-active]=\"activeSelectedIndex === 1\"\n        [tabindex]=\"activeSelectedIndex === 1 ? 0 : -1\"\n        (click)=\"setActiveSelectedIndex(1)\"\n        (keydown)=\"handleKeydownOnInfoGroup($event, from, 1)\"\n        class=\"owl-dt-control owl-dt-container-range owl-dt-container-to\"\n        role=\"radio\">\n        <span\n          class=\"owl-dt-control-content owl-dt-container-range-content\"\n          tabindex=\"-1\">\n          <span class=\"owl-dt-container-info-label\">{{ toLabel }}:</span>\n          <span class=\"owl-dt-container-info-value\">{{ toFormattedValue }}</span>\n        </span>\n      </div>\n    </div>\n  }\n</div>\n"]}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export class OwlDateTimeIntl {
|
|
5
|
-
constructor() {
|
|
6
|
-
/**
|
|
7
|
-
* Stream that emits whenever the labels here are changed. Use this to notify
|
|
8
|
-
* components if the labels have changed after initialization.
|
|
9
|
-
*/
|
|
10
|
-
this.changes = new Subject();
|
|
11
|
-
/** A label for the up second button (used by screen readers). */
|
|
12
|
-
this.upSecondLabel = 'Add a second';
|
|
13
|
-
/** A label for the down second button (used by screen readers). */
|
|
14
|
-
this.downSecondLabel = 'Minus a second';
|
|
15
|
-
/** A label for the up minute button (used by screen readers). */
|
|
16
|
-
this.upMinuteLabel = 'Add a minute';
|
|
17
|
-
/** A label for the down minute button (used by screen readers). */
|
|
18
|
-
this.downMinuteLabel = 'Minus a minute';
|
|
19
|
-
/** A label for the up hour button (used by screen readers). */
|
|
20
|
-
this.upHourLabel = 'Add a hour';
|
|
21
|
-
/** A label for the down hour button (used by screen readers). */
|
|
22
|
-
this.downHourLabel = 'Minus a hour';
|
|
23
|
-
/** A label for the previous month button (used by screen readers). */
|
|
24
|
-
this.prevMonthLabel = 'Previous month';
|
|
25
|
-
/** A label for the next month button (used by screen readers). */
|
|
26
|
-
this.nextMonthLabel = 'Next month';
|
|
27
|
-
/** A label for the previous year button (used by screen readers). */
|
|
28
|
-
this.prevYearLabel = 'Previous year';
|
|
29
|
-
/** A label for the next year button (used by screen readers). */
|
|
30
|
-
this.nextYearLabel = 'Next year';
|
|
31
|
-
/** A label for the previous multi-year button (used by screen readers). */
|
|
32
|
-
this.prevMultiYearLabel = 'Previous 21 years';
|
|
33
|
-
/** A label for the next multi-year button (used by screen readers). */
|
|
34
|
-
this.nextMultiYearLabel = 'Next 21 years';
|
|
35
|
-
/** A label for the 'switch to month view' button (used by screen readers). */
|
|
36
|
-
this.switchToMonthViewLabel = 'Change to month view';
|
|
37
|
-
/** A label for the 'switch to year view' button (used by screen readers). */
|
|
38
|
-
this.switchToMultiYearViewLabel = 'Choose month and year';
|
|
39
|
-
/** A label for the range 'from' in picker info */
|
|
40
|
-
this.rangeFromLabel = 'From';
|
|
41
|
-
/** A label for the range 'to' in picker info */
|
|
42
|
-
this.rangeToLabel = 'To';
|
|
43
|
-
/** A label for the hour12 button (AM) */
|
|
44
|
-
this.hour12AMLabel = 'AM';
|
|
45
|
-
/** A label for the hour12 button (PM) */
|
|
46
|
-
this.hour12PMLabel = 'PM';
|
|
47
|
-
}
|
|
48
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeIntl, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
49
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeIntl, providedIn: 'root' }); }
|
|
50
|
-
}
|
|
51
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlDateTimeIntl, decorators: [{
|
|
52
|
-
type: Injectable,
|
|
53
|
-
args: [{ providedIn: 'root' }]
|
|
54
|
-
}] });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLXBpY2tlci1pbnRsLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9waWNrZXIvc3JjL2xpYi9kYXRlLXRpbWUvZGF0ZS10aW1lLXBpY2tlci1pbnRsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQUcvQixNQUFNLE9BQU8sZUFBZTtJQUQ1QjtRQUVFOzs7V0FHRztRQUNNLFlBQU8sR0FBa0IsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUV0RCxrRUFBa0U7UUFDbEUsa0JBQWEsR0FBRyxjQUFjLENBQUM7UUFFL0Isb0VBQW9FO1FBQ3BFLG9CQUFlLEdBQUcsZ0JBQWdCLENBQUM7UUFFbkMsa0VBQWtFO1FBQ2xFLGtCQUFhLEdBQUcsY0FBYyxDQUFDO1FBRS9CLG9FQUFvRTtRQUNwRSxvQkFBZSxHQUFHLGdCQUFnQixDQUFDO1FBRW5DLGdFQUFnRTtRQUNoRSxnQkFBVyxHQUFHLFlBQVksQ0FBQztRQUUzQixrRUFBa0U7UUFDbEUsa0JBQWEsR0FBRyxjQUFjLENBQUM7UUFFL0Isc0VBQXNFO1FBQ3RFLG1CQUFjLEdBQUcsZ0JBQWdCLENBQUM7UUFFbEMsa0VBQWtFO1FBQ2xFLG1CQUFjLEdBQUcsWUFBWSxDQUFDO1FBRTlCLHFFQUFxRTtRQUNyRSxrQkFBYSxHQUFHLGVBQWUsQ0FBQztRQUVoQyxpRUFBaUU7UUFDakUsa0JBQWEsR0FBRyxXQUFXLENBQUM7UUFFNUIsMkVBQTJFO1FBQzNFLHVCQUFrQixHQUFHLG1CQUFtQixDQUFDO1FBRXpDLHVFQUF1RTtRQUN2RSx1QkFBa0IsR0FBRyxlQUFlLENBQUM7UUFFckMsOEVBQThFO1FBQzlFLDJCQUFzQixHQUFHLHNCQUFzQixDQUFDO1FBRWhELDZFQUE2RTtRQUM3RSwrQkFBMEIsR0FBRyx1QkFBdUIsQ0FBQztRQUVyRCxrREFBa0Q7UUFDbEQsbUJBQWMsR0FBRyxNQUFNLENBQUM7UUFFeEIsZ0RBQWdEO1FBQ2hELGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBRXBCLHlDQUF5QztRQUN6QyxrQkFBYSxHQUFHLElBQUksQ0FBQztRQUVyQix5Q0FBeUM7UUFDekMsa0JBQWEsR0FBRyxJQUFJLENBQUM7S0FDdEI7K0dBNURZLGVBQWU7bUhBQWYsZUFBZSxjQURGLE1BQU07OzRGQUNuQixlQUFlO2tCQUQzQixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBPd2xEYXRlVGltZUludGwge1xuICAvKipcbiAgICogU3RyZWFtIHRoYXQgZW1pdHMgd2hlbmV2ZXIgdGhlIGxhYmVscyBoZXJlIGFyZSBjaGFuZ2VkLiBVc2UgdGhpcyB0byBub3RpZnlcbiAgICogY29tcG9uZW50cyBpZiB0aGUgbGFiZWxzIGhhdmUgY2hhbmdlZCBhZnRlciBpbml0aWFsaXphdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IGNoYW5nZXM6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgdXAgc2Vjb25kIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICAqL1xuICB1cFNlY29uZExhYmVsID0gJ0FkZCBhIHNlY29uZCc7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBkb3duIHNlY29uZCBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAgKi9cbiAgZG93blNlY29uZExhYmVsID0gJ01pbnVzIGEgc2Vjb25kJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIHVwIG1pbnV0ZSBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAgKi9cbiAgdXBNaW51dGVMYWJlbCA9ICdBZGQgYSBtaW51dGUnO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgZG93biBtaW51dGUgYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gICovXG4gIGRvd25NaW51dGVMYWJlbCA9ICdNaW51cyBhIG1pbnV0ZSc7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSB1cCBob3VyIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICAqL1xuICB1cEhvdXJMYWJlbCA9ICdBZGQgYSBob3VyJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIGRvd24gaG91ciBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAgKi9cbiAgZG93bkhvdXJMYWJlbCA9ICdNaW51cyBhIGhvdXInO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgcHJldmlvdXMgbW9udGggYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgcHJldk1vbnRoTGFiZWwgPSAnUHJldmlvdXMgbW9udGgnO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgbmV4dCBtb250aCBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBuZXh0TW9udGhMYWJlbCA9ICdOZXh0IG1vbnRoJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIHByZXZpb3VzIHllYXIgYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgcHJldlllYXJMYWJlbCA9ICdQcmV2aW91cyB5ZWFyJztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlIG5leHQgeWVhciBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBuZXh0WWVhckxhYmVsID0gJ05leHQgeWVhcic7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBwcmV2aW91cyBtdWx0aS15ZWFyIGJ1dHRvbiAodXNlZCBieSBzY3JlZW4gcmVhZGVycykuICovXG4gIHByZXZNdWx0aVllYXJMYWJlbCA9ICdQcmV2aW91cyAyMSB5ZWFycyc7XG5cbiAgLyoqIEEgbGFiZWwgZm9yIHRoZSBuZXh0IG11bHRpLXllYXIgYnV0dG9uICh1c2VkIGJ5IHNjcmVlbiByZWFkZXJzKS4gKi9cbiAgbmV4dE11bHRpWWVhckxhYmVsID0gJ05leHQgMjEgeWVhcnMnO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgJ3N3aXRjaCB0byBtb250aCB2aWV3JyBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBzd2l0Y2hUb01vbnRoVmlld0xhYmVsID0gJ0NoYW5nZSB0byBtb250aCB2aWV3JztcblxuICAvKiogQSBsYWJlbCBmb3IgdGhlICdzd2l0Y2ggdG8geWVhciB2aWV3JyBidXR0b24gKHVzZWQgYnkgc2NyZWVuIHJlYWRlcnMpLiAqL1xuICBzd2l0Y2hUb011bHRpWWVhclZpZXdMYWJlbCA9ICdDaG9vc2UgbW9udGggYW5kIHllYXInO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgcmFuZ2UgJ2Zyb20nIGluIHBpY2tlciBpbmZvICovXG4gIHJhbmdlRnJvbUxhYmVsID0gJ0Zyb20nO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgcmFuZ2UgJ3RvJyBpbiBwaWNrZXIgaW5mbyAqL1xuICByYW5nZVRvTGFiZWwgPSAnVG8nO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgaG91cjEyIGJ1dHRvbiAoQU0pICovXG4gIGhvdXIxMkFNTGFiZWwgPSAnQU0nO1xuXG4gIC8qKiBBIGxhYmVsIGZvciB0aGUgaG91cjEyIGJ1dHRvbiAoUE0pICovXG4gIGhvdXIxMlBNTGFiZWwgPSAnUE0nO1xufVxuIl19
|