UNPKG

@hxui/angular

Version:

* * *

351 lines (350 loc) 37.9 kB
/** * @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 {?} */ const moment = moment_; export class DatepickerComponent { /** * @param {?} _changeDetectionRef * @param {?} datePickerConfig */ constructor(_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 /** * @return {?} */ renderCalendar() { for (let i = 0; i <= this.cellCount; i++) { // date will be set to the first day of the month set in this.viewDate /** @type {?} */ const 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 {?} */ const dayOffset = date.getDay() === 0 ? 7 : date.getDay(); this.days[i] = new Date(date.setDate(2 - dayOffset + i)); } } /** * @return {?} */ previousMonth() { this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() - 1); this.renderCalendar(); } /** * @return {?} */ nextMonth() { this.viewDate = new Date(this.viewDate.getFullYear(), this.viewDate.getMonth() + 1); this.renderCalendar(); } /** * @param {?} inputDate * @return {?} */ isCurrentMonth(inputDate) { return inputDate.getMonth() === this.viewDate.getMonth(); } /** * @param {?} inputDate * @return {?} */ isCurrentDay(inputDate) { return inputDate.getTime() === this.presentDate.getTime(); } /** * @param {?} inputDate * @return {?} */ isSelectedDay(inputDate) { if (this.selectedDate) { return inputDate.getTime() === this.selectedDate.getTime(); } return false; } /** * @param {?} inputDate * @return {?} */ isInvalidDay(inputDate) { return this.validators.map((fn) => fn(inputDate)).reduce((prev, next) => prev || next, false); } /** * @param {?} date * @return {?} */ setSelectedDate(date) { if (!this.isInvalidDay(date)) { this.selectedDate = date; this.onDateSelected(date); } } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (!!changes.selectedDate.currentValue) { this.viewDate = new Date(this.selectedDate.getFullYear(), this.selectedDate.getMonth()); } } /** * @return {?} */ ngOnInit() { /** @type {?} */ const 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. * @return {?} */ show(delay) { // Cancel the delayed hide if it is scheduled if (this._hideTimeoutId) { clearTimeout(this._hideTimeoutId); } this._showTimeoutId = window.setTimeout(() => { // 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. * @return {?} */ hide(delay) { // Cancel the delayed show if it is scheduled if (this._showTimeoutId) { clearTimeout(this._showTimeoutId); } this._hideTimeoutId = window.setTimeout(() => { this.visibility = Visibility.Hidden; this._onHide.next(); }, delay); } /** * Returns an observable that notifies when the tooltip has been hidden from view. * @return {?} */ afterHidden() { return this._onHide.asObservable(); } /** * @return {?} */ isVisible() { return this.visibility === Visibility.Visible; } /** * @param {?} tabname * @return {?} */ onTabSelect(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"> <div class="hxa-tabs"> <hx-tabset class="hxa-tabset"> <hx-tab heading="Set interval" (select)="onTabSelect('tab1')" [active]="activeVariable"> <hxa-datepicker-interval></hxa-datepicker-interval> </hx-tab> <hx-tab heading="Specific date" (select)="onTabSelect('tab2')" [active]="activeVariable1"> <div class="hxui-reset"> <div class="hx-card hxa-datepicker-container"> <div class="hx-card-header hxa-datepicker-header"> <div class="hxa-datepicker-month"> <div class="hxa-datepicker-icon" title="Previous Month" (click)="previousMonth()"> <a class="hx-button is-transparent"><i class="hx-icon icon-angle-left"></i></a> </div> <div class="hxa-datepicker-month-title"> <span>{{viewDate.toLocaleString("en-au", { month: "long", year: "numeric" })}}</span></div> <div class="hxa-datepicker-icon" title="Next Month" (click)="nextMonth()"> <a class="hx-button is-transparent"><i class="hx-icon icon-angle-right"></i></a> </div> </div> <div class="hxa-datepicker-week"> <div class="hxa-datepicker-weekday" *ngFor="let weekday of week"> {{weekday | slice:0:3}} </div> </div> </div> <div class="hxa-datepicker-contents"> <div class="hxa-datepicker-day" *ngFor="let day of days" [ngClass]="{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day), 'hxa-datepicker-day-currentday': isCurrentDay(day), 'hxa-datepicker-day-selectedday': isSelectedDay(day), 'hxa-datepicker-day-invalidday': isInvalidDay(day)}" (click)="setSelectedDate(day)"> <a class="hx-button is-transparent">{{day.getDate()}}</a> </div> </div> </div> </div> </hx-tab> </hx-tabset> </div> </div> <div class="hxui-reset" *ngIf="showCalendar"> <div class="hx-card hxa-datepicker-container"> <div class="hx-card-header hxa-datepicker-header"> <div class="hxa-datepicker-month"> <div class="hxa-datepicker-icon" title="Previous Month" (click)="previousMonth()"> <a class="hx-button is-transparent"><i class="hx-icon icon-angle-left"></i></a> </div> <div class="hxa-datepicker-month-title"> <span>{{viewDate.toLocaleString("en-au", { month: "long", year: "numeric" })}}</span></div> <div class="hxa-datepicker-icon" title="Next Month" (click)="nextMonth()"> <a class="hx-button is-transparent"><i class="hx-icon icon-angle-right"></i></a> </div> </div> <div class="hxa-datepicker-week"> <div class="hxa-datepicker-weekday" *ngFor="let weekday of week"> {{weekday | slice:0:3}} </div> </div> </div> <div class="hxa-datepicker-contents"> <div class="hxa-datepicker-day" *ngFor="let day of days" [ngClass]="{'hxa-datepicker-day-siblingmonth': !isCurrentMonth(day), 'hxa-datepicker-day-currentday': isCurrentDay(day), 'hxa-datepicker-day-selectedday': isSelectedDay(day), 'hxa-datepicker-day-invalidday': isInvalidDay(day)}" (click)="setSelectedDate(day)"> <a class="hx-button is-transparent">{{day.getDate()}}</a> </div> </div> </div> </div> `, 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 = () => [ { type: ChangeDetectorRef }, { type: DatepickerConfig } ]; DatepickerComponent.propDecorators = { selectedDate: [{ type: Input }], validators: [{ type: Input }], placement: [{ type: Input }], allowInterval: [{ type: Input }], selectedDueDateInterval: [{ type: Input }] }; 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":";;;;AACA,OAAO,EACL,SAAS,EAAkB,KAAK,EAChC,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAa,OAAO,EAAC,MAAM,YAAY,CAAC;AAC/C,OAAO,EAAC,UAAU,EAAC,MAAM,UAAU,CAAC;AACpC,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;;MAC5B,MAAM,GAAG,OAAO;AAiFtB,MAAM,OAAO,mBAAmB;;;;;IAwC9B,YAAoB,mBAAsC,EAAU,gBAAkC;QAAlF,wBAAmB,GAAnB,mBAAmB,CAAmB;QAAU,qBAAgB,GAAhB,gBAAgB,CAAkB;QAvC/F,YAAO,GAAY,IAAI,CAAC;QACxB,iBAAY,GAAY,IAAI,CAAC;QAE7B,mBAAc,GAAY,IAAI,CAAC;QAUtC,cAAS,GAAwC,QAAQ,CAAC;QAG1D,kBAAa,GAAG,KAAK,CAAC;QAGtB,4BAAuB,GAAG,UAAU,CAAC;QAGrC,mBAAc,GAAG,UAAU,CAAC;QAC5B,eAAU,GAAe,UAAU,CAAC,MAAM,CAAC;QAE3C,SAAI,GAAgB,IAAI,KAAK,EAAQ,CAAC;QACtC,SAAI,GAAkB,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QAE7F,cAAS,GAAG,EAAE,CAAC;;;;QAGN,YAAO,GAAiB,IAAI,OAAO,EAAE,CAAC;IASrD,CAAC;;;;;IAGI,cAAc;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;;;kBAElC,IAAI,GAAS,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;;;kBAE5E,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE;YACzD,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC;SAC1D;IACH,CAAC;;;;IAGM,aAAa;QAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;;;IAEM,SAAS;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;;;;IAEM,cAAc,CAAC,SAAe;QACnC,OAAO,SAAS,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3D,CAAC;;;;;IAEM,YAAY,CAAC,SAAe;QACjC,OAAO,SAAS,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC5D,CAAC;;;;;IAEM,aAAa,CAAC,SAAe;QAClC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,OAAO,SAAS,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;SAC5D;QAED,OAAO,KAAK,CAAC;IACf,CAAC;;;;;IAEM,YAAY,CAAC,SAAe;QACjC,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,IAAI,EAAE,KAAK,CAAC,CAAC;IAChG,CAAC;;;;;IAEM,eAAe,CAAC,IAAU;QAC/B,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;YAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;SAC3B;IACH,CAAC;;;;;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,YAAY,EAAE;YACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC;SACzF;IACH,CAAC;;;;IAED,QAAQ;;cACA,IAAI,GAAS,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;QACrE,IAAI,CAAC,WAAW,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC/E,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAK,IAAI,CAAC,gBAAgB,CAAC,WAAW,KAAK,MAAM,EAAE;YAClD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;QACD,IAAK,IAAI,CAAC,gBAAgB,CAAC,WAAW,KAAK,MAAM,EAAE;YACjD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC5B;IACJ,CAAC;;;;;;IAMD,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,oEAAoE;YACpE,yCAAyC;YACzC,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC;QACvC,CAAC,EAAE,KAAK,CAAC,CAAC;QAEV,IAAI,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAE5B;aAAM;YACN,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SACzB;IACH,CAAC;;;;;;IAMD,IAAI,CAAC,KAAa;QAChB,6CAA6C;QAC7C,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACnC;QAED,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;;;;;IAGD,WAAW;QACT,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;;;;IAED,SAAS;QACP,OAAO,IAAI,CAAC,UAAU,KAAK,UAAU,CAAC,OAAO,CAAC;IAChD,CAAC;;;;;IACD,WAAW,CAAC,OAAe;QACxB,IAAI,OAAO,KAAK,MAAM,EAAE;YACvB,IAAI,CAAC,gBAAgB,CAAC,WAAW,GAAG,OAAO,CAAC;SAC5C;aAAM;YACN,IAAI,CAAC,gBAAgB,CAAC,WAAW,GAAG,OAAO,CAAC;SAC5C;IACH,CAAC;;;YAxPH,SAAS,SAAC;gBACT,QAAQ,EAAE,gBAAgB;gBAC1B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA0EX;gBACC,MAAM,EAAE,CAAC,2/DAA2/D,CAAC;aACtgE;;;;YAtFC,iBAAiB;YAIX,gBAAgB;;;2BA0FrB,KAAK;yBAGL,KAAK;wBAGL,KAAK;4BAGL,KAAK;sCAGL,KAAK;;;;IAlBN,sCAA+B;;IAC/B,2CAAoC;;IACpC,uCAAwB;;IACxB,6CAAsC;;IACtC,8CAAgC;;IAEhC,2CACmB;;IAEnB,yCAC2C;;IAE3C,wCAC0D;;IAE1D,4CACsB;;IAEtB,sDACqC;;IAErC,6CAA0C;;IAC1C,6CAA4B;;IAC5B,yCAA2C;;IAC3C,uCAAe;;IACf,mCAAsC;;IACtC,mCAAqG;;IACrG,0CAA0B;;IAC1B,wCAAuB;;IACvB,kCAAgD;;;;;IAEhD,sCAAuD;;;;;IAGvD,6CAA+B;;;;;IAG/B,6CAA+B;;IAEnB,kDAA8C;;IAAE,+CAA0C","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"]}