@netwin/angular-datetime-picker 18.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/README.md +225 -0
  2. package/assets/style/picker.min.css +1 -0
  3. package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +121 -0
  4. package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
  5. package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +261 -0
  6. package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +10 -0
  7. package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +39 -0
  8. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +235 -0
  9. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +10 -0
  10. package/esm2022/lib/date-time/calendar-body.component.mjs +147 -0
  11. package/esm2022/lib/date-time/calendar-month-view.component.mjs +451 -0
  12. package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +361 -0
  13. package/esm2022/lib/date-time/calendar-year-view.component.mjs +371 -0
  14. package/esm2022/lib/date-time/calendar.component.mjs +383 -0
  15. package/esm2022/lib/date-time/date-time-inline.component.mjs +296 -0
  16. package/esm2022/lib/date-time/date-time-picker-container.component.mjs +420 -0
  17. package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +638 -0
  18. package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
  19. package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +69 -0
  20. package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
  21. package/esm2022/lib/date-time/date-time-picker.component.mjs +580 -0
  22. package/esm2022/lib/date-time/date-time.class.mjs +180 -0
  23. package/esm2022/lib/date-time/date-time.module.mjs +91 -0
  24. package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
  25. package/esm2022/lib/date-time/options-provider.mjs +34 -0
  26. package/esm2022/lib/date-time/timer-box.component.mjs +135 -0
  27. package/esm2022/lib/date-time/timer.component.mjs +292 -0
  28. package/esm2022/lib/dialog/dialog-config.class.mjs +56 -0
  29. package/esm2022/lib/dialog/dialog-container.component.mjs +230 -0
  30. package/esm2022/lib/dialog/dialog-ref.class.mjs +123 -0
  31. package/esm2022/lib/dialog/dialog.module.mjs +34 -0
  32. package/esm2022/lib/dialog/dialog.service.mjs +245 -0
  33. package/esm2022/lib/utils/array.utils.mjs +12 -0
  34. package/esm2022/lib/utils/constants.mjs +55 -0
  35. package/esm2022/lib/utils/date.utils.mjs +49 -0
  36. package/esm2022/lib/utils/index.mjs +5 -0
  37. package/esm2022/lib/utils/object.utils.mjs +26 -0
  38. package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
  39. package/esm2022/public_api.mjs +25 -0
  40. package/fesm2022/netwin-angular-datetime-picker.mjs +5913 -0
  41. package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
  42. package/index.d.ts +5 -0
  43. package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
  44. package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
  45. package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +69 -0
  46. package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
  47. package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
  48. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +64 -0
  49. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
  50. package/lib/date-time/calendar-body.component.d.ts +80 -0
  51. package/lib/date-time/calendar-month-view.component.d.ts +144 -0
  52. package/lib/date-time/calendar-multi-year-view.component.d.ts +111 -0
  53. package/lib/date-time/calendar-year-view.component.d.ts +123 -0
  54. package/lib/date-time/calendar.component.d.ts +155 -0
  55. package/lib/date-time/date-time-inline.component.d.ts +105 -0
  56. package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
  57. package/lib/date-time/date-time-picker-input.directive.d.ts +167 -0
  58. package/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
  59. package/lib/date-time/date-time-picker-trigger.directive.d.ts +24 -0
  60. package/lib/date-time/date-time-picker.animations.d.ts +8 -0
  61. package/lib/date-time/date-time-picker.component.d.ts +177 -0
  62. package/lib/date-time/date-time.class.d.ts +106 -0
  63. package/lib/date-time/date-time.module.d.ts +23 -0
  64. package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
  65. package/lib/date-time/options-provider.d.ts +23 -0
  66. package/lib/date-time/timer-box.component.d.ts +46 -0
  67. package/lib/date-time/timer.component.d.ts +132 -0
  68. package/lib/dialog/dialog-config.class.d.ts +169 -0
  69. package/lib/dialog/dialog-container.component.d.ts +59 -0
  70. package/lib/dialog/dialog-ref.class.d.ts +51 -0
  71. package/lib/dialog/dialog.module.d.ts +11 -0
  72. package/lib/dialog/dialog.service.d.ts +76 -0
  73. package/lib/utils/array.utils.d.ts +5 -0
  74. package/lib/utils/constants.d.ts +19 -0
  75. package/lib/utils/date.utils.d.ts +12 -0
  76. package/lib/utils/index.d.ts +4 -0
  77. package/lib/utils/object.utils.d.ts +11 -0
  78. package/package.json +51 -0
  79. package/public_api.d.ts +24 -0
@@ -0,0 +1,292 @@
1
+ /**
2
+ * timer.component
3
+ */
4
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Optional, Output } from '@angular/core';
5
+ import { take } from 'rxjs/operators';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./date-time-picker-intl.service";
8
+ import * as i2 from "./adapter/date-time-adapter.class";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "./timer-box.component";
11
+ export class OwlTimerComponent {
12
+ get pickerMoment() {
13
+ return this._pickerMoment;
14
+ }
15
+ set pickerMoment(value) {
16
+ value = this.dateTimeAdapter.deserialize(value);
17
+ this._pickerMoment =
18
+ this.getValidDate(value) || this.dateTimeAdapter.now();
19
+ }
20
+ get minDateTime() {
21
+ return this._minDateTime;
22
+ }
23
+ set minDateTime(value) {
24
+ value = this.dateTimeAdapter.deserialize(value);
25
+ this._minDateTime = this.getValidDate(value);
26
+ }
27
+ get maxDateTime() {
28
+ return this._maxDateTime;
29
+ }
30
+ set maxDateTime(value) {
31
+ value = this.dateTimeAdapter.deserialize(value);
32
+ this._maxDateTime = this.getValidDate(value);
33
+ }
34
+ get hourValue() {
35
+ return this.dateTimeAdapter.getHours(this.pickerMoment);
36
+ }
37
+ /**
38
+ * The value would be displayed in hourBox.
39
+ * We need this because the value displayed in hourBox it not
40
+ * the same as the hourValue when the timer is in hour12Timer mode.
41
+ * */
42
+ get hourBoxValue() {
43
+ let hours = this.hourValue;
44
+ if (!this.hour12Timer) {
45
+ return hours;
46
+ }
47
+ else {
48
+ if (hours === 0) {
49
+ hours = 12;
50
+ this.isPM = false;
51
+ }
52
+ else if (hours > 0 && hours < 12) {
53
+ this.isPM = false;
54
+ }
55
+ else if (hours === 12) {
56
+ this.isPM = true;
57
+ }
58
+ else if (hours > 12 && hours < 24) {
59
+ hours = hours - 12;
60
+ this.isPM = true;
61
+ }
62
+ return hours;
63
+ }
64
+ }
65
+ get minuteValue() {
66
+ return this.dateTimeAdapter.getMinutes(this.pickerMoment);
67
+ }
68
+ get secondValue() {
69
+ return this.dateTimeAdapter.getSeconds(this.pickerMoment);
70
+ }
71
+ get upHourButtonLabel() {
72
+ return this.pickerIntl.upHourLabel;
73
+ }
74
+ get downHourButtonLabel() {
75
+ return this.pickerIntl.downHourLabel;
76
+ }
77
+ get upMinuteButtonLabel() {
78
+ return this.pickerIntl.upMinuteLabel;
79
+ }
80
+ get downMinuteButtonLabel() {
81
+ return this.pickerIntl.downMinuteLabel;
82
+ }
83
+ get upSecondButtonLabel() {
84
+ return this.pickerIntl.upSecondLabel;
85
+ }
86
+ get downSecondButtonLabel() {
87
+ return this.pickerIntl.downSecondLabel;
88
+ }
89
+ get hour12ButtonLabel() {
90
+ return this.isPM
91
+ ? this.pickerIntl.hour12PMLabel
92
+ : this.pickerIntl.hour12AMLabel;
93
+ }
94
+ get owlDTTimerClass() {
95
+ return true;
96
+ }
97
+ get owlDTTimeTabIndex() {
98
+ return -1;
99
+ }
100
+ constructor(ngZone, elmRef, pickerIntl, cdRef, dateTimeAdapter) {
101
+ this.ngZone = ngZone;
102
+ this.elmRef = elmRef;
103
+ this.pickerIntl = pickerIntl;
104
+ this.cdRef = cdRef;
105
+ this.dateTimeAdapter = dateTimeAdapter;
106
+ this.isPM = false; // a flag indicates the current timer moment is in PM or AM
107
+ /**
108
+ * Hours to change per step
109
+ */
110
+ this.stepHour = 1;
111
+ /**
112
+ * Minutes to change per step
113
+ */
114
+ this.stepMinute = 1;
115
+ /**
116
+ * Seconds to change per step
117
+ */
118
+ this.stepSecond = 1;
119
+ this.selectedChange = new EventEmitter();
120
+ }
121
+ ngOnInit() { }
122
+ /**
123
+ * Focus to the host element
124
+ * */
125
+ focus() {
126
+ this.ngZone.runOutsideAngular(() => {
127
+ this.ngZone.onStable
128
+ .asObservable()
129
+ .pipe(take(1))
130
+ .subscribe(() => {
131
+ this.elmRef.nativeElement.focus();
132
+ });
133
+ });
134
+ }
135
+ /**
136
+ * Set the hour value via typing into timer box input
137
+ * We need this to handle the hour value when the timer is in hour12 mode
138
+ * */
139
+ setHourValueViaInput(hours) {
140
+ if (this.hour12Timer && this.isPM && hours >= 1 && hours <= 11) {
141
+ hours = hours + 12;
142
+ }
143
+ else if (this.hour12Timer && !this.isPM && hours === 12) {
144
+ hours = 0;
145
+ }
146
+ this.setHourValue(hours);
147
+ }
148
+ setHourValue(hours) {
149
+ const m = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
150
+ this.selectedChange.emit(m);
151
+ this.cdRef.markForCheck();
152
+ }
153
+ setMinuteValue(minutes) {
154
+ const m = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
155
+ this.selectedChange.emit(m);
156
+ this.cdRef.markForCheck();
157
+ }
158
+ setSecondValue(seconds) {
159
+ const m = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
160
+ this.selectedChange.emit(m);
161
+ this.cdRef.markForCheck();
162
+ }
163
+ setMeridiem(event) {
164
+ this.isPM = !this.isPM;
165
+ let hours = this.hourValue;
166
+ if (this.isPM) {
167
+ hours = hours + 12;
168
+ }
169
+ else {
170
+ hours = hours - 12;
171
+ }
172
+ if (hours >= 0 && hours <= 23) {
173
+ this.setHourValue(hours);
174
+ }
175
+ this.cdRef.markForCheck();
176
+ event.preventDefault();
177
+ }
178
+ /**
179
+ * Check if the up hour button is enabled
180
+ */
181
+ upHourEnabled() {
182
+ return (!this.maxDateTime ||
183
+ this.compareHours(this.stepHour, this.maxDateTime) < 1);
184
+ }
185
+ /**
186
+ * Check if the down hour button is enabled
187
+ */
188
+ downHourEnabled() {
189
+ return (!this.minDateTime ||
190
+ this.compareHours(-this.stepHour, this.minDateTime) > -1);
191
+ }
192
+ /**
193
+ * Check if the up minute button is enabled
194
+ */
195
+ upMinuteEnabled() {
196
+ return (!this.maxDateTime ||
197
+ this.compareMinutes(this.stepMinute, this.maxDateTime) < 1);
198
+ }
199
+ /**
200
+ * Check if the down minute button is enabled
201
+ */
202
+ downMinuteEnabled() {
203
+ return (!this.minDateTime ||
204
+ this.compareMinutes(-this.stepMinute, this.minDateTime) > -1);
205
+ }
206
+ /**
207
+ * Check if the up second button is enabled
208
+ */
209
+ upSecondEnabled() {
210
+ return (!this.maxDateTime ||
211
+ this.compareSeconds(this.stepSecond, this.maxDateTime) < 1);
212
+ }
213
+ /**
214
+ * Check if the down second button is enabled
215
+ */
216
+ downSecondEnabled() {
217
+ return (!this.minDateTime ||
218
+ this.compareSeconds(-this.stepSecond, this.minDateTime) > -1);
219
+ }
220
+ /**
221
+ * PickerMoment's hour value +/- certain amount and compare it to the give date
222
+ * 1 is after the comparedDate
223
+ * -1 is before the comparedDate
224
+ * 0 is equal the comparedDate
225
+ * */
226
+ compareHours(amount, comparedDate) {
227
+ const hours = this.dateTimeAdapter.getHours(this.pickerMoment) + amount;
228
+ const result = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
229
+ return this.dateTimeAdapter.compare(result, comparedDate);
230
+ }
231
+ /**
232
+ * PickerMoment's minute value +/- certain amount and compare it to the give date
233
+ * 1 is after the comparedDate
234
+ * -1 is before the comparedDate
235
+ * 0 is equal the comparedDate
236
+ * */
237
+ compareMinutes(amount, comparedDate) {
238
+ const minutes = this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;
239
+ const result = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
240
+ return this.dateTimeAdapter.compare(result, comparedDate);
241
+ }
242
+ /**
243
+ * PickerMoment's second value +/- certain amount and compare it to the give date
244
+ * 1 is after the comparedDate
245
+ * -1 is before the comparedDate
246
+ * 0 is equal the comparedDate
247
+ * */
248
+ compareSeconds(amount, comparedDate) {
249
+ const seconds = this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;
250
+ const result = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
251
+ return this.dateTimeAdapter.compare(result, comparedDate);
252
+ }
253
+ /**
254
+ * Get a valid date object
255
+ */
256
+ getValidDate(obj) {
257
+ return this.dateTimeAdapter.isDateInstance(obj) &&
258
+ this.dateTimeAdapter.isValid(obj)
259
+ ? obj
260
+ : null;
261
+ }
262
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlTimerComponent, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i1.OwlDateTimeIntl }, { token: i0.ChangeDetectorRef }, { token: i2.DateTimeAdapter, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
263
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.3", type: OwlTimerComponent, selector: "owl-date-time-timer", inputs: { pickerMoment: "pickerMoment", minDateTime: "minDateTime", maxDateTime: "maxDateTime", showSecondsTimer: "showSecondsTimer", hour12Timer: "hour12Timer", stepHour: "stepHour", stepMinute: "stepMinute", stepSecond: "stepSecond" }, outputs: { selectedChange: "selectedChange" }, host: { properties: { "class.owl-dt-timer": "owlDTTimerClass", "attr.tabindex": "owlDTTimeTabIndex" } }, exportAs: ["owlDateTimeTimer"], ngImport: i0, template: "<owl-date-time-timer-box\n [upBtnAriaLabel]=\"upHourButtonLabel\"\n [downBtnAriaLabel]=\"downHourButtonLabel\"\n [upBtnDisabled]=\"!upHourEnabled()\"\n [downBtnDisabled]=\"!downHourEnabled()\"\n [boxValue]=\"hourBoxValue\"\n [value]=\"hourValue\" [min]=\"0\" [max]=\"23\"\n [step]=\"stepHour\" [inputLabel]=\"'Hour'\"\n (inputChange)=\"setHourValueViaInput($event)\"\n (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n [upBtnDisabled]=\"!upMinuteEnabled()\"\n [downBtnDisabled]=\"!downMinuteEnabled()\"\n [value]=\"minuteValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepMinute\" [inputLabel]=\"'Minute'\"\n (inputChange)=\"setMinuteValue($event)\"\n (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n *ngIf=\"showSecondsTimer\"\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upSecondButtonLabel\"\n [downBtnAriaLabel]=\"downSecondButtonLabel\"\n [upBtnDisabled]=\"!upSecondEnabled()\"\n [downBtnDisabled]=\"!downSecondEnabled()\"\n [value]=\"secondValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepSecond\" [inputLabel]=\"'Second'\"\n (inputChange)=\"setSecondValue($event)\"\n (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div *ngIf=\"hour12Timer\" class=\"owl-dt-timer-hour12\">\n <button class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n type=\"button\" tabindex=\"0\"\n (click)=\"setMeridiem($event)\">\n <span class=\"owl-dt-control-button-content\" tabindex=\"-1\">\n {{hour12ButtonLabel}}\n </span>\n </button>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.OwlTimerBoxComponent, selector: "owl-date-time-timer-box", inputs: ["showDivider", "upBtnAriaLabel", "upBtnDisabled", "downBtnAriaLabel", "downBtnDisabled", "boxValue", "value", "min", "max", "step", "inputLabel"], outputs: ["valueChange", "inputChange"], exportAs: ["owlDateTimeTimerBox"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
264
+ }
265
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: OwlTimerComponent, decorators: [{
266
+ type: Component,
267
+ args: [{ exportAs: 'owlDateTimeTimer', selector: 'owl-date-time-timer', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, host: {
268
+ '[class.owl-dt-timer]': 'owlDTTimerClass',
269
+ '[attr.tabindex]': 'owlDTTimeTabIndex'
270
+ }, template: "<owl-date-time-timer-box\n [upBtnAriaLabel]=\"upHourButtonLabel\"\n [downBtnAriaLabel]=\"downHourButtonLabel\"\n [upBtnDisabled]=\"!upHourEnabled()\"\n [downBtnDisabled]=\"!downHourEnabled()\"\n [boxValue]=\"hourBoxValue\"\n [value]=\"hourValue\" [min]=\"0\" [max]=\"23\"\n [step]=\"stepHour\" [inputLabel]=\"'Hour'\"\n (inputChange)=\"setHourValueViaInput($event)\"\n (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n [upBtnDisabled]=\"!upMinuteEnabled()\"\n [downBtnDisabled]=\"!downMinuteEnabled()\"\n [value]=\"minuteValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepMinute\" [inputLabel]=\"'Minute'\"\n (inputChange)=\"setMinuteValue($event)\"\n (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n *ngIf=\"showSecondsTimer\"\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upSecondButtonLabel\"\n [downBtnAriaLabel]=\"downSecondButtonLabel\"\n [upBtnDisabled]=\"!upSecondEnabled()\"\n [downBtnDisabled]=\"!downSecondEnabled()\"\n [value]=\"secondValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepSecond\" [inputLabel]=\"'Second'\"\n (inputChange)=\"setSecondValue($event)\"\n (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div *ngIf=\"hour12Timer\" class=\"owl-dt-timer-hour12\">\n <button class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n type=\"button\" tabindex=\"0\"\n (click)=\"setMeridiem($event)\">\n <span class=\"owl-dt-control-button-content\" tabindex=\"-1\">\n {{hour12ButtonLabel}}\n </span>\n </button>\n</div>\n" }]
271
+ }], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i1.OwlDateTimeIntl }, { type: i0.ChangeDetectorRef }, { type: i2.DateTimeAdapter, decorators: [{
272
+ type: Optional
273
+ }] }], propDecorators: { pickerMoment: [{
274
+ type: Input
275
+ }], minDateTime: [{
276
+ type: Input
277
+ }], maxDateTime: [{
278
+ type: Input
279
+ }], showSecondsTimer: [{
280
+ type: Input
281
+ }], hour12Timer: [{
282
+ type: Input
283
+ }], stepHour: [{
284
+ type: Input
285
+ }], stepMinute: [{
286
+ type: Input
287
+ }], stepSecond: [{
288
+ type: Input
289
+ }], selectedChange: [{
290
+ type: Output
291
+ }] } });
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timer.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/timer.component.ts","../../../../../projects/picker/src/lib/date-time/timer.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * timer.component\n */\n\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnInit,\n    Optional,\n    Output\n} from '@angular/core';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { take } from 'rxjs/operators';\n\n@Component({\n    exportAs: 'owlDateTimeTimer',\n    selector: 'owl-date-time-timer',\n    templateUrl: './timer.component.html',\n    styleUrls: ['./timer.component.scss'],\n    preserveWhitespaces: false,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class.owl-dt-timer]': 'owlDTTimerClass',\n        '[attr.tabindex]': 'owlDTTimeTabIndex'\n    }\n})\nexport class OwlTimerComponent<T> implements OnInit {\n    /** The current picker moment */\n    private _pickerMoment: T;\n    @Input()\n    get pickerMoment() {\n        return this._pickerMoment;\n    }\n\n    set pickerMoment(value: T) {\n        value = this.dateTimeAdapter.deserialize(value);\n        this._pickerMoment =\n            this.getValidDate(value) || this.dateTimeAdapter.now();\n    }\n\n    /** The minimum selectable date time. */\n    private _minDateTime: T | null;\n    @Input()\n    get minDateTime(): T | null {\n        return this._minDateTime;\n    }\n\n    set minDateTime(value: T | null) {\n        value = this.dateTimeAdapter.deserialize(value);\n        this._minDateTime = this.getValidDate(value);\n    }\n\n    /** The maximum selectable date time. */\n    private _maxDateTime: T | null;\n    @Input()\n    get maxDateTime(): T | null {\n        return this._maxDateTime;\n    }\n\n    set maxDateTime(value: T | null) {\n        value = this.dateTimeAdapter.deserialize(value);\n        this._maxDateTime = this.getValidDate(value);\n    }\n\n    private isPM = false; // a flag indicates the current timer moment is in PM or AM\n\n    /**\n     * Whether to show the second's timer\n     */\n    @Input()\n    showSecondsTimer: boolean;\n\n    /**\n     * Whether the timer is in hour12 format\n     */\n    @Input()\n    hour12Timer: boolean;\n\n    /**\n     * Hours to change per step\n     */\n    @Input()\n    stepHour = 1;\n\n    /**\n     * Minutes to change per step\n     */\n    @Input()\n    stepMinute = 1;\n\n    /**\n     * Seconds to change per step\n     */\n    @Input()\n    stepSecond = 1;\n\n    get hourValue(): number {\n        return this.dateTimeAdapter.getHours(this.pickerMoment);\n    }\n\n    /**\n     * The value would be displayed in hourBox.\n     * We need this because the value displayed in hourBox it not\n     * the same as the hourValue when the timer is in hour12Timer mode.\n     * */\n    get hourBoxValue(): number {\n        let hours = this.hourValue;\n\n        if (!this.hour12Timer) {\n            return hours;\n        } else {\n            if (hours === 0) {\n                hours = 12;\n                this.isPM = false;\n            } else if (hours > 0 && hours < 12) {\n                this.isPM = false;\n            } else if (hours === 12) {\n                this.isPM = true;\n            } else if (hours > 12 && hours < 24) {\n                hours = hours - 12;\n                this.isPM = true;\n            }\n\n            return hours;\n        }\n    }\n\n    get minuteValue(): number {\n        return this.dateTimeAdapter.getMinutes(this.pickerMoment);\n    }\n\n    get secondValue(): number {\n        return this.dateTimeAdapter.getSeconds(this.pickerMoment);\n    }\n\n    get upHourButtonLabel(): string {\n        return this.pickerIntl.upHourLabel;\n    }\n\n    get downHourButtonLabel(): string {\n        return this.pickerIntl.downHourLabel;\n    }\n\n    get upMinuteButtonLabel(): string {\n        return this.pickerIntl.upMinuteLabel;\n    }\n\n    get downMinuteButtonLabel(): string {\n        return this.pickerIntl.downMinuteLabel;\n    }\n\n    get upSecondButtonLabel(): string {\n        return this.pickerIntl.upSecondLabel;\n    }\n\n    get downSecondButtonLabel(): string {\n        return this.pickerIntl.downSecondLabel;\n    }\n\n    get hour12ButtonLabel(): string {\n        return this.isPM\n            ? this.pickerIntl.hour12PMLabel\n            : this.pickerIntl.hour12AMLabel;\n    }\n\n    @Output()\n    selectedChange = new EventEmitter<T>();\n\n    get owlDTTimerClass(): boolean {\n        return true;\n    }\n\n    get owlDTTimeTabIndex(): number {\n        return -1;\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private elmRef: ElementRef,\n        private pickerIntl: OwlDateTimeIntl,\n        private cdRef: ChangeDetectorRef,\n        @Optional() private dateTimeAdapter: DateTimeAdapter<T>\n    ) {}\n\n    public ngOnInit() {}\n\n    /**\n     * Focus to the host element\n     * */\n    public focus() {\n        this.ngZone.runOutsideAngular(() => {\n            this.ngZone.onStable\n                .asObservable()\n                .pipe(take(1))\n                .subscribe(() => {\n                    this.elmRef.nativeElement.focus();\n                });\n        });\n    }\n\n    /**\n     * Set the hour value via typing into timer box input\n     * We need this to handle the hour value when the timer is in hour12 mode\n     * */\n    public setHourValueViaInput(hours: number): void {\n        if (this.hour12Timer && this.isPM && hours >= 1 && hours <= 11) {\n            hours = hours + 12;\n        } else if (this.hour12Timer && !this.isPM && hours === 12) {\n            hours = 0;\n        }\n\n        this.setHourValue(hours);\n    }\n\n    public setHourValue(hours: number): void {\n        const m = this.dateTimeAdapter.setHours(this.pickerMoment, hours);\n        this.selectedChange.emit(m);\n        this.cdRef.markForCheck();\n    }\n\n    public setMinuteValue(minutes: number): void {\n        const m = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);\n        this.selectedChange.emit(m);\n        this.cdRef.markForCheck();\n    }\n\n    public setSecondValue(seconds: number): void {\n        const m = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);\n        this.selectedChange.emit(m);\n        this.cdRef.markForCheck();\n    }\n\n    public setMeridiem(event: any): void {\n        this.isPM = !this.isPM;\n\n        let hours = this.hourValue;\n        if (this.isPM) {\n            hours = hours + 12;\n        } else {\n            hours = hours - 12;\n        }\n\n        if (hours >= 0 && hours <= 23) {\n            this.setHourValue(hours);\n        }\n\n        this.cdRef.markForCheck();\n        event.preventDefault();\n    }\n\n    /**\n     * Check if the up hour button is enabled\n     */\n    public upHourEnabled(): boolean {\n        return (\n            !this.maxDateTime ||\n            this.compareHours(this.stepHour, this.maxDateTime) < 1\n        );\n    }\n\n    /**\n     * Check if the down hour button is enabled\n     */\n    public downHourEnabled(): boolean {\n        return (\n            !this.minDateTime ||\n            this.compareHours(-this.stepHour, this.minDateTime) > -1\n        );\n    }\n\n    /**\n     * Check if the up minute button is enabled\n     */\n    public upMinuteEnabled(): boolean {\n        return (\n            !this.maxDateTime ||\n            this.compareMinutes(this.stepMinute, this.maxDateTime) < 1\n        );\n    }\n\n    /**\n     * Check if the down minute button is enabled\n     */\n    public downMinuteEnabled(): boolean {\n        return (\n            !this.minDateTime ||\n            this.compareMinutes(-this.stepMinute, this.minDateTime) > -1\n        );\n    }\n\n    /**\n     * Check if the up second button is enabled\n     */\n    public upSecondEnabled(): boolean {\n        return (\n            !this.maxDateTime ||\n            this.compareSeconds(this.stepSecond, this.maxDateTime) < 1\n        );\n    }\n\n    /**\n     * Check if the down second button is enabled\n     */\n    public downSecondEnabled(): boolean {\n        return (\n            !this.minDateTime ||\n            this.compareSeconds(-this.stepSecond, this.minDateTime) > -1\n        );\n    }\n\n    /**\n     * PickerMoment's hour value +/- certain amount and compare it to the give date\n     * 1 is after the comparedDate\n     * -1 is before the comparedDate\n     * 0 is equal the comparedDate\n     * */\n    private compareHours(amount: number, comparedDate: T): number {\n        const hours = this.dateTimeAdapter.getHours(this.pickerMoment) + amount;\n        const result = this.dateTimeAdapter.setHours(this.pickerMoment, hours);\n        return this.dateTimeAdapter.compare(result, comparedDate);\n    }\n\n    /**\n     * PickerMoment's minute value +/- certain amount and compare it to the give date\n     * 1 is after the comparedDate\n     * -1 is before the comparedDate\n     * 0 is equal the comparedDate\n     * */\n    private compareMinutes(amount: number, comparedDate: T): number {\n        const minutes =\n            this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;\n        const result = this.dateTimeAdapter.setMinutes(\n            this.pickerMoment,\n            minutes\n        );\n        return this.dateTimeAdapter.compare(result, comparedDate);\n    }\n\n    /**\n     * PickerMoment's second value +/- certain amount and compare it to the give date\n     * 1 is after the comparedDate\n     * -1 is before the comparedDate\n     * 0 is equal the comparedDate\n     * */\n    private compareSeconds(amount: number, comparedDate: T): number {\n        const seconds =\n            this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;\n        const result = this.dateTimeAdapter.setSeconds(\n            this.pickerMoment,\n            seconds\n        );\n        return this.dateTimeAdapter.compare(result, comparedDate);\n    }\n\n    /**\n     * Get a valid date object\n     */\n    private getValidDate(obj: any): T | null {\n        return this.dateTimeAdapter.isDateInstance(obj) &&\n            this.dateTimeAdapter.isValid(obj)\n            ? obj\n            : null;\n    }\n}\n","<owl-date-time-timer-box\n        [upBtnAriaLabel]=\"upHourButtonLabel\"\n        [downBtnAriaLabel]=\"downHourButtonLabel\"\n        [upBtnDisabled]=\"!upHourEnabled()\"\n        [downBtnDisabled]=\"!downHourEnabled()\"\n        [boxValue]=\"hourBoxValue\"\n        [value]=\"hourValue\" [min]=\"0\" [max]=\"23\"\n        [step]=\"stepHour\" [inputLabel]=\"'Hour'\"\n        (inputChange)=\"setHourValueViaInput($event)\"\n        (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n        [showDivider]=\"true\"\n        [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n        [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n        [upBtnDisabled]=\"!upMinuteEnabled()\"\n        [downBtnDisabled]=\"!downMinuteEnabled()\"\n        [value]=\"minuteValue\" [min]=\"0\" [max]=\"59\"\n        [step]=\"stepMinute\" [inputLabel]=\"'Minute'\"\n        (inputChange)=\"setMinuteValue($event)\"\n        (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n        *ngIf=\"showSecondsTimer\"\n        [showDivider]=\"true\"\n        [upBtnAriaLabel]=\"upSecondButtonLabel\"\n        [downBtnAriaLabel]=\"downSecondButtonLabel\"\n        [upBtnDisabled]=\"!upSecondEnabled()\"\n        [downBtnDisabled]=\"!downSecondEnabled()\"\n        [value]=\"secondValue\" [min]=\"0\" [max]=\"59\"\n        [step]=\"stepSecond\" [inputLabel]=\"'Second'\"\n        (inputChange)=\"setSecondValue($event)\"\n        (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div *ngIf=\"hour12Timer\" class=\"owl-dt-timer-hour12\">\n    <button class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n            type=\"button\" tabindex=\"0\"\n            (click)=\"setMeridiem($event)\">\n        <span class=\"owl-dt-control-button-content\" tabindex=\"-1\">\n            {{hour12ButtonLabel}}\n        </span>\n    </button>\n</div>\n"]}
@@ -0,0 +1,56 @@
1
+ import { NoopScrollStrategy } from '@angular/cdk/overlay';
2
+ let uniqueId = 0;
3
+ export class OwlDialogConfig {
4
+ constructor() {
5
+ /**
6
+ * ID of the element that describes the dialog.
7
+ */
8
+ this.ariaDescribedBy = null;
9
+ /**
10
+ * Whether to focus the dialog when the dialog is opened
11
+ */
12
+ this.autoFocus = true;
13
+ /** Whether the dialog has a backdrop. */
14
+ this.hasBackdrop = true;
15
+ /** Data being injected into the child component. */
16
+ this.data = null;
17
+ /** Whether the user can use escape or clicking outside to close a modal. */
18
+ this.disableClose = false;
19
+ /**
20
+ * The ARIA role of the dialog element.
21
+ */
22
+ this.role = 'dialog';
23
+ /**
24
+ * Custom class for the pane
25
+ * */
26
+ this.paneClass = '';
27
+ /**
28
+ * Mouse Event
29
+ * */
30
+ this.event = null;
31
+ /**
32
+ * Custom class for the backdrop
33
+ * */
34
+ this.backdropClass = '';
35
+ /**
36
+ * Whether the dialog should close when the user goes backwards/forwards in history.
37
+ * */
38
+ this.closeOnNavigation = true;
39
+ /** Width of the dialog. */
40
+ this.width = '';
41
+ /** Height of the dialog. */
42
+ this.height = '';
43
+ /**
44
+ * The max-width of the overlay panel.
45
+ * If a number is provided, pixel units are assumed.
46
+ * */
47
+ this.maxWidth = '85vw';
48
+ /**
49
+ * The scroll strategy when the dialog is open
50
+ * Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies
51
+ * */
52
+ this.scrollStrategy = new NoopScrollStrategy();
53
+ this.id = `owl-dialog-${uniqueId++}`;
54
+ }
55
+ }
56
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-config.class.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/dialog/dialog-config.class.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,kBAAkB,EAAkB,MAAM,sBAAsB,CAAC;AAE1E,IAAI,QAAQ,GAAG,CAAC,CAAC;AAkHjB,MAAM,OAAO,eAAe;IAgGxB;QA/FA;;WAEG;QACI,oBAAe,GAAkB,IAAI,CAAC;QAE7C;;WAEG;QACI,cAAS,GAAG,IAAI,CAAC;QAExB,yCAAyC;QAClC,gBAAW,GAAG,IAAI,CAAC;QAO1B,oDAAoD;QAC7C,SAAI,GAAQ,IAAI,CAAC;QAExB,4EAA4E;QACrE,iBAAY,GAAG,KAAK,CAAC;QAO5B;;WAEG;QACI,SAAI,GAA6B,QAAQ,CAAC;QAEjD;;aAEK;QACE,cAAS,GAAsB,EAAE,CAAC;QAEzC;;aAEK;QACE,UAAK,GAAe,IAAI,CAAC;QAEhC;;aAEK;QACE,kBAAa,GAAsB,EAAE,CAAC;QAE7C;;aAEK;QACE,sBAAiB,GAAG,IAAI,CAAC;QAEhC,2BAA2B;QACpB,UAAK,GAAG,EAAE,CAAC;QAElB,4BAA4B;QACrB,WAAM,GAAG,EAAE,CAAC;QAcnB;;;aAGK;QACE,aAAQ,GAAoB,MAAM,CAAC;QAW1C;;;aAGK;QACE,mBAAc,GAAmB,IAAI,kBAAkB,EAAE,CAAC;QAK7D,IAAI,CAAC,EAAE,GAAG,cAAc,QAAQ,EAAE,EAAE,CAAC;IACzC,CAAC;CACJ","sourcesContent":["/**\n * dialog-config.class\n */\nimport { ViewContainerRef } from '@angular/core';\nimport { NoopScrollStrategy, ScrollStrategy } from '@angular/cdk/overlay';\n\nlet uniqueId = 0;\n\n/** Possible overrides for a dialog's position. */\nexport interface DialogPosition {\n    /** Override for the dialog's top position. */\n    top?: string;\n\n    /** Override for the dialog's bottom position. */\n    bottom?: string;\n\n    /** Override for the dialog's left position. */\n    left?: string;\n\n    /** Override for the dialog's right position. */\n    right?: string;\n}\n\nexport interface OwlDialogConfigInterface {\n    /**\n     * ID of the element that describes the dialog.\n     */\n    ariaDescribedBy?: string | null;\n\n    /**\n     * Whether to focus the dialog when the dialog is opened\n     */\n    autoFocus?: boolean;\n\n    /** Whether the dialog has a backdrop. */\n    hasBackdrop?: boolean;\n\n    /**\n     * Custom style for the backdrop\n     * */\n    backdropStyle?: any;\n\n    /** Data being injected into the child component. */\n    data?: any ;\n\n    /** Whether the user can use escape or clicking outside to close a modal. */\n    disableClose?: boolean;\n\n    /**\n     * ID for the modal. If omitted, a unique one will be generated.\n     */\n    id?: string;\n\n    /**\n     * The ARIA role of the dialog element.\n     */\n    role?: 'dialog' | 'alertdialog';\n\n    /**\n     * Custom class for the pane\n     * */\n    paneClass?: string | string[];\n\n    /**\n     * Mouse Event\n     * */\n    event?: MouseEvent;\n\n    /**\n     * Custom class for the backdrop\n     * */\n    backdropClass?: string | string[];\n\n    /**\n     * Whether the dialog should close when the user goes backwards/forwards in history.\n     * */\n    closeOnNavigation?: boolean;\n\n    /** Width of the dialog. */\n    width?: string ;\n\n    /** Height of the dialog. */\n    height?: string;\n\n    /**\n     * The min-width of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    minWidth?: number | string;\n\n    /**\n     * The min-height of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    minHeight?: number | string;\n\n    /**\n     * The max-width of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    maxWidth?: number | string;\n\n    /**\n     * The max-height of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    maxHeight?: number | string;\n\n    /** Position overrides. */\n    position?: DialogPosition;\n\n    /**\n     * The scroll strategy when the dialog is open\n     * Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies\n     * */\n    scrollStrategy?: ScrollStrategy;\n\n    viewContainerRef?: ViewContainerRef;\n}\n\nexport class OwlDialogConfig implements OwlDialogConfigInterface {\n    /**\n     * ID of the element that describes the dialog.\n     */\n    public ariaDescribedBy: string | null = null;\n\n    /**\n     * Whether to focus the dialog when the dialog is opened\n     */\n    public autoFocus = true;\n\n    /** Whether the dialog has a backdrop. */\n    public hasBackdrop = true;\n\n    /**\n     * Custom style for the backdrop\n     * */\n    public backdropStyle: any;\n\n    /** Data being injected into the child component. */\n    public data: any = null;\n\n    /** Whether the user can use escape or clicking outside to close a modal. */\n    public disableClose = false;\n\n    /**\n     * ID for the modal. If omitted, a unique one will be generated.\n     */\n    public id: string;\n\n    /**\n     * The ARIA role of the dialog element.\n     */\n    public role: 'dialog' | 'alertdialog' = 'dialog';\n\n    /**\n     * Custom class for the pane\n     * */\n    public paneClass: string | string[] = '';\n\n    /**\n     * Mouse Event\n     * */\n    public event: MouseEvent = null;\n\n    /**\n     * Custom class for the backdrop\n     * */\n    public backdropClass: string | string[] = '';\n\n    /**\n     * Whether the dialog should close when the user goes backwards/forwards in history.\n     * */\n    public closeOnNavigation = true;\n\n    /** Width of the dialog. */\n    public width = '';\n\n    /** Height of the dialog. */\n    public height = '';\n\n    /**\n     * The min-width of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    public minWidth: number | string;\n\n    /**\n     * The min-height of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    public minHeight: number | string;\n\n    /**\n     * The max-width of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    public maxWidth: number | string = '85vw';\n\n    /**\n     * The max-height of the overlay panel.\n     * If a number is provided, pixel units are assumed.\n     * */\n    public maxHeight: number | string;\n\n    /** Position overrides. */\n    public position: DialogPosition;\n\n    /**\n     * The scroll strategy when the dialog is open\n     * Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies\n     * */\n    public scrollStrategy: ScrollStrategy = new NoopScrollStrategy();\n\n    public viewContainerRef: ViewContainerRef;\n\n    constructor() {\n        this.id = `owl-dialog-${uniqueId++}`;\n    }\n}\n"]}