@skyux/datetime 7.0.0-beta.9 → 7.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +1633 -988
- package/esm2020/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
- package/esm2020/lib/modules/date-pipe/date.pipe.mjs +4 -5
- package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +4 -5
- package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +267 -212
- package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +14 -6
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +45 -42
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
- package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
- package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +11 -18
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +46 -23
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +29 -37
- package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +227 -217
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +217 -228
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +122 -145
- package/esm2020/lib/modules/datepicker/datepicker.module.mjs +5 -5
- package/esm2020/lib/modules/datepicker/datepicker.service.mjs +4 -4
- package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +5 -6
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +63 -63
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +146 -141
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +126 -136
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +53 -52
- package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +55 -54
- package/esm2020/lib/modules/shared/sky-datetime-resources.module.mjs +5 -5
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +109 -95
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +109 -103
- package/esm2020/lib/modules/timepicker/timepicker.module.mjs +5 -5
- package/fesm2015/skyux-datetime.mjs +1717 -1591
- package/fesm2015/skyux-datetime.mjs.map +1 -1
- package/fesm2020/skyux-datetime.mjs +1695 -1587
- package/fesm2020/skyux-datetime.mjs.map +1 -1
- package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
- package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
- package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
- package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
- package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
- package/lib/modules/datepicker/date-formatter.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
- package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
- package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +14 -69
- package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
- package/lib/modules/datepicker/datepicker.service.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
- package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
- package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
- package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
- package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
- package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
- package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
- package/package.json +12 -12
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyDatepickerCalendarInnerComponent_instances, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, _SkyDatepickerCalendarInnerComponent__selectedDate, _SkyDatepickerCalendarInnerComponent__startingDay, _SkyDatepickerCalendarInnerComponent_getCustomDate;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
2
4
|
import { Subject } from 'rxjs';
|
3
5
|
import { SkyDateFormatter } from './date-formatter';
|
@@ -9,8 +11,12 @@ let nextDatepickerId = 0;
|
|
9
11
|
*/
|
10
12
|
export class SkyDatepickerCalendarInnerComponent {
|
11
13
|
constructor() {
|
14
|
+
_SkyDatepickerCalendarInnerComponent_instances.add(this);
|
12
15
|
this.selectedDateChange = new EventEmitter(undefined);
|
13
16
|
this.calendarModeChange = new EventEmitter();
|
17
|
+
// TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.
|
18
|
+
this.activeDate = new Date();
|
19
|
+
this.activeDateId = '';
|
14
20
|
this.minMode = 'day';
|
15
21
|
this.maxMode = 'year';
|
16
22
|
this.monthColLimit = 3;
|
@@ -41,16 +47,28 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
41
47
|
39: 'right',
|
42
48
|
40: 'down',
|
43
49
|
};
|
44
|
-
this
|
50
|
+
_SkyDatepickerCalendarInnerComponent_ngUnsubscribe.set(this, new Subject());
|
51
|
+
_SkyDatepickerCalendarInnerComponent__selectedDate.set(this, void 0);
|
52
|
+
_SkyDatepickerCalendarInnerComponent__startingDay.set(this, 0);
|
53
|
+
}
|
54
|
+
set startingDay(value) {
|
55
|
+
__classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__startingDay, value || 0, "f");
|
56
|
+
}
|
57
|
+
get startingDay() {
|
58
|
+
return __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent__startingDay, "f");
|
45
59
|
}
|
46
60
|
set selectedDate(value) {
|
47
|
-
if (this.dateFormatter.dateIsValid(value)) {
|
48
|
-
this
|
61
|
+
if (value && this.dateFormatter.dateIsValid(value)) {
|
62
|
+
__classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, value, "f");
|
49
63
|
this.activeDate = value;
|
50
64
|
}
|
65
|
+
else {
|
66
|
+
__classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, undefined, "f");
|
67
|
+
this.activeDate = new Date();
|
68
|
+
}
|
51
69
|
}
|
52
70
|
get selectedDate() {
|
53
|
-
return this
|
71
|
+
return __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, "f");
|
54
72
|
}
|
55
73
|
ngOnInit() {
|
56
74
|
if (this.selectedDate) {
|
@@ -64,8 +82,8 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
64
82
|
this.refreshView();
|
65
83
|
}
|
66
84
|
ngOnDestroy() {
|
67
|
-
this.
|
68
|
-
this.
|
85
|
+
__classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, "f").next();
|
86
|
+
__classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, "f").complete();
|
69
87
|
}
|
70
88
|
setCompareHandler(handler, type) {
|
71
89
|
if (type === 'day') {
|
@@ -93,6 +111,8 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
93
111
|
if (this.datepickerMode === 'year' && this.compareHandlerYear) {
|
94
112
|
return this.compareHandlerYear(date1, date2);
|
95
113
|
}
|
114
|
+
/* istanbul ignore next */
|
115
|
+
return undefined;
|
96
116
|
}
|
97
117
|
setRefreshViewHandler(handler, type) {
|
98
118
|
if (type === 'day') {
|
@@ -170,11 +190,11 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
170
190
|
}
|
171
191
|
}
|
172
192
|
createDateObject(date, format, isSecondary, id) {
|
173
|
-
const customDateMatch = this.
|
193
|
+
const customDateMatch = __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_instances, "m", _SkyDatepickerCalendarInnerComponent_getCustomDate).call(this, date);
|
174
194
|
const dateObject = {
|
175
195
|
date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),
|
176
196
|
label: this.dateFilter(date, format),
|
177
|
-
selected: this.compare(date, this.selectedDate) === 0,
|
197
|
+
selected: !!this.selectedDate && this.compare(date, this.selectedDate) === 0,
|
178
198
|
disabled: this.isDisabled(date),
|
179
199
|
current: this.compare(date, new Date()) === 0,
|
180
200
|
secondary: isSecondary,
|
@@ -274,22 +294,25 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
274
294
|
* 2. Date is marked as disabled in the customDates array.
|
275
295
|
*/
|
276
296
|
isDisabled(date) {
|
277
|
-
const customDate = this.
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
if (this.customDates) {
|
284
|
-
return this.customDates.find((customDate) => {
|
285
|
-
return customDate.date.getTime() === date.getTime();
|
286
|
-
});
|
287
|
-
}
|
297
|
+
const customDate = __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_instances, "m", _SkyDatepickerCalendarInnerComponent_getCustomDate).call(this, date);
|
298
|
+
const minDateCompare = this.compare(date, this.minDate);
|
299
|
+
const maxDateCompare = this.compare(date, this.maxDate);
|
300
|
+
return ((minDateCompare !== undefined && minDateCompare < 0) ||
|
301
|
+
(maxDateCompare !== undefined && maxDateCompare > 0) ||
|
302
|
+
!!customDate?.disabled);
|
288
303
|
}
|
289
304
|
}
|
290
|
-
|
291
|
-
|
292
|
-
|
305
|
+
_SkyDatepickerCalendarInnerComponent_ngUnsubscribe = new WeakMap(), _SkyDatepickerCalendarInnerComponent__selectedDate = new WeakMap(), _SkyDatepickerCalendarInnerComponent__startingDay = new WeakMap(), _SkyDatepickerCalendarInnerComponent_instances = new WeakSet(), _SkyDatepickerCalendarInnerComponent_getCustomDate = function _SkyDatepickerCalendarInnerComponent_getCustomDate(date) {
|
306
|
+
if (this.customDates) {
|
307
|
+
return this.customDates.find((customDate) => {
|
308
|
+
return customDate.date.getTime() === date.getTime();
|
309
|
+
});
|
310
|
+
}
|
311
|
+
return undefined;
|
312
|
+
};
|
313
|
+
SkyDatepickerCalendarInnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
314
|
+
SkyDatepickerCalendarInnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: { customDates: "customDates", startingDay: "startingDay", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate" }, outputs: { selectedDateChange: "selectedDateChange", calendarModeChange: "calendarModeChange" }, usesOnChanges: true, ngImport: i0, template: "<div\n *ngIf=\"datepickerMode\"\n class=\"sky-datepicker-calendar-inner\"\n (keydown)=\"onKeydown($event)\"\n>\n <ng-content></ng-content>\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-chevron-modern{display:none}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner:focus-within{border:none;box-shadow:inset 0 0 0 2px #1870b8,0 1px 3px #0000004d}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron-default{display:none}.sky-theme-modern .sky-datepicker-chevron-modern{display:inline;font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
315
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, decorators: [{
|
293
316
|
type: Component,
|
294
317
|
args: [{ selector: 'sky-datepicker-inner', encapsulation: ViewEncapsulation.None, template: "<div\n *ngIf=\"datepickerMode\"\n class=\"sky-datepicker-calendar-inner\"\n (keydown)=\"onKeydown($event)\"\n>\n <ng-content></ng-content>\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-chevron-modern{display:none}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner:focus-within{border:none;box-shadow:inset 0 0 0 2px #1870b8,0 1px 3px #0000004d}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron-default{display:none}.sky-theme-modern .sky-datepicker-chevron-modern{display:inline;font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"] }]
|
295
318
|
}], propDecorators: { customDates: [{
|
@@ -307,4 +330,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
307
330
|
}], calendarModeChange: [{
|
308
331
|
type: Output
|
309
332
|
}] } });
|
310
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar-inner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\ntype DateComparator = (date1: Date, date2: Date) => number | undefined;\ntype KeyboardEventHandler = (key: string, event: KeyboardEvent) => void;\n\nlet nextDatepickerId = 0;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-inner',\n  templateUrl: './datepicker-calendar-inner.component.html',\n  styleUrls: ['./datepicker-calendar-inner.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDatepickerCalendarInnerComponent\n  implements OnDestroy, OnInit, OnChanges\n{\n  @Input()\n  public customDates: SkyDatepickerCustomDate[];\n\n  @Input()\n  public startingDay: number;\n\n  @Input()\n  public minDate: Date;\n\n  @Input()\n  public maxDate: Date;\n\n  @Input()\n  public set selectedDate(value: Date) {\n    if (this.dateFormatter.dateIsValid(value)) {\n      this._selectedDate = value;\n      this.activeDate = value;\n    }\n  }\n\n  public get selectedDate(): Date {\n    return this._selectedDate;\n  }\n\n  @Output()\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined\n  );\n\n  @Output()\n  public calendarModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  public activeDate: Date;\n  public activeDateId: string;\n\n  public minMode = 'day';\n  public maxMode = 'year';\n  public monthColLimit = 3;\n  public yearColLimit = 5;\n  public datepickerMode = 'day';\n  public yearRange = 20;\n\n  public formatDay = 'DD';\n  public formatMonth = 'MMMM';\n  public formatYear = 'YYYY';\n  public formatDayHeader = 'dd';\n  public formatDayTitle = 'MMMM YYYY';\n  public formatMonthTitle = 'YYYY';\n\n  public datepickerId = `sky-datepicker-${++nextDatepickerId}`;\n\n  public stepDay: any = {};\n  public stepMonth: any = {};\n  public stepYear: any = {};\n\n  protected modes: string[] = ['day', 'month', 'year'];\n  protected dateFormatter: SkyDateFormatter = new SkyDateFormatter();\n\n  public refreshViewHandlerDay: () => void;\n  public compareHandlerDay: DateComparator;\n  public refreshViewHandlerMonth: () => void;\n  public compareHandlerMonth: DateComparator;\n  public refreshViewHandlerYear: () => void;\n  public compareHandlerYear: DateComparator;\n\n  public handleKeydownDay: KeyboardEventHandler;\n  public handleKeydownMonth: KeyboardEventHandler;\n  public handleKeydownYear: KeyboardEventHandler;\n\n  public keys: any = {\n    13: 'enter',\n    32: 'space',\n    33: 'pageup',\n    34: 'pagedown',\n    35: 'end',\n    36: 'home',\n    37: 'left',\n    38: 'up',\n    39: 'right',\n    40: 'down',\n  };\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private _selectedDate: Date;\n\n  public ngOnInit(): void {\n    if (this.selectedDate) {\n      this.activeDate = new Date(this.selectedDate);\n    } else {\n      this.activeDate = new Date();\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  public setCompareHandler(handler: DateComparator, type: string): void {\n    if (type === 'day') {\n      this.compareHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.compareHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.compareHandlerYear = handler;\n    }\n  }\n\n  public compare(date1: Date, date2: Date): undefined | number {\n    if (date1 === undefined || date2 === undefined) {\n      return undefined;\n    }\n\n    if (this.datepickerMode === 'day' && this.compareHandlerDay) {\n      return this.compareHandlerDay(date1, date2);\n    }\n\n    if (this.datepickerMode === 'month' && this.compareHandlerMonth) {\n      return this.compareHandlerMonth(date1, date2);\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (this.datepickerMode === 'year' && this.compareHandlerYear) {\n      return this.compareHandlerYear(date1, date2);\n    }\n  }\n\n  public setRefreshViewHandler(handler: () => void, type: string): void {\n    if (type === 'day') {\n      this.refreshViewHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.refreshViewHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.refreshViewHandlerYear = handler;\n    }\n  }\n\n  public refreshView(): void {\n    if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {\n      this.refreshViewHandlerDay();\n    }\n\n    if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {\n      this.refreshViewHandlerMonth();\n    }\n\n    if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {\n      this.refreshViewHandlerYear();\n    }\n  }\n\n  public setKeydownHandler(handler: KeyboardEventHandler, type: string) {\n    if (type === 'day') {\n      this.handleKeydownDay = handler;\n    }\n\n    if (type === 'month') {\n      this.handleKeydownMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.handleKeydownYear = handler;\n    }\n  }\n\n  public handleKeydown(key: string, event: KeyboardEvent): void {\n    if (this.datepickerMode === 'day' && this.handleKeydownDay) {\n      this.handleKeydownDay(key, event);\n    }\n\n    if (this.datepickerMode === 'month' && this.handleKeydownMonth) {\n      this.handleKeydownMonth(key, event);\n    }\n\n    if (this.datepickerMode === 'year' && this.handleKeydownYear) {\n      this.handleKeydownYear(key, event);\n    }\n  }\n\n  public dateFilter(date: Date, format: string): string {\n    return this.dateFormatter.format(date, format);\n  }\n\n  public isActive(dateObject: any): boolean {\n    if (this.compare(dateObject.date, this.activeDate) === 0) {\n      this.activeDateId = dateObject.uid;\n      return true;\n    }\n\n    return false;\n  }\n\n  public onKeydown(event: KeyboardEvent) {\n    const key = this.keys[event.which];\n\n    if (!key || event.shiftKey || event.altKey) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (key === 'enter' || key === 'space') {\n      if (this.isDisabled(this.activeDate)) {\n        return;\n      }\n      this.select(this.activeDate);\n    } else if (event.ctrlKey && (key === 'up' || key === 'down')) {\n      this.toggleMode(key === 'up' ? 1 : -1);\n    } else {\n      this.handleKeydown(key, event);\n      this.refreshView();\n    }\n  }\n\n  public createDateObject(\n    date: Date,\n    format: string,\n    isSecondary: boolean,\n    id: string\n  ): SkyDatepickerDate {\n    const customDateMatch = this.getCustomDate(date);\n\n    const dateObject: SkyDatepickerDate = {\n      date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),\n      label: this.dateFilter(date, format),\n      selected: this.compare(date, this.selectedDate) === 0,\n      disabled: this.isDisabled(date),\n      current: this.compare(date, new Date()) === 0,\n      secondary: isSecondary,\n      uid: id,\n      keyDate: customDateMatch ? customDateMatch.keyDate : undefined,\n      keyDateText: customDateMatch ? customDateMatch.keyDateText : [],\n    };\n\n    return dateObject;\n  }\n\n  public createCalendarRows(\n    dates: Array<SkyDatepickerDate>,\n    size: number\n  ): Array<Array<SkyDatepickerDate>> {\n    const rows: Array<Array<SkyDatepickerDate>> = [];\n    while (dates.length > 0) {\n      rows.push(dates.splice(0, size));\n    }\n    return rows;\n  }\n\n  /*\n    This is ensures that no strangeness happens when converting a date to local time.\n  */\n  public fixTimeZone(date: Date): Date {\n    const newDate = new Date(date);\n    newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n\n    return newDate;\n  }\n\n  public selectCalendar(\n    event: Event,\n    date: Date,\n    closePicker: boolean = false\n  ) {\n    if (!closePicker) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.select(date);\n  }\n\n  public select(date: Date, isManual: boolean = true): void {\n    this.activeDate = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate()\n    );\n\n    /*\n        Only actually select date if in minmode (day picker mode).\n        Otherwise, just change the active view for the datepicker.\n    */\n    if (this.datepickerMode === this.minMode) {\n      this.selectedDate = new Date(this.activeDate);\n      if (isManual) {\n        this.selectedDateChange.emit(this.selectedDate);\n      }\n    } else {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) - 1];\n      this.calendarModeChange.emit(this.datepickerMode);\n    }\n\n    this.refreshView();\n  }\n\n  public moveCalendar(event: Event, direction: number) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.move(direction);\n  }\n\n  public move(direction: number): void {\n    let expectedStep: any;\n    if (this.datepickerMode === 'day') {\n      expectedStep = this.stepDay;\n    }\n\n    if (this.datepickerMode === 'month') {\n      expectedStep = this.stepMonth;\n    }\n\n    if (this.datepickerMode === 'year') {\n      expectedStep = this.stepYear;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (expectedStep) {\n      const year =\n        this.activeDate.getFullYear() + direction * (expectedStep.years || 0);\n      const month =\n        this.activeDate.getMonth() + direction * (expectedStep.months || 0);\n\n      this.activeDate = new Date(year, month, 1);\n\n      this.refreshView();\n    }\n  }\n\n  public toggleModeCalendar(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggleMode(1);\n  }\n\n  public toggleMode(direction: number): void {\n    /*istanbul ignore next */\n    direction = direction || 1;\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (\n      !(direction === 1 && this.datepickerMode === this.maxMode) &&\n      !(this.datepickerMode === this.minMode && direction === -1)\n    ) {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) + direction];\n      this.calendarModeChange.emit(this.datepickerMode);\n      this.refreshView();\n    }\n  }\n\n  /**\n   * Date is disabled if it meets any of these criteria:\n   * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.\n   * 2. Date is marked as disabled in the customDates array.\n   */\n  protected isDisabled(date: Date): boolean {\n    const customDate = this.getCustomDate(date);\n    return (\n      (this.minDate && this.compare(date, this.minDate) < 0) ||\n      (this.maxDate && this.compare(date, this.maxDate) > 0) ||\n      (customDate && customDate.disabled)\n    );\n  }\n  private getCustomDate(date: Date): SkyDatepickerCustomDate | undefined {\n    if (this.customDates) {\n      return this.customDates.find((customDate: SkyDatepickerCustomDate) => {\n        return customDate.date.getTime() === date.getTime();\n      });\n    }\n  }\n}\n","<div\n  *ngIf=\"datepickerMode\"\n  class=\"sky-datepicker-calendar-inner\"\n  (keydown)=\"onKeydown($event)\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar-inner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\ntype DateComparator = (date1: Date, date2: Date) => number | undefined;\ntype KeyboardEventHandler = (key: string, event: KeyboardEvent) => void;\n\nlet nextDatepickerId = 0;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-inner',\n  templateUrl: './datepicker-calendar-inner.component.html',\n  styleUrls: ['./datepicker-calendar-inner.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDatepickerCalendarInnerComponent\n  implements OnDestroy, OnInit, OnChanges\n{\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public set startingDay(value: number | undefined) {\n    this.#_startingDay = value || 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  @Input()\n  public set selectedDate(value: Date | undefined) {\n    if (value && this.dateFormatter.dateIsValid(value)) {\n      this.#_selectedDate = value;\n      this.activeDate = value;\n    } else {\n      this.#_selectedDate = undefined;\n      this.activeDate = new Date();\n    }\n  }\n\n  public get selectedDate(): Date | undefined {\n    return this.#_selectedDate;\n  }\n\n  @Output()\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined\n  );\n\n  @Output()\n  public calendarModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  // TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.\n  public activeDate = new Date();\n  public activeDateId = '';\n\n  public minMode = 'day';\n  public maxMode = 'year';\n  public monthColLimit = 3;\n  public yearColLimit = 5;\n  public datepickerMode = 'day';\n  public yearRange = 20;\n\n  public formatDay = 'DD';\n  public formatMonth = 'MMMM';\n  public formatYear = 'YYYY';\n  public formatDayHeader = 'dd';\n  public formatDayTitle = 'MMMM YYYY';\n  public formatMonthTitle = 'YYYY';\n\n  public datepickerId = `sky-datepicker-${++nextDatepickerId}`;\n\n  public stepDay: any = {};\n  public stepMonth: any = {};\n  public stepYear: any = {};\n\n  protected modes: string[] = ['day', 'month', 'year'];\n  protected dateFormatter: SkyDateFormatter = new SkyDateFormatter();\n\n  public refreshViewHandlerDay: (() => void) | undefined;\n  public compareHandlerDay: DateComparator | undefined;\n  public refreshViewHandlerMonth: (() => void) | undefined;\n  public compareHandlerMonth: DateComparator | undefined;\n  public refreshViewHandlerYear: (() => void) | undefined;\n  public compareHandlerYear: DateComparator | undefined;\n\n  public handleKeydownDay: KeyboardEventHandler | undefined;\n  public handleKeydownMonth: KeyboardEventHandler | undefined;\n  public handleKeydownYear: KeyboardEventHandler | undefined;\n\n  public keys: any = {\n    13: 'enter',\n    32: 'space',\n    33: 'pageup',\n    34: 'pagedown',\n    35: 'end',\n    36: 'home',\n    37: 'left',\n    38: 'up',\n    39: 'right',\n    40: 'down',\n  };\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_selectedDate: Date | undefined;\n  #_startingDay = 0;\n\n  public ngOnInit(): void {\n    if (this.selectedDate) {\n      this.activeDate = new Date(this.selectedDate);\n    } else {\n      this.activeDate = new Date();\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public setCompareHandler(handler: DateComparator, type: string): void {\n    if (type === 'day') {\n      this.compareHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.compareHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.compareHandlerYear = handler;\n    }\n  }\n\n  public compare(\n    date1: Date | undefined,\n    date2: Date | undefined\n  ): number | undefined {\n    if (date1 === undefined || date2 === undefined) {\n      return undefined;\n    }\n\n    if (this.datepickerMode === 'day' && this.compareHandlerDay) {\n      return this.compareHandlerDay(date1, date2);\n    }\n\n    if (this.datepickerMode === 'month' && this.compareHandlerMonth) {\n      return this.compareHandlerMonth(date1, date2);\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (this.datepickerMode === 'year' && this.compareHandlerYear) {\n      return this.compareHandlerYear(date1, date2);\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n\n  public setRefreshViewHandler(handler: () => void, type: string): void {\n    if (type === 'day') {\n      this.refreshViewHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.refreshViewHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.refreshViewHandlerYear = handler;\n    }\n  }\n\n  public refreshView(): void {\n    if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {\n      this.refreshViewHandlerDay();\n    }\n\n    if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {\n      this.refreshViewHandlerMonth();\n    }\n\n    if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {\n      this.refreshViewHandlerYear();\n    }\n  }\n\n  public setKeydownHandler(handler: KeyboardEventHandler, type: string) {\n    if (type === 'day') {\n      this.handleKeydownDay = handler;\n    }\n\n    if (type === 'month') {\n      this.handleKeydownMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.handleKeydownYear = handler;\n    }\n  }\n\n  public handleKeydown(key: string, event: KeyboardEvent): void {\n    if (this.datepickerMode === 'day' && this.handleKeydownDay) {\n      this.handleKeydownDay(key, event);\n    }\n\n    if (this.datepickerMode === 'month' && this.handleKeydownMonth) {\n      this.handleKeydownMonth(key, event);\n    }\n\n    if (this.datepickerMode === 'year' && this.handleKeydownYear) {\n      this.handleKeydownYear(key, event);\n    }\n  }\n\n  public dateFilter(date: Date, format: string): string {\n    return this.dateFormatter.format(date, format);\n  }\n\n  public isActive(dateObject: any): boolean {\n    if (this.compare(dateObject.date, this.activeDate) === 0) {\n      this.activeDateId = dateObject.uid;\n      return true;\n    }\n\n    return false;\n  }\n\n  public onKeydown(event: KeyboardEvent) {\n    const key = this.keys[event.which];\n\n    if (!key || event.shiftKey || event.altKey) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (key === 'enter' || key === 'space') {\n      if (this.isDisabled(this.activeDate)) {\n        return;\n      }\n      this.select(this.activeDate);\n    } else if (event.ctrlKey && (key === 'up' || key === 'down')) {\n      this.toggleMode(key === 'up' ? 1 : -1);\n    } else {\n      this.handleKeydown(key, event);\n      this.refreshView();\n    }\n  }\n\n  public createDateObject(\n    date: Date,\n    format: string,\n    isSecondary: boolean,\n    id: string\n  ): SkyDatepickerDate {\n    const customDateMatch = this.#getCustomDate(date);\n\n    const dateObject: SkyDatepickerDate = {\n      date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),\n      label: this.dateFilter(date, format),\n      selected:\n        !!this.selectedDate && this.compare(date, this.selectedDate) === 0,\n      disabled: this.isDisabled(date),\n      current: this.compare(date, new Date()) === 0,\n      secondary: isSecondary,\n      uid: id,\n      keyDate: customDateMatch ? customDateMatch.keyDate : undefined,\n      keyDateText: customDateMatch ? customDateMatch.keyDateText : [],\n    };\n\n    return dateObject;\n  }\n\n  public createCalendarRows(\n    dates: Array<SkyDatepickerDate>,\n    size: number\n  ): Array<Array<SkyDatepickerDate>> {\n    const rows: Array<Array<SkyDatepickerDate>> = [];\n    while (dates.length > 0) {\n      rows.push(dates.splice(0, size));\n    }\n    return rows;\n  }\n\n  /*\n    This is ensures that no strangeness happens when converting a date to local time.\n  */\n  public fixTimeZone(date: Date): Date {\n    const newDate = new Date(date);\n    newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n\n    return newDate;\n  }\n\n  public selectCalendar(\n    event: Event,\n    date: Date,\n    closePicker: boolean = false\n  ) {\n    if (!closePicker) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.select(date);\n  }\n\n  public select(date: Date, isManual: boolean = true): void {\n    this.activeDate = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate()\n    );\n\n    /*\n        Only actually select date if in minmode (day picker mode).\n        Otherwise, just change the active view for the datepicker.\n    */\n    if (this.datepickerMode === this.minMode) {\n      this.selectedDate = new Date(this.activeDate);\n      if (isManual) {\n        this.selectedDateChange.emit(this.selectedDate);\n      }\n    } else {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) - 1];\n      this.calendarModeChange.emit(this.datepickerMode);\n    }\n\n    this.refreshView();\n  }\n\n  public moveCalendar(event: Event, direction: number) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.move(direction);\n  }\n\n  public move(direction: number): void {\n    let expectedStep: any;\n    if (this.datepickerMode === 'day') {\n      expectedStep = this.stepDay;\n    }\n\n    if (this.datepickerMode === 'month') {\n      expectedStep = this.stepMonth;\n    }\n\n    if (this.datepickerMode === 'year') {\n      expectedStep = this.stepYear;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (expectedStep) {\n      const year =\n        this.activeDate.getFullYear() + direction * (expectedStep.years || 0);\n      const month =\n        this.activeDate.getMonth() + direction * (expectedStep.months || 0);\n\n      this.activeDate = new Date(year, month, 1);\n\n      this.refreshView();\n    }\n  }\n\n  public toggleModeCalendar(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggleMode(1);\n  }\n\n  public toggleMode(direction: number): void {\n    /*istanbul ignore next */\n    direction = direction || 1;\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (\n      !(direction === 1 && this.datepickerMode === this.maxMode) &&\n      !(this.datepickerMode === this.minMode && direction === -1)\n    ) {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) + direction];\n      this.calendarModeChange.emit(this.datepickerMode);\n      this.refreshView();\n    }\n  }\n\n  /**\n   * Date is disabled if it meets any of these criteria:\n   * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.\n   * 2. Date is marked as disabled in the customDates array.\n   */\n  protected isDisabled(date: Date): boolean {\n    const customDate = this.#getCustomDate(date);\n    const minDateCompare = this.compare(date, this.minDate);\n    const maxDateCompare = this.compare(date, this.maxDate);\n\n    return (\n      (minDateCompare !== undefined && minDateCompare < 0) ||\n      (maxDateCompare !== undefined && maxDateCompare > 0) ||\n      !!customDate?.disabled\n    );\n  }\n\n  #getCustomDate(date: Date): SkyDatepickerCustomDate | undefined {\n    if (this.customDates) {\n      return this.customDates.find((customDate: SkyDatepickerCustomDate) => {\n        return customDate.date.getTime() === date.getTime();\n      });\n    }\n    return undefined;\n  }\n}\n","<div\n  *ngIf=\"datepickerMode\"\n  class=\"sky-datepicker-calendar-inner\"\n  (keydown)=\"onKeydown($event)\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
|
@@ -1,49 +1,39 @@
|
|
1
|
-
|
1
|
+
var _SkyDatepickerCalendarComponent_formatter, _SkyDatepickerCalendarComponent__startingDay, _SkyDatepickerCalendarComponent_config;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
3
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
2
4
|
import { SkyDateFormatter } from './date-formatter';
|
3
5
|
import { SkyDatepickerAdapterService } from './datepicker-adapter.service';
|
4
6
|
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
5
|
-
import { SkyDatepickerConfigService } from './datepicker-config.service';
|
6
7
|
import * as i0 from "@angular/core";
|
7
|
-
import * as i1 from "./datepicker-
|
8
|
-
import * as i2 from "./datepicker-
|
9
|
-
import * as i3 from "./
|
10
|
-
import * as i4 from "./
|
11
|
-
import * as i5 from "./
|
12
|
-
import * as i6 from "./yearpicker.component";
|
8
|
+
import * as i1 from "./datepicker-config.service";
|
9
|
+
import * as i2 from "./datepicker-calendar-inner.component";
|
10
|
+
import * as i3 from "./daypicker.component";
|
11
|
+
import * as i4 from "./monthpicker.component";
|
12
|
+
import * as i5 from "./yearpicker.component";
|
13
13
|
/**
|
14
14
|
* @internal
|
15
15
|
*/
|
16
16
|
export class SkyDatepickerCalendarComponent {
|
17
|
-
constructor(
|
18
|
-
this.adapter = adapter;
|
19
|
-
this.config = config;
|
20
|
-
this.elementRef = elementRef;
|
17
|
+
constructor(config) {
|
21
18
|
this.calendarDateRangeChange = new EventEmitter();
|
22
19
|
this.calendarModeChange = new EventEmitter();
|
23
20
|
this.selectedDateChange = new EventEmitter(undefined);
|
24
21
|
this._now = new Date();
|
25
|
-
this
|
22
|
+
_SkyDatepickerCalendarComponent_formatter.set(this, new SkyDateFormatter());
|
23
|
+
_SkyDatepickerCalendarComponent__startingDay.set(this, 0);
|
24
|
+
_SkyDatepickerCalendarComponent_config.set(this, void 0);
|
25
|
+
__classPrivateFieldSet(this, _SkyDatepickerCalendarComponent_config, config, "f");
|
26
26
|
this.configureOptions();
|
27
27
|
}
|
28
28
|
/** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */
|
29
29
|
set startingDay(start) {
|
30
|
-
this
|
30
|
+
__classPrivateFieldSet(this, _SkyDatepickerCalendarComponent__startingDay, start ?? 0, "f");
|
31
31
|
}
|
32
32
|
get startingDay() {
|
33
|
-
return this
|
34
|
-
}
|
35
|
-
/**
|
36
|
-
* @internal
|
37
|
-
* Indicates if the calendar element's visibility property is 'visible'.
|
38
|
-
*/
|
39
|
-
get isVisible() {
|
40
|
-
return this.adapter.elementIsVisible();
|
41
|
-
}
|
42
|
-
ngAfterViewInit() {
|
43
|
-
this.adapter.init(this.elementRef);
|
33
|
+
return __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent__startingDay, "f");
|
44
34
|
}
|
45
35
|
configureOptions() {
|
46
|
-
Object.assign(this, this
|
36
|
+
Object.assign(this, __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_config, "f"));
|
47
37
|
}
|
48
38
|
onCalendarDateRangeChange(event) {
|
49
39
|
this.calendarDateRangeChange.next(event);
|
@@ -56,27 +46,29 @@ export class SkyDatepickerCalendarComponent {
|
|
56
46
|
}
|
57
47
|
writeValue(value) {
|
58
48
|
if (value !== undefined &&
|
59
|
-
this.
|
49
|
+
__classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_formatter, "f").dateIsValid(value) &&
|
60
50
|
this.selectedDate !== undefined &&
|
61
|
-
this.
|
51
|
+
this.datepicker?.compareHandlerDay &&
|
52
|
+
this.datepicker.compareHandlerDay(value, this.selectedDate) === 0) {
|
62
53
|
return;
|
63
54
|
}
|
64
|
-
if (this.
|
55
|
+
if (value && __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_formatter, "f").dateIsValid(value)) {
|
65
56
|
this.selectedDate = value;
|
66
|
-
this.
|
57
|
+
this.datepicker?.select(value, false);
|
67
58
|
}
|
68
59
|
else {
|
69
60
|
this.selectedDate = new Date();
|
70
|
-
this.
|
61
|
+
this.datepicker?.select(new Date(), false);
|
71
62
|
}
|
72
63
|
}
|
73
64
|
}
|
74
|
-
|
75
|
-
SkyDatepickerCalendarComponent.ɵ
|
76
|
-
i0.ɵɵ
|
65
|
+
_SkyDatepickerCalendarComponent_formatter = new WeakMap(), _SkyDatepickerCalendarComponent__startingDay = new WeakMap(), _SkyDatepickerCalendarComponent_config = new WeakMap();
|
66
|
+
SkyDatepickerCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerCalendarComponent, deps: [{ token: i1.SkyDatepickerConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
67
|
+
SkyDatepickerCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: { customDates: "customDates", isDaypickerWaiting: "isDaypickerWaiting", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate", startingDay: "startingDay" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", calendarModeChange: "calendarModeChange", selectedDateChange: "selectedDateChange" }, providers: [SkyDatepickerAdapterService], viewQueries: [{ propertyName: "datepicker", first: true, predicate: SkyDatepickerCalendarInnerComponent, descendants: true, read: SkyDatepickerCalendarInnerComponent, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <sky-daypicker\n tabindex=\"0\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"], dependencies: [{ kind: "component", type: i2.SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: ["customDates", "startingDay", "minDate", "maxDate", "selectedDate"], outputs: ["selectedDateChange", "calendarModeChange"] }, { kind: "component", type: i3.SkyDayPickerComponent, selector: "sky-daypicker", inputs: ["customDates", "isWaiting"], outputs: ["calendarDateRangeChange"] }, { kind: "component", type: i4.SkyMonthPickerComponent, selector: "sky-monthpicker" }, { kind: "component", type: i5.SkyYearPickerComponent, selector: "sky-yearpicker" }] });
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerCalendarComponent, decorators: [{
|
77
69
|
type: Component,
|
78
70
|
args: [{ selector: 'sky-datepicker-calendar', providers: [SkyDatepickerAdapterService], template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <sky-daypicker\n tabindex=\"0\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"] }]
|
79
|
-
}], ctorParameters: function () { return [{ type: i1.
|
71
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDatepickerConfigService }]; }, propDecorators: { customDates: [{
|
80
72
|
type: Input
|
81
73
|
}], isDaypickerWaiting: [{
|
82
74
|
type: Input
|
@@ -94,11 +86,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
94
86
|
type: Output
|
95
87
|
}], selectedDateChange: [{
|
96
88
|
type: Output
|
97
|
-
}],
|
89
|
+
}], datepicker: [{
|
98
90
|
type: ViewChild,
|
99
91
|
args: [SkyDatepickerCalendarInnerComponent, {
|
100
92
|
read: SkyDatepickerCalendarInnerComponent,
|
101
93
|
static: true,
|
102
94
|
}]
|
103
95
|
}] } });
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerAdapterService } from './datepicker-adapter.service';\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerConfigService } from './datepicker-config.service';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-calendar',\n  templateUrl: './datepicker-calendar.component.html',\n  styleUrls: ['./datepicker-calendar.component.scss'],\n  providers: [SkyDatepickerAdapterService],\n})\nexport class SkyDatepickerCalendarComponent {\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public isDaypickerWaiting: boolean | undefined;\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  /** currently selected date */\n  @Input()\n  public selectedDate: Date | undefined;\n\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  public set startingDay(start: number | undefined) {\n    this.#_startingDay = start ?? 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Output()\n  public calendarModeChange = new EventEmitter<string>();\n\n  @Output()\n  public selectedDateChange = new EventEmitter<Date>(undefined);\n\n  @ViewChild(SkyDatepickerCalendarInnerComponent, {\n    read: SkyDatepickerCalendarInnerComponent,\n    static: true,\n  })\n  public datepicker: SkyDatepickerCalendarInnerComponent | undefined;\n\n  protected _now: Date = new Date();\n\n  #formatter = new SkyDateFormatter();\n\n  #_startingDay = 0;\n\n  #config: SkyDatepickerConfigService;\n\n  public constructor(config: SkyDatepickerConfigService) {\n    this.#config = config;\n    this.configureOptions();\n  }\n\n  public configureOptions(): void {\n    Object.assign(this, this.#config);\n  }\n\n  public onCalendarDateRangeChange(\n    event: SkyDatepickerCalendarChange | undefined\n  ): void {\n    this.calendarDateRangeChange.next(event);\n  }\n\n  public onCalendarModeChange(event: string): void {\n    this.calendarModeChange.emit(event);\n  }\n\n  public onSelectedDateChange(event: Date): void {\n    this.selectedDateChange.emit(event);\n  }\n\n  public writeValue(value: Date | undefined): void {\n    if (\n      value !== undefined &&\n      this.#formatter.dateIsValid(value) &&\n      this.selectedDate !== undefined &&\n      this.datepicker?.compareHandlerDay &&\n      this.datepicker.compareHandlerDay(value, this.selectedDate) === 0\n    ) {\n      return;\n    }\n\n    if (value && this.#formatter.dateIsValid(value)) {\n      this.selectedDate = value;\n      this.datepicker?.select(value, false);\n    } else {\n      this.selectedDate = new Date();\n      this.datepicker?.select(new Date(), false);\n    }\n  }\n}\n","<div class=\"sky-datepicker-calendar\">\n  <sky-datepicker-inner\n    [customDates]=\"customDates\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [selectedDate]=\"selectedDate\"\n    [startingDay]=\"startingDay\"\n    (calendarModeChange)=\"onCalendarModeChange($event)\"\n    (selectedDateChange)=\"onSelectedDateChange($event)\"\n  >\n    <sky-daypicker\n      tabindex=\"0\"\n      [customDates]=\"customDates\"\n      [isWaiting]=\"isDaypickerWaiting\"\n      (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n    ></sky-daypicker>\n    <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n    <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n  </sky-datepicker-inner>\n</div>\n"]}
|
@@ -10,12 +10,12 @@ export class SkyDatepickerConfigService {
|
|
10
10
|
this.startingDay = 0;
|
11
11
|
}
|
12
12
|
}
|
13
|
-
SkyDatepickerConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.
|
14
|
-
SkyDatepickerConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.
|
13
|
+
SkyDatepickerConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
14
|
+
SkyDatepickerConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerConfigService, providedIn: 'root' });
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerConfigService, decorators: [{
|
16
16
|
type: Injectable,
|
17
17
|
args: [{
|
18
18
|
providedIn: 'root',
|
19
19
|
}]
|
20
20
|
}] });
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1jb25maWcuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRldGltZS9zcmMvbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWNvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTywwQkFBMEI7SUFIdkM7UUFvQkU7Ozs7V0FJRztRQUNJLGdCQUFXLEdBQUcsQ0FBQyxDQUFDO0tBQ3hCOzt3SEF2QlksMEJBQTBCOzRIQUExQiwwQkFBMEIsY0FGekIsTUFBTTs0RkFFUCwwQkFBMEI7a0JBSHRDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5RGF0ZXBpY2tlckNvbmZpZ1NlcnZpY2Uge1xuICAvKipcbiAgICogU3BlY2lmaWVzIHRoZSBkYXRlIGZvcm1hdCBmb3IgdGhlIGlucHV0LlxuICAgKiBAZGVmYXVsdCBcIk1NL0REL1lZWVlcIlxuICAgKi9cbiAgcHVibGljIGRhdGVGb3JtYXQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogU3BlY2lmaWVzIHRoZSBsYXRlc3Qgc2VsZWN0YWJsZSBkYXRlIHRoYXQgaXMgYXZhaWxhYmxlIGluIHRoZSBjYWxlbmRhci5cbiAgICovXG4gIHB1YmxpYyBtYXhEYXRlOiBEYXRlIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgdGhlIGVhcmxpZXN0IHNlbGVjdGFibGUgZGF0ZSB0aGF0IGlzIGF2YWlsYWJsZSBpbiB0aGUgY2FsZW5kYXIuXG4gICAqL1xuICBwdWJsaWMgbWluRGF0ZTogRGF0ZSB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogU3BlY2lmaWVzIHRoZSBzdGFydGluZyBkYXkgb2YgdGhlIHdlZWsgaW4gdGhlIGNhbGVuZGFyLFxuICAgKiB3aGVyZSBgMGAgc2V0cyB0aGUgc3RhcnRpbmcgZGF5IHRvIFN1bmRheS5cbiAgICogQGRlZmF1bHQgMFxuICAgKi9cbiAgcHVibGljIHN0YXJ0aW5nRGF5ID0gMDtcbn1cbiJdfQ==
|