@hxui/angular
Version:
* * *
346 lines • 40.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import { Component, Input, ChangeDetectorRef } from '@angular/core';
import { Subject } from 'rxjs/index';
import { Visibility } from '../enums';
import { DatepickerConfig } from './datepicker.config';
import * as moment_ from 'moment';
/** @type {?} */
var moment = moment_;
var DatepickerComponent = /** @class */ (function () {
function DatepickerComponent(_changeDetectionRef, datePickerConfig) {
this._changeDetectionRef = _changeDetectionRef;
this.datePickerConfig = datePickerConfig;
this.OpenDiv = true;
this.showCalendar = true;
this.activeVariable = true;
this.placement = 'bottom';
this.allowInterval = false;
this.selectedDueDateInterval = '0 day(s)';
this.visibilityEnum = Visibility;
this.visibility = Visibility.Hidden;
this.days = new Array();
this.week = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'];
this.cellCount = 41;
/**
* Subject for notifying that the calendar has been hidden from the view
*/
this._onHide = new Subject();
}
// Populates the days array with the current month, and completes the view with partial dates from sibling months
// Populates the days array with the current month, and completes the view with partial dates from sibling months
/**
* @return {?}
*/
DatepickerComponent.prototype.renderCalendar =
// Populates the days array with the current month, and completes the view with partial dates from sibling months
/**
* @return {?}
*/
function () {
for (var i = 0; i <= this.cellCount; i++) {
// date will be set to the first day of the month set in this.viewDate
/** @type {?} */
var date = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth());
// Shifts the week to start from Monday, rather than Sunday, this causes the index to start at 1
/** @type {?} */
var dayOffset = date.getDay() === 0 ? 7 : date.getDay();
this.days[i] = new Date(date.setDate(2 - dayOffset + i));
}
};
/**
* @return {?}
*/
DatepickerComponent.prototype.previousMonth = /**
* @return {?}
*/
function () {
this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() - 1);
this.renderCalendar();
};
/**
* @return {?}
*/
DatepickerComponent.prototype.nextMonth = /**
* @return {?}
*/
function () {
this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() + 1);
this.renderCalendar();
};
/**
* @param {?} inputDate
* @return {?}
*/
DatepickerComponent.prototype.isCurrentMonth = /**
* @param {?} inputDate
* @return {?}
*/
function (inputDate) {
return inputDate.getMonth() === this.viewDate.getMonth();
};
/**
* @param {?} inputDate
* @return {?}
*/
DatepickerComponent.prototype.isCurrentDay = /**
* @param {?} inputDate
* @return {?}
*/
function (inputDate) {
return inputDate.getTime() === this.presentDate.getTime();
};
/**
* @param {?} inputDate
* @return {?}
*/
DatepickerComponent.prototype.isSelectedDay = /**
* @param {?} inputDate
* @return {?}
*/
function (inputDate) {
if (this.selectedDate) {
return inputDate.getTime() === this.selectedDate.getTime();
}
return false;
};
/**
* @param {?} inputDate
* @return {?}
*/
DatepickerComponent.prototype.isInvalidDay = /**
* @param {?} inputDate
* @return {?}
*/
function (inputDate) {
return this.validators.map(function (fn) { return fn(inputDate); }).reduce(function (prev, next) { return prev || next; }, false);
};
/**
* @param {?} date
* @return {?}
*/
DatepickerComponent.prototype.setSelectedDate = /**
* @param {?} date
* @return {?}
*/
function (date) {
if (!this.isInvalidDay(date)) {
this.selectedDate = date;
this.onDateSelected(date);
}
};
/**
* @param {?} changes
* @return {?}
*/
DatepickerComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (!!changes.selectedDate.currentValue) {
this.viewDate = new Date(this.selectedDate.getFullYear(), this.selectedDate.getMonth());
}
};
/**
* @return {?}
*/
DatepickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
/** @type {?} */
var date = this.selectedDate ? this.selectedDate : new Date();
this.presentDate = new Date(date.getFullYear(), date.getMonth(), date.getDate());
this.viewDate = this.viewDate || new Date(date.getFullYear(), date.getMonth());
this.renderCalendar();
if (this.datePickerConfig.tabSelected === 'tab1') {
this.activeVariable1 = false;
this.activeVariable = true;
}
if (this.datePickerConfig.tabSelected === 'tab2') {
this.activeVariable1 = true;
this.activeVariable = false;
}
};
/**
* Shows the tooltip
* @param delay Amount of milliseconds to the delay showing the tooltip.
*/
/**
* Shows the tooltip
* @param {?} delay Amount of milliseconds to the delay showing the tooltip.
* @return {?}
*/
DatepickerComponent.prototype.show = /**
* Shows the tooltip
* @param {?} delay Amount of milliseconds to the delay showing the tooltip.
* @return {?}
*/
function (delay) {
var _this = this;
// Cancel the delayed hide if it is scheduled
if (this._hideTimeoutId) {
clearTimeout(this._hideTimeoutId);
}
this._showTimeoutId = window.setTimeout(function () {
// Schedule for change detection incase the tooltip is used within a
// component with OnPush change detection
_this._changeDetectionRef.markForCheck();
_this.visibility = Visibility.Visible;
}, delay);
if (this.allowInterval) {
this.OpenDiv = true;
this.showCalendar = false;
}
else {
this.OpenDiv = false;
this.showCalendar = true;
}
};
/**
* Hide the tooltip after the provided delay in ms.
* @param delay Amount of milliseconds to delay hiding the tooltip.
*/
/**
* Hide the tooltip after the provided delay in ms.
* @param {?} delay Amount of milliseconds to delay hiding the tooltip.
* @return {?}
*/
DatepickerComponent.prototype.hide = /**
* Hide the tooltip after the provided delay in ms.
* @param {?} delay Amount of milliseconds to delay hiding the tooltip.
* @return {?}
*/
function (delay) {
var _this = this;
// Cancel the delayed show if it is scheduled
if (this._showTimeoutId) {
clearTimeout(this._showTimeoutId);
}
this._hideTimeoutId = window.setTimeout(function () {
_this.visibility = Visibility.Hidden;
_this._onHide.next();
}, delay);
};
/** Returns an observable that notifies when the tooltip has been hidden from view. */
/**
* Returns an observable that notifies when the tooltip has been hidden from view.
* @return {?}
*/
DatepickerComponent.prototype.afterHidden = /**
* Returns an observable that notifies when the tooltip has been hidden from view.
* @return {?}
*/
function () {
return this._onHide.asObservable();
};
/**
* @return {?}
*/
DatepickerComponent.prototype.isVisible = /**
* @return {?}
*/
function () {
return this.visibility === Visibility.Visible;
};
/**
* @param {?} tabname
* @return {?}
*/
DatepickerComponent.prototype.onTabSelect = /**
* @param {?} tabname
* @return {?}
*/
function (tabname) {
if (tabname === 'tab1') {
this.datePickerConfig.tabSelected = tabname;
}
else {
this.datePickerConfig.tabSelected = tabname;
}
};
DatepickerComponent.decorators = [
{ type: Component, args: [{
selector: 'hxa-datepicker',
template: "<div class=\"hxui-reset\" *ngIf=\"OpenDiv\">\n <div class=\"hxa-tabs\">\n <hx-tabset class=\"hxa-tabset\">\n <hx-tab heading=\"Set interval\" (select)=\"onTabSelect('tab1')\" [active]=\"activeVariable\">\n <hxa-datepicker-interval></hxa-datepicker-interval>\n </hx-tab>\n <hx-tab heading=\"Specific date\" (select)=\"onTabSelect('tab2')\" [active]=\"activeVariable1\">\n <div class=\"hxui-reset\">\n <div class=\"hx-card hxa-datepicker-container\">\n <div class=\"hx-card-header hxa-datepicker-header\">\n <div class=\"hxa-datepicker-month\">\n <div class=\"hxa-datepicker-icon\" title=\"Previous Month\" (click)=\"previousMonth()\">\n <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-left\"></i></a>\n </div>\n <div class=\"hxa-datepicker-month-title\">\n <span>{{viewDate.toLocaleString(\"en-au\", { month: \"long\", year: \"numeric\" })}}</span></div>\n <div class=\"hxa-datepicker-icon\" title=\"Next Month\" (click)=\"nextMonth()\">\n <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-right\"></i></a>\n </div>\n </div>\n <div class=\"hxa-datepicker-week\">\n <div class=\"hxa-datepicker-weekday\" *ngFor=\"let weekday of week\">\n {{weekday | slice:0:3}}\n </div>\n </div>\n </div>\n <div class=\"hxa-datepicker-contents\">\n <div class=\"hxa-datepicker-day\" *ngFor=\"let day of days\"\n [ngClass]=\"{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day),\n 'hxa-datepicker-day-currentday': isCurrentDay(day),\n 'hxa-datepicker-day-selectedday': isSelectedDay(day),\n 'hxa-datepicker-day-invalidday': isInvalidDay(day)}\"\n (click)=\"setSelectedDate(day)\">\n <a class=\"hx-button is-transparent\">{{day.getDate()}}</a>\n </div>\n </div>\n </div>\n </div>\n </hx-tab>\n </hx-tabset>\n </div>\n</div>\n<div class=\"hxui-reset\" *ngIf=\"showCalendar\">\n <div class=\"hx-card hxa-datepicker-container\">\n <div class=\"hx-card-header hxa-datepicker-header\">\n <div class=\"hxa-datepicker-month\">\n <div class=\"hxa-datepicker-icon\" title=\"Previous Month\" (click)=\"previousMonth()\">\n <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-left\"></i></a>\n </div>\n <div class=\"hxa-datepicker-month-title\">\n <span>{{viewDate.toLocaleString(\"en-au\", { month: \"long\", year: \"numeric\" })}}</span></div>\n <div class=\"hxa-datepicker-icon\" title=\"Next Month\" (click)=\"nextMonth()\">\n <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-right\"></i></a>\n </div>\n </div>\n <div class=\"hxa-datepicker-week\">\n <div class=\"hxa-datepicker-weekday\" *ngFor=\"let weekday of week\">\n {{weekday | slice:0:3}}\n </div>\n </div>\n </div>\n <div class=\"hxa-datepicker-contents\">\n <div class=\"hxa-datepicker-day\" *ngFor=\"let day of days\"\n [ngClass]=\"{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day),\n 'hxa-datepicker-day-currentday': isCurrentDay(day),\n 'hxa-datepicker-day-selectedday': isSelectedDay(day),\n 'hxa-datepicker-day-invalidday': isInvalidDay(day)}\"\n (click)=\"setSelectedDate(day)\">\n <a class=\"hx-button is-transparent\">{{day.getDate()}}</a>\n </div>\n </div>\n </div>\n</div>\n\n",
styles: [".hxa-datepicker-container{max-width:19rem;width:19rem;height:21rem;display:flex;flex-direction:column;font-size:1rem}.hxa-datepicker-header{padding:.5rem .5rem 0;flex-direction:column;align-items:initial;justify-content:space-around;font-weight:100}.hxa-datepicker-icon{cursor:pointer;display:flex;flex:1;flex-direction:column;justify-content:center;align-items:center}.hxa-datepicker-icon .hx-button{position:initial!important;top:initial!important}.hxa-datepicker-icon .hx-button.is-transparent:hover{color:#000}.hxa-datepicker-icon .hx-icon{font-size:2em;position:initial!important;top:initial!important;color:#0d4d78}.hxa-datepicker-month{display:flex;text-align:center;margin-bottom:.5rem}.hxa-datepicker-month-title{font-size:1.25em;font-weight:400;flex:3;display:flex;justify-content:center;align-items:center;color:#0d4d78}.hxa-datepicker-week{display:flex;width:100%;text-align:center}.hxa-datepicker-weekday{flex:1;color:#0d4d78;font-size:.85em}.hxa-datepicker-contents{padding:.5rem;background-color:rgba(246,246,249,.5);display:flex;flex-flow:row wrap;flex:1;justify-content:space-around;align-content:space-around}.hxa-datepicker-day{flex:1 1 14%;height:16.666%;display:flex;justify-content:center;align-items:center}.hxa-datepicker-day .hx-button{position:initial;top:initial;flex:1;font-weight:400;height:100%;padding:0;color:#41b987}.hxa-datepicker-day-siblingmonth .hx-button{color:#3b3b3b;font-weight:100}.hxa-datepicker-day-selectedday .hx-button{color:#fff;background:#41b987}.hxa-datepicker-day-invalidday .hx-button{color:#e0e0e1!important;pointer-events:none}.hxa-datepicker-day-currentday .hx-button{border:2px solid #41b987}:host{max-width:24rem;border:1px solid #d3d3d3;background:#fff}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul{background-color:#fff;margin-bottom:0}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul ::ng-deep li{width:50%}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul ::ng-deep li a span{font-size:medium;margin:auto}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep .hx-tab-content{padding:0}"]
},] },
];
/** @nocollapse */
DatepickerComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef },
{ type: DatepickerConfig }
]; };
DatepickerComponent.propDecorators = {
selectedDate: [{ type: Input }],
validators: [{ type: Input }],
placement: [{ type: Input }],
allowInterval: [{ type: Input }],
selectedDueDateInterval: [{ type: Input }]
};
return DatepickerComponent;
}());
export { DatepickerComponent };
if (false) {
/** @type {?} */
DatepickerComponent.prototype.OpenDiv;
/** @type {?} */
DatepickerComponent.prototype.showCalendar;
/** @type {?} */
DatepickerComponent.prototype.tabname1;
/** @type {?} */
DatepickerComponent.prototype.activeVariable;
/** @type {?} */
DatepickerComponent.prototype.activeVariable1;
/** @type {?} */
DatepickerComponent.prototype.selectedDate;
/** @type {?} */
DatepickerComponent.prototype.validators;
/** @type {?} */
DatepickerComponent.prototype.placement;
/** @type {?} */
DatepickerComponent.prototype.allowInterval;
/** @type {?} */
DatepickerComponent.prototype.selectedDueDateInterval;
/** @type {?} */
DatepickerComponent.prototype.onDateSelected;
/** @type {?} */
DatepickerComponent.prototype.visibilityEnum;
/** @type {?} */
DatepickerComponent.prototype.visibility;
/** @type {?} */
DatepickerComponent.prototype.viewDate;
/** @type {?} */
DatepickerComponent.prototype.days;
/** @type {?} */
DatepickerComponent.prototype.week;
/** @type {?} */
DatepickerComponent.prototype.presentDate;
/** @type {?} */
DatepickerComponent.prototype.cellCount;
/** @type {?} */
DatepickerComponent.prototype._dp;
/**
* Subject for notifying that the calendar has been hidden from the view
* @type {?}
*/
DatepickerComponent.prototype._onHide;
/**
* The timeout ID of any current timer set to show the calendar
* @type {?}
*/
DatepickerComponent.prototype._showTimeoutId;
/**
* The timeout ID of any current timer set to hide the calendar
* @type {?}
*/
DatepickerComponent.prototype._hideTimeoutId;
/** @type {?} */
DatepickerComponent.prototype._changeDetectionRef;
/** @type {?} */
DatepickerComponent.prototype.datePickerConfig;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/datepicker/datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatepickerIntervalComponent } from './datepicker-interval.component';\r\nimport {\r\n  Component, OnInit, Output, Input, SimpleChanges, OnChanges,\r\n  ChangeDetectorRef\r\n} from '@angular/core';\r\nimport {Observable, Subject} from 'rxjs/index';\r\nimport {Visibility} from '../enums';\r\nimport {DatepickerConfig} from './datepicker.config';\r\nimport * as moment_ from 'moment';\r\nconst moment = moment_;\r\n\r\n@Component({\r\n  selector: 'hxa-datepicker',\r\n  template: `<div class=\"hxui-reset\" *ngIf=\"OpenDiv\">\r\n  <div class=\"hxa-tabs\">\r\n    <hx-tabset class=\"hxa-tabset\">\r\n      <hx-tab  heading=\"Set interval\" (select)=\"onTabSelect('tab1')\" [active]=\"activeVariable\">\r\n        <hxa-datepicker-interval></hxa-datepicker-interval>\r\n      </hx-tab>\r\n      <hx-tab  heading=\"Specific date\" (select)=\"onTabSelect('tab2')\" [active]=\"activeVariable1\">\r\n        <div class=\"hxui-reset\">\r\n          <div class=\"hx-card hxa-datepicker-container\">\r\n            <div class=\"hx-card-header hxa-datepicker-header\">\r\n              <div class=\"hxa-datepicker-month\">\r\n                <div class=\"hxa-datepicker-icon\" title=\"Previous Month\" (click)=\"previousMonth()\">\r\n                    <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-left\"></i></a>\r\n                </div>\r\n                <div class=\"hxa-datepicker-month-title\">\r\n                  <span>{{viewDate.toLocaleString(\"en-au\", { month: \"long\", year: \"numeric\" })}}</span></div>\r\n                <div class=\"hxa-datepicker-icon\" title=\"Next Month\" (click)=\"nextMonth()\">\r\n                    <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-right\"></i></a>\r\n                </div>\r\n              </div>\r\n              <div class=\"hxa-datepicker-week\">\r\n                <div class=\"hxa-datepicker-weekday\" *ngFor=\"let weekday of week\">\r\n                  {{weekday | slice:0:3}}\r\n                </div>\r\n              </div>\r\n            </div>\r\n            <div class=\"hxa-datepicker-contents\">\r\n              <div class=\"hxa-datepicker-day\" *ngFor=\"let day of days\"\r\n                [ngClass]=\"{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day),\r\n                'hxa-datepicker-day-currentday': isCurrentDay(day),\r\n                'hxa-datepicker-day-selectedday': isSelectedDay(day),\r\n                'hxa-datepicker-day-invalidday': isInvalidDay(day)}\"\r\n                (click)=\"setSelectedDate(day)\">\r\n              <a class=\"hx-button is-transparent\">{{day.getDate()}}</a>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </hx-tab>\r\n    </hx-tabset>\r\n  </div>\r\n</div>\r\n<div class=\"hxui-reset\" *ngIf=\"showCalendar\">\r\n  <div class=\"hx-card hxa-datepicker-container\">\r\n    <div class=\"hx-card-header hxa-datepicker-header\">\r\n      <div class=\"hxa-datepicker-month\">\r\n        <div class=\"hxa-datepicker-icon\" title=\"Previous Month\" (click)=\"previousMonth()\">\r\n            <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-left\"></i></a>\r\n        </div>\r\n        <div class=\"hxa-datepicker-month-title\">\r\n          <span>{{viewDate.toLocaleString(\"en-au\", { month: \"long\", year: \"numeric\" })}}</span></div>\r\n        <div class=\"hxa-datepicker-icon\" title=\"Next Month\" (click)=\"nextMonth()\">\r\n            <a class=\"hx-button is-transparent\"><i class=\"hx-icon icon-angle-right\"></i></a>\r\n        </div>\r\n      </div>\r\n      <div class=\"hxa-datepicker-week\">\r\n        <div class=\"hxa-datepicker-weekday\" *ngFor=\"let weekday of week\">\r\n          {{weekday | slice:0:3}}\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"hxa-datepicker-contents\">\r\n      <div class=\"hxa-datepicker-day\" *ngFor=\"let day of days\"\r\n        [ngClass]=\"{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day),\r\n        'hxa-datepicker-day-currentday': isCurrentDay(day),\r\n        'hxa-datepicker-day-selectedday': isSelectedDay(day),\r\n        'hxa-datepicker-day-invalidday': isInvalidDay(day)}\"\r\n        (click)=\"setSelectedDate(day)\">\r\n      <a class=\"hx-button is-transparent\">{{day.getDate()}}</a>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n`,\r\n  styles: [`.hxa-datepicker-container{max-width:19rem;width:19rem;height:21rem;display:flex;flex-direction:column;font-size:1rem}.hxa-datepicker-header{padding:.5rem .5rem 0;flex-direction:column;align-items:initial;justify-content:space-around;font-weight:100}.hxa-datepicker-icon{cursor:pointer;display:flex;flex:1;flex-direction:column;justify-content:center;align-items:center}.hxa-datepicker-icon .hx-button{position:initial!important;top:initial!important}.hxa-datepicker-icon .hx-button.is-transparent:hover{color:#000}.hxa-datepicker-icon .hx-icon{font-size:2em;position:initial!important;top:initial!important;color:#0d4d78}.hxa-datepicker-month{display:flex;text-align:center;margin-bottom:.5rem}.hxa-datepicker-month-title{font-size:1.25em;font-weight:400;flex:3;display:flex;justify-content:center;align-items:center;color:#0d4d78}.hxa-datepicker-week{display:flex;width:100%;text-align:center}.hxa-datepicker-weekday{flex:1;color:#0d4d78;font-size:.85em}.hxa-datepicker-contents{padding:.5rem;background-color:rgba(246,246,249,.5);display:flex;flex-flow:row wrap;flex:1;justify-content:space-around;align-content:space-around}.hxa-datepicker-day{flex:1 1 14%;height:16.666%;display:flex;justify-content:center;align-items:center}.hxa-datepicker-day .hx-button{position:initial;top:initial;flex:1;font-weight:400;height:100%;padding:0;color:#41b987}.hxa-datepicker-day-siblingmonth .hx-button{color:#3b3b3b;font-weight:100}.hxa-datepicker-day-selectedday .hx-button{color:#fff;background:#41b987}.hxa-datepicker-day-invalidday .hx-button{color:#e0e0e1!important;pointer-events:none}.hxa-datepicker-day-currentday .hx-button{border:2px solid #41b987}:host{max-width:24rem;border:1px solid #d3d3d3;background:#fff}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul{background-color:#fff;margin-bottom:0}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul ::ng-deep li{width:50%}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep ul ::ng-deep li a span{font-size:medium;margin:auto}:host .hxa-tabs ::ng-deep hx-tabset ::ng-deep .hx-tab-content{padding:0}`]\r\n})\r\nexport class DatepickerComponent implements OnInit, OnChanges {\r\n  public OpenDiv: Boolean = true;\r\n  public showCalendar: Boolean = true;\r\n  public tabname1: String;\r\n  public activeVariable: Boolean = true;\r\n  public activeVariable1: Boolean;\r\n\r\n  @Input()\r\n  selectedDate: Date;\r\n\r\n  @Input()\r\n  validators: Array<(date: Date) => boolean>;\r\n\r\n  @Input()\r\n  placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\r\n\r\n  @Input()\r\n  allowInterval = false;\r\n\r\n  @Input()\r\n  selectedDueDateInterval = '0 day(s)';\r\n\r\n  onDateSelected: (inputDate: Date) => void;\r\n  visibilityEnum = Visibility;\r\n  visibility: Visibility = Visibility.Hidden;\r\n  viewDate: Date;\r\n  days: Array<Date> = new Array<Date>();\r\n  week: Array<string> = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'];\r\n  private presentDate: Date;\r\n  private cellCount = 41;\r\n  private _dp: DatepickerIntervalComponent | null;\r\n  /** Subject for notifying that the calendar has been hidden from the view */\r\n  private readonly _onHide: Subject<any> = new Subject();\r\n\r\n  /** The timeout ID of any current timer set to show the calendar */\r\n  private _showTimeoutId: number;\r\n\r\n  /** The timeout ID of any current timer set to hide the calendar */\r\n  private _hideTimeoutId: number;\r\n\r\n  constructor(private _changeDetectionRef: ChangeDetectorRef, private datePickerConfig: DatepickerConfig) {\r\n    }\r\n\r\n  // Populates the days array with the current month, and completes the view with partial dates from sibling months\r\n  public renderCalendar(): void {\r\n    for (let i = 0; i <= this.cellCount; i++) {\r\n      // date will be set to the first day of the month set in this.viewDate\r\n      const date: Date = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth());\r\n      // Shifts the week to start from Monday, rather than Sunday, this causes the index to start at 1\r\n      const dayOffset = date.getDay() === 0 ? 7 : date.getDay();\r\n      this.days[i] = new Date(date.setDate(2 - dayOffset + i));\r\n    }\r\n  }\r\n\r\n\r\n  public previousMonth(): void {\r\n    this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() - 1);\r\n    this.renderCalendar();\r\n  }\r\n\r\n  public nextMonth(): void {\r\n    this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() + 1);\r\n    this.renderCalendar();\r\n  }\r\n\r\n  public isCurrentMonth(inputDate: Date): boolean {\r\n    return inputDate.getMonth() === this.viewDate.getMonth();\r\n  }\r\n\r\n  public isCurrentDay(inputDate: Date): boolean {\r\n    return inputDate.getTime() === this.presentDate.getTime();\r\n  }\r\n\r\n  public isSelectedDay(inputDate: Date): boolean {\r\n    if (this.selectedDate) {\r\n      return inputDate.getTime() === this.selectedDate.getTime();\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public isInvalidDay(inputDate: Date): boolean {\r\n    return this.validators.map((fn) => fn(inputDate)).reduce((prev, next) => prev || next, false);\r\n  }\r\n\r\n  public setSelectedDate(date: Date): void {\r\n    if (!this.isInvalidDay(date)) {\r\n      this.selectedDate = date;\r\n      this.onDateSelected(date);\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!changes.selectedDate.currentValue) {\r\n      this.viewDate = new Date(this.selectedDate.getFullYear(), this.selectedDate.getMonth());\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const date: Date = this.selectedDate ? this.selectedDate : new Date();\r\n    this.presentDate = new Date(date.getFullYear(), date.getMonth(), date.getDate());\r\n    this.viewDate = this.viewDate || new Date(date.getFullYear(), date.getMonth());\r\n    this.renderCalendar();\r\n    if ( this.datePickerConfig.tabSelected === 'tab1') {\r\n     this.activeVariable1 = false;\r\n      this.activeVariable = true;\r\n    }\r\n    if ( this.datePickerConfig.tabSelected === 'tab2') {\r\n      this.activeVariable1 = true;\r\n      this.activeVariable = false;\r\n     }\r\n  }\r\n\r\n  /**\r\n   * Shows the tooltip\r\n   * @param delay Amount of milliseconds to the delay showing the tooltip.\r\n   */\r\n  show(delay: number): void {\r\n    // Cancel the delayed hide if it is scheduled\r\n    if (this._hideTimeoutId) {\r\n      clearTimeout(this._hideTimeoutId);\r\n    }\r\n    this._showTimeoutId = window.setTimeout(() => {\r\n      // Schedule for change detection incase the tooltip is used within a\r\n      // component with OnPush change detection\r\n      this._changeDetectionRef.markForCheck();\r\n      this.visibility = Visibility.Visible;\r\n    }, delay);\r\n\r\n    if (this.allowInterval) {\r\n       this.OpenDiv = true;\r\n       this.showCalendar = false;\r\n\r\n    } else {\r\n     this.OpenDiv = false;\r\n     this.showCalendar = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Hide the tooltip after the provided delay in ms.\r\n   * @param delay Amount of milliseconds to delay hiding the tooltip.\r\n   */\r\n  hide(delay: number): void {\r\n    // Cancel the delayed show if it is scheduled\r\n    if (this._showTimeoutId) {\r\n      clearTimeout(this._showTimeoutId);\r\n    }\r\n\r\n    this._hideTimeoutId = window.setTimeout(() => {\r\n      this.visibility = Visibility.Hidden;\r\n      this._onHide.next();\r\n    }, delay);\r\n  }\r\n\r\n  /** Returns an observable that notifies when the tooltip has been hidden from view. */\r\n  afterHidden(): Observable<void> {\r\n    return this._onHide.asObservable();\r\n  }\r\n\r\n  isVisible(): boolean {\r\n    return this.visibility === Visibility.Visible;\r\n  }\r\n  onTabSelect(tabname: String) {\r\n     if (tabname === 'tab1') {\r\n      this.datePickerConfig.tabSelected = tabname;\r\n     } else {\r\n      this.datePickerConfig.tabSelected = tabname;\r\n     }\r\n   }\r\n}\r\n"]}