@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,228 @@
|
|
|
1
|
+
import { Inject, Injectable, Optional } from '@angular/core';
|
|
2
|
+
import { range } from '../../../utils/array.utils';
|
|
3
|
+
import { DEFAULT_DATE_NAMES, DEFAULT_DAY_OF_WEEK_NAMES, DEFAULT_MONTH_NAMES, SUPPORTS_INTL_API } from '../../../utils/constants';
|
|
4
|
+
import { createDate, getNumDaysInMonth } from '../../../utils/date.utils';
|
|
5
|
+
import { DateTimeAdapter, OWL_DATE_TIME_LOCALE } from '../date-time-adapter.class';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/cdk/platform";
|
|
8
|
+
export class UnixTimestampDateTimeAdapter extends DateTimeAdapter {
|
|
9
|
+
constructor(owlDateTimeLocale, platform) {
|
|
10
|
+
super();
|
|
11
|
+
this.owlDateTimeLocale = owlDateTimeLocale;
|
|
12
|
+
super.setLocale(owlDateTimeLocale);
|
|
13
|
+
// IE does its own time zone correction, so we disable this on IE.
|
|
14
|
+
this.useUtcForDisplay = !platform.TRIDENT;
|
|
15
|
+
this._clampDate = platform.TRIDENT || platform.EDGE;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Strip out unicode LTR and RTL characters. Edge and IE insert these into formatted dates while
|
|
19
|
+
* other browsers do not. We remove them to make output consistent and because they interfere with
|
|
20
|
+
* date parsing.
|
|
21
|
+
*/
|
|
22
|
+
static { this.search_ltr_rtl_pattern = '/[\u200e\u200f]/g'; }
|
|
23
|
+
static stripDirectionalityCharacters(str) {
|
|
24
|
+
return str.replace(UnixTimestampDateTimeAdapter.search_ltr_rtl_pattern, '');
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* When converting Date object to string, javascript built-in functions may return wrong
|
|
28
|
+
* results because it applies its internal DST rules. The DST rules around the world change
|
|
29
|
+
* very frequently, and the current valid rule is not always valid in previous years though.
|
|
30
|
+
* We work around this problem building a new Date object which has its internal UTC
|
|
31
|
+
* representation with the local date and time.
|
|
32
|
+
*/
|
|
33
|
+
static _format(dtf, date) {
|
|
34
|
+
const d = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()));
|
|
35
|
+
return dtf.format(d);
|
|
36
|
+
}
|
|
37
|
+
addCalendarDays(date, amount) {
|
|
38
|
+
const result = new Date(date);
|
|
39
|
+
amount = Number(amount);
|
|
40
|
+
result.setDate(result.getDate() + amount);
|
|
41
|
+
return result.getTime();
|
|
42
|
+
}
|
|
43
|
+
addCalendarMonths(date, amount) {
|
|
44
|
+
const result = new Date(date);
|
|
45
|
+
amount = Number(amount);
|
|
46
|
+
const desiredMonth = result.getMonth() + amount;
|
|
47
|
+
const dateWithDesiredMonth = new Date(0);
|
|
48
|
+
dateWithDesiredMonth.setFullYear(result.getFullYear(), desiredMonth, 1);
|
|
49
|
+
dateWithDesiredMonth.setHours(0, 0, 0, 0);
|
|
50
|
+
const daysInMonth = this.getNumDaysInMonth(dateWithDesiredMonth.getTime());
|
|
51
|
+
// Set the last day of the new month
|
|
52
|
+
// if the original date was the last day of the longer month
|
|
53
|
+
result.setMonth(desiredMonth, Math.min(daysInMonth, result.getDate()));
|
|
54
|
+
return result.getTime();
|
|
55
|
+
}
|
|
56
|
+
addCalendarYears(date, amount) {
|
|
57
|
+
return this.addCalendarMonths(date, amount * 12);
|
|
58
|
+
}
|
|
59
|
+
clone(date) {
|
|
60
|
+
return date;
|
|
61
|
+
}
|
|
62
|
+
createDate(year, month, date, hours = 0, minutes = 0, seconds = 0) {
|
|
63
|
+
return createDate(year, month, date, hours, minutes, seconds).getTime();
|
|
64
|
+
}
|
|
65
|
+
differenceInCalendarDays(dateLeft, dateRight) {
|
|
66
|
+
if (this.isValid(dateLeft) && this.isValid(dateRight)) {
|
|
67
|
+
const dateLeftStartOfDay = this.createDate(this.getYear(dateLeft), this.getMonth(dateLeft), this.getDate(dateLeft));
|
|
68
|
+
const dateRightStartOfDay = this.createDate(this.getYear(dateRight), this.getMonth(dateRight), this.getDate(dateRight));
|
|
69
|
+
const timeStampLeft = this.getTime(dateLeftStartOfDay) - new Date(dateLeftStartOfDay).getTimezoneOffset() * this.milliseondsInMinute;
|
|
70
|
+
const timeStampRight = this.getTime(dateRightStartOfDay) -
|
|
71
|
+
new Date(dateRightStartOfDay).getTimezoneOffset() * this.milliseondsInMinute;
|
|
72
|
+
return Math.round((timeStampLeft - timeStampRight) / this.millisecondsInDay);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
format(date, displayFormat) {
|
|
79
|
+
if (!this.isValid(date)) {
|
|
80
|
+
throw Error('JSNativeDate: Cannot format invalid date.');
|
|
81
|
+
}
|
|
82
|
+
const jsDate = new Date(date);
|
|
83
|
+
if (SUPPORTS_INTL_API) {
|
|
84
|
+
if (this._clampDate && (jsDate.getFullYear() < 1 || jsDate.getFullYear() > 9999)) {
|
|
85
|
+
jsDate.setFullYear(Math.max(1, Math.min(9999, jsDate.getFullYear())));
|
|
86
|
+
}
|
|
87
|
+
displayFormat = { ...displayFormat, timeZone: 'utc' };
|
|
88
|
+
const dtf = new Intl.DateTimeFormat(this.locale, displayFormat);
|
|
89
|
+
return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(UnixTimestampDateTimeAdapter._format(dtf, jsDate));
|
|
90
|
+
}
|
|
91
|
+
return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(jsDate.toDateString());
|
|
92
|
+
}
|
|
93
|
+
getDate(date) {
|
|
94
|
+
return new Date(date).getDate();
|
|
95
|
+
}
|
|
96
|
+
getDateNames() {
|
|
97
|
+
if (SUPPORTS_INTL_API) {
|
|
98
|
+
const dtf = new Intl.DateTimeFormat(this.locale, {
|
|
99
|
+
day: 'numeric',
|
|
100
|
+
timeZone: 'utc'
|
|
101
|
+
});
|
|
102
|
+
return range(31, (i) => UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, 0, i + 1))));
|
|
103
|
+
}
|
|
104
|
+
return DEFAULT_DATE_NAMES;
|
|
105
|
+
}
|
|
106
|
+
getDay(date) {
|
|
107
|
+
return new Date(date).getDay();
|
|
108
|
+
}
|
|
109
|
+
getDayOfWeekNames(style) {
|
|
110
|
+
if (SUPPORTS_INTL_API) {
|
|
111
|
+
const dtf = new Intl.DateTimeFormat(this.locale, {
|
|
112
|
+
weekday: style,
|
|
113
|
+
timeZone: 'utc'
|
|
114
|
+
});
|
|
115
|
+
return range(7, (i) => UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, 0, i + 1))));
|
|
116
|
+
}
|
|
117
|
+
return DEFAULT_DAY_OF_WEEK_NAMES[style];
|
|
118
|
+
}
|
|
119
|
+
getHours(date) {
|
|
120
|
+
return new Date(date).getHours();
|
|
121
|
+
}
|
|
122
|
+
getMinutes(date) {
|
|
123
|
+
return new Date(date).getMinutes();
|
|
124
|
+
}
|
|
125
|
+
getMonth(date) {
|
|
126
|
+
return new Date(date).getMonth();
|
|
127
|
+
}
|
|
128
|
+
getMonthNames(style) {
|
|
129
|
+
if (SUPPORTS_INTL_API) {
|
|
130
|
+
const dtf = new Intl.DateTimeFormat(this.locale, {
|
|
131
|
+
month: style,
|
|
132
|
+
timeZone: 'utc'
|
|
133
|
+
});
|
|
134
|
+
return range(12, (i) => UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, i, 1))));
|
|
135
|
+
}
|
|
136
|
+
return DEFAULT_MONTH_NAMES[style];
|
|
137
|
+
}
|
|
138
|
+
getNumDaysInMonth(date) {
|
|
139
|
+
return getNumDaysInMonth(new Date(date));
|
|
140
|
+
}
|
|
141
|
+
getSeconds(date) {
|
|
142
|
+
return new Date(date).getSeconds();
|
|
143
|
+
}
|
|
144
|
+
getTime(date) {
|
|
145
|
+
return date;
|
|
146
|
+
}
|
|
147
|
+
getYear(date) {
|
|
148
|
+
return new Date(date).getFullYear();
|
|
149
|
+
}
|
|
150
|
+
getYearName(date) {
|
|
151
|
+
if (SUPPORTS_INTL_API) {
|
|
152
|
+
const dtf = new Intl.DateTimeFormat(this.locale, {
|
|
153
|
+
year: 'numeric',
|
|
154
|
+
timeZone: 'utc'
|
|
155
|
+
});
|
|
156
|
+
return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(UnixTimestampDateTimeAdapter._format(dtf, new Date(date)));
|
|
157
|
+
}
|
|
158
|
+
return String(this.getYear(date));
|
|
159
|
+
}
|
|
160
|
+
invalid() {
|
|
161
|
+
return NaN;
|
|
162
|
+
}
|
|
163
|
+
isDateInstance(obj) {
|
|
164
|
+
return typeof obj === 'number';
|
|
165
|
+
}
|
|
166
|
+
isEqual(dateLeft, dateRight) {
|
|
167
|
+
if (this.isValid(dateLeft) && this.isValid(dateRight)) {
|
|
168
|
+
return dateLeft === dateRight;
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
return false;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
isSameDay(dateLeft, dateRight) {
|
|
175
|
+
if (this.isValid(dateLeft) && this.isValid(dateRight)) {
|
|
176
|
+
const dateLeftStartOfDay = new Date(dateLeft);
|
|
177
|
+
const dateRightStartOfDay = new Date(dateRight);
|
|
178
|
+
dateLeftStartOfDay.setHours(0, 0, 0, 0);
|
|
179
|
+
dateRightStartOfDay.setHours(0, 0, 0, 0);
|
|
180
|
+
return dateLeftStartOfDay.getTime() === dateRightStartOfDay.getTime();
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
return false;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
isValid(date) {
|
|
187
|
+
return (date || date === 0) && !isNaN(date);
|
|
188
|
+
}
|
|
189
|
+
now() {
|
|
190
|
+
return new Date().getTime();
|
|
191
|
+
}
|
|
192
|
+
parse(value, parseFormat) {
|
|
193
|
+
// There is no way using the native JS Date to set the parse format or locale
|
|
194
|
+
if (typeof value === 'number') {
|
|
195
|
+
return value;
|
|
196
|
+
}
|
|
197
|
+
return value ? new Date(Date.parse(value)).getTime() : null;
|
|
198
|
+
}
|
|
199
|
+
setHours(date, amount) {
|
|
200
|
+
const result = new Date(date);
|
|
201
|
+
result.setHours(amount);
|
|
202
|
+
return result.getTime();
|
|
203
|
+
}
|
|
204
|
+
setMinutes(date, amount) {
|
|
205
|
+
const result = new Date(date);
|
|
206
|
+
result.setMinutes(amount);
|
|
207
|
+
return result.getTime();
|
|
208
|
+
}
|
|
209
|
+
setSeconds(date, amount) {
|
|
210
|
+
const result = new Date(date);
|
|
211
|
+
result.setSeconds(amount);
|
|
212
|
+
return result.getTime();
|
|
213
|
+
}
|
|
214
|
+
toIso8601(date) {
|
|
215
|
+
return new Date(date).toISOString();
|
|
216
|
+
}
|
|
217
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UnixTimestampDateTimeAdapter, deps: [{ token: OWL_DATE_TIME_LOCALE, optional: true }, { token: i1.Platform }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
218
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UnixTimestampDateTimeAdapter }); }
|
|
219
|
+
}
|
|
220
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: UnixTimestampDateTimeAdapter, decorators: [{
|
|
221
|
+
type: Injectable
|
|
222
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
223
|
+
type: Optional
|
|
224
|
+
}, {
|
|
225
|
+
type: Inject,
|
|
226
|
+
args: [OWL_DATE_TIME_LOCALE]
|
|
227
|
+
}] }, { type: i1.Platform }] });
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"unix-timestamp-date-time-adapter.class.js","sourceRoot":"","sources":["../../../../../../../projects/picker/src/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * unix-timestamp-date-time-adapter.class\n */\n\nimport { Platform } from '@angular/cdk/platform';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { range } from '../../../utils/array.utils';\nimport {\n  DEFAULT_DATE_NAMES,\n  DEFAULT_DAY_OF_WEEK_NAMES,\n  DEFAULT_MONTH_NAMES,\n  SUPPORTS_INTL_API\n} from '../../../utils/constants';\nimport { createDate, getNumDaysInMonth } from '../../../utils/date.utils';\nimport { DateTimeAdapter, OWL_DATE_TIME_LOCALE } from '../date-time-adapter.class';\n\n@Injectable()\nexport class UnixTimestampDateTimeAdapter extends DateTimeAdapter<number> {\n  constructor(\n    @Optional()\n    @Inject(OWL_DATE_TIME_LOCALE)\n    private owlDateTimeLocale: string,\n    platform: Platform\n  ) {\n    super();\n    super.setLocale(owlDateTimeLocale);\n\n    // IE does its own time zone correction, so we disable this on IE.\n    this.useUtcForDisplay = !platform.TRIDENT;\n    this._clampDate = platform.TRIDENT || platform.EDGE;\n  }\n\n  /** Whether to clamp the date between 1 and 9999 to avoid IE and Edge errors. */\n  private readonly _clampDate: boolean;\n\n  /**\n   * Whether to use `timeZone: 'utc'` with `Intl.DateTimeFormat` when formatting dates.\n   * Without this `Intl.DateTimeFormat` sometimes chooses the wrong timeZone, which can throw off\n   * the result. (e.g. in the en-US locale `new Date(1800, 7, 14).toLocaleDateString()`\n   * will produce `'8/13/1800'`.\n   */\n  useUtcForDisplay: boolean;\n\n  /**\n   * Strip out unicode LTR and RTL characters. Edge and IE insert these into formatted dates while\n   * other browsers do not. We remove them to make output consistent and because they interfere with\n   * date parsing.\n   */\n  private static search_ltr_rtl_pattern = '/[\\u200e\\u200f]/g';\n  private static stripDirectionalityCharacters(str: string) {\n    return str.replace(UnixTimestampDateTimeAdapter.search_ltr_rtl_pattern, '');\n  }\n\n  /**\n   * When converting Date object to string, javascript built-in functions may return wrong\n   * results because it applies its internal DST rules. The DST rules around the world change\n   * very frequently, and the current valid rule is not always valid in previous years though.\n   * We work around this problem building a new Date object which has its internal UTC\n   * representation with the local date and time.\n   */\n  private static _format(dtf: Intl.DateTimeFormat, date: Date) {\n    const d = new Date(\n      Date.UTC(\n        date.getFullYear(),\n        date.getMonth(),\n        date.getDate(),\n        date.getHours(),\n        date.getMinutes(),\n        date.getSeconds(),\n        date.getMilliseconds()\n      )\n    );\n    return dtf.format(d);\n  }\n\n  addCalendarDays(date: number, amount: number): number {\n    const result = new Date(date);\n    amount = Number(amount);\n    result.setDate(result.getDate() + amount);\n    return result.getTime();\n  }\n\n  addCalendarMonths(date: number, amount: number): number {\n    const result = new Date(date);\n    amount = Number(amount);\n\n    const desiredMonth = result.getMonth() + amount;\n    const dateWithDesiredMonth = new Date(0);\n    dateWithDesiredMonth.setFullYear(result.getFullYear(), desiredMonth, 1);\n    dateWithDesiredMonth.setHours(0, 0, 0, 0);\n\n    const daysInMonth = this.getNumDaysInMonth(dateWithDesiredMonth.getTime());\n    // Set the last day of the new month\n    // if the original date was the last day of the longer month\n    result.setMonth(desiredMonth, Math.min(daysInMonth, result.getDate()));\n    return result.getTime();\n  }\n\n  addCalendarYears(date: number, amount: number): number {\n    return this.addCalendarMonths(date, amount * 12);\n  }\n\n  clone(date: number): number {\n    return date;\n  }\n\n  public createDate(\n    year: number,\n    month: number,\n    date: number,\n    hours: number = 0,\n    minutes: number = 0,\n    seconds: number = 0\n  ): number {\n    return createDate(year, month, date, hours, minutes, seconds).getTime();\n  }\n\n  differenceInCalendarDays(dateLeft: number, dateRight: number): number {\n    if (this.isValid(dateLeft) && this.isValid(dateRight)) {\n      const dateLeftStartOfDay = this.createDate(\n        this.getYear(dateLeft),\n        this.getMonth(dateLeft),\n        this.getDate(dateLeft)\n      );\n      const dateRightStartOfDay = this.createDate(\n        this.getYear(dateRight),\n        this.getMonth(dateRight),\n        this.getDate(dateRight)\n      );\n\n      const timeStampLeft =\n        this.getTime(dateLeftStartOfDay) - new Date(dateLeftStartOfDay).getTimezoneOffset() * this.milliseondsInMinute;\n      const timeStampRight =\n        this.getTime(dateRightStartOfDay) -\n        new Date(dateRightStartOfDay).getTimezoneOffset() * this.milliseondsInMinute;\n      return Math.round((timeStampLeft - timeStampRight) / this.millisecondsInDay);\n    } else {\n      return null;\n    }\n  }\n\n  format(date: number, displayFormat: any): string {\n    if (!this.isValid(date)) {\n      throw Error('JSNativeDate: Cannot format invalid date.');\n    }\n\n    const jsDate = new Date(date);\n\n    if (SUPPORTS_INTL_API) {\n      if (this._clampDate && (jsDate.getFullYear() < 1 || jsDate.getFullYear() > 9999)) {\n        jsDate.setFullYear(Math.max(1, Math.min(9999, jsDate.getFullYear())));\n      }\n\n      displayFormat = { ...displayFormat, timeZone: 'utc' };\n      const dtf = new Intl.DateTimeFormat(this.locale, displayFormat);\n      return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(\n        UnixTimestampDateTimeAdapter._format(dtf, jsDate)\n      );\n    }\n\n    return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(jsDate.toDateString());\n  }\n\n  getDate(date: number): number {\n    return new Date(date).getDate();\n  }\n\n  getDateNames(): Array<string> {\n    if (SUPPORTS_INTL_API) {\n      const dtf = new Intl.DateTimeFormat(this.locale, {\n        day: 'numeric',\n        timeZone: 'utc'\n      });\n      return range(31, (i) =>\n        UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(\n          UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, 0, i + 1))\n        )\n      );\n    }\n    return DEFAULT_DATE_NAMES;\n  }\n\n  getDay(date: number): number {\n    return new Date(date).getDay();\n  }\n\n  getDayOfWeekNames(style: 'long' | 'short' | 'narrow'): Array<string> {\n    if (SUPPORTS_INTL_API) {\n      const dtf = new Intl.DateTimeFormat(this.locale, {\n        weekday: style,\n        timeZone: 'utc'\n      });\n      return range(7, (i) =>\n        UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(\n          UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, 0, i + 1))\n        )\n      );\n    }\n\n    return DEFAULT_DAY_OF_WEEK_NAMES[style];\n  }\n\n  getHours(date: number): number {\n    return new Date(date).getHours();\n  }\n\n  getMinutes(date: number): number {\n    return new Date(date).getMinutes();\n  }\n\n  getMonth(date: number): number {\n    return new Date(date).getMonth();\n  }\n\n  getMonthNames(style: 'long' | 'short' | 'narrow'): Array<string> {\n    if (SUPPORTS_INTL_API) {\n      const dtf = new Intl.DateTimeFormat(this.locale, {\n        month: style,\n        timeZone: 'utc'\n      });\n      return range(12, (i) =>\n        UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(\n          UnixTimestampDateTimeAdapter._format(dtf, new Date(2017, i, 1))\n        )\n      );\n    }\n    return DEFAULT_MONTH_NAMES[style];\n  }\n\n  getNumDaysInMonth(date: number): number {\n    return getNumDaysInMonth(new Date(date));\n  }\n\n  getSeconds(date: number): number {\n    return new Date(date).getSeconds();\n  }\n\n  getTime(date: number): number {\n    return date;\n  }\n\n  getYear(date: number): number {\n    return new Date(date).getFullYear();\n  }\n\n  getYearName(date: number): string {\n    if (SUPPORTS_INTL_API) {\n      const dtf = new Intl.DateTimeFormat(this.locale, {\n        year: 'numeric',\n        timeZone: 'utc'\n      });\n      return UnixTimestampDateTimeAdapter.stripDirectionalityCharacters(\n        UnixTimestampDateTimeAdapter._format(dtf, new Date(date))\n      );\n    }\n    return String(this.getYear(date));\n  }\n\n  invalid(): number {\n    return NaN;\n  }\n\n  isDateInstance(obj: any): boolean {\n    return typeof obj === 'number';\n  }\n\n  isEqual(dateLeft: number, dateRight: number): boolean {\n    if (this.isValid(dateLeft) && this.isValid(dateRight)) {\n      return dateLeft === dateRight;\n    } else {\n      return false;\n    }\n  }\n\n  isSameDay(dateLeft: number, dateRight: number): boolean {\n    if (this.isValid(dateLeft) && this.isValid(dateRight)) {\n      const dateLeftStartOfDay = new Date(dateLeft);\n      const dateRightStartOfDay = new Date(dateRight);\n      dateLeftStartOfDay.setHours(0, 0, 0, 0);\n      dateRightStartOfDay.setHours(0, 0, 0, 0);\n      return dateLeftStartOfDay.getTime() === dateRightStartOfDay.getTime();\n    } else {\n      return false;\n    }\n  }\n\n  isValid(date: number): boolean {\n    return (date || date === 0) && !isNaN(date);\n  }\n\n  now(): number {\n    return new Date().getTime();\n  }\n\n  parse(value: any, parseFormat: any): number | null {\n    // There is no way using the native JS Date to set the parse format or locale\n    if (typeof value === 'number') {\n      return value;\n    }\n    return value ? new Date(Date.parse(value)).getTime() : null;\n  }\n\n  setHours(date: number, amount: number): number {\n    const result = new Date(date);\n    result.setHours(amount);\n    return result.getTime();\n  }\n\n  setMinutes(date: number, amount: number): number {\n    const result = new Date(date);\n    result.setMinutes(amount);\n    return result.getTime();\n  }\n\n  setSeconds(date: number, amount: number): number {\n    const result = new Date(date);\n    result.setSeconds(amount);\n    return result.getTime();\n  }\n\n  toIso8601(date: number): string {\n    return new Date(date).toISOString();\n  }\n}\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export const OWL_UNIX_TIMESTAMP_DATE_TIME_FORMATS = {
|
|
2
|
+
parseInput: null,
|
|
3
|
+
fullPickerInput: {
|
|
4
|
+
year: 'numeric',
|
|
5
|
+
month: 'numeric',
|
|
6
|
+
day: 'numeric',
|
|
7
|
+
hour: 'numeric',
|
|
8
|
+
minute: 'numeric'
|
|
9
|
+
},
|
|
10
|
+
datePickerInput: { year: 'numeric', month: 'numeric', day: 'numeric' },
|
|
11
|
+
timePickerInput: { hour: 'numeric', minute: 'numeric' },
|
|
12
|
+
monthYearLabel: { year: 'numeric', month: 'short' },
|
|
13
|
+
dateA11yLabel: { year: 'numeric', month: 'long', day: 'numeric' },
|
|
14
|
+
monthYearA11yLabel: { year: 'numeric', month: 'long' }
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5peC10aW1lc3RhbXAtZGF0ZS10aW1lLWZvcm1hdC5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BpY2tlci9zcmMvbGliL2RhdGUtdGltZS9hZGFwdGVyL3VuaXgtdGltZXN0YW1wLWFkYXB0ZXIvdW5peC10aW1lc3RhbXAtZGF0ZS10aW1lLWZvcm1hdC5jbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQSxNQUFNLENBQUMsTUFBTSxvQ0FBb0MsR0FBdUI7SUFDdEUsVUFBVSxFQUFFLElBQUk7SUFDaEIsZUFBZSxFQUFFO1FBQ2YsSUFBSSxFQUFFLFNBQVM7UUFDZixLQUFLLEVBQUUsU0FBUztRQUNoQixHQUFHLEVBQUUsU0FBUztRQUNkLElBQUksRUFBRSxTQUFTO1FBQ2YsTUFBTSxFQUFFLFNBQVM7S0FDbEI7SUFDRCxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRTtJQUN0RSxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUU7SUFDdkQsY0FBYyxFQUFFLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFO0lBQ25ELGFBQWEsRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsU0FBUyxFQUFFO0lBQ2pFLGtCQUFrQixFQUFFLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFO0NBQ3ZELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIHVuaXgtdGltZXN0YW1wLWRhdGUtdGltZS1mb3JtYXQuY2xhc3NcbiAqL1xuaW1wb3J0IHsgT3dsRGF0ZVRpbWVGb3JtYXRzIH0gZnJvbSAnLi4vZGF0ZS10aW1lLWZvcm1hdC5jbGFzcyc7XG5cbmV4cG9ydCBjb25zdCBPV0xfVU5JWF9USU1FU1RBTVBfREFURV9USU1FX0ZPUk1BVFM6IE93bERhdGVUaW1lRm9ybWF0cyA9IHtcbiAgcGFyc2VJbnB1dDogbnVsbCxcbiAgZnVsbFBpY2tlcklucHV0OiB7XG4gICAgeWVhcjogJ251bWVyaWMnLFxuICAgIG1vbnRoOiAnbnVtZXJpYycsXG4gICAgZGF5OiAnbnVtZXJpYycsXG4gICAgaG91cjogJ251bWVyaWMnLFxuICAgIG1pbnV0ZTogJ251bWVyaWMnXG4gIH0sXG4gIGRhdGVQaWNrZXJJbnB1dDogeyB5ZWFyOiAnbnVtZXJpYycsIG1vbnRoOiAnbnVtZXJpYycsIGRheTogJ251bWVyaWMnIH0sXG4gIHRpbWVQaWNrZXJJbnB1dDogeyBob3VyOiAnbnVtZXJpYycsIG1pbnV0ZTogJ251bWVyaWMnIH0sXG4gIG1vbnRoWWVhckxhYmVsOiB7IHllYXI6ICdudW1lcmljJywgbW9udGg6ICdzaG9ydCcgfSxcbiAgZGF0ZUExMXlMYWJlbDogeyB5ZWFyOiAnbnVtZXJpYycsIG1vbnRoOiAnbG9uZycsIGRheTogJ251bWVyaWMnIH0sXG4gIG1vbnRoWWVhckExMXlMYWJlbDogeyB5ZWFyOiAnbnVtZXJpYycsIG1vbnRoOiAnbG9uZycgfVxufTtcbiJdfQ==
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* calendar-body.component
|
|
3
|
+
*/
|
|
4
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
5
|
+
import { take } from 'rxjs/operators';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class CalendarCell {
|
|
9
|
+
constructor(value, displayValue, ariaLabel, enabled, out = false, cellClass = '') {
|
|
10
|
+
this.value = value;
|
|
11
|
+
this.displayValue = displayValue;
|
|
12
|
+
this.ariaLabel = ariaLabel;
|
|
13
|
+
this.enabled = enabled;
|
|
14
|
+
this.out = out;
|
|
15
|
+
this.cellClass = cellClass;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
export class OwlCalendarBodyComponent {
|
|
19
|
+
get owlDTCalendarBodyClass() {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
get isInSingleMode() {
|
|
23
|
+
return this.selectMode === 'single';
|
|
24
|
+
}
|
|
25
|
+
get isInRangeMode() {
|
|
26
|
+
return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
|
|
27
|
+
}
|
|
28
|
+
constructor(elmRef, ngZone) {
|
|
29
|
+
this.elmRef = elmRef;
|
|
30
|
+
this.ngZone = ngZone;
|
|
31
|
+
/**
|
|
32
|
+
* The cell number of the active cell in the table.
|
|
33
|
+
*/
|
|
34
|
+
this.activeCell = 0;
|
|
35
|
+
/**
|
|
36
|
+
* The number of columns in the table.
|
|
37
|
+
* */
|
|
38
|
+
this.numCols = 7;
|
|
39
|
+
/**
|
|
40
|
+
* The ratio (width / height) to use for the cells in the table.
|
|
41
|
+
*/
|
|
42
|
+
this.cellRatio = 1;
|
|
43
|
+
/**
|
|
44
|
+
* Emit when a calendar cell is selected
|
|
45
|
+
* */
|
|
46
|
+
this.select = new EventEmitter();
|
|
47
|
+
}
|
|
48
|
+
selectCell(cell) {
|
|
49
|
+
this.select.emit(cell);
|
|
50
|
+
}
|
|
51
|
+
isActiveCell(rowIndex, colIndex) {
|
|
52
|
+
const cellNumber = rowIndex * this.numCols + colIndex;
|
|
53
|
+
return cellNumber === this.activeCell;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Check if the cell is selected
|
|
57
|
+
*/
|
|
58
|
+
isSelected(value) {
|
|
59
|
+
if (!this.selectedValues || this.selectedValues.length === 0) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
if (this.isInSingleMode) {
|
|
63
|
+
return value === this.selectedValues[0];
|
|
64
|
+
}
|
|
65
|
+
if (this.isInRangeMode) {
|
|
66
|
+
const fromValue = this.selectedValues[0];
|
|
67
|
+
const toValue = this.selectedValues[1];
|
|
68
|
+
return value === fromValue || value === toValue;
|
|
69
|
+
}
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Check if the cell in the range
|
|
74
|
+
* */
|
|
75
|
+
isInRange(value) {
|
|
76
|
+
if (this.isInRangeMode) {
|
|
77
|
+
const fromValue = this.selectedValues[0];
|
|
78
|
+
const toValue = this.selectedValues[1];
|
|
79
|
+
if (fromValue !== null && toValue !== null) {
|
|
80
|
+
return value >= fromValue && value <= toValue;
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
return value === fromValue || value === toValue;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Check if the cell is the range from
|
|
90
|
+
* */
|
|
91
|
+
isRangeFrom(value) {
|
|
92
|
+
if (this.isInRangeMode) {
|
|
93
|
+
const fromValue = this.selectedValues[0];
|
|
94
|
+
return fromValue !== null && value === fromValue;
|
|
95
|
+
}
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Check if the cell is the range to
|
|
100
|
+
* */
|
|
101
|
+
isRangeTo(value) {
|
|
102
|
+
if (this.isInRangeMode) {
|
|
103
|
+
const toValue = this.selectedValues[1];
|
|
104
|
+
return toValue !== null && value === toValue;
|
|
105
|
+
}
|
|
106
|
+
return false;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Focus to a active cell
|
|
110
|
+
* */
|
|
111
|
+
focusActiveCell() {
|
|
112
|
+
this.ngZone.runOutsideAngular(() => {
|
|
113
|
+
this.ngZone.onStable
|
|
114
|
+
.asObservable()
|
|
115
|
+
.pipe(take(1))
|
|
116
|
+
.subscribe(() => {
|
|
117
|
+
this.elmRef.nativeElement.querySelector('.owl-dt-calendar-cell-active').focus();
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlCalendarBodyComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
122
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: OwlCalendarBodyComponent, selector: "[owl-date-time-calendar-body]", inputs: { activeCell: "activeCell", rows: "rows", numCols: "numCols", cellRatio: "cellRatio", todayValue: "todayValue", selectedValues: "selectedValues", selectMode: "selectMode" }, outputs: { select: "select" }, host: { properties: { "class.owl-dt-calendar-body": "owlDTCalendarBodyClass" } }, exportAs: ["owlDateTimeCalendarBody"], ngImport: i0, template: "<tr\n *ngFor=\"let row of rows; let rowIndex = index\"\n role=\"row\">\n <td\n *ngFor=\"let item of row; let colIndex = index\"\n [attr.aria-current]=\"item.value === todayValue ? 'date' : null\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n [attr.aria-label]=\"item.ariaLabel\"\n [attr.aria-selected]=\"isSelected(item.value)\"\n class=\"owl-dt-calendar-cell {{ item.cellClass }}\"\n [class.owl-dt-calendar-cell-active]=\"isActiveCell(rowIndex, colIndex)\"\n [class.owl-dt-calendar-cell-disabled]=\"!item.enabled\"\n [class.owl-dt-calendar-cell-in-range]=\"isInRange(item.value)\"\n [class.owl-dt-calendar-cell-range-from]=\"isRangeFrom(item.value)\"\n [class.owl-dt-calendar-cell-range-to]=\"isRangeTo(item.value)\"\n [style.paddingBottom.%]=\"(50 * cellRatio) / numCols\"\n [style.paddingTop.%]=\"(50 * cellRatio) / numCols\"\n [style.width.%]=\"100 / numCols\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n (click)=\"selectCell(item)\">\n <span\n [ngClass]=\"{\n 'owl-dt-calendar-cell-out': item.out,\n 'owl-dt-calendar-cell-today': item.value === todayValue,\n 'owl-dt-calendar-cell-selected': isSelected(item.value)\n }\"\n class=\"owl-dt-calendar-cell-content\">\n {{ item.displayValue }}\n </span>\n </td>\n</tr>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
123
|
+
}
|
|
124
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlCalendarBodyComponent, decorators: [{
|
|
125
|
+
type: Component,
|
|
126
|
+
args: [{ selector: '[owl-date-time-calendar-body]', exportAs: 'owlDateTimeCalendarBody', host: {
|
|
127
|
+
'[class.owl-dt-calendar-body]': 'owlDTCalendarBodyClass'
|
|
128
|
+
}, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, template: "<tr\n *ngFor=\"let row of rows; let rowIndex = index\"\n role=\"row\">\n <td\n *ngFor=\"let item of row; let colIndex = index\"\n [attr.aria-current]=\"item.value === todayValue ? 'date' : null\"\n [attr.aria-disabled]=\"!item.enabled || null\"\n [attr.aria-label]=\"item.ariaLabel\"\n [attr.aria-selected]=\"isSelected(item.value)\"\n class=\"owl-dt-calendar-cell {{ item.cellClass }}\"\n [class.owl-dt-calendar-cell-active]=\"isActiveCell(rowIndex, colIndex)\"\n [class.owl-dt-calendar-cell-disabled]=\"!item.enabled\"\n [class.owl-dt-calendar-cell-in-range]=\"isInRange(item.value)\"\n [class.owl-dt-calendar-cell-range-from]=\"isRangeFrom(item.value)\"\n [class.owl-dt-calendar-cell-range-to]=\"isRangeTo(item.value)\"\n [style.paddingBottom.%]=\"(50 * cellRatio) / numCols\"\n [style.paddingTop.%]=\"(50 * cellRatio) / numCols\"\n [style.width.%]=\"100 / numCols\"\n [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n (click)=\"selectCell(item)\">\n <span\n [ngClass]=\"{\n 'owl-dt-calendar-cell-out': item.out,\n 'owl-dt-calendar-cell-today': item.value === todayValue,\n 'owl-dt-calendar-cell-selected': isSelected(item.value)\n }\"\n class=\"owl-dt-calendar-cell-content\">\n {{ item.displayValue }}\n </span>\n </td>\n</tr>\n" }]
|
|
129
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }], propDecorators: { activeCell: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], rows: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], numCols: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], cellRatio: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], todayValue: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], selectedValues: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], selectMode: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], select: [{
|
|
144
|
+
type: Output
|
|
145
|
+
}] } });
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-body.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/calendar-body.component.ts","../../../../../projects/picker/src/lib/date-time/calendar-body.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * calendar-body.component\n */\n\nimport { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, NgZone, Output } from '@angular/core';\nimport { take } from 'rxjs/operators';\nimport { SelectMode } from './date-time.class';\n\nexport class CalendarCell {\n  constructor(\n    public value: number,\n    public displayValue: string,\n    public ariaLabel: string,\n    public enabled: boolean,\n    public out: boolean = false,\n    public cellClass: string = ''\n  ) {}\n}\n\n@Component({\n  selector: '[owl-date-time-calendar-body]',\n  exportAs: 'owlDateTimeCalendarBody',\n  templateUrl: './calendar-body.component.html',\n  styleUrls: ['./calendar-body.component.scss'],\n  host: {\n    '[class.owl-dt-calendar-body]': 'owlDTCalendarBodyClass'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlCalendarBodyComponent {\n  /**\n   * The cell number of the active cell in the table.\n   */\n  @Input()\n  activeCell = 0;\n\n  /**\n   * The cells to display in the table.\n   * */\n  @Input()\n  rows: Array<Array<CalendarCell>>;\n\n  /**\n   * The number of columns in the table.\n   * */\n  @Input()\n  numCols = 7;\n\n  /**\n   * The ratio (width / height) to use for the cells in the table.\n   */\n  @Input()\n  cellRatio = 1;\n\n  /**\n   * The value in the table that corresponds to today.\n   * */\n  @Input()\n  todayValue: number;\n\n  /**\n   * The value in the table that is currently selected.\n   * */\n  @Input()\n  selectedValues: Array<number>;\n\n  /**\n   * Current picker select mode\n   */\n  @Input()\n  selectMode: SelectMode;\n\n  /**\n   * Emit when a calendar cell is selected\n   * */\n  @Output()\n  public readonly select = new EventEmitter<CalendarCell>();\n\n  get owlDTCalendarBodyClass(): boolean {\n    return true;\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';\n  }\n\n  constructor(\n    private elmRef: ElementRef,\n    private ngZone: NgZone\n  ) {}\n\n  public selectCell(cell: CalendarCell): void {\n    this.select.emit(cell);\n  }\n\n  public isActiveCell(rowIndex: number, colIndex: number): boolean {\n    const cellNumber = rowIndex * this.numCols + colIndex;\n    return cellNumber === this.activeCell;\n  }\n\n  /**\n   * Check if the cell is selected\n   */\n  public isSelected(value: number): boolean {\n    if (!this.selectedValues || this.selectedValues.length === 0) {\n      return false;\n    }\n\n    if (this.isInSingleMode) {\n      return value === this.selectedValues[0];\n    }\n\n    if (this.isInRangeMode) {\n      const fromValue = this.selectedValues[0];\n      const toValue = this.selectedValues[1];\n\n      return value === fromValue || value === toValue;\n    }\n\n    return false;\n  }\n\n  /**\n   * Check if the cell in the range\n   * */\n  public isInRange(value: number): boolean {\n    if (this.isInRangeMode) {\n      const fromValue = this.selectedValues[0];\n      const toValue = this.selectedValues[1];\n\n      if (fromValue !== null && toValue !== null) {\n        return value >= fromValue && value <= toValue;\n      } else {\n        return value === fromValue || value === toValue;\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Check if the cell is the range from\n   * */\n  public isRangeFrom(value: number): boolean {\n    if (this.isInRangeMode) {\n      const fromValue = this.selectedValues[0];\n      return fromValue !== null && value === fromValue;\n    }\n    return false;\n  }\n\n  /**\n   * Check if the cell is the range to\n   * */\n  public isRangeTo(value: number): boolean {\n    if (this.isInRangeMode) {\n      const toValue = this.selectedValues[1];\n      return toValue !== null && value === toValue;\n    }\n    return false;\n  }\n\n  /**\n   * Focus to a active cell\n   * */\n  public focusActiveCell(): void {\n    this.ngZone.runOutsideAngular(() => {\n      this.ngZone.onStable\n        .asObservable()\n        .pipe(take(1))\n        .subscribe(() => {\n          this.elmRef.nativeElement.querySelector('.owl-dt-calendar-cell-active').focus();\n        });\n    });\n  }\n}\n","<tr\n  *ngFor=\"let row of rows; let rowIndex = index\"\n  role=\"row\">\n  <td\n    *ngFor=\"let item of row; let colIndex = index\"\n    [attr.aria-current]=\"item.value === todayValue ? 'date' : null\"\n    [attr.aria-disabled]=\"!item.enabled || null\"\n    [attr.aria-label]=\"item.ariaLabel\"\n    [attr.aria-selected]=\"isSelected(item.value)\"\n    class=\"owl-dt-calendar-cell {{ item.cellClass }}\"\n    [class.owl-dt-calendar-cell-active]=\"isActiveCell(rowIndex, colIndex)\"\n    [class.owl-dt-calendar-cell-disabled]=\"!item.enabled\"\n    [class.owl-dt-calendar-cell-in-range]=\"isInRange(item.value)\"\n    [class.owl-dt-calendar-cell-range-from]=\"isRangeFrom(item.value)\"\n    [class.owl-dt-calendar-cell-range-to]=\"isRangeTo(item.value)\"\n    [style.paddingBottom.%]=\"(50 * cellRatio) / numCols\"\n    [style.paddingTop.%]=\"(50 * cellRatio) / numCols\"\n    [style.width.%]=\"100 / numCols\"\n    [tabindex]=\"isActiveCell(rowIndex, colIndex) ? 0 : -1\"\n    (click)=\"selectCell(item)\">\n    <span\n      [ngClass]=\"{\n        'owl-dt-calendar-cell-out': item.out,\n        'owl-dt-calendar-cell-today': item.value === todayValue,\n        'owl-dt-calendar-cell-selected': isSelected(item.value)\n      }\"\n      class=\"owl-dt-calendar-cell-content\">\n      {{ item.displayValue }}\n    </span>\n  </td>\n</tr>\n"]}
|