@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.
Files changed (79) hide show
  1. package/README.md +225 -0
  2. package/assets/style/picker.min.css +1 -0
  3. package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +120 -0
  4. package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
  5. package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +253 -0
  6. package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +16 -0
  7. package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +45 -0
  8. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +228 -0
  9. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +16 -0
  10. package/esm2022/lib/date-time/calendar-body.component.mjs +146 -0
  11. package/esm2022/lib/date-time/calendar-month-view.component.mjs +436 -0
  12. package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +366 -0
  13. package/esm2022/lib/date-time/calendar-year-view.component.mjs +362 -0
  14. package/esm2022/lib/date-time/calendar.component.mjs +368 -0
  15. package/esm2022/lib/date-time/date-time-inline.component.mjs +293 -0
  16. package/esm2022/lib/date-time/date-time-picker-container.component.mjs +405 -0
  17. package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +598 -0
  18. package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
  19. package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +64 -0
  20. package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
  21. package/esm2022/lib/date-time/date-time-picker.component.mjs +564 -0
  22. package/esm2022/lib/date-time/date-time.class.mjs +176 -0
  23. package/esm2022/lib/date-time/date-time.module.mjs +83 -0
  24. package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
  25. package/esm2022/lib/date-time/options-provider.mjs +34 -0
  26. package/esm2022/lib/date-time/timer-box.component.mjs +140 -0
  27. package/esm2022/lib/date-time/timer.component.mjs +279 -0
  28. package/esm2022/lib/dialog/dialog-config.class.mjs +59 -0
  29. package/esm2022/lib/dialog/dialog-container.component.mjs +232 -0
  30. package/esm2022/lib/dialog/dialog-ref.class.mjs +134 -0
  31. package/esm2022/lib/dialog/dialog.module.mjs +26 -0
  32. package/esm2022/lib/dialog/dialog.service.mjs +228 -0
  33. package/esm2022/lib/utils/array.utils.mjs +12 -0
  34. package/esm2022/lib/utils/constants.mjs +34 -0
  35. package/esm2022/lib/utils/date.utils.mjs +49 -0
  36. package/esm2022/lib/utils/index.mjs +5 -0
  37. package/esm2022/lib/utils/object.utils.mjs +26 -0
  38. package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
  39. package/esm2022/public_api.mjs +25 -0
  40. package/fesm2022/netwin-angular-datetime-picker.mjs +5751 -0
  41. package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
  42. package/index.d.ts +5 -0
  43. package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
  44. package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
  45. package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +72 -0
  46. package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
  47. package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
  48. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +67 -0
  49. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
  50. package/lib/date-time/calendar-body.component.d.ts +79 -0
  51. package/lib/date-time/calendar-month-view.component.d.ts +141 -0
  52. package/lib/date-time/calendar-multi-year-view.component.d.ts +107 -0
  53. package/lib/date-time/calendar-year-view.component.d.ts +120 -0
  54. package/lib/date-time/calendar.component.d.ts +154 -0
  55. package/lib/date-time/date-time-inline.component.d.ts +102 -0
  56. package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
  57. package/lib/date-time/date-time-picker-input.directive.d.ts +164 -0
  58. package/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
  59. package/lib/date-time/date-time-picker-trigger.directive.d.ts +23 -0
  60. package/lib/date-time/date-time-picker.animations.d.ts +8 -0
  61. package/lib/date-time/date-time-picker.component.d.ts +173 -0
  62. package/lib/date-time/date-time.class.d.ts +103 -0
  63. package/lib/date-time/date-time.module.d.ts +23 -0
  64. package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
  65. package/lib/date-time/options-provider.d.ts +23 -0
  66. package/lib/date-time/timer-box.component.d.ts +42 -0
  67. package/lib/date-time/timer.component.d.ts +131 -0
  68. package/lib/dialog/dialog-config.class.d.ts +169 -0
  69. package/lib/dialog/dialog-container.component.d.ts +58 -0
  70. package/lib/dialog/dialog-ref.class.d.ts +51 -0
  71. package/lib/dialog/dialog.module.d.ts +11 -0
  72. package/lib/dialog/dialog.service.d.ts +76 -0
  73. package/lib/utils/array.utils.d.ts +5 -0
  74. package/lib/utils/constants.d.ts +19 -0
  75. package/lib/utils/date.utils.d.ts +12 -0
  76. package/lib/utils/index.d.ts +4 -0
  77. package/lib/utils/object.utils.d.ts +11 -0
  78. package/package.json +51 -0
  79. package/public_api.d.ts +24 -0
@@ -0,0 +1,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"]}