@netwin/angular-datetime-picker 1.0.0-rc.3
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 +225 -0
- package/assets/style/picker.min.css +1 -0
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +120 -0
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +253 -0
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +16 -0
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +45 -0
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +228 -0
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +16 -0
- package/esm2022/lib/date-time/calendar-body.component.mjs +146 -0
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +436 -0
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +366 -0
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +362 -0
- package/esm2022/lib/date-time/calendar.component.mjs +368 -0
- package/esm2022/lib/date-time/date-time-inline.component.mjs +293 -0
- package/esm2022/lib/date-time/date-time-picker-container.component.mjs +405 -0
- package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +598 -0
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
- package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +64 -0
- package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
- package/esm2022/lib/date-time/date-time-picker.component.mjs +564 -0
- package/esm2022/lib/date-time/date-time.class.mjs +176 -0
- package/esm2022/lib/date-time/date-time.module.mjs +83 -0
- package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
- package/esm2022/lib/date-time/options-provider.mjs +34 -0
- package/esm2022/lib/date-time/timer-box.component.mjs +140 -0
- package/esm2022/lib/date-time/timer.component.mjs +279 -0
- package/esm2022/lib/dialog/dialog-config.class.mjs +59 -0
- package/esm2022/lib/dialog/dialog-container.component.mjs +232 -0
- package/esm2022/lib/dialog/dialog-ref.class.mjs +134 -0
- package/esm2022/lib/dialog/dialog.module.mjs +26 -0
- package/esm2022/lib/dialog/dialog.service.mjs +228 -0
- package/esm2022/lib/utils/array.utils.mjs +12 -0
- package/esm2022/lib/utils/constants.mjs +34 -0
- package/esm2022/lib/utils/date.utils.mjs +49 -0
- package/esm2022/lib/utils/index.mjs +5 -0
- package/esm2022/lib/utils/object.utils.mjs +26 -0
- package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
- package/esm2022/public_api.mjs +25 -0
- package/fesm2022/netwin-angular-datetime-picker.mjs +5751 -0
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
- package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +72 -0
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
- package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +67 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
- package/lib/date-time/calendar-body.component.d.ts +79 -0
- package/lib/date-time/calendar-month-view.component.d.ts +141 -0
- package/lib/date-time/calendar-multi-year-view.component.d.ts +107 -0
- package/lib/date-time/calendar-year-view.component.d.ts +120 -0
- package/lib/date-time/calendar.component.d.ts +154 -0
- package/lib/date-time/date-time-inline.component.d.ts +102 -0
- package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
- package/lib/date-time/date-time-picker-input.directive.d.ts +164 -0
- package/lib/date-time/date-time-picker-intl.service.d.ts +51 -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 +173 -0
- package/lib/date-time/date-time.class.d.ts +103 -0
- package/lib/date-time/date-time.module.d.ts +23 -0
- package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
- package/lib/date-time/options-provider.d.ts +23 -0
- package/lib/date-time/timer-box.component.d.ts +42 -0
- package/lib/date-time/timer.component.d.ts +131 -0
- package/lib/dialog/dialog-config.class.d.ts +169 -0
- package/lib/dialog/dialog-container.component.d.ts +58 -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/array.utils.d.ts +5 -0
- package/lib/utils/constants.d.ts +19 -0
- package/lib/utils/date.utils.d.ts +12 -0
- package/lib/utils/index.d.ts +4 -0
- package/lib/utils/object.utils.d.ts +11 -0
- package/package.json +51 -0
- package/public_api.d.ts +24 -0
|
@@ -0,0 +1,279 @@
|
|
|
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 = this.getValidDate(value) || this.dateTimeAdapter.now();
|
|
18
|
+
}
|
|
19
|
+
get minDateTime() {
|
|
20
|
+
return this._minDateTime;
|
|
21
|
+
}
|
|
22
|
+
set minDateTime(value) {
|
|
23
|
+
value = this.dateTimeAdapter.deserialize(value);
|
|
24
|
+
this._minDateTime = this.getValidDate(value);
|
|
25
|
+
}
|
|
26
|
+
get maxDateTime() {
|
|
27
|
+
return this._maxDateTime;
|
|
28
|
+
}
|
|
29
|
+
set maxDateTime(value) {
|
|
30
|
+
value = this.dateTimeAdapter.deserialize(value);
|
|
31
|
+
this._maxDateTime = this.getValidDate(value);
|
|
32
|
+
}
|
|
33
|
+
get hourValue() {
|
|
34
|
+
return this.dateTimeAdapter.getHours(this.pickerMoment);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* The value would be displayed in hourBox.
|
|
38
|
+
* We need this because the value displayed in hourBox it not
|
|
39
|
+
* the same as the hourValue when the timer is in hour12Timer mode.
|
|
40
|
+
* */
|
|
41
|
+
get hourBoxValue() {
|
|
42
|
+
let hours = this.hourValue;
|
|
43
|
+
if (!this.hour12Timer) {
|
|
44
|
+
return hours;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
if (hours === 0) {
|
|
48
|
+
hours = 12;
|
|
49
|
+
this.isPM = false;
|
|
50
|
+
}
|
|
51
|
+
else if (hours > 0 && hours < 12) {
|
|
52
|
+
this.isPM = false;
|
|
53
|
+
}
|
|
54
|
+
else if (hours === 12) {
|
|
55
|
+
this.isPM = true;
|
|
56
|
+
}
|
|
57
|
+
else if (hours > 12 && hours < 24) {
|
|
58
|
+
hours = hours - 12;
|
|
59
|
+
this.isPM = true;
|
|
60
|
+
}
|
|
61
|
+
return hours;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
get minuteValue() {
|
|
65
|
+
return this.dateTimeAdapter.getMinutes(this.pickerMoment);
|
|
66
|
+
}
|
|
67
|
+
get secondValue() {
|
|
68
|
+
return this.dateTimeAdapter.getSeconds(this.pickerMoment);
|
|
69
|
+
}
|
|
70
|
+
get upHourButtonLabel() {
|
|
71
|
+
return this.pickerIntl.upHourLabel;
|
|
72
|
+
}
|
|
73
|
+
get downHourButtonLabel() {
|
|
74
|
+
return this.pickerIntl.downHourLabel;
|
|
75
|
+
}
|
|
76
|
+
get upMinuteButtonLabel() {
|
|
77
|
+
return this.pickerIntl.upMinuteLabel;
|
|
78
|
+
}
|
|
79
|
+
get downMinuteButtonLabel() {
|
|
80
|
+
return this.pickerIntl.downMinuteLabel;
|
|
81
|
+
}
|
|
82
|
+
get upSecondButtonLabel() {
|
|
83
|
+
return this.pickerIntl.upSecondLabel;
|
|
84
|
+
}
|
|
85
|
+
get downSecondButtonLabel() {
|
|
86
|
+
return this.pickerIntl.downSecondLabel;
|
|
87
|
+
}
|
|
88
|
+
get hour12ButtonLabel() {
|
|
89
|
+
return this.isPM ? this.pickerIntl.hour12PMLabel : this.pickerIntl.hour12AMLabel;
|
|
90
|
+
}
|
|
91
|
+
get owlDTTimerClass() {
|
|
92
|
+
return true;
|
|
93
|
+
}
|
|
94
|
+
get owlDTTimeTabIndex() {
|
|
95
|
+
return -1;
|
|
96
|
+
}
|
|
97
|
+
constructor(ngZone, elmRef, pickerIntl, cdRef, dateTimeAdapter) {
|
|
98
|
+
this.ngZone = ngZone;
|
|
99
|
+
this.elmRef = elmRef;
|
|
100
|
+
this.pickerIntl = pickerIntl;
|
|
101
|
+
this.cdRef = cdRef;
|
|
102
|
+
this.dateTimeAdapter = dateTimeAdapter;
|
|
103
|
+
this.isPM = false; // a flag indicates the current timer moment is in PM or AM
|
|
104
|
+
/**
|
|
105
|
+
* Hours to change per step
|
|
106
|
+
*/
|
|
107
|
+
this.stepHour = 1;
|
|
108
|
+
/**
|
|
109
|
+
* Minutes to change per step
|
|
110
|
+
*/
|
|
111
|
+
this.stepMinute = 1;
|
|
112
|
+
/**
|
|
113
|
+
* Seconds to change per step
|
|
114
|
+
*/
|
|
115
|
+
this.stepSecond = 1;
|
|
116
|
+
this.selectedChange = new EventEmitter();
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Focus to the host element
|
|
120
|
+
* */
|
|
121
|
+
focus() {
|
|
122
|
+
this.ngZone.runOutsideAngular(() => {
|
|
123
|
+
this.ngZone.onStable
|
|
124
|
+
.asObservable()
|
|
125
|
+
.pipe(take(1))
|
|
126
|
+
.subscribe(() => {
|
|
127
|
+
this.elmRef.nativeElement.focus();
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Set the hour value via typing into timer box input
|
|
133
|
+
* We need this to handle the hour value when the timer is in hour12 mode
|
|
134
|
+
* */
|
|
135
|
+
setHourValueViaInput(hours) {
|
|
136
|
+
if (this.hour12Timer && this.isPM && hours >= 1 && hours <= 11) {
|
|
137
|
+
hours = hours + 12;
|
|
138
|
+
}
|
|
139
|
+
else if (this.hour12Timer && !this.isPM && hours === 12) {
|
|
140
|
+
hours = 0;
|
|
141
|
+
}
|
|
142
|
+
this.setHourValue(hours);
|
|
143
|
+
}
|
|
144
|
+
setHourValue(hours) {
|
|
145
|
+
const m = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
|
|
146
|
+
this.selectedChange.emit(m);
|
|
147
|
+
this.cdRef.markForCheck();
|
|
148
|
+
}
|
|
149
|
+
setMinuteValue(minutes) {
|
|
150
|
+
const m = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
|
|
151
|
+
this.selectedChange.emit(m);
|
|
152
|
+
this.cdRef.markForCheck();
|
|
153
|
+
}
|
|
154
|
+
setSecondValue(seconds) {
|
|
155
|
+
const m = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
|
|
156
|
+
this.selectedChange.emit(m);
|
|
157
|
+
this.cdRef.markForCheck();
|
|
158
|
+
}
|
|
159
|
+
setMeridiem(event) {
|
|
160
|
+
this.isPM = !this.isPM;
|
|
161
|
+
let hours = this.hourValue;
|
|
162
|
+
if (this.isPM) {
|
|
163
|
+
hours = hours + 12;
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
hours = hours - 12;
|
|
167
|
+
}
|
|
168
|
+
if (hours >= 0 && hours <= 23) {
|
|
169
|
+
this.setHourValue(hours);
|
|
170
|
+
}
|
|
171
|
+
this.cdRef.markForCheck();
|
|
172
|
+
event.preventDefault();
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Check if the up hour button is enabled
|
|
176
|
+
*/
|
|
177
|
+
upHourEnabled() {
|
|
178
|
+
return !this.maxDateTime || this.compareHours(this.stepHour, this.maxDateTime) < 1;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Check if the down hour button is enabled
|
|
182
|
+
*/
|
|
183
|
+
downHourEnabled() {
|
|
184
|
+
return !this.minDateTime || this.compareHours(-this.stepHour, this.minDateTime) > -1;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Check if the up minute button is enabled
|
|
188
|
+
*/
|
|
189
|
+
upMinuteEnabled() {
|
|
190
|
+
return !this.maxDateTime || this.compareMinutes(this.stepMinute, this.maxDateTime) < 1;
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Check if the down minute button is enabled
|
|
194
|
+
*/
|
|
195
|
+
downMinuteEnabled() {
|
|
196
|
+
return !this.minDateTime || this.compareMinutes(-this.stepMinute, this.minDateTime) > -1;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Check if the up second button is enabled
|
|
200
|
+
*/
|
|
201
|
+
upSecondEnabled() {
|
|
202
|
+
return !this.maxDateTime || this.compareSeconds(this.stepSecond, this.maxDateTime) < 1;
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* Check if the down second button is enabled
|
|
206
|
+
*/
|
|
207
|
+
downSecondEnabled() {
|
|
208
|
+
return !this.minDateTime || this.compareSeconds(-this.stepSecond, this.minDateTime) > -1;
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* PickerMoment's hour value +/- certain amount and compare it to the give date
|
|
212
|
+
* 1 is after the comparedDate
|
|
213
|
+
* -1 is before the comparedDate
|
|
214
|
+
* 0 is equal the comparedDate
|
|
215
|
+
* */
|
|
216
|
+
compareHours(amount, comparedDate) {
|
|
217
|
+
const hours = this.dateTimeAdapter.getHours(this.pickerMoment) + amount;
|
|
218
|
+
const result = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
|
|
219
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* PickerMoment's minute value +/- certain amount and compare it to the give date
|
|
223
|
+
* 1 is after the comparedDate
|
|
224
|
+
* -1 is before the comparedDate
|
|
225
|
+
* 0 is equal the comparedDate
|
|
226
|
+
* */
|
|
227
|
+
compareMinutes(amount, comparedDate) {
|
|
228
|
+
const minutes = this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;
|
|
229
|
+
const result = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
|
|
230
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* PickerMoment's second value +/- certain amount and compare it to the give date
|
|
234
|
+
* 1 is after the comparedDate
|
|
235
|
+
* -1 is before the comparedDate
|
|
236
|
+
* 0 is equal the comparedDate
|
|
237
|
+
* */
|
|
238
|
+
compareSeconds(amount, comparedDate) {
|
|
239
|
+
const seconds = this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;
|
|
240
|
+
const result = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
|
|
241
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
242
|
+
}
|
|
243
|
+
/**
|
|
244
|
+
* Get a valid date object
|
|
245
|
+
*/
|
|
246
|
+
getValidDate(obj) {
|
|
247
|
+
return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;
|
|
248
|
+
}
|
|
249
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", 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 }); }
|
|
250
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", 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 [boxValue]=\"hourBoxValue\"\n [downBtnAriaLabel]=\"downHourButtonLabel\"\n [downBtnDisabled]=\"!downHourEnabled()\"\n [inputLabel]=\"'Hour'\"\n [max]=\"23\"\n [min]=\"0\"\n [step]=\"stepHour\"\n [upBtnAriaLabel]=\"upHourButtonLabel\"\n [upBtnDisabled]=\"!upHourEnabled()\"\n [value]=\"hourValue\"\n (inputChange)=\"setHourValueViaInput($event)\"\n (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n [downBtnDisabled]=\"!downMinuteEnabled()\"\n [inputLabel]=\"'Minute'\"\n [max]=\"59\"\n [min]=\"0\"\n [showDivider]=\"true\"\n [step]=\"stepMinute\"\n [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n [upBtnDisabled]=\"!upMinuteEnabled()\"\n [value]=\"minuteValue\"\n (inputChange)=\"setMinuteValue($event)\"\n (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n *ngIf=\"showSecondsTimer\"\n [downBtnAriaLabel]=\"downSecondButtonLabel\"\n [downBtnDisabled]=\"!downSecondEnabled()\"\n [inputLabel]=\"'Second'\"\n [max]=\"59\"\n [min]=\"0\"\n [showDivider]=\"true\"\n [step]=\"stepSecond\"\n [upBtnAriaLabel]=\"upSecondButtonLabel\"\n [upBtnDisabled]=\"!upSecondEnabled()\"\n [value]=\"secondValue\"\n (inputChange)=\"setSecondValue($event)\"\n (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div\n *ngIf=\"hour12Timer\"\n class=\"owl-dt-timer-hour12\">\n <button\n (click)=\"setMeridiem($event)\"\n class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n 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 }); }
|
|
251
|
+
}
|
|
252
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlTimerComponent, decorators: [{
|
|
253
|
+
type: Component,
|
|
254
|
+
args: [{ exportAs: 'owlDateTimeTimer', selector: 'owl-date-time-timer', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
255
|
+
'[class.owl-dt-timer]': 'owlDTTimerClass',
|
|
256
|
+
'[attr.tabindex]': 'owlDTTimeTabIndex'
|
|
257
|
+
}, template: "<owl-date-time-timer-box\n [boxValue]=\"hourBoxValue\"\n [downBtnAriaLabel]=\"downHourButtonLabel\"\n [downBtnDisabled]=\"!downHourEnabled()\"\n [inputLabel]=\"'Hour'\"\n [max]=\"23\"\n [min]=\"0\"\n [step]=\"stepHour\"\n [upBtnAriaLabel]=\"upHourButtonLabel\"\n [upBtnDisabled]=\"!upHourEnabled()\"\n [value]=\"hourValue\"\n (inputChange)=\"setHourValueViaInput($event)\"\n (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n [downBtnDisabled]=\"!downMinuteEnabled()\"\n [inputLabel]=\"'Minute'\"\n [max]=\"59\"\n [min]=\"0\"\n [showDivider]=\"true\"\n [step]=\"stepMinute\"\n [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n [upBtnDisabled]=\"!upMinuteEnabled()\"\n [value]=\"minuteValue\"\n (inputChange)=\"setMinuteValue($event)\"\n (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n *ngIf=\"showSecondsTimer\"\n [downBtnAriaLabel]=\"downSecondButtonLabel\"\n [downBtnDisabled]=\"!downSecondEnabled()\"\n [inputLabel]=\"'Second'\"\n [max]=\"59\"\n [min]=\"0\"\n [showDivider]=\"true\"\n [step]=\"stepSecond\"\n [upBtnAriaLabel]=\"upSecondButtonLabel\"\n [upBtnDisabled]=\"!upSecondEnabled()\"\n [value]=\"secondValue\"\n (inputChange)=\"setSecondValue($event)\"\n (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div\n *ngIf=\"hour12Timer\"\n class=\"owl-dt-timer-hour12\">\n <button\n (click)=\"setMeridiem($event)\"\n class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n tabindex=\"-1\">\n {{ hour12ButtonLabel }}\n </span>\n </button>\n</div>\n" }]
|
|
258
|
+
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i1.OwlDateTimeIntl }, { type: i0.ChangeDetectorRef }, { type: i2.DateTimeAdapter, decorators: [{
|
|
259
|
+
type: Optional
|
|
260
|
+
}] }], propDecorators: { pickerMoment: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], minDateTime: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], maxDateTime: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], showSecondsTimer: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], hour12Timer: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], stepHour: [{
|
|
271
|
+
type: Input
|
|
272
|
+
}], stepMinute: [{
|
|
273
|
+
type: Input
|
|
274
|
+
}], stepSecond: [{
|
|
275
|
+
type: Input
|
|
276
|
+
}], selectedChange: [{
|
|
277
|
+
type: Output
|
|
278
|
+
}] } });
|
|
279
|
+
//# 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  Optional,\n  Output\n} from '@angular/core';\nimport { take } from 'rxjs/operators';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\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> {\n  /** The current picker moment */\n  private _pickerMoment: T;\n  @Input()\n  get pickerMoment(): T {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = 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 ? this.pickerIntl.hour12PMLabel : 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  /**\n   * Focus to the host element\n   * */\n  public focus(): void {\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 !this.maxDateTime || this.compareHours(this.stepHour, this.maxDateTime) < 1;\n  }\n\n  /**\n   * Check if the down hour button is enabled\n   */\n  public downHourEnabled(): boolean {\n    return !this.minDateTime || this.compareHours(-this.stepHour, this.minDateTime) > -1;\n  }\n\n  /**\n   * Check if the up minute button is enabled\n   */\n  public upMinuteEnabled(): boolean {\n    return !this.maxDateTime || this.compareMinutes(this.stepMinute, this.maxDateTime) < 1;\n  }\n\n  /**\n   * Check if the down minute button is enabled\n   */\n  public downMinuteEnabled(): boolean {\n    return !this.minDateTime || this.compareMinutes(-this.stepMinute, this.minDateTime) > -1;\n  }\n\n  /**\n   * Check if the up second button is enabled\n   */\n  public upSecondEnabled(): boolean {\n    return !this.maxDateTime || this.compareSeconds(this.stepSecond, this.maxDateTime) < 1;\n  }\n\n  /**\n   * Check if the down second button is enabled\n   */\n  public downSecondEnabled(): boolean {\n    return !this.minDateTime || this.compareSeconds(-this.stepSecond, this.minDateTime) > -1;\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 = this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;\n    const result = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);\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 = this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;\n    const result = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);\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) && this.dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n}\n","<owl-date-time-timer-box\n  [boxValue]=\"hourBoxValue\"\n  [downBtnAriaLabel]=\"downHourButtonLabel\"\n  [downBtnDisabled]=\"!downHourEnabled()\"\n  [inputLabel]=\"'Hour'\"\n  [max]=\"23\"\n  [min]=\"0\"\n  [step]=\"stepHour\"\n  [upBtnAriaLabel]=\"upHourButtonLabel\"\n  [upBtnDisabled]=\"!upHourEnabled()\"\n  [value]=\"hourValue\"\n  (inputChange)=\"setHourValueViaInput($event)\"\n  (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n  [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n  [downBtnDisabled]=\"!downMinuteEnabled()\"\n  [inputLabel]=\"'Minute'\"\n  [max]=\"59\"\n  [min]=\"0\"\n  [showDivider]=\"true\"\n  [step]=\"stepMinute\"\n  [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n  [upBtnDisabled]=\"!upMinuteEnabled()\"\n  [value]=\"minuteValue\"\n  (inputChange)=\"setMinuteValue($event)\"\n  (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n  *ngIf=\"showSecondsTimer\"\n  [downBtnAriaLabel]=\"downSecondButtonLabel\"\n  [downBtnDisabled]=\"!downSecondEnabled()\"\n  [inputLabel]=\"'Second'\"\n  [max]=\"59\"\n  [min]=\"0\"\n  [showDivider]=\"true\"\n  [step]=\"stepSecond\"\n  [upBtnAriaLabel]=\"upSecondButtonLabel\"\n  [upBtnDisabled]=\"!upSecondEnabled()\"\n  [value]=\"secondValue\"\n  (inputChange)=\"setSecondValue($event)\"\n  (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div\n  *ngIf=\"hour12Timer\"\n  class=\"owl-dt-timer-hour12\">\n  <button\n    (click)=\"setMeridiem($event)\"\n    class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n    tabindex=\"0\"\n    type=\"button\">\n    <span\n      class=\"owl-dt-control-button-content\"\n      tabindex=\"-1\">\n      {{ hour12ButtonLabel }}\n    </span>\n  </button>\n</div>\n"]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* dialog-config.class
|
|
3
|
+
*/
|
|
4
|
+
import { NoopScrollStrategy } from '@angular/cdk/overlay';
|
|
5
|
+
let uniqueId = 0;
|
|
6
|
+
export class OwlDialogConfig {
|
|
7
|
+
constructor() {
|
|
8
|
+
/**
|
|
9
|
+
* ID of the element that describes the dialog.
|
|
10
|
+
*/
|
|
11
|
+
this.ariaDescribedBy = null;
|
|
12
|
+
/**
|
|
13
|
+
* Whether to focus the dialog when the dialog is opened
|
|
14
|
+
*/
|
|
15
|
+
this.autoFocus = true;
|
|
16
|
+
/** Whether the dialog has a backdrop. */
|
|
17
|
+
this.hasBackdrop = true;
|
|
18
|
+
/** Data being injected into the child component. */
|
|
19
|
+
this.data = null;
|
|
20
|
+
/** Whether the user can use escape or clicking outside to close a modal. */
|
|
21
|
+
this.disableClose = false;
|
|
22
|
+
/**
|
|
23
|
+
* The ARIA role of the dialog element.
|
|
24
|
+
*/
|
|
25
|
+
this.role = 'dialog';
|
|
26
|
+
/**
|
|
27
|
+
* Custom class for the pane
|
|
28
|
+
* */
|
|
29
|
+
this.paneClass = '';
|
|
30
|
+
/**
|
|
31
|
+
* Mouse Event
|
|
32
|
+
* */
|
|
33
|
+
this.event = null;
|
|
34
|
+
/**
|
|
35
|
+
* Custom class for the backdrop
|
|
36
|
+
* */
|
|
37
|
+
this.backdropClass = '';
|
|
38
|
+
/**
|
|
39
|
+
* Whether the dialog should close when the user goes backwards/forwards in history.
|
|
40
|
+
* */
|
|
41
|
+
this.closeOnNavigation = true;
|
|
42
|
+
/** Width of the dialog. */
|
|
43
|
+
this.width = '';
|
|
44
|
+
/** Height of the dialog. */
|
|
45
|
+
this.height = '';
|
|
46
|
+
/**
|
|
47
|
+
* The max-width of the overlay panel.
|
|
48
|
+
* If a number is provided, pixel units are assumed.
|
|
49
|
+
* */
|
|
50
|
+
this.maxWidth = '85vw';
|
|
51
|
+
/**
|
|
52
|
+
* The scroll strategy when the dialog is open
|
|
53
|
+
* Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies
|
|
54
|
+
* */
|
|
55
|
+
this.scrollStrategy = new NoopScrollStrategy();
|
|
56
|
+
this.id = `owl-dialog-${uniqueId++}`;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# 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":"AAAA;;GAEG;AACH,OAAO,EAAE,kBAAkB,EAAkB,MAAM,sBAAsB,CAAC;AAG1E,IAAI,QAAQ,GAAG,CAAC,CAAC;AAkHjB,MAAM,OAAO,eAAe;IAgG1B;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,GAA2B,EAAE,CAAC;QAE9C;;aAEK;QACE,UAAK,GAAe,IAAI,CAAC;QAEhC;;aAEK;QACE,kBAAa,GAA2B,EAAE,CAAC;QAElD;;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;QAK/D,IAAI,CAAC,EAAE,GAAG,cAAc,QAAQ,EAAE,EAAE,CAAC;IACvC,CAAC;CACF","sourcesContent":["/**\n * dialog-config.class\n */\nimport { NoopScrollStrategy, ScrollStrategy } from '@angular/cdk/overlay';\nimport { ViewContainerRef } from '@angular/core';\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 | Array<string>;\n\n  /**\n   * Mouse Event\n   * */\n  event?: MouseEvent;\n\n  /**\n   * Custom class for the backdrop\n   * */\n  backdropClass?: string | Array<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 | Array<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 | Array<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"]}
|