@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,176 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* date-time.class
|
|
3
|
+
*/
|
|
4
|
+
import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
|
|
5
|
+
import { Directive, Inject, Input, Optional } from '@angular/core';
|
|
6
|
+
import { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./adapter/date-time-adapter.class";
|
|
9
|
+
let nextUniqueId = 0;
|
|
10
|
+
export var DateView;
|
|
11
|
+
(function (DateView) {
|
|
12
|
+
DateView["MONTH"] = "month";
|
|
13
|
+
DateView["YEAR"] = "year";
|
|
14
|
+
DateView["MULTI_YEARS"] = "multi-years";
|
|
15
|
+
})(DateView || (DateView = {}));
|
|
16
|
+
export class OwlDateTime {
|
|
17
|
+
get showSecondsTimer() {
|
|
18
|
+
return this._showSecondsTimer;
|
|
19
|
+
}
|
|
20
|
+
set showSecondsTimer(val) {
|
|
21
|
+
this._showSecondsTimer = coerceBooleanProperty(val);
|
|
22
|
+
}
|
|
23
|
+
get hour12Timer() {
|
|
24
|
+
return this._hour12Timer;
|
|
25
|
+
}
|
|
26
|
+
set hour12Timer(val) {
|
|
27
|
+
this._hour12Timer = coerceBooleanProperty(val);
|
|
28
|
+
}
|
|
29
|
+
get stepHour() {
|
|
30
|
+
return this._stepHour;
|
|
31
|
+
}
|
|
32
|
+
set stepHour(val) {
|
|
33
|
+
this._stepHour = coerceNumberProperty(val, 1);
|
|
34
|
+
}
|
|
35
|
+
get stepMinute() {
|
|
36
|
+
return this._stepMinute;
|
|
37
|
+
}
|
|
38
|
+
set stepMinute(val) {
|
|
39
|
+
this._stepMinute = coerceNumberProperty(val, 1);
|
|
40
|
+
}
|
|
41
|
+
get stepSecond() {
|
|
42
|
+
return this._stepSecond;
|
|
43
|
+
}
|
|
44
|
+
set stepSecond(val) {
|
|
45
|
+
this._stepSecond = coerceNumberProperty(val, 1);
|
|
46
|
+
}
|
|
47
|
+
get firstDayOfWeek() {
|
|
48
|
+
return this._firstDayOfWeek;
|
|
49
|
+
}
|
|
50
|
+
set firstDayOfWeek(value) {
|
|
51
|
+
value = coerceNumberProperty(value);
|
|
52
|
+
if (value > 6 || value < 0) {
|
|
53
|
+
this._firstDayOfWeek = undefined;
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this._firstDayOfWeek = value;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
get hideOtherMonths() {
|
|
60
|
+
return this._hideOtherMonths;
|
|
61
|
+
}
|
|
62
|
+
set hideOtherMonths(val) {
|
|
63
|
+
this._hideOtherMonths = coerceBooleanProperty(val);
|
|
64
|
+
}
|
|
65
|
+
get id() {
|
|
66
|
+
return this._id;
|
|
67
|
+
}
|
|
68
|
+
get formatString() {
|
|
69
|
+
if (this.pickerType === 'both') {
|
|
70
|
+
return this.dateTimeFormats.fullPickerInput;
|
|
71
|
+
}
|
|
72
|
+
if (this.pickerType === 'calendar') {
|
|
73
|
+
return this.dateTimeFormats.datePickerInput;
|
|
74
|
+
}
|
|
75
|
+
return this.dateTimeFormats.timePickerInput;
|
|
76
|
+
}
|
|
77
|
+
get disabled() {
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
constructor(dateTimeAdapter, dateTimeFormats) {
|
|
81
|
+
this.dateTimeAdapter = dateTimeAdapter;
|
|
82
|
+
this.dateTimeFormats = dateTimeFormats;
|
|
83
|
+
/**
|
|
84
|
+
* Whether to show the second's timer
|
|
85
|
+
*/
|
|
86
|
+
this._showSecondsTimer = false;
|
|
87
|
+
/**
|
|
88
|
+
* Whether the timer is in hour12 format
|
|
89
|
+
*/
|
|
90
|
+
this._hour12Timer = false;
|
|
91
|
+
/**
|
|
92
|
+
* The view that the calendar should start in.
|
|
93
|
+
*/
|
|
94
|
+
this.startView = DateView.MONTH;
|
|
95
|
+
/**
|
|
96
|
+
* Whether to should only the year and multi-year views.
|
|
97
|
+
*/
|
|
98
|
+
this.yearOnly = false;
|
|
99
|
+
/**
|
|
100
|
+
* Whether to should only the multi-year view.
|
|
101
|
+
*/
|
|
102
|
+
this.multiyearOnly = false;
|
|
103
|
+
/**
|
|
104
|
+
* Hours to change per step
|
|
105
|
+
*/
|
|
106
|
+
this._stepHour = 1;
|
|
107
|
+
/**
|
|
108
|
+
* Minutes to change per step
|
|
109
|
+
*/
|
|
110
|
+
this._stepMinute = 1;
|
|
111
|
+
/**
|
|
112
|
+
* Seconds to change per step
|
|
113
|
+
*/
|
|
114
|
+
this._stepSecond = 1;
|
|
115
|
+
/**
|
|
116
|
+
* Whether to hide dates in other months at the start or end of the current month.
|
|
117
|
+
*/
|
|
118
|
+
this._hideOtherMonths = false;
|
|
119
|
+
/**
|
|
120
|
+
* Date Time Checker to check if the give dateTime is selectable
|
|
121
|
+
*/
|
|
122
|
+
this.dateTimeChecker = (dateTime) => {
|
|
123
|
+
return (!!dateTime &&
|
|
124
|
+
(!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&
|
|
125
|
+
(!this.minDateTime || this.dateTimeAdapter.compare(dateTime, this.minDateTime) >= 0) &&
|
|
126
|
+
(!this.maxDateTime || this.dateTimeAdapter.compare(dateTime, this.maxDateTime) <= 0));
|
|
127
|
+
};
|
|
128
|
+
if (!this.dateTimeAdapter) {
|
|
129
|
+
throw Error(`OwlDateTimePicker: No provider found for DateTimeAdapter. You must import one of the following ` +
|
|
130
|
+
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
131
|
+
`custom implementation.`);
|
|
132
|
+
}
|
|
133
|
+
if (!this.dateTimeFormats) {
|
|
134
|
+
throw Error(`OwlDateTimePicker: No provider found for OWL_DATE_TIME_FORMATS. You must import one of the following ` +
|
|
135
|
+
`modules at your application root: OwlNativeDateTimeModule, OwlMomentDateTimeModule, or provide a ` +
|
|
136
|
+
`custom implementation.`);
|
|
137
|
+
}
|
|
138
|
+
this._id = `owl-dt-picker-${nextUniqueId++}`;
|
|
139
|
+
}
|
|
140
|
+
getValidDate(obj) {
|
|
141
|
+
return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;
|
|
142
|
+
}
|
|
143
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTime, deps: [{ token: i1.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
144
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: OwlDateTime, inputs: { showSecondsTimer: "showSecondsTimer", hour12Timer: "hour12Timer", startView: "startView", yearOnly: "yearOnly", multiyearOnly: "multiyearOnly", stepHour: "stepHour", stepMinute: "stepMinute", stepSecond: "stepSecond", firstDayOfWeek: "firstDayOfWeek", hideOtherMonths: "hideOtherMonths" }, ngImport: i0 }); }
|
|
145
|
+
}
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTime, decorators: [{
|
|
147
|
+
type: Directive
|
|
148
|
+
}], ctorParameters: () => [{ type: i1.DateTimeAdapter, decorators: [{
|
|
149
|
+
type: Optional
|
|
150
|
+
}] }, { type: undefined, decorators: [{
|
|
151
|
+
type: Optional
|
|
152
|
+
}, {
|
|
153
|
+
type: Inject,
|
|
154
|
+
args: [OWL_DATE_TIME_FORMATS]
|
|
155
|
+
}] }], propDecorators: { showSecondsTimer: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], hour12Timer: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], startView: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], yearOnly: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], multiyearOnly: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], stepHour: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], stepMinute: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], stepSecond: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], firstDayOfWeek: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], hideOtherMonths: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}] } });
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time.class.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/date-time.class.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * date-time.class\n */\nimport { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';\nimport { Directive, EventEmitter, Inject, Input, Optional } from '@angular/core';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OWL_DATE_TIME_FORMATS, OwlDateTimeFormats } from './adapter/date-time-format.class';\n\nlet nextUniqueId = 0;\n\nexport type PickerType = 'both' | 'calendar' | 'timer';\n\nexport type PickerMode = 'popup' | 'dialog' | 'inline';\n\nexport type SelectMode = 'single' | 'range' | 'rangeFrom' | 'rangeTo';\n\nexport enum DateView {\n  MONTH = 'month',\n  YEAR = 'year',\n  MULTI_YEARS = 'multi-years'\n}\n\nexport type DateViewType = DateView.MONTH | DateView.YEAR | DateView.MULTI_YEARS;\n\n@Directive()\nexport abstract class OwlDateTime<T> {\n  /**\n   * Whether to show the second's timer\n   */\n  private _showSecondsTimer = false;\n  @Input()\n  get showSecondsTimer(): boolean {\n    return this._showSecondsTimer;\n  }\n\n  set showSecondsTimer(val: boolean) {\n    this._showSecondsTimer = coerceBooleanProperty(val);\n  }\n\n  /**\n   * Whether the timer is in hour12 format\n   */\n  private _hour12Timer = false;\n  @Input()\n  get hour12Timer(): boolean {\n    return this._hour12Timer;\n  }\n\n  set hour12Timer(val: boolean) {\n    this._hour12Timer = coerceBooleanProperty(val);\n  }\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  startView: DateViewType = DateView.MONTH;\n\n  /**\n   * Whether to should only the year and multi-year views.\n   */\n  @Input()\n  yearOnly = false;\n\n  /**\n   * Whether to should only the multi-year view.\n   */\n  @Input()\n  multiyearOnly = false;\n\n  /**\n   * Hours to change per step\n   */\n  private _stepHour = 1;\n  @Input()\n  get stepHour(): number {\n    return this._stepHour;\n  }\n\n  set stepHour(val: number) {\n    this._stepHour = coerceNumberProperty(val, 1);\n  }\n\n  /**\n   * Minutes to change per step\n   */\n  private _stepMinute = 1;\n  @Input()\n  get stepMinute(): number {\n    return this._stepMinute;\n  }\n\n  set stepMinute(val: number) {\n    this._stepMinute = coerceNumberProperty(val, 1);\n  }\n\n  /**\n   * Seconds to change per step\n   */\n  private _stepSecond = 1;\n  @Input()\n  get stepSecond(): number {\n    return this._stepSecond;\n  }\n\n  set stepSecond(val: number) {\n    this._stepSecond = coerceNumberProperty(val, 1);\n  }\n\n  /**\n   * Set the first day of week\n   */\n  private _firstDayOfWeek: number;\n  @Input()\n  get firstDayOfWeek() {\n    return this._firstDayOfWeek;\n  }\n\n  set firstDayOfWeek(value: number) {\n    value = coerceNumberProperty(value);\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  private _hideOtherMonths = false;\n  @Input()\n  get hideOtherMonths(): boolean {\n    return this._hideOtherMonths;\n  }\n\n  set hideOtherMonths(val: boolean) {\n    this._hideOtherMonths = coerceBooleanProperty(val);\n  }\n\n  private readonly _id: string;\n  get id(): string {\n    return this._id;\n  }\n\n  abstract get selected(): T | null;\n\n  abstract get selecteds(): Array<T> | null;\n\n  abstract get dateTimeFilter(): (date: T | null) => boolean;\n\n  abstract get maxDateTime(): T | null;\n\n  abstract get minDateTime(): T | null;\n\n  abstract get selectMode(): SelectMode;\n\n  abstract get startAt(): T | null;\n\n  abstract get endAt(): T | null;\n\n  abstract get opened(): boolean;\n\n  abstract get pickerMode(): PickerMode;\n\n  abstract get pickerType(): PickerType;\n\n  abstract get isInSingleMode(): boolean;\n\n  abstract get isInRangeMode(): boolean;\n\n  abstract select(date: T | Array<T>): void;\n\n  abstract yearSelected: EventEmitter<T>;\n\n  abstract monthSelected: EventEmitter<T>;\n\n  abstract dateSelected: EventEmitter<T>;\n\n  abstract selectYear(normalizedYear: T): void;\n\n  abstract selectMonth(normalizedMonth: T): void;\n\n  abstract selectDate(normalizedDate: T): void;\n\n  get formatString(): string {\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: T) => {\n    return (\n      !!dateTime &&\n      (!this.dateTimeFilter || this.dateTimeFilter(dateTime)) &&\n      (!this.minDateTime || this.dateTimeAdapter.compare(dateTime, this.minDateTime) >= 0) &&\n      (!this.maxDateTime || this.dateTimeAdapter.compare(dateTime, this.maxDateTime) <= 0)\n    );\n  };\n\n  get disabled(): boolean {\n    return false;\n  }\n\n  protected constructor(\n    @Optional() protected dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    protected dateTimeFormats: OwlDateTimeFormats\n  ) {\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-${nextUniqueId++}`;\n  }\n\n  protected getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n}\n"]}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* date-time.module
|
|
3
|
+
*/
|
|
4
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
5
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
6
|
+
import { CommonModule } from '@angular/common';
|
|
7
|
+
import { NgModule } from '@angular/core';
|
|
8
|
+
import { OwlDialogModule } from '../dialog/dialog.module';
|
|
9
|
+
import { OwlCalendarBodyComponent } from './calendar-body.component';
|
|
10
|
+
import { OwlMonthViewComponent } from './calendar-month-view.component';
|
|
11
|
+
import { OwlMultiYearViewComponent } from './calendar-multi-year-view.component';
|
|
12
|
+
import { OwlYearViewComponent } from './calendar-year-view.component';
|
|
13
|
+
import { OwlCalendarComponent } from './calendar.component';
|
|
14
|
+
import { OwlDateTimeInlineComponent } from './date-time-inline.component';
|
|
15
|
+
import { OwlDateTimeContainerComponent } from './date-time-picker-container.component';
|
|
16
|
+
import { OwlDateTimeInputDirective } from './date-time-picker-input.directive';
|
|
17
|
+
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
|
|
18
|
+
import { OwlDateTimeTriggerDirective } from './date-time-picker-trigger.directive';
|
|
19
|
+
import { OWL_DTPICKER_SCROLL_STRATEGY_PROVIDER, OwlDateTimeComponent } from './date-time-picker.component';
|
|
20
|
+
import { NumberFixedLenPipe } from './numberedFixLen.pipe';
|
|
21
|
+
import { optionsProviders } from './options-provider';
|
|
22
|
+
import { OwlTimerBoxComponent } from './timer-box.component';
|
|
23
|
+
import { OwlTimerComponent } from './timer.component';
|
|
24
|
+
import * as i0 from "@angular/core";
|
|
25
|
+
export class OwlDateTimeModule {
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTimeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
27
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTimeModule, declarations: [OwlDateTimeTriggerDirective,
|
|
28
|
+
OwlDateTimeInputDirective,
|
|
29
|
+
OwlDateTimeComponent,
|
|
30
|
+
OwlDateTimeContainerComponent,
|
|
31
|
+
OwlMultiYearViewComponent,
|
|
32
|
+
OwlYearViewComponent,
|
|
33
|
+
OwlMonthViewComponent,
|
|
34
|
+
OwlTimerComponent,
|
|
35
|
+
OwlTimerBoxComponent,
|
|
36
|
+
OwlCalendarComponent,
|
|
37
|
+
OwlCalendarBodyComponent,
|
|
38
|
+
NumberFixedLenPipe,
|
|
39
|
+
OwlDateTimeInlineComponent], imports: [CommonModule, OverlayModule, OwlDialogModule, A11yModule], exports: [OwlCalendarComponent,
|
|
40
|
+
OwlTimerComponent,
|
|
41
|
+
OwlDateTimeTriggerDirective,
|
|
42
|
+
OwlDateTimeInputDirective,
|
|
43
|
+
OwlDateTimeComponent,
|
|
44
|
+
OwlDateTimeInlineComponent,
|
|
45
|
+
OwlMultiYearViewComponent,
|
|
46
|
+
OwlYearViewComponent,
|
|
47
|
+
OwlMonthViewComponent] }); }
|
|
48
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTimeModule, providers: [OwlDateTimeIntl, OWL_DTPICKER_SCROLL_STRATEGY_PROVIDER, ...optionsProviders], imports: [CommonModule, OverlayModule, OwlDialogModule, A11yModule] }); }
|
|
49
|
+
}
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlDateTimeModule, decorators: [{
|
|
51
|
+
type: NgModule,
|
|
52
|
+
args: [{
|
|
53
|
+
imports: [CommonModule, OverlayModule, OwlDialogModule, A11yModule],
|
|
54
|
+
exports: [
|
|
55
|
+
OwlCalendarComponent,
|
|
56
|
+
OwlTimerComponent,
|
|
57
|
+
OwlDateTimeTriggerDirective,
|
|
58
|
+
OwlDateTimeInputDirective,
|
|
59
|
+
OwlDateTimeComponent,
|
|
60
|
+
OwlDateTimeInlineComponent,
|
|
61
|
+
OwlMultiYearViewComponent,
|
|
62
|
+
OwlYearViewComponent,
|
|
63
|
+
OwlMonthViewComponent
|
|
64
|
+
],
|
|
65
|
+
declarations: [
|
|
66
|
+
OwlDateTimeTriggerDirective,
|
|
67
|
+
OwlDateTimeInputDirective,
|
|
68
|
+
OwlDateTimeComponent,
|
|
69
|
+
OwlDateTimeContainerComponent,
|
|
70
|
+
OwlMultiYearViewComponent,
|
|
71
|
+
OwlYearViewComponent,
|
|
72
|
+
OwlMonthViewComponent,
|
|
73
|
+
OwlTimerComponent,
|
|
74
|
+
OwlTimerBoxComponent,
|
|
75
|
+
OwlCalendarComponent,
|
|
76
|
+
OwlCalendarBodyComponent,
|
|
77
|
+
NumberFixedLenPipe,
|
|
78
|
+
OwlDateTimeInlineComponent
|
|
79
|
+
],
|
|
80
|
+
providers: [OwlDateTimeIntl, OWL_DTPICKER_SCROLL_STRATEGY_PROVIDER, ...optionsProviders]
|
|
81
|
+
}]
|
|
82
|
+
}] });
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS10aW1lLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RhdGUtdGltZS9kYXRlLXRpbWUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDeEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDakYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDMUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDdkYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDL0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzNHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzdELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQWdDdEQsTUFBTSxPQUFPLGlCQUFpQjs4R0FBakIsaUJBQWlCOytHQUFqQixpQkFBaUIsaUJBaEIxQiwyQkFBMkI7WUFDM0IseUJBQXlCO1lBQ3pCLG9CQUFvQjtZQUNwQiw2QkFBNkI7WUFDN0IseUJBQXlCO1lBQ3pCLG9CQUFvQjtZQUNwQixxQkFBcUI7WUFDckIsaUJBQWlCO1lBQ2pCLG9CQUFvQjtZQUNwQixvQkFBb0I7WUFDcEIsd0JBQXdCO1lBQ3hCLGtCQUFrQjtZQUNsQiwwQkFBMEIsYUF6QmxCLFlBQVksRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLFVBQVUsYUFFaEUsb0JBQW9CO1lBQ3BCLGlCQUFpQjtZQUNqQiwyQkFBMkI7WUFDM0IseUJBQXlCO1lBQ3pCLG9CQUFvQjtZQUNwQiwwQkFBMEI7WUFDMUIseUJBQXlCO1lBQ3pCLG9CQUFvQjtZQUNwQixxQkFBcUI7K0dBbUJaLGlCQUFpQixhQUZqQixDQUFDLGVBQWUsRUFBRSxxQ0FBcUMsRUFBRSxHQUFHLGdCQUFnQixDQUFDLFlBM0I5RSxZQUFZLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxVQUFVOzsyRkE2QnZELGlCQUFpQjtrQkE5QjdCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxlQUFlLEVBQUUsVUFBVSxDQUFDO29CQUNuRSxPQUFPLEVBQUU7d0JBQ1Asb0JBQW9CO3dCQUNwQixpQkFBaUI7d0JBQ2pCLDJCQUEyQjt3QkFDM0IseUJBQXlCO3dCQUN6QixvQkFBb0I7d0JBQ3BCLDBCQUEwQjt3QkFDMUIseUJBQXlCO3dCQUN6QixvQkFBb0I7d0JBQ3BCLHFCQUFxQjtxQkFDdEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLDJCQUEyQjt3QkFDM0IseUJBQXlCO3dCQUN6QixvQkFBb0I7d0JBQ3BCLDZCQUE2Qjt3QkFDN0IseUJBQXlCO3dCQUN6QixvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIsaUJBQWlCO3dCQUNqQixvQkFBb0I7d0JBQ3BCLG9CQUFvQjt3QkFDcEIsd0JBQXdCO3dCQUN4QixrQkFBa0I7d0JBQ2xCLDBCQUEwQjtxQkFDM0I7b0JBQ0QsU0FBUyxFQUFFLENBQUMsZUFBZSxFQUFFLHFDQUFxQyxFQUFFLEdBQUcsZ0JBQWdCLENBQUM7aUJBQ3pGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBkYXRlLXRpbWUubW9kdWxlXG4gKi9cblxuaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE93bERpYWxvZ01vZHVsZSB9IGZyb20gJy4uL2RpYWxvZy9kaWFsb2cubW9kdWxlJztcbmltcG9ydCB7IE93bENhbGVuZGFyQm9keUNvbXBvbmVudCB9IGZyb20gJy4vY2FsZW5kYXItYm9keS5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3dsTW9udGhWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9jYWxlbmRhci1tb250aC12aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPd2xNdWx0aVllYXJWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9jYWxlbmRhci1tdWx0aS15ZWFyLXZpZXcuY29tcG9uZW50JztcbmltcG9ydCB7IE93bFllYXJWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9jYWxlbmRhci15ZWFyLXZpZXcuY29tcG9uZW50JztcbmltcG9ydCB7IE93bENhbGVuZGFyQ29tcG9uZW50IH0gZnJvbSAnLi9jYWxlbmRhci5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3dsRGF0ZVRpbWVJbmxpbmVDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtdGltZS1pbmxpbmUuY29tcG9uZW50JztcbmltcG9ydCB7IE93bERhdGVUaW1lQ29udGFpbmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlLXRpbWUtcGlja2VyLWNvbnRhaW5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgT3dsRGF0ZVRpbWVJbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vZGF0ZS10aW1lLXBpY2tlci1pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgT3dsRGF0ZVRpbWVJbnRsIH0gZnJvbSAnLi9kYXRlLXRpbWUtcGlja2VyLWludGwuc2VydmljZSc7XG5pbXBvcnQgeyBPd2xEYXRlVGltZVRyaWdnZXJEaXJlY3RpdmUgfSBmcm9tICcuL2RhdGUtdGltZS1waWNrZXItdHJpZ2dlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgT1dMX0RUUElDS0VSX1NDUk9MTF9TVFJBVEVHWV9QUk9WSURFUiwgT3dsRGF0ZVRpbWVDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtdGltZS1waWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IE51bWJlckZpeGVkTGVuUGlwZSB9IGZyb20gJy4vbnVtYmVyZWRGaXhMZW4ucGlwZSc7XG5pbXBvcnQgeyBvcHRpb25zUHJvdmlkZXJzIH0gZnJvbSAnLi9vcHRpb25zLXByb3ZpZGVyJztcbmltcG9ydCB7IE93bFRpbWVyQm94Q29tcG9uZW50IH0gZnJvbSAnLi90aW1lci1ib3guY29tcG9uZW50JztcbmltcG9ydCB7IE93bFRpbWVyQ29tcG9uZW50IH0gZnJvbSAnLi90aW1lci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBPd2xEaWFsb2dNb2R1bGUsIEExMXlNb2R1bGVdLFxuICBleHBvcnRzOiBbXG4gICAgT3dsQ2FsZW5kYXJDb21wb25lbnQsXG4gICAgT3dsVGltZXJDb21wb25lbnQsXG4gICAgT3dsRGF0ZVRpbWVUcmlnZ2VyRGlyZWN0aXZlLFxuICAgIE93bERhdGVUaW1lSW5wdXREaXJlY3RpdmUsXG4gICAgT3dsRGF0ZVRpbWVDb21wb25lbnQsXG4gICAgT3dsRGF0ZVRpbWVJbmxpbmVDb21wb25lbnQsXG4gICAgT3dsTXVsdGlZZWFyVmlld0NvbXBvbmVudCxcbiAgICBPd2xZZWFyVmlld0NvbXBvbmVudCxcbiAgICBPd2xNb250aFZpZXdDb21wb25lbnRcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgT3dsRGF0ZVRpbWVUcmlnZ2VyRGlyZWN0aXZlLFxuICAgIE93bERhdGVUaW1lSW5wdXREaXJlY3RpdmUsXG4gICAgT3dsRGF0ZVRpbWVDb21wb25lbnQsXG4gICAgT3dsRGF0ZVRpbWVDb250YWluZXJDb21wb25lbnQsXG4gICAgT3dsTXVsdGlZZWFyVmlld0NvbXBvbmVudCxcbiAgICBPd2xZZWFyVmlld0NvbXBvbmVudCxcbiAgICBPd2xNb250aFZpZXdDb21wb25lbnQsXG4gICAgT3dsVGltZXJDb21wb25lbnQsXG4gICAgT3dsVGltZXJCb3hDb21wb25lbnQsXG4gICAgT3dsQ2FsZW5kYXJDb21wb25lbnQsXG4gICAgT3dsQ2FsZW5kYXJCb2R5Q29tcG9uZW50LFxuICAgIE51bWJlckZpeGVkTGVuUGlwZSxcbiAgICBPd2xEYXRlVGltZUlubGluZUNvbXBvbmVudFxuICBdLFxuICBwcm92aWRlcnM6IFtPd2xEYXRlVGltZUludGwsIE9XTF9EVFBJQ0tFUl9TQ1JPTExfU1RSQVRFR1lfUFJPVklERVIsIC4uLm9wdGlvbnNQcm92aWRlcnNdXG59KVxuZXhwb3J0IGNsYXNzIE93bERhdGVUaW1lTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* numberFixedLen.pipe
|
|
3
|
+
*/
|
|
4
|
+
import { Pipe } from '@angular/core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class NumberFixedLenPipe {
|
|
7
|
+
transform(num, len) {
|
|
8
|
+
const number = Math.floor(num);
|
|
9
|
+
const length = Math.floor(len);
|
|
10
|
+
if (num === null || isNaN(number) || isNaN(length)) {
|
|
11
|
+
return num;
|
|
12
|
+
}
|
|
13
|
+
let numString = number.toString();
|
|
14
|
+
while (numString.length < length) {
|
|
15
|
+
numString = `0${numString}`;
|
|
16
|
+
}
|
|
17
|
+
return numString;
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: NumberFixedLenPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
20
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.7", ngImport: i0, type: NumberFixedLenPipe, name: "numberFixedLen" }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: NumberFixedLenPipe, decorators: [{
|
|
23
|
+
type: Pipe,
|
|
24
|
+
args: [{
|
|
25
|
+
name: 'numberFixedLen'
|
|
26
|
+
}]
|
|
27
|
+
}] });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyZWRGaXhMZW4ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RhdGUtdGltZS9udW1iZXJlZEZpeExlbi5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxrQkFBa0I7SUFDN0IsU0FBUyxDQUFDLEdBQVcsRUFBRSxHQUFXO1FBQ2hDLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDL0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUUvQixJQUFJLEdBQUcsS0FBSyxJQUFJLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ25ELE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQztRQUVELElBQUksU0FBUyxHQUFHLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUVsQyxPQUFPLFNBQVMsQ0FBQyxNQUFNLEdBQUcsTUFBTSxFQUFFLENBQUM7WUFDakMsU0FBUyxHQUFHLElBQU0sU0FBUyxFQUFFLENBQUM7UUFDaEMsQ0FBQztRQUVELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7OEdBaEJVLGtCQUFrQjs0R0FBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUg5QixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxnQkFBZ0I7aUJBQ3ZCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBudW1iZXJGaXhlZExlbi5waXBlXG4gKi9cblxuaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdudW1iZXJGaXhlZExlbidcbn0pXG5leHBvcnQgY2xhc3MgTnVtYmVyRml4ZWRMZW5QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShudW06IG51bWJlciwgbGVuOiBudW1iZXIpOiBhbnkge1xuICAgIGNvbnN0IG51bWJlciA9IE1hdGguZmxvb3IobnVtKTtcbiAgICBjb25zdCBsZW5ndGggPSBNYXRoLmZsb29yKGxlbik7XG5cbiAgICBpZiAobnVtID09PSBudWxsIHx8IGlzTmFOKG51bWJlcikgfHwgaXNOYU4obGVuZ3RoKSkge1xuICAgICAgcmV0dXJuIG51bTtcbiAgICB9XG5cbiAgICBsZXQgbnVtU3RyaW5nID0gbnVtYmVyLnRvU3RyaW5nKCk7XG5cbiAgICB3aGlsZSAobnVtU3RyaW5nLmxlbmd0aCA8IGxlbmd0aCkge1xuICAgICAgbnVtU3RyaW5nID0gYDAkeyAgbnVtU3RyaW5nfWA7XG4gICAgfVxuXG4gICAgcmV0dXJuIG51bVN0cmluZztcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export function defaultOptionsFactory() {
|
|
3
|
+
return DefaultOptions.create();
|
|
4
|
+
}
|
|
5
|
+
export function multiYearOptionsFactory(options) {
|
|
6
|
+
return options.multiYear;
|
|
7
|
+
}
|
|
8
|
+
export class DefaultOptions {
|
|
9
|
+
static create() {
|
|
10
|
+
// Always return new instance
|
|
11
|
+
return {
|
|
12
|
+
multiYear: {
|
|
13
|
+
yearRows: 7,
|
|
14
|
+
yearsPerRow: 3
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
export class OptionsTokens {
|
|
20
|
+
static { this.all = new InjectionToken('All options token'); }
|
|
21
|
+
static { this.multiYear = new InjectionToken('Grid view options token'); }
|
|
22
|
+
}
|
|
23
|
+
export const optionsProviders = [
|
|
24
|
+
{
|
|
25
|
+
provide: OptionsTokens.all,
|
|
26
|
+
useFactory: defaultOptionsFactory
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
provide: OptionsTokens.multiYear,
|
|
30
|
+
useFactory: multiYearOptionsFactory,
|
|
31
|
+
deps: [OptionsTokens.all]
|
|
32
|
+
}
|
|
33
|
+
];
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy1wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RhdGUtdGltZS9vcHRpb25zLXByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQVksTUFBTSxlQUFlLENBQUM7QUFFekQsTUFBTSxVQUFVLHFCQUFxQjtJQUNuQyxPQUFPLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztBQUNqQyxDQUFDO0FBQ0QsTUFBTSxVQUFVLHVCQUF1QixDQUFDLE9BQWdCO0lBQ3RELE9BQU8sT0FBTyxDQUFDLFNBQVMsQ0FBQztBQUMzQixDQUFDO0FBUUQsTUFBTSxPQUFPLGNBQWM7SUFDbEIsTUFBTSxDQUFDLE1BQU07UUFDbEIsNkJBQTZCO1FBQzdCLE9BQU87WUFDTCxTQUFTLEVBQUU7Z0JBQ1QsUUFBUSxFQUFFLENBQUM7Z0JBQ1gsV0FBVyxFQUFFLENBQUM7YUFDZjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQWdCLGFBQWE7YUFDbkIsUUFBRyxHQUFHLElBQUksY0FBYyxDQUFVLG1CQUFtQixDQUFDLENBQUM7YUFDdkQsY0FBUyxHQUFHLElBQUksY0FBYyxDQUF1Qix5QkFBeUIsQ0FBQyxDQUFDOztBQUdoRyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBb0I7SUFDL0M7UUFDRSxPQUFPLEVBQUUsYUFBYSxDQUFDLEdBQUc7UUFDMUIsVUFBVSxFQUFFLHFCQUFxQjtLQUNsQztJQUNEO1FBQ0UsT0FBTyxFQUFFLGFBQWEsQ0FBQyxTQUFTO1FBQ2hDLFVBQVUsRUFBRSx1QkFBdUI7UUFDbkMsSUFBSSxFQUFFLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQztLQUMxQjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgUHJvdmlkZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmF1bHRPcHRpb25zRmFjdG9yeSgpIHtcbiAgcmV0dXJuIERlZmF1bHRPcHRpb25zLmNyZWF0ZSgpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIG11bHRpWWVhck9wdGlvbnNGYWN0b3J5KG9wdGlvbnM6IE9wdGlvbnMpIHtcbiAgcmV0dXJuIG9wdGlvbnMubXVsdGlZZWFyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9wdGlvbnMge1xuICBtdWx0aVllYXI6IHtcbiAgICB5ZWFyc1BlclJvdzogbnVtYmVyO1xuICAgIHllYXJSb3dzOiBudW1iZXI7XG4gIH07XG59XG5leHBvcnQgY2xhc3MgRGVmYXVsdE9wdGlvbnMge1xuICBwdWJsaWMgc3RhdGljIGNyZWF0ZSgpOiBPcHRpb25zIHtcbiAgICAvLyBBbHdheXMgcmV0dXJuIG5ldyBpbnN0YW5jZVxuICAgIHJldHVybiB7XG4gICAgICBtdWx0aVllYXI6IHtcbiAgICAgICAgeWVhclJvd3M6IDcsXG4gICAgICAgIHllYXJzUGVyUm93OiAzXG4gICAgICB9XG4gICAgfTtcbiAgfVxufVxuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgT3B0aW9uc1Rva2VucyB7XG4gIHB1YmxpYyBzdGF0aWMgYWxsID0gbmV3IEluamVjdGlvblRva2VuPE9wdGlvbnM+KCdBbGwgb3B0aW9ucyB0b2tlbicpO1xuICBwdWJsaWMgc3RhdGljIG11bHRpWWVhciA9IG5ldyBJbmplY3Rpb25Ub2tlbjxPcHRpb25zWydtdWx0aVllYXInXT4oJ0dyaWQgdmlldyBvcHRpb25zIHRva2VuJyk7XG59XG5cbmV4cG9ydCBjb25zdCBvcHRpb25zUHJvdmlkZXJzOiBBcnJheTxQcm92aWRlcj4gPSBbXG4gIHtcbiAgICBwcm92aWRlOiBPcHRpb25zVG9rZW5zLmFsbCxcbiAgICB1c2VGYWN0b3J5OiBkZWZhdWx0T3B0aW9uc0ZhY3RvcnlcbiAgfSxcbiAge1xuICAgIHByb3ZpZGU6IE9wdGlvbnNUb2tlbnMubXVsdGlZZWFyLFxuICAgIHVzZUZhY3Rvcnk6IG11bHRpWWVhck9wdGlvbnNGYWN0b3J5LFxuICAgIGRlcHM6IFtPcHRpb25zVG9rZW5zLmFsbF1cbiAgfVxuXTtcbiJdfQ==
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* timer-box.component
|
|
3
|
+
*/
|
|
4
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
5
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
6
|
+
import { Subject, Subscription } from 'rxjs';
|
|
7
|
+
import { debounceTime } from 'rxjs/operators';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/common";
|
|
10
|
+
export class OwlTimerBoxComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.showDivider = false;
|
|
13
|
+
this.step = 1;
|
|
14
|
+
this.valueChange = new EventEmitter();
|
|
15
|
+
this.inputChange = new EventEmitter();
|
|
16
|
+
this.inputStream = new Subject();
|
|
17
|
+
this.inputStreamSub = Subscription.EMPTY;
|
|
18
|
+
this.hasFocus = false;
|
|
19
|
+
this.onValueInputMouseWheelBind = this.onValueInputMouseWheel.bind(this);
|
|
20
|
+
}
|
|
21
|
+
get displayValue() {
|
|
22
|
+
if (this.hasFocus) {
|
|
23
|
+
// Don't try to reformat the value that user is currently editing
|
|
24
|
+
return this.valueInput.nativeElement.value;
|
|
25
|
+
}
|
|
26
|
+
const value = this.boxValue || this.value;
|
|
27
|
+
if (value === null || isNaN(value)) {
|
|
28
|
+
return '';
|
|
29
|
+
}
|
|
30
|
+
return value < 10 ? `0${value.toString()}` : value.toString();
|
|
31
|
+
}
|
|
32
|
+
get owlDTTimerBoxClass() {
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.inputStreamSub = this.inputStream.pipe(debounceTime(750)).subscribe((val) => {
|
|
37
|
+
if (val) {
|
|
38
|
+
const inputValue = coerceNumberProperty(val, 0);
|
|
39
|
+
this.updateValueViaInput(inputValue);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
this.bindValueInputMouseWheel();
|
|
43
|
+
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
this.unbindValueInputMouseWheel();
|
|
46
|
+
this.inputStreamSub.unsubscribe();
|
|
47
|
+
}
|
|
48
|
+
upBtnClicked() {
|
|
49
|
+
this.updateValue(this.value + this.step);
|
|
50
|
+
}
|
|
51
|
+
downBtnClicked() {
|
|
52
|
+
this.updateValue(this.value - this.step);
|
|
53
|
+
}
|
|
54
|
+
handleInputChange(val) {
|
|
55
|
+
this.inputStream.next(val);
|
|
56
|
+
}
|
|
57
|
+
focusIn() {
|
|
58
|
+
this.hasFocus = true;
|
|
59
|
+
}
|
|
60
|
+
focusOut(value) {
|
|
61
|
+
this.hasFocus = false;
|
|
62
|
+
if (value) {
|
|
63
|
+
const inputValue = coerceNumberProperty(value, 0);
|
|
64
|
+
this.updateValueViaInput(inputValue);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
updateValue(value) {
|
|
68
|
+
this.valueChange.emit(value);
|
|
69
|
+
}
|
|
70
|
+
updateValueViaInput(value) {
|
|
71
|
+
if (value > this.max || value < this.min) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
this.inputChange.emit(value);
|
|
75
|
+
}
|
|
76
|
+
onValueInputMouseWheel(event) {
|
|
77
|
+
event = event || window.event;
|
|
78
|
+
const delta = event.wheelDelta || -event.deltaY || -event.detail;
|
|
79
|
+
if (delta > 0) {
|
|
80
|
+
if (!this.upBtnDisabled) {
|
|
81
|
+
this.upBtnClicked();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
else if (delta < 0) {
|
|
85
|
+
if (!this.downBtnDisabled) {
|
|
86
|
+
this.downBtnClicked();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
if (event.preventDefault) {
|
|
90
|
+
event.preventDefault();
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
event.returnValue = false;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
bindValueInputMouseWheel() {
|
|
97
|
+
this.valueInput.nativeElement.addEventListener('onwheel' in document ? 'wheel' : 'mousewheel', this.onValueInputMouseWheelBind);
|
|
98
|
+
}
|
|
99
|
+
unbindValueInputMouseWheel() {
|
|
100
|
+
this.valueInput.nativeElement.removeEventListener('onwheel' in document ? 'wheel' : 'mousewheel', this.onValueInputMouseWheelBind);
|
|
101
|
+
}
|
|
102
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlTimerBoxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: OwlTimerBoxComponent, selector: "owl-date-time-timer-box", inputs: { showDivider: "showDivider", upBtnAriaLabel: "upBtnAriaLabel", upBtnDisabled: "upBtnDisabled", downBtnAriaLabel: "downBtnAriaLabel", downBtnDisabled: "downBtnDisabled", boxValue: "boxValue", value: "value", min: "min", max: "max", step: "step", inputLabel: "inputLabel" }, outputs: { valueChange: "valueChange", inputChange: "inputChange" }, host: { properties: { "class.owl-dt-timer-box": "owlDTTimerBoxClass" } }, viewQueries: [{ propertyName: "valueInput", first: true, predicate: ["valueInput"], descendants: true, static: true }], exportAs: ["owlDateTimeTimerBox"], ngImport: i0, template: "<div\n *ngIf=\"showDivider\"\n aria-hidden=\"true\"\n class=\"owl-dt-timer-divider\"></div>\n<button\n [attr.aria-label]=\"upBtnAriaLabel\"\n [disabled]=\"upBtnDisabled\"\n (click)=\"upBtnClicked()\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"-1\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Up\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 451.847 451.846\"\n version=\"1.1\"\n viewBox=\"0 0 451.847 451.846\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M248.292,106.406l194.281,194.29c12.365,12.359,12.365,32.391,0,44.744c-12.354,12.354-32.391,12.354-44.744,0\n L225.923,173.529L54.018,345.44c-12.36,12.354-32.395,12.354-44.748,0c-12.359-12.354-12.359-32.391,0-44.75L203.554,106.4\n c6.18-6.174,14.271-9.259,22.369-9.259C234.018,97.141,242.115,100.232,248.292,106.406z\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n</button>\n<label class=\"owl-dt-timer-content\">\n <input\n #valueInput\n [value]=\"displayValue\"\n (focusin)=\"focusIn()\"\n (focusout)=\"focusOut(valueInput.value)\"\n (input)=\"handleInputChange(valueInput.value)\"\n (keydown.arrowdown)=\"!downBtnDisabled && downBtnClicked()\"\n (keydown.arrowup)=\"!upBtnDisabled && upBtnClicked()\"\n class=\"owl-dt-timer-input\"\n maxlength=\"2\" />\n <span class=\"owl-hidden-accessible\">{{ inputLabel }}</span>\n</label>\n<button\n [attr.aria-label]=\"downBtnAriaLabel\"\n [disabled]=\"downBtnDisabled\"\n (click)=\"downBtnClicked()\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"-1\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Down\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 451.847 451.846\"\n version=\"1.1\"\n viewBox=\"0 0 451.847 451.846\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M225.923,354.706c-8.098,0-16.195-3.092-22.369-9.263L9.27,151.157c-12.359-12.359-12.359-32.397,0-44.751\n c12.354-12.354,32.388-12.354,44.748,0l171.905,171.915l171.906-171.909c12.359-12.354,32.391-12.354,44.744,0\n c12.365,12.354,12.365,32.392,0,44.751L248.292,345.449C242.115,351.621,234.018,354.706,225.923,354.706z\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n</button>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
104
|
+
}
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlTimerBoxComponent, decorators: [{
|
|
106
|
+
type: Component,
|
|
107
|
+
args: [{ exportAs: 'owlDateTimeTimerBox', selector: 'owl-date-time-timer-box', preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
108
|
+
'[class.owl-dt-timer-box]': 'owlDTTimerBoxClass'
|
|
109
|
+
}, template: "<div\n *ngIf=\"showDivider\"\n aria-hidden=\"true\"\n class=\"owl-dt-timer-divider\"></div>\n<button\n [attr.aria-label]=\"upBtnAriaLabel\"\n [disabled]=\"upBtnDisabled\"\n (click)=\"upBtnClicked()\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"-1\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Up\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 451.847 451.846\"\n version=\"1.1\"\n viewBox=\"0 0 451.847 451.846\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M248.292,106.406l194.281,194.29c12.365,12.359,12.365,32.391,0,44.744c-12.354,12.354-32.391,12.354-44.744,0\n L225.923,173.529L54.018,345.44c-12.36,12.354-32.395,12.354-44.748,0c-12.359-12.354-12.359-32.391,0-44.75L203.554,106.4\n c6.18-6.174,14.271-9.259,22.369-9.259C234.018,97.141,242.115,100.232,248.292,106.406z\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n</button>\n<label class=\"owl-dt-timer-content\">\n <input\n #valueInput\n [value]=\"displayValue\"\n (focusin)=\"focusIn()\"\n (focusout)=\"focusOut(valueInput.value)\"\n (input)=\"handleInputChange(valueInput.value)\"\n (keydown.arrowdown)=\"!downBtnDisabled && downBtnClicked()\"\n (keydown.arrowup)=\"!upBtnDisabled && upBtnClicked()\"\n class=\"owl-dt-timer-input\"\n maxlength=\"2\" />\n <span class=\"owl-hidden-accessible\">{{ inputLabel }}</span>\n</label>\n<button\n [attr.aria-label]=\"downBtnAriaLabel\"\n [disabled]=\"downBtnDisabled\"\n (click)=\"downBtnClicked()\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"-1\"\n type=\"button\">\n <span\n class=\"owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Down\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 451.847 451.846\"\n version=\"1.1\"\n viewBox=\"0 0 451.847 451.846\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M225.923,354.706c-8.098,0-16.195-3.092-22.369-9.263L9.27,151.157c-12.359-12.359-12.359-32.397,0-44.751\n c12.354-12.354,32.388-12.354,44.748,0l171.905,171.915l171.906-171.909c12.359-12.354,32.391-12.354,44.744,0\n c12.365,12.354,12.365,32.392,0,44.751L248.292,345.449C242.115,351.621,234.018,354.706,225.923,354.706z\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n</button>\n" }]
|
|
110
|
+
}], propDecorators: { showDivider: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], upBtnAriaLabel: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], upBtnDisabled: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], downBtnAriaLabel: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], downBtnDisabled: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], boxValue: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], value: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], min: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], max: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], step: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}], inputLabel: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}], valueChange: [{
|
|
133
|
+
type: Output
|
|
134
|
+
}], inputChange: [{
|
|
135
|
+
type: Output
|
|
136
|
+
}], valueInput: [{
|
|
137
|
+
type: ViewChild,
|
|
138
|
+
args: ['valueInput', { static: true }]
|
|
139
|
+
}] } });
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timer-box.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/timer-box.component.ts","../../../../../projects/picker/src/lib/date-time/timer-box.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * timer-box.component\n */\n\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\n\n@Component({\n\n  exportAs: 'owlDateTimeTimerBox',\n  selector: 'owl-date-time-timer-box',\n  templateUrl: './timer-box.component.html',\n  styleUrls: ['./timer-box.component.scss'],\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.owl-dt-timer-box]': 'owlDTTimerBoxClass'\n  }\n})\nexport class OwlTimerBoxComponent implements OnInit, OnDestroy {\n  @Input() showDivider = false;\n\n  @Input() upBtnAriaLabel: string;\n\n  @Input() upBtnDisabled: boolean;\n\n  @Input() downBtnAriaLabel: string;\n\n  @Input() downBtnDisabled: boolean;\n\n  /**\n   * Value would be displayed in the box\n   * If it is null, the box would display [value]\n   * */\n  @Input() boxValue: number;\n\n  @Input() value: number;\n\n  @Input() min: number;\n\n  @Input() max: number;\n\n  @Input() step = 1;\n\n  @Input() inputLabel: string;\n\n  @Output() valueChange = new EventEmitter<number>();\n\n  @Output() inputChange = new EventEmitter<number>();\n\n  private inputStream = new Subject<string>();\n\n  private inputStreamSub = Subscription.EMPTY;\n\n  private hasFocus = false;\n\n  get displayValue(): string {\n    if (this.hasFocus) {\n      // Don't try to reformat the value that user is currently editing\n      return this.valueInput.nativeElement.value;\n    }\n\n    const value = this.boxValue || this.value;\n\n    if (value === null || isNaN(value)) {\n      return '';\n    }\n\n    return value < 10 ? `0${value.toString()}` : value.toString();\n  }\n\n  get owlDTTimerBoxClass(): boolean {\n    return true;\n  }\n\n  @ViewChild('valueInput', { static: true })\n  private valueInput: ElementRef<HTMLInputElement>;\n  private onValueInputMouseWheelBind = this.onValueInputMouseWheel.bind(this);\n\n  public ngOnInit() {\n    this.inputStreamSub = this.inputStream.pipe(debounceTime(750)).subscribe((val: string) => {\n      if (val) {\n        const inputValue = coerceNumberProperty(val, 0);\n        this.updateValueViaInput(inputValue);\n      }\n    });\n    this.bindValueInputMouseWheel();\n  }\n\n  public ngOnDestroy(): void {\n    this.unbindValueInputMouseWheel();\n    this.inputStreamSub.unsubscribe();\n  }\n\n  public upBtnClicked(): void {\n    this.updateValue(this.value + this.step);\n  }\n\n  public downBtnClicked(): void {\n    this.updateValue(this.value - this.step);\n  }\n\n  public handleInputChange(val: string): void {\n    this.inputStream.next(val);\n  }\n\n  public focusIn(): void {\n    this.hasFocus = true;\n  }\n\n  public focusOut(value: string): void {\n    this.hasFocus = false;\n    if (value) {\n      const inputValue = coerceNumberProperty(value, 0);\n      this.updateValueViaInput(inputValue);\n    }\n  }\n\n  private updateValue(value: number): void {\n    this.valueChange.emit(value);\n  }\n\n  private updateValueViaInput(value: number): void {\n    if (value > this.max || value < this.min) {\n      return;\n    }\n    this.inputChange.emit(value);\n  }\n\n  private onValueInputMouseWheel(event: any): void {\n    event = event || window.event;\n    const delta = event.wheelDelta || -event.deltaY || -event.detail;\n\n    if (delta > 0) {\n      if (!this.upBtnDisabled) {\n        this.upBtnClicked();\n      }\n    } else if (delta < 0) {\n      if (!this.downBtnDisabled) {\n        this.downBtnClicked();\n      }\n    }\n\n    if (event.preventDefault) {\n      event.preventDefault();\n    } else {\n      event.returnValue = false;\n    }\n  }\n\n  private bindValueInputMouseWheel(): void {\n    this.valueInput.nativeElement.addEventListener(\n      'onwheel' in document ? 'wheel' : 'mousewheel',\n      this.onValueInputMouseWheelBind\n    );\n  }\n\n  private unbindValueInputMouseWheel(): void {\n    this.valueInput.nativeElement.removeEventListener(\n      'onwheel' in document ? 'wheel' : 'mousewheel',\n      this.onValueInputMouseWheelBind\n    );\n  }\n}\n","<div\n  *ngIf=\"showDivider\"\n  aria-hidden=\"true\"\n  class=\"owl-dt-timer-divider\"></div>\n<button\n  [attr.aria-label]=\"upBtnAriaLabel\"\n  [disabled]=\"upBtnDisabled\"\n  (click)=\"upBtnClicked()\"\n  class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n  tabindex=\"-1\"\n  type=\"button\">\n  <span\n    class=\"owl-dt-control-button-content\"\n    tabindex=\"-1\">\n    <!-- <editor-fold desc=\"SVG Arrow Up\"> -->\n    <svg\n      xml:space=\"preserve\"\n      xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n      height=\"100%\"\n      style=\"enable-background: new 0 0 451.847 451.846\"\n      version=\"1.1\"\n      viewBox=\"0 0 451.847 451.846\"\n      width=\"100%\"\n      x=\"0px\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      y=\"0px\">\n      <path\n        d=\"M248.292,106.406l194.281,194.29c12.365,12.359,12.365,32.391,0,44.744c-12.354,12.354-32.391,12.354-44.744,0\n                        L225.923,173.529L54.018,345.44c-12.36,12.354-32.395,12.354-44.748,0c-12.359-12.354-12.359-32.391,0-44.75L203.554,106.4\n                        c6.18-6.174,14.271-9.259,22.369-9.259C234.018,97.141,242.115,100.232,248.292,106.406z\" />\n    </svg>\n    <!-- </editor-fold> -->\n  </span>\n</button>\n<label class=\"owl-dt-timer-content\">\n  <input\n    #valueInput\n    [value]=\"displayValue\"\n    (focusin)=\"focusIn()\"\n    (focusout)=\"focusOut(valueInput.value)\"\n    (input)=\"handleInputChange(valueInput.value)\"\n    (keydown.arrowdown)=\"!downBtnDisabled && downBtnClicked()\"\n    (keydown.arrowup)=\"!upBtnDisabled && upBtnClicked()\"\n    class=\"owl-dt-timer-input\"\n    maxlength=\"2\" />\n  <span class=\"owl-hidden-accessible\">{{ inputLabel }}</span>\n</label>\n<button\n  [attr.aria-label]=\"downBtnAriaLabel\"\n  [disabled]=\"downBtnDisabled\"\n  (click)=\"downBtnClicked()\"\n  class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n  tabindex=\"-1\"\n  type=\"button\">\n  <span\n    class=\"owl-dt-control-button-content\"\n    tabindex=\"-1\">\n    <!-- <editor-fold desc=\"SVG Arrow Down\"> -->\n    <svg\n      xml:space=\"preserve\"\n      xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n      height=\"100%\"\n      style=\"enable-background: new 0 0 451.847 451.846\"\n      version=\"1.1\"\n      viewBox=\"0 0 451.847 451.846\"\n      width=\"100%\"\n      x=\"0px\"\n      xmlns=\"http://www.w3.org/2000/svg\"\n      y=\"0px\">\n      <path\n        d=\"M225.923,354.706c-8.098,0-16.195-3.092-22.369-9.263L9.27,151.157c-12.359-12.359-12.359-32.397,0-44.751\n                        c12.354-12.354,32.388-12.354,44.748,0l171.905,171.915l171.906-171.909c12.359-12.354,32.391-12.354,44.744,0\n                        c12.365,12.354,12.365,32.392,0,44.751L248.292,345.449C242.115,351.621,234.018,354.706,225.923,354.706z\" />\n    </svg>\n    <!-- </editor-fold> -->\n  </span>\n</button>\n"]}
|