fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
587 lines • 43.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, Output, ViewEncapsulation } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { Subject } from 'rxjs';
import { DateFormatParser } from '../calendar/format/date-parser';
export class DatePickerComponent {
/**
* @param {?} eRef
* @param {?} dateAdapter
*/
constructor(eRef, dateAdapter) {
this.eRef = eRef;
this.dateAdapter = dateAdapter;
/**
* @hidden The value of the input
*/
this.inputFieldDate = null;
/**
* @hidden Whether the date input is invalid
*/
this.isInvalidDateInput = false;
/**
* @hidden Whether the date picker is open
*/
this.isOpen = false;
/**
* @hidden Subject the calendar subscribes to when the date value from the datePicker component changes. For internal use.
*/
this.dateFromDatePicker = new Subject();
/**
* The type of calendar, 'single' for single date selection or 'range' for a range of dates.
*/
this.type = 'single';
/**
* Date picker input placeholder string
*/
this.placeholder = 'mm/dd/yyyy';
/**
* Whether this is the compact input date picker
*/
this.compact = false;
/**
* The currently selected CalendarDay model
*/
this.selectedDay = {
date: null
};
/**
* Fired when a new date is selected.
*/
this.selectedDayChange = new EventEmitter();
/**
* The currently selected first CalendarDay in a range type calendar.
*/
this.selectedRangeFirst = {
date: null
};
/**
* Fired when the user selects a new first date in a range of dates is selected.
*/
this.selectedRangeFirstChange = new EventEmitter();
/**
* The currently selected last CalendarDay in a range type calendar.
*/
this.selectedRangeLast = {
date: null
};
/**
* Fired when the user selects a new last date in a range of dates is selected.
*/
this.selectedRangeLastChange = new EventEmitter();
/**
* The day of the week the calendar should start on. 0 represents Sunday, 1 is Monday, 2 is Tuesday, and so on.
*/
this.startingDayOfWeek = 0;
/**
* Whether to validate the date picker input.
*/
this.validate = true;
/**
* Aria label for the datepicker input.
*/
this.dateInputLabel = 'Date input';
/**
* Aria label for the button to show/hide the calendar.
*/
this.displayCalendarToggleLabel = 'Display calendar toggle';
/**
* Whether a null input is considered valid.
*/
this.allowNull = true;
/**
* The placement of the popover. It can be one of: top, top-start, top-end, bottom,
* bottom-start, bottom-end, right, right-start, right-end, left, left-start, left-end.
*/
this.placement = 'bottom-start';
/**
* Function used to disable certain dates in the calendar.
* @param d Date
*/
this.disableFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* Function used to block certain dates in the calendar.
* @param d Date
*/
this.blockFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* Function used to disable certain dates in the calendar for the range start selection.
* @param d Date
*/
this.disableRangeStartFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* Function used to disable certain dates in the calendar for the range end selection.
* @param d Date
*/
this.disableRangeEndFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* Function used to block certain dates in the calendar for the range start selection.
* @param d Date
*/
this.blockRangeStartFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* Function used to block certain dates in the calendar for the range end selection.
* @param d Date
*/
this.blockRangeEndFunction = (/**
* @param {?} d
* @return {?}
*/
function (d) {
return false;
});
/**
* @hidden
*/
this.onChange = (/**
* @param {?} selected
* @return {?}
*/
(selected) => { });
/**
* @hidden
*/
this.onTouched = (/**
* @return {?}
*/
() => { });
}
/**
* Opens the calendar
* @param {?} e
* @return {?}
*/
openCalendar(e) {
if (!this.disabled) {
this.onTouched({ date: this.selectedDay.date });
this.isOpen = true;
this.getInputValue(e);
}
}
/**
* Toggles the calendar open or closed
* @param {?} e
* @return {?}
*/
toggleCalendar(e) {
this.onTouched({ date: this.selectedDay.date });
this.isOpen = !this.isOpen;
this.getInputValue(e);
}
/**
* Closes the calendar if it is open
* @return {?}
*/
closeCalendar() {
if (this.isOpen) {
this.isOpen = false;
}
}
/**
* @hidden
* @param {?} d
* @return {?}
*/
updateDatePickerInputHandler(d) {
if (this.type === 'single') {
if (d.selectedDay.date) {
/** @type {?} */
const newInputDate = this.dateAdapter.format(d.selectedDay.date);
if (this.inputFieldDate !== newInputDate) {
this.inputFieldDate = newInputDate;
this.selectedDay = d.selectedDay;
this.selectedDayChange.emit(this.selectedDay);
this.onChange({ date: this.selectedDay.date });
}
}
}
else {
if (d.selectedFirstDay.date) {
/** @type {?} */
const newInputDates = this.dateAdapter.format(d.selectedFirstDay.date) + this.dateAdapter.rangeDelimiter
+ this.dateAdapter.format(d.selectedLastDay.date);
if (this.inputFieldDate !== newInputDates) {
this.inputFieldDate = newInputDates;
this.selectedRangeFirst = d.selectedFirstDay;
this.selectedRangeLast = d.selectedLastDay;
this.selectedRangeFirstChange.emit(this.selectedRangeFirst);
this.selectedRangeLastChange.emit(this.selectedRangeLast);
this.onChange({ date: this.selectedRangeFirst.date, rangeEnd: this.selectedRangeLast.date });
}
}
}
}
/**
* @hidden
* @param {?} e
* @return {?}
*/
isInvalidDateInputHandler(e) {
this.isInvalidDateInput = e;
}
/**
* @hidden
* @param {?} e
* @return {?}
*/
getInputValue(e) {
this.dateFromDatePicker.next(e);
}
/**
* @hidden
* @return {?}
*/
onEscapeKeydownHandler() {
this.closeCalendar();
}
/**
* @hidden
* @param {?} event
* @return {?}
*/
onGlobalClick(event) {
if (!this.eRef.nativeElement.contains(event.target)) {
this.closeCalendar();
}
}
/**
* @hidden
* @return {?}
*/
ngOnInit() {
if (this.dateFromDatePicker) {
this.dateFromDatePicker.subscribe((/**
* @param {?} date
* @return {?}
*/
date => {
if (date && typeof date === 'object') {
this.updateDatePickerInputHandler(date);
}
else if (date === '' && this.allowNull) {
this.isInvalidDateInput = false;
if (this.type === 'single') {
this.selectedDay.date = null;
this.selectedDay.selected = null;
}
else {
this.selectedRangeFirst.date = null;
this.selectedRangeFirst.selected = null;
this.selectedRangeLast.date = null;
this.selectedRangeLast.selected = null;
}
}
else {
this.isInvalidDateInput = true;
}
}));
}
}
/**
* @hidden
* @return {?}
*/
ngOnDestroy() {
if (this.dateFromDatePicker) {
this.dateFromDatePicker.unsubscribe();
}
}
/**
* @hidden
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChange = fn;
}
/**
* @hidden
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouched = fn;
}
/**
* @hidden
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
/**
* @hidden
* @param {?} selected
* @return {?}
*/
writeValue(selected) {
if (!selected) {
return;
}
if (this.type.toLocaleLowerCase() === 'single') {
this.selectedDay.date = selected.date;
if (selected.date !== null) {
this.inputFieldDate = this.dateAdapter.format(selected.date);
}
else {
this.inputFieldDate = '';
}
}
else {
this.selectedRangeFirst.date = selected.date;
this.selectedRangeLast.date = selected.rangeEnd;
if (selected.date !== null) {
this.inputFieldDate = this.dateAdapter.format(selected.date) +
this.dateAdapter.rangeDelimiter + this.dateAdapter.format(selected.rangeEnd);
}
else {
this.inputFieldDate = '';
}
}
}
}
DatePickerComponent.decorators = [
{ type: Component, args: [{
selector: 'fd-date-picker',
template: "<fd-popover [(isOpen)]=\"isOpen\"\n [triggers]=\"[]\"\n [placement]=\"placement\"\n [disabled]=\"disabled\">\n <fd-popover-control>\n <div class=\"fd-input-group fd-input-group--after\"\n [ngClass]=\"{'fd-input-group--compact' : compact}\">\n <input #datePicker\n type=\"text\"\n [attr.aria-label]=\"dateInputLabel\"\n [value]=\"inputFieldDate\"\n [placeholder]=\"placeholder\"\n (keyup.enter)=\"getInputValue(datePicker.value)\"\n (blur)=\"getInputValue(datePicker.value)\"\n (click)=\"openCalendar(datePicker.value)\"\n [disabled]=\"disabled\"\n [ngClass]=\"{ 'fd-input--compact': compact, 'is-invalid': isInvalidDateInput && validate }\">\n <span class=\"fd-input-group__addon fd-input-group__addon--after fd-input-group__addon--button\">\n <button [disabled]=\"disabled\" class=\"fd-popover__control fd-button--icon fd-button--light sap-icon--calendar\"\n (click)=\"toggleCalendar(datePicker.value)\" [attr.aria-label]=\"displayCalendarToggleLabel\"\n [attr.aria-expanded]=\"isOpen\" type=\"button\"></button>\n </span>\n </div>\n </fd-popover-control>\n <fd-popover-body\n [style.display]=\"'block'\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-hidden]=\"!isOpen\">\n <fd-calendar (closeCalendar)=\"isOpen = false;\" [calType]=\"type\"\n [disableFunction]=\"disableFunction ? disableFunction : null\"\n [blockFunction]=\"blockFunction ? blockFunction : null\"\n [disableRangeStartFunction]=\"disableRangeStartFunction ? disableRangeStartFunction : null\"\n [disableRangeEndFunction]=\"disableRangeEndFunction ? disableRangeEndFunction : null\"\n [blockRangeStartFunction]=\"blockRangeStartFunction ? blockRangeStartFunction : null\"\n [blockRangeEndFunction]=\"blockRangeEndFunction ? blockRangeEndFunction : null\"\n [(selectedDay)]=\"selectedDay\"\n [(selectedRangeFirst)]=\"selectedRangeFirst\"\n [(selectedRangeLast)]=\"selectedRangeLast\"\n (isInvalidDateInput)=\"isInvalidDateInputHandler($event)\"\n [dateFromDatePicker]=\"dateFromDatePicker\"\n [startingDayOfWeek]=\"startingDayOfWeek\"></fd-calendar>\n </fd-popover-body>\n</fd-popover>\n",
host: {
'(blur)': 'onTouched()',
'[class.fd-date-picker]': 'true',
'[class.fd-date-picker-custom]': 'true'
},
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => DatePickerComponent)),
multi: true
}
],
encapsulation: ViewEncapsulation.None,
styles: [".fd-date-picker-custom{display:inline-block}.fd-date-picker-custom fd-popover{display:block}"]
}] }
];
/** @nocollapse */
DatePickerComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: DateFormatParser }
];
DatePickerComponent.propDecorators = {
type: [{ type: Input }],
placeholder: [{ type: Input }],
compact: [{ type: Input }],
selectedDay: [{ type: Input }],
selectedDayChange: [{ type: Output }],
selectedRangeFirst: [{ type: Input }],
selectedRangeFirstChange: [{ type: Output }],
selectedRangeLast: [{ type: Input }],
selectedRangeLastChange: [{ type: Output }],
startingDayOfWeek: [{ type: Input }],
validate: [{ type: Input }],
dateInputLabel: [{ type: Input }],
displayCalendarToggleLabel: [{ type: Input }],
allowNull: [{ type: Input }],
placement: [{ type: Input }],
disabled: [{ type: Input }],
disableFunction: [{ type: Input }],
blockFunction: [{ type: Input }],
disableRangeStartFunction: [{ type: Input }],
disableRangeEndFunction: [{ type: Input }],
blockRangeStartFunction: [{ type: Input }],
blockRangeEndFunction: [{ type: Input }],
onEscapeKeydownHandler: [{ type: HostListener, args: ['document:keydown.escape', [],] }],
onGlobalClick: [{ type: HostListener, args: ['document:click', ['$event'],] }]
};
if (false) {
/**
* @hidden The value of the input
* @type {?}
*/
DatePickerComponent.prototype.inputFieldDate;
/**
* @hidden Whether the date input is invalid
* @type {?}
*/
DatePickerComponent.prototype.isInvalidDateInput;
/**
* @hidden Whether the date picker is open
* @type {?}
*/
DatePickerComponent.prototype.isOpen;
/**
* @hidden Subject the calendar subscribes to when the date value from the datePicker component changes. For internal use.
* @type {?}
*/
DatePickerComponent.prototype.dateFromDatePicker;
/**
* The type of calendar, 'single' for single date selection or 'range' for a range of dates.
* @type {?}
*/
DatePickerComponent.prototype.type;
/**
* Date picker input placeholder string
* @type {?}
*/
DatePickerComponent.prototype.placeholder;
/**
* Whether this is the compact input date picker
* @type {?}
*/
DatePickerComponent.prototype.compact;
/**
* The currently selected CalendarDay model
* @type {?}
*/
DatePickerComponent.prototype.selectedDay;
/**
* Fired when a new date is selected.
* @type {?}
*/
DatePickerComponent.prototype.selectedDayChange;
/**
* The currently selected first CalendarDay in a range type calendar.
* @type {?}
*/
DatePickerComponent.prototype.selectedRangeFirst;
/**
* Fired when the user selects a new first date in a range of dates is selected.
* @type {?}
*/
DatePickerComponent.prototype.selectedRangeFirstChange;
/**
* The currently selected last CalendarDay in a range type calendar.
* @type {?}
*/
DatePickerComponent.prototype.selectedRangeLast;
/**
* Fired when the user selects a new last date in a range of dates is selected.
* @type {?}
*/
DatePickerComponent.prototype.selectedRangeLastChange;
/**
* The day of the week the calendar should start on. 0 represents Sunday, 1 is Monday, 2 is Tuesday, and so on.
* @type {?}
*/
DatePickerComponent.prototype.startingDayOfWeek;
/**
* Whether to validate the date picker input.
* @type {?}
*/
DatePickerComponent.prototype.validate;
/**
* Aria label for the datepicker input.
* @type {?}
*/
DatePickerComponent.prototype.dateInputLabel;
/**
* Aria label for the button to show/hide the calendar.
* @type {?}
*/
DatePickerComponent.prototype.displayCalendarToggleLabel;
/**
* Whether a null input is considered valid.
* @type {?}
*/
DatePickerComponent.prototype.allowNull;
/**
* The placement of the popover. It can be one of: top, top-start, top-end, bottom,
* bottom-start, bottom-end, right, right-start, right-end, left, left-start, left-end.
* @type {?}
*/
DatePickerComponent.prototype.placement;
/**
* Whether the date picker is disabled.
* @type {?}
*/
DatePickerComponent.prototype.disabled;
/**
* Function used to disable certain dates in the calendar.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.disableFunction;
/**
* Function used to block certain dates in the calendar.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.blockFunction;
/**
* Function used to disable certain dates in the calendar for the range start selection.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.disableRangeStartFunction;
/**
* Function used to disable certain dates in the calendar for the range end selection.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.disableRangeEndFunction;
/**
* Function used to block certain dates in the calendar for the range start selection.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.blockRangeStartFunction;
/**
* Function used to block certain dates in the calendar for the range end selection.
* \@param d Date
* @type {?}
*/
DatePickerComponent.prototype.blockRangeEndFunction;
/**
* @hidden
* @type {?}
*/
DatePickerComponent.prototype.onChange;
/**
* @hidden
* @type {?}
*/
DatePickerComponent.prototype.onTouched;
/**
* @type {?}
* @private
*/
DatePickerComponent.prototype.eRef;
/** @type {?} */
DatePickerComponent.prototype.dateAdapter;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/date-picker/date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewEncapsulation\n} from '@angular/core';\nimport { CalendarDay, CalendarType } from '../calendar/calendar.component';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { DateFormatParser } from '../calendar/format/date-parser';\nimport { Placement } from 'popper.js';\n\n@Component({\n    selector: 'fd-date-picker',\n    templateUrl: './date-picker.component.html',\n    styleUrls: ['./date-picker.component.scss'],\n    host: {\n        '(blur)': 'onTouched()',\n        '[class.fd-date-picker]': 'true',\n        '[class.fd-date-picker-custom]': 'true'\n    },\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => DatePickerComponent),\n            multi: true\n        }\n    ],\n    encapsulation: ViewEncapsulation.None\n})\nexport class DatePickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    /** @hidden The value of the input */\n    inputFieldDate = null;\n    /** @hidden Whether the date input is invalid */\n    isInvalidDateInput: boolean = false;\n    /** @hidden Whether the date picker is open */\n    isOpen: boolean = false;\n    /** @hidden Subject the calendar subscribes to when the date value from the datePicker component changes. For internal use. */\n    dateFromDatePicker: Subject<string> = new Subject();\n\n    /** The type of calendar, 'single' for single date selection or 'range' for a range of dates. */\n    @Input()\n    type: CalendarType = 'single';\n\n    /** Date picker input placeholder string */\n    @Input()\n    placeholder: string = 'mm/dd/yyyy';\n\n    /** Whether this is the compact input date picker */\n    @Input()\n    compact: boolean = false;\n\n    /** The currently selected CalendarDay model */\n    @Input()\n    selectedDay: CalendarDay = {\n        date: null\n    };\n\n    /** Fired when a new date is selected. */\n    @Output()\n    selectedDayChange = new EventEmitter();\n\n    /** The currently selected first CalendarDay in a range type calendar. */\n    @Input()\n    selectedRangeFirst: CalendarDay = {\n        date: null\n    };\n\n    /** Fired when the user selects a new first date in a range of dates is selected. */\n    @Output()\n    selectedRangeFirstChange = new EventEmitter();\n\n    /** The currently selected last CalendarDay in a range type calendar. */\n    @Input()\n    selectedRangeLast: CalendarDay = {\n        date: null\n    };\n\n    /** Fired when the user selects a new last date in a range of dates is selected. */\n    @Output()\n    selectedRangeLastChange = new EventEmitter();\n\n    /** The day of the week the calendar should start on. 0 represents Sunday, 1 is Monday, 2 is Tuesday, and so on. */\n    @Input()\n    startingDayOfWeek: number = 0;\n\n    /** Whether to validate the date picker input. */\n    @Input() validate: boolean = true;\n\n    /** Aria label for the datepicker input. */\n    @Input()\n    dateInputLabel: string = 'Date input';\n\n    /** Aria label for the button to show/hide the calendar. */\n    @Input()\n    displayCalendarToggleLabel: string = 'Display calendar toggle';\n\n    /** Whether a null input is considered valid. */\n    @Input()\n    allowNull: boolean = true;\n\n    /** The placement of the popover. It can be one of: top, top-start, top-end, bottom,\n     *  bottom-start, bottom-end, right, right-start, right-end, left, left-start, left-end. */\n    @Input()\n    placement: Placement = 'bottom-start';\n\n    /** Whether the date picker is disabled. */\n    @Input()\n    disabled: boolean;\n\n    /**\n     * Function used to disable certain dates in the calendar.\n     * @param d Date\n     */\n    @Input()\n    disableFunction = function(d): boolean {\n        return false;\n    };\n    /**\n     * Function used to block certain dates in the calendar.\n     * @param d Date\n     */\n    @Input()\n    blockFunction = function(d): boolean {\n        return false;\n    };\n    /**\n     * Function used to disable certain dates in the calendar for the range start selection.\n     * @param d Date\n     */\n    @Input()\n    disableRangeStartFunction = function(d): boolean {\n        return false;\n    };\n    /**\n     * Function used to disable certain dates in the calendar for the range end selection.\n     * @param d Date\n     */\n    @Input()\n    disableRangeEndFunction = function(d): boolean {\n        return false;\n    };\n    /**\n     * Function used to block certain dates in the calendar for the range start selection.\n     * @param d Date\n     */\n    @Input()\n    blockRangeStartFunction = function(d): boolean {\n        return false;\n    };\n    /**\n     * Function used to block certain dates in the calendar for the range end selection.\n     * @param d Date\n     */\n    @Input()\n    blockRangeEndFunction = function(d): boolean {\n        return false;\n    };\n\n    /** @hidden */\n    onChange: any = (selected: any) => {};\n    /** @hidden */\n    onTouched: any = () => {};\n\n    /** Opens the calendar */\n    openCalendar(e) {\n        if (!this.disabled) {\n            this.onTouched({date: this.selectedDay.date});\n            this.isOpen = true;\n            this.getInputValue(e);\n        }\n    }\n\n    /** Toggles the calendar open or closed */\n    toggleCalendar(e) {\n        this.onTouched({date: this.selectedDay.date});\n        this.isOpen = !this.isOpen;\n        this.getInputValue(e);\n    }\n\n    /** Closes the calendar if it is open */\n    closeCalendar() {\n        if (this.isOpen) {\n            this.isOpen = false;\n        }\n    }\n\n    /** @hidden */\n    updateDatePickerInputHandler(d) {\n        if (this.type === 'single') {\n            if (d.selectedDay.date) {\n                const newInputDate = this.dateAdapter.format(d.selectedDay.date);\n                if (this.inputFieldDate !== newInputDate) {\n                    this.inputFieldDate = newInputDate;\n                    this.selectedDay = d.selectedDay;\n                    this.selectedDayChange.emit(this.selectedDay);\n                    this.onChange({date: this.selectedDay.date});\n                }\n            }\n        } else {\n            if (d.selectedFirstDay.date) {\n                const newInputDates = this.dateAdapter.format(d.selectedFirstDay.date) + this.dateAdapter.rangeDelimiter\n                    + this.dateAdapter.format(d.selectedLastDay.date);\n                if (this.inputFieldDate !== newInputDates) {\n                    this.inputFieldDate = newInputDates;\n                    this.selectedRangeFirst = d.selectedFirstDay;\n                    this.selectedRangeLast = d.selectedLastDay;\n                    this.selectedRangeFirstChange.emit(this.selectedRangeFirst);\n                    this.selectedRangeLastChange.emit(this.selectedRangeLast);\n                    this.onChange({date: this.selectedRangeFirst.date, rangeEnd: this.selectedRangeLast.date});\n                }\n            }\n        }\n    }\n\n    /** @hidden */\n    isInvalidDateInputHandler(e) {\n        this.isInvalidDateInput = e;\n    }\n\n    /** @hidden */\n    getInputValue(e) {\n        this.dateFromDatePicker.next(e);\n    }\n\n    /** @hidden */\n    @HostListener('document:keydown.escape', [])\n    onEscapeKeydownHandler() {\n        this.closeCalendar();\n    }\n\n    /** @hidden */\n    @HostListener('document:click', ['$event'])\n    public onGlobalClick(event: MouseEvent) {\n        if (!this.eRef.nativeElement.contains(event.target)) {\n            this.closeCalendar();\n        }\n    }\n\n    /** @hidden */\n    ngOnInit() {\n        if (this.dateFromDatePicker) {\n            this.dateFromDatePicker.subscribe(date => {\n                if (date && typeof date === 'object') {\n                    this.updateDatePickerInputHandler(date);\n                } else if (date === '' && this.allowNull) {\n                    this.isInvalidDateInput = false;\n                    if (this.type === 'single') {\n                        this.selectedDay.date = null;\n                        this.selectedDay.selected = null;\n                    } else {\n                        this.selectedRangeFirst.date = null;\n                        this.selectedRangeFirst.selected = null;\n                        this.selectedRangeLast.date = null;\n                        this.selectedRangeLast.selected = null;\n                    }\n                } else {\n                    this.isInvalidDateInput = true;\n                }\n            })\n        }\n    }\n\n    /** @hidden */\n    ngOnDestroy() {\n        if (this.dateFromDatePicker) {\n            this.dateFromDatePicker.unsubscribe();\n        }\n    }\n\n    constructor(private eRef: ElementRef, public dateAdapter: DateFormatParser) {}\n\n    /** @hidden */\n    registerOnChange(fn: (selected: any) => {void}): void {\n        this.onChange = fn;\n    }\n\n    /** @hidden */\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    /** @hidden */\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden */\n    writeValue(selected: {date: Date, rangeEnd?: Date}): void {\n        if (!selected) {\n            return;\n        }\n        if (this.type.toLocaleLowerCase() === 'single') {\n            this.selectedDay.date = selected.date;\n            if (selected.date !== null) {\n                this.inputFieldDate = this.dateAdapter.format(selected.date);\n            } else {\n                this.inputFieldDate = '';\n            }\n        } else {\n            this.selectedRangeFirst.date = selected.date;\n            this.selectedRangeLast.date = selected.rangeEnd;\n            if (selected.date !== null) {\n                this.inputFieldDate = this.dateAdapter.format(selected.date) +\n                    this.dateAdapter.rangeDelimiter + this.dateAdapter.format(selected.rangeEnd);\n            } else {\n                this.inputFieldDate = '';\n            }\n        }\n    }\n}\n"]}