@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
592 lines • 60.6 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Input, Output, EventEmitter, Directive } from '@angular/core';
import { Calendar, isDateInRanges } from './calendar';
import { Subject } from 'rxjs';
import { isDate } from '../core/utils';
/**
* Sets the selction type - single, multi or range.
*/
export var CalendarSelection;
(function (CalendarSelection) {
CalendarSelection["SINGLE"] = "single";
CalendarSelection["MULTI"] = "multi";
CalendarSelection["RANGE"] = "range";
})(CalendarSelection || (CalendarSelection = {}));
export var ScrollMonth;
(function (ScrollMonth) {
ScrollMonth["PREV"] = "prev";
ScrollMonth["NEXT"] = "next";
ScrollMonth["NONE"] = "none";
})(ScrollMonth || (ScrollMonth = {}));
/** @hidden @internal */
let IgxCalendarBaseDirective = class IgxCalendarBaseDirective {
/**
* @hidden
*/
constructor() {
/**
* Sets/gets whether the outside dates (dates that are out of the current month) will be hidden.
* Default value is `false`.
* ```html
* <igx-calendar [hideOutsideDays] = "true"></igx-calendar>
* ```
* ```typescript
* let hideOutsideDays = this.calendar.hideOutsideDays;
* ```
*/
this.hideOutsideDays = false;
/**
* Emits an event when a date is selected.
* Provides reference the `selectedDates` property.
*/
this.onSelection = new EventEmitter();
/**
*@hidden
*/
this._selection = CalendarSelection.SINGLE;
/**
*@hidden
*/
this.rangeStarted = false;
/**
*@hidden
*/
this._locale = 'en';
/**
*@hidden
*/
this._disabledDates = null;
/**
*@hidden
*/
this._specialDates = null;
/**
*@hidden
*/
this._formatOptions = {
day: 'numeric',
month: 'short',
weekday: 'short',
year: 'numeric'
};
/**
*@hidden
*/
this._formatViews = {
day: false,
month: true,
year: false
};
/**
* @hidden
*/
this.monthScrollDirection = ScrollMonth.NONE;
/**
*@hidden
*/
this.scrollMonth$ = new Subject();
/**
*@hidden
*/
this.stopMonthScroll$ = new Subject();
/**
*@hidden
*/
this.startMonthScroll$ = new Subject();
/**
*@hidden
*/
this._onTouchedCallback = () => { };
/**
*@hidden
*/
this._onChangeCallback = () => { };
this.calendarModel = new Calendar();
this.viewDate = this.viewDate ? this.viewDate : new Date();
this.calendarModel.firstWeekDay = this.weekStart;
this.initFormatters();
}
/**
* Gets the start day of the week.
* Can return a numeric or an enum representation of the week day.
* Defaults to `Sunday` / `0`.
*/
get weekStart() {
return this.calendarModel.firstWeekDay;
}
/**
* Sets the start day of the week.
* Can be assigned to a numeric value or to `WEEKDAYS` enum value.
*/
set weekStart(value) {
this.calendarModel.firstWeekDay = value;
}
/**
* Gets the `locale` of the calendar.
* Default value is `"en"`.
*/
get locale() {
return this._locale;
}
/**
* Sets the `locale` of the calendar.
* Expects a valid BCP 47 language tag.
* Default value is `"en"`.
*/
set locale(value) {
this._locale = value;
this.initFormatters();
}
/**
* Gets the date format options of the days view.
*/
get formatOptions() {
return this._formatOptions;
}
/**
* Sets the date format options of the days view.
* Default is { day: 'numeric', month: 'short', weekday: 'short', year: 'numeric' }
*/
set formatOptions(formatOptions) {
this._formatOptions = Object.assign(this._formatOptions, formatOptions);
this.initFormatters();
}
/**
* Gets whether the `day`, `month` and `year` should be rendered
* according to the locale and formatOptions, if any.
*/
get formatViews() {
return this._formatViews;
}
/**
* Gets whether the `day`, `month` and `year` should be rendered
* according to the locale and formatOptions, if any.
*/
set formatViews(formatViews) {
this._formatViews = Object.assign(this._formatViews, formatViews);
}
/**
*
* Gets the selection type.
* Default value is `"single"`.
* Changing the type of selection resets the currently
* selected values if any.
*/
get selection() {
return this._selection;
}
/**
* Sets the selection.
*/
set selection(value) {
switch (value) {
case CalendarSelection.SINGLE:
this.selectedDates = null;
break;
case CalendarSelection.MULTI:
case CalendarSelection.RANGE:
this.selectedDates = [];
break;
default:
throw new Error('Invalid selection value');
}
this._onChangeCallback(this.selectedDates);
this.rangeStarted = false;
this._selection = value;
}
/**
* Gets the selected date(s).
*
* When selection is set to `single`, it returns
* a single `Date` object.
* Otherwise it is an array of `Date` objects.
*/
get value() {
return this.selectedDates;
}
/**
* Sets the selected date(s).
*
* When selection is set to `single`, it accepts
* a single `Date` object.
* Otherwise it is an array of `Date` objects.
*/
set value(value) {
if (!value || !!value && value.length === 0) {
return;
}
this.selectDate(value);
}
/**
* Gets the date that is presented.
* By default it is the current date.
*/
get viewDate() {
return this._viewDate;
}
/**
* Sets the date that will be presented in the default view when the component renders.
*/
set viewDate(value) {
this._viewDate = this.getDateOnly(value);
}
/**
* Gets the disabled dates descriptors.
*/
get disabledDates() {
return this._disabledDates;
}
/**
* Sets the disabled dates' descriptors.
* ```typescript
*@ViewChild("MyCalendar")
*public calendar: IgxCalendarComponent;
*ngOnInit(){
* this.calendar.disabledDates = [
* {type: DateRangeType.Between, dateRange: [new Date("2020-1-1"), new Date("2020-1-15")]},
* {type: DateRangeType.Weekends}];
*}
*```
*/
set disabledDates(value) {
this._disabledDates = value;
}
/**
* Gets the special dates descriptors.
*/
get specialDates() {
return this._specialDates;
}
/**
* Sets the special dates' descriptors.
* ```typescript
*@ViewChild("MyCalendar")
*public calendar: IgxCalendarComponent;
*ngOnInit(){
* this.calendar.specialDates = [
* {type: DateRangeType.Between, dateRange: [new Date("2020-1-1"), new Date("2020-1-15")]},
* {type: DateRangeType.Weekends}];
*}
*```
*/
set specialDates(value) {
this._specialDates = value;
}
/**
*@hidden
*/
getDateOnlyInMs(date) {
return this.getDateOnly(date).getTime();
}
/**
*@hidden
*/
generateDateRange(start, end) {
const result = [];
start = this.getDateOnly(start);
end = this.getDateOnly(end);
while (start.getTime() !== end.getTime()) {
start = this.calendarModel.timedelta(start, 'day', 1);
result.push(start);
}
return result;
}
/**
* Performs a single selection.
* @hidden
*/
selectSingle(value) {
this.selectedDates = this.getDateOnly(value);
this._onChangeCallback(this.selectedDates);
}
/**
* Performs a multiple selection
* @hidden
*/
selectMultiple(value) {
if (Array.isArray(value)) {
const newDates = value.map(v => this.getDateOnly(v).getTime());
const selDates = this.selectedDates.map(v => this.getDateOnly(v).getTime());
if (JSON.stringify(newDates) === JSON.stringify(selDates)) {
return;
}
this.selectedDates = Array.from(new Set([...newDates, ...selDates])).map(v => new Date(v));
}
else {
const valueDateOnly = this.getDateOnly(value);
const newSelection = [];
if (this.selectedDates.every((date) => date.getTime() !== valueDateOnly.getTime())) {
newSelection.push(valueDateOnly);
}
else {
this.selectedDates = this.selectedDates.filter((date) => date.getTime() !== valueDateOnly.getTime());
}
if (newSelection.length > 0) {
this.selectedDates = this.selectedDates.concat(newSelection);
}
}
this.selectedDates = this.selectedDates.filter(d => !this.isDateDisabled(d));
this.selectedDates.sort((a, b) => a.valueOf() - b.valueOf());
this._onChangeCallback(this.selectedDates);
}
/**
*@hidden
*/
selectRange(value, excludeDisabledDates = false) {
let start;
let end;
if (Array.isArray(value)) {
// this.rangeStarted = false;
value.sort((a, b) => a.valueOf() - b.valueOf());
start = this.getDateOnly(value[0]);
end = this.getDateOnly(value[value.length - 1]);
this.selectedDates = [start, ...this.generateDateRange(start, end)];
}
else {
if (!this.rangeStarted) {
this.rangeStarted = true;
this.selectedDates = [value];
}
else {
this.rangeStarted = false;
if (this.selectedDates[0].getTime() === value.getTime()) {
this.selectedDates = [];
this._onChangeCallback(this.selectedDates);
return;
}
this.selectedDates.push(value);
this.selectedDates.sort((a, b) => a.valueOf() - b.valueOf());
start = this.selectedDates.shift();
end = this.selectedDates.pop();
this.selectedDates = [start, ...this.generateDateRange(start, end)];
}
}
if (excludeDisabledDates) {
this.selectedDates = this.selectedDates.filter(d => !this.isDateDisabled(d));
}
this._onChangeCallback(this.selectedDates);
}
/**
* Performs a single deselection.
* @hidden
*/
deselectSingle(value) {
if (this.selectedDates !== null &&
this.getDateOnlyInMs(value) === this.getDateOnlyInMs(this.selectedDates)) {
this.selectedDates = null;
this._onChangeCallback(this.selectedDates);
}
}
/**
* Performs a multiple deselection.
* @hidden
*/
deselectMultiple(value) {
value = value.filter(v => v !== null);
const selectedDatesCount = this.selectedDates.length;
const datesInMsToDeselect = new Set(value.map(v => this.getDateOnlyInMs(v)));
for (let i = this.selectedDates.length - 1; i >= 0; i--) {
if (datesInMsToDeselect.has(this.getDateOnlyInMs(this.selectedDates[i]))) {
this.selectedDates.splice(i, 1);
}
}
if (this.selectedDates.length !== selectedDatesCount) {
this._onChangeCallback(this.selectedDates);
}
}
/**
* Performs deselection of a single value, when selection is multi
* Usually performed by the selectMultiple method, but leads to bug when multiple months are in view
* @hidden
*/
deselectMultipleInMonth(value) {
const valueDateOnly = this.getDateOnly(value);
this.selectedDates = this.selectedDates.filter((date) => date.getTime() !== valueDateOnly.getTime());
}
/**
* Performs a range deselection.
* @hidden
*/
deselectRange(value) {
value = value.filter(v => v !== null);
if (value.length < 1) {
return;
}
value.sort((a, b) => a.valueOf() - b.valueOf());
const valueStart = this.getDateOnlyInMs(value[0]);
const valueEnd = this.getDateOnlyInMs(value[value.length - 1]);
this.selectedDates.sort((a, b) => a.valueOf() - b.valueOf());
const selectedDatesStart = this.getDateOnlyInMs(this.selectedDates[0]);
const selectedDatesEnd = this.getDateOnlyInMs(this.selectedDates[this.selectedDates.length - 1]);
if (!(valueEnd < selectedDatesStart) && !(valueStart > selectedDatesEnd)) {
this.selectedDates = [];
this.rangeStarted = false;
this._onChangeCallback(this.selectedDates);
}
}
/**
* @hidden
*/
initFormatters() {
this.formatterDay = new Intl.DateTimeFormat(this._locale, { day: this._formatOptions.day });
this.formatterWeekday = new Intl.DateTimeFormat(this._locale, { weekday: this._formatOptions.weekday });
this.formatterMonth = new Intl.DateTimeFormat(this._locale, { month: this._formatOptions.month });
this.formatterYear = new Intl.DateTimeFormat(this._locale, { year: this._formatOptions.year });
this.formatterMonthday = new Intl.DateTimeFormat(this._locale, { month: this._formatOptions.month, day: this._formatOptions.day });
}
/**
*@hidden
*/
getDateOnly(date) {
return new Date(date.getFullYear(), date.getMonth(), date.getDate());
}
/**
* @hidden
*/
registerOnChange(fn) {
this._onChangeCallback = fn;
}
/**
* @hidden
*/
registerOnTouched(fn) {
this._onTouchedCallback = fn;
}
/**
* @hidden
*/
writeValue(value) {
this.selectDate(value);
}
/**
* Checks whether a date is disabled.
* @hidden
*/
isDateDisabled(date) {
if (this.disabledDates === null) {
return false;
}
return isDateInRanges(date, this.disabledDates);
}
/**
* Selects date(s) (based on the selection type).
*/
selectDate(value) {
if (value === null || value === undefined || (Array.isArray(value) && value.length === 0)) {
return;
}
switch (this.selection) {
case CalendarSelection.SINGLE:
if (isDate(value) && !this.isDateDisabled(value)) {
this.selectSingle(value);
}
break;
case CalendarSelection.MULTI:
this.selectMultiple(value);
break;
case CalendarSelection.RANGE:
this.selectRange(value, true);
break;
}
}
/**
* Deselects date(s) (based on the selection type).
*/
deselectDate(value) {
if (this.selectedDates === null || this.selectedDates.length === 0) {
return;
}
if (value === null || value === undefined) {
this.selectedDates = this.selection === CalendarSelection.SINGLE ? null : [];
this.rangeStarted = false;
this._onChangeCallback(this.selectedDates);
return;
}
switch (this.selection) {
case CalendarSelection.SINGLE:
this.deselectSingle(value);
break;
case CalendarSelection.MULTI:
this.deselectMultiple(value);
break;
case CalendarSelection.RANGE:
this.deselectRange(value);
break;
}
}
/**
* @hidden
*/
selectDateFromClient(value) {
switch (this.selection) {
case CalendarSelection.SINGLE:
case CalendarSelection.MULTI:
this.selectDate(value);
break;
case CalendarSelection.RANGE:
this.selectRange(value, true);
break;
}
}
};
__decorate([
Input(),
__metadata("design:type", Number),
__metadata("design:paramtypes", [Number])
], IgxCalendarBaseDirective.prototype, "weekStart", null);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxCalendarBaseDirective.prototype, "locale", null);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxCalendarBaseDirective.prototype, "formatOptions", null);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxCalendarBaseDirective.prototype, "formatViews", null);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxCalendarBaseDirective.prototype, "selection", null);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxCalendarBaseDirective.prototype, "value", null);
__decorate([
Input(),
__metadata("design:type", Date),
__metadata("design:paramtypes", [Date])
], IgxCalendarBaseDirective.prototype, "viewDate", null);
__decorate([
Input(),
__metadata("design:type", Array),
__metadata("design:paramtypes", [Array])
], IgxCalendarBaseDirective.prototype, "disabledDates", null);
__decorate([
Input(),
__metadata("design:type", Array),
__metadata("design:paramtypes", [Array])
], IgxCalendarBaseDirective.prototype, "specialDates", null);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxCalendarBaseDirective.prototype, "hideOutsideDays", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxCalendarBaseDirective.prototype, "onSelection", void 0);
IgxCalendarBaseDirective = __decorate([
Directive({
selector: '[igxCalendarBase]'
}),
__metadata("design:paramtypes", [])
], IgxCalendarBaseDirective);
export { IgxCalendarBaseDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-base.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/calendar-base.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, Directive } from '@angular/core';\nimport { WEEKDAYS, Calendar, isDateInRanges, IFormattingOptions, IFormattingViews } from './calendar';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { DateRangeDescriptor } from '../core/dates';\nimport { Subject } from 'rxjs';\nimport { isDate } from '../core/utils';\n\n/**\n * Sets the selction type - single, multi or range.\n */\nexport enum CalendarSelection {\n    SINGLE = 'single',\n    MULTI = 'multi',\n    RANGE = 'range'\n}\n\nexport enum ScrollMonth {\n    PREV = 'prev',\n    NEXT = 'next',\n    NONE = 'none'\n}\n\n/** @hidden @internal */\n@Directive({\n    selector: '[igxCalendarBase]'\n})\nexport class IgxCalendarBaseDirective implements ControlValueAccessor {\n    /**\n     * Gets the start day of the week.\n     * Can return a numeric or an enum representation of the week day.\n     * Defaults to `Sunday` / `0`.\n     */\n    @Input()\n    public get weekStart(): WEEKDAYS | number {\n        return this.calendarModel.firstWeekDay;\n    }\n\n    /**\n     * Sets the start day of the week.\n     * Can be assigned to a numeric value or to `WEEKDAYS` enum value.\n     */\n    public set weekStart(value: WEEKDAYS | number) {\n        this.calendarModel.firstWeekDay = value;\n    }\n\n    /**\n     * Gets the `locale` of the calendar.\n     * Default value is `\"en\"`.\n     */\n    @Input()\n    public get locale(): string {\n        return this._locale;\n    }\n\n    /**\n     * Sets the `locale` of the calendar.\n     * Expects a valid BCP 47 language tag.\n     * Default value is `\"en\"`.\n     */\n    public set locale(value: string) {\n        this._locale = value;\n        this.initFormatters();\n    }\n\n    /**\n     * Gets the date format options of the days view.\n     */\n    @Input()\n    public get formatOptions(): IFormattingOptions {\n        return this._formatOptions;\n    }\n\n    /**\n     * Sets the date format options of the days view.\n     * Default is { day: 'numeric', month: 'short', weekday: 'short', year: 'numeric' }\n     */\n    public set formatOptions(formatOptions: IFormattingOptions) {\n        this._formatOptions = Object.assign(this._formatOptions, formatOptions);\n        this.initFormatters();\n    }\n\n    /**\n     * Gets whether the `day`, `month` and `year` should be rendered\n     * according to the locale and formatOptions, if any.\n     */\n    @Input()\n    public get formatViews(): IFormattingViews {\n        return this._formatViews;\n    }\n\n    /**\n     * Gets whether the `day`, `month` and `year` should be rendered\n     * according to the locale and formatOptions, if any.\n     */\n    public set formatViews(formatViews: IFormattingViews) {\n        this._formatViews = Object.assign(this._formatViews, formatViews);\n    }\n\n    /**\n     *\n     * Gets the selection type.\n     * Default value is `\"single\"`.\n     * Changing the type of selection resets the currently\n     * selected values if any.\n     */\n    @Input()\n    public get selection(): string {\n        return this._selection;\n    }\n\n    /**\n     * Sets the selection.\n     */\n    public set selection(value: string) {\n        switch (value) {\n            case CalendarSelection.SINGLE:\n                this.selectedDates = null;\n                break;\n            case CalendarSelection.MULTI:\n            case CalendarSelection.RANGE:\n                this.selectedDates = [];\n                break;\n            default:\n                throw new Error('Invalid selection value');\n        }\n        this._onChangeCallback(this.selectedDates);\n        this.rangeStarted = false;\n        this._selection = value;\n    }\n\n    /**\n     * Gets the selected date(s).\n     *\n     * When selection is set to `single`, it returns\n     * a single `Date` object.\n     * Otherwise it is an array of `Date` objects.\n     */\n    @Input()\n    public get value(): Date | Date[] {\n        return this.selectedDates;\n    }\n\n    /**\n     * Sets the selected date(s).\n     *\n     * When selection is set to `single`, it accepts\n     * a single `Date` object.\n     * Otherwise it is an array of `Date` objects.\n     */\n    public set value(value: Date | Date[]) {\n        if (!value || !!value && (value as Date[]).length === 0) {\n            return;\n        }\n\n        this.selectDate(value);\n    }\n\n    /**\n     * Gets the date that is presented.\n     * By default it is the current date.\n     */\n    @Input()\n    public get viewDate(): Date {\n        return this._viewDate;\n    }\n\n    /**\n     * Sets the date that will be presented in the default view when the component renders.\n     */\n    public set viewDate(value: Date) {\n        this._viewDate = this.getDateOnly(value);\n    }\n\n    /**\n     * Gets the disabled dates descriptors.\n     */\n    @Input()\n    public get disabledDates(): DateRangeDescriptor[] {\n        return this._disabledDates;\n    }\n\n    /**\n     * Sets the disabled dates' descriptors.\n     * ```typescript\n     *@ViewChild(\"MyCalendar\")\n     *public calendar: IgxCalendarComponent;\n     *ngOnInit(){\n     *    this.calendar.disabledDates = [\n     *     {type: DateRangeType.Between, dateRange: [new Date(\"2020-1-1\"), new Date(\"2020-1-15\")]},\n     *     {type: DateRangeType.Weekends}];\n     *}\n     *```\n     */\n    public set disabledDates(value: DateRangeDescriptor[]) {\n        this._disabledDates = value;\n    }\n\n    /**\n     * Gets the special dates descriptors.\n     */\n    @Input()\n    public get specialDates(): DateRangeDescriptor[] {\n        return this._specialDates;\n    }\n\n    /**\n     * Sets the special dates' descriptors.\n     * ```typescript\n     *@ViewChild(\"MyCalendar\")\n     *public calendar: IgxCalendarComponent;\n     *ngOnInit(){\n     *    this.calendar.specialDates = [\n     *     {type: DateRangeType.Between, dateRange: [new Date(\"2020-1-1\"), new Date(\"2020-1-15\")]},\n     *     {type: DateRangeType.Weekends}];\n     *}\n     *```\n     */\n    public set specialDates(value: DateRangeDescriptor[]) {\n        this._specialDates = value;\n    }\n\n    /**\n     * Sets/gets whether the outside dates (dates that are out of the current month) will be hidden.\n     * Default value is `false`.\n     * ```html\n     * <igx-calendar [hideOutsideDays] = \"true\"></igx-calendar>\n     * ```\n     * ```typescript\n     * let hideOutsideDays = this.calendar.hideOutsideDays;\n     * ```\n     */\n\n    @Input()\n    public hideOutsideDays = false;\n\n    /**\n     * Emits an event when a date is selected.\n     * Provides reference the `selectedDates` property.\n     */\n    @Output()\n    public onSelection = new EventEmitter<Date | Date[]>();\n\n    /**\n     *@hidden\n     */\n    private _selection: CalendarSelection | string = CalendarSelection.SINGLE;\n\n    /**\n     *@hidden\n     */\n    public rangeStarted = false;\n\n    /**\n    *@hidden\n    */\n    private _locale = 'en';\n\n    /**\n     *@hidden\n     */\n    private _viewDate: Date;\n\n    /**\n     *@hidden\n     */\n    private _disabledDates: DateRangeDescriptor[] = null;\n\n    /**\n     *@hidden\n     */\n    private _specialDates: DateRangeDescriptor[] = null;\n\n    /**\n     *@hidden\n     */\n    private _formatOptions: IFormattingOptions = {\n        day: 'numeric',\n        month: 'short',\n        weekday: 'short',\n        year: 'numeric'\n    };\n\n    /**\n     *@hidden\n     */\n    private _formatViews: IFormattingViews = {\n        day: false,\n        month: true,\n        year: false\n    };\n\n    /**\n     *@hidden\n     */\n    protected formatterWeekday;\n\n    /**\n     *@hidden\n     */\n    protected formatterDay;\n\n    /**\n     *@hidden\n     */\n    protected formatterMonth;\n\n    /**\n     *@hidden\n     */\n    protected formatterYear;\n\n    /**\n     *@hidden\n     */\n    protected formatterMonthday;\n\n    /**\n     *@hidden\n     */\n    public calendarModel: Calendar;\n\n    /**\n     * @hidden\n     */\n    public monthScrollDirection = ScrollMonth.NONE;\n\n    /**\n     *@hidden\n     */\n    public scrollMonth$ = new Subject();\n\n    /**\n     *@hidden\n     */\n    public stopMonthScroll$ = new Subject<boolean>();\n\n    /**\n     *@hidden\n     */\n    public startMonthScroll$ = new Subject();\n\n    /**\n     *@hidden\n     */\n    public selectedDates;\n\n    /**\n     *@hidden\n     */\n    protected _onTouchedCallback: () => void = () => { };\n    /**\n     *@hidden\n     */\n    protected _onChangeCallback: (_: Date) => void = () => { };\n\n    /**\n     * @hidden\n     */\n    constructor() {\n        this.calendarModel = new Calendar();\n\n        this.viewDate = this.viewDate ? this.viewDate : new Date();\n\n        this.calendarModel.firstWeekDay = this.weekStart;\n        this.initFormatters();\n    }\n\n    /**\n     *@hidden\n     */\n    private getDateOnlyInMs(date: Date) {\n        return this.getDateOnly(date).getTime();\n    }\n\n    /**\n     *@hidden\n     */\n    private generateDateRange(start: Date, end: Date): Date[] {\n        const result = [];\n        start = this.getDateOnly(start);\n        end = this.getDateOnly(end);\n        while (start.getTime() !== end.getTime()) {\n            start = this.calendarModel.timedelta(start, 'day', 1);\n            result.push(start);\n        }\n\n        return result;\n    }\n\n    /**\n     * Performs a single selection.\n     * @hidden\n     */\n    private selectSingle(value: Date) {\n        this.selectedDates = this.getDateOnly(value);\n        this._onChangeCallback(this.selectedDates);\n    }\n\n    /**\n     * Performs a multiple selection\n     * @hidden\n     */\n    private selectMultiple(value: Date | Date[]) {\n        if (Array.isArray(value)) {\n            const newDates = value.map(v => this.getDateOnly(v).getTime());\n            const selDates = this.selectedDates.map(v => this.getDateOnly(v).getTime());\n\n            if (JSON.stringify(newDates) === JSON.stringify(selDates)) {\n                return;\n            }\n\n            this.selectedDates = Array.from(new Set([...newDates, ...selDates])).map(v => new Date(v));\n        } else {\n            const valueDateOnly = this.getDateOnly(value);\n            const newSelection = [];\n            if (this.selectedDates.every((date: Date) => date.getTime() !== valueDateOnly.getTime())) {\n                newSelection.push(valueDateOnly);\n            } else {\n                this.selectedDates = this.selectedDates.filter(\n                    (date: Date) => date.getTime() !== valueDateOnly.getTime()\n                );\n            }\n\n            if (newSelection.le