UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

666 lines 45.9 kB
/** * @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'; var DatePickerComponent = /** @class */ (function () { function DatePickerComponent(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 {?} */ function (selected) { }); /** * @hidden */ this.onTouched = (/** * @return {?} */ function () { }); } /** Opens the calendar */ /** * Opens the calendar * @param {?} e * @return {?} */ DatePickerComponent.prototype.openCalendar = /** * Opens the calendar * @param {?} e * @return {?} */ function (e) { if (!this.disabled) { this.onTouched({ date: this.selectedDay.date }); this.isOpen = true; this.getInputValue(e); } }; /** Toggles the calendar open or closed */ /** * Toggles the calendar open or closed * @param {?} e * @return {?} */ DatePickerComponent.prototype.toggleCalendar = /** * Toggles the calendar open or closed * @param {?} e * @return {?} */ function (e) { this.onTouched({ date: this.selectedDay.date }); this.isOpen = !this.isOpen; this.getInputValue(e); }; /** Closes the calendar if it is open */ /** * Closes the calendar if it is open * @return {?} */ DatePickerComponent.prototype.closeCalendar = /** * Closes the calendar if it is open * @return {?} */ function () { if (this.isOpen) { this.isOpen = false; } }; /** @hidden */ /** * @hidden * @param {?} d * @return {?} */ DatePickerComponent.prototype.updateDatePickerInputHandler = /** * @hidden * @param {?} d * @return {?} */ function (d) { if (this.type === 'single') { if (d.selectedDay.date) { /** @type {?} */ var 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 {?} */ var 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 */ /** * @hidden * @param {?} e * @return {?} */ DatePickerComponent.prototype.isInvalidDateInputHandler = /** * @hidden * @param {?} e * @return {?} */ function (e) { this.isInvalidDateInput = e; }; /** @hidden */ /** * @hidden * @param {?} e * @return {?} */ DatePickerComponent.prototype.getInputValue = /** * @hidden * @param {?} e * @return {?} */ function (e) { this.dateFromDatePicker.next(e); }; /** @hidden */ /** * @hidden * @return {?} */ DatePickerComponent.prototype.onEscapeKeydownHandler = /** * @hidden * @return {?} */ function () { this.closeCalendar(); }; /** @hidden */ /** * @hidden * @param {?} event * @return {?} */ DatePickerComponent.prototype.onGlobalClick = /** * @hidden * @param {?} event * @return {?} */ function (event) { if (!this.eRef.nativeElement.contains(event.target)) { this.closeCalendar(); } }; /** @hidden */ /** * @hidden * @return {?} */ DatePickerComponent.prototype.ngOnInit = /** * @hidden * @return {?} */ function () { var _this = this; if (this.dateFromDatePicker) { this.dateFromDatePicker.subscribe((/** * @param {?} date * @return {?} */ function (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 */ /** * @hidden * @return {?} */ DatePickerComponent.prototype.ngOnDestroy = /** * @hidden * @return {?} */ function () { if (this.dateFromDatePicker) { this.dateFromDatePicker.unsubscribe(); } }; /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ DatePickerComponent.prototype.registerOnChange = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ DatePickerComponent.prototype.registerOnTouched = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** @hidden */ /** * @hidden * @param {?} isDisabled * @return {?} */ DatePickerComponent.prototype.setDisabledState = /** * @hidden * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; }; /** @hidden */ /** * @hidden * @param {?} selected * @return {?} */ DatePickerComponent.prototype.writeValue = /** * @hidden * @param {?} selected * @return {?} */ function (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 {?} */ function () { 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 = function () { return [ { 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'],] }] }; return DatePickerComponent; }()); export { DatePickerComponent }; 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"]}