UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

592 lines 60.6 kB
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