@nova-ui/bits
Version:
SolarWinds Nova Framework
312 lines • 61.4 kB
JavaScript
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild, ViewEncapsulation, } from "@angular/core";
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from "@angular/forms";
import _defaults from "lodash/defaults";
import _isEqual from "lodash/isEqual";
import _isNil from "lodash/isNil";
import _isNull from "lodash/isNull";
import moment from "moment/moment";
import { Subject } from "rxjs";
import { debounceTime, takeUntil } from "rxjs/operators";
import { DatePickerInnerComponent } from "./date-picker-inner.component";
import { datePickerDateFormats, datePickerDefaults, } from "./public-api";
import { NuiValidators } from "../../validators";
import { NuiFormFieldControl } from "../form-field/public-api";
import { OVERLAY_WITH_POPUP_STYLES_CLASS } from "../overlay/constants";
import { OverlayComponent } from "../overlay/overlay-component/overlay.component";
import { TextboxComponent } from "../textbox/textbox.component";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../textbox/textbox.component";
import * as i3 from "../icon/icon.component";
import * as i4 from "../overlay/overlay-component/overlay.component";
import * as i5 from "./date-picker-year-picker.component";
import * as i6 from "./date-picker-month-picker.component";
import * as i7 from "./date-picker-inner.component";
import * as i8 from "./date-picker-day-picker.component";
// <example-url>./../examples/index.html#/date-picker</example-url><br />
export class DatePickerComponent {
/** currently active date */
get value() {
return this._value;
}
set value(value) {
if (!this.preserveInsignificant && value) {
value.set({ hour: 0, minute: 0, second: 0, millisecond: 0 });
}
if (!value || (value && value.isSame(this._value))) {
return;
}
this.setDate(value);
this.updateTextboxValue();
}
constructor(cd) {
this.cd = cd;
/** Input to set aria label text */
this.ariaLabel = "Date Picker";
/** sets date-picker mode, supports: `day`, `month`, `year` */
this.datepickerMode = "day";
/** if false week numbers will be hidden */
this.showWeeks = false;
/** number of months displayed in a single row of month picker */
this.preserveInsignificant = false;
this.selectionDone = new EventEmitter();
/** callback to invoke when the value is changed. */
this.valueChange = new EventEmitter();
this.calendarNavigated = new EventEmitter();
this.inputBlurred = new EventEmitter();
this.onDestroy$ = new Subject();
this.overlayConfig = {
panelClass: [OVERLAY_WITH_POPUP_STYLES_CLASS],
};
this._todayDate = moment();
this.inputChanged = new Subject();
}
ngOnInit() {
_defaults(this, datePickerDefaults);
this.selectedDate = this._value;
this.initDate = this.value && this.value.clone();
this.setDateFormat();
this.inputChanged.pipe(debounceTime(500)).subscribe((value) => {
const momentValue = moment(value, datePickerDateFormats, true);
this.onTouched();
// In case of FormControl absence we still need to perform validation
const templateDrivenControlValid = !this.formControl &&
_isNull(NuiValidators.dateFormat(momentValue));
const reactiveDrivenControlValid = this.formControl &&
this.formControl.valid &&
_isNull(NuiValidators.dateFormat(momentValue));
const isInputValid = (templateDrivenControlValid || reactiveDrivenControlValid) &&
!this.isDateDisabled(momentValue);
this.setDate(momentValue);
this.setErrorState(!isInputValid);
if (this.value.isValid() &&
!_isEqual(this.value.format(this.momentDateFormat), value)) {
this.updateTextboxValue();
}
});
this.onAppendToBodyChange(this.appendToBody);
}
ngOnChanges(changes) {
if (changes.appendToBody) {
this.onAppendToBodyChange(changes.appendToBody.currentValue);
}
}
ngAfterViewInit() {
this.calendarChanged = this._datePicker.calendarMoved.subscribe((value) => this.calendarNavigated.emit(value));
this.updateTextboxValue();
this.cd.detectChanges();
if (this.overlay) {
this.overlay.clickOutside
.pipe(takeUntil(this.onDestroy$))
.subscribe((_) => this.overlay.hide());
// Sets innerDatePicker 'value' to 'null' on popup close and refreshView() on popup open,
// so in case datePicker.value is invalid it will build the calendar from the scratch
// and not keep its previous state.
this.overlay.show$
.pipe(takeUntil(this.onDestroy$))
.subscribe((_) => this._datePicker.refreshView());
this.overlay.hide$
.pipe(takeUntil(this.onDestroy$))
.subscribe((_) => {
const currentDateValid = this.value?.isValid();
if (!currentDateValid) {
this._datePicker.value = undefined;
this._datePicker.datepickerMode = "day";
}
});
}
}
updateTouchedState() {
setTimeout(() => this.inputBlurred.emit(), 100);
this.onTouched();
}
onUpdate(event) {
this.value = event;
this.selectionDone.emit(event);
this.setErrorState(false);
}
setDate(value) {
this._value = value;
this.selectedDate = value;
this.valueChange.emit(value);
this.onChange(value);
}
onInputActiveDateChanged(value) {
this.inputChanged.next(value);
}
getIconColor() {
return this.isDisabled ? "gray" : "primary-blue";
}
onChange(value) { }
onTouched() { }
validate(control) {
this.formControl = control;
return NuiValidators.dateFormat(control.value);
}
writeValue(value) {
this.value = value;
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.isDisabled = isDisabled;
}
setErrorState(isInErrorState) {
this.isInErrorState = isInErrorState;
}
onSelectionDone(value) {
this.value = value;
this.overlay?.hide();
}
updateTextboxValue(value = this._value) {
if (!this.textbox || !value) {
return;
}
this.textbox.writeValue(moment(value).format(this.momentDateFormat));
}
isDateDisabled(value) {
return this._datePicker.isDisabled(value);
}
setDateFormat() {
const isCustomFormatValid = !_isNil(this.dateFormat) &&
moment(this._todayDate.format(this.dateFormat), datePickerDateFormats, true).isValid();
this.momentDateFormat = isCustomFormatValid
? this.dateFormat
: datePickerDefaults.dateFormat;
}
ngOnDestroy() {
// The following resolves a known 'Error during cleanup of component:' error during unit tests
// Details: https://github.com/angular/angular/issues/17013
if (this.calendarChanged) {
this.calendarChanged.unsubscribe();
}
if (this.overlay?.showing) {
this.overlay.hide();
}
this.onDestroy$.next();
this.onDestroy$.complete();
}
onAppendToBodyChange(appendToBody) {
this.customContainer = appendToBody ? undefined : this.popupArea;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DatePickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DatePickerComponent, selector: "nui-date-picker", inputs: { inline: "inline", isRequired: "isRequired", isDisabled: "isDisabled", isInErrorState: "isInErrorState", ariaLabel: "ariaLabel", locale: "locale", datepickerMode: "datepickerMode", minDate: "minDate", maxDate: "maxDate", minMode: "minMode", maxMode: "maxMode", showWeeks: "showWeeks", dateFormat: "dateFormat", formatDay: "formatDay", formatMonth: "formatMonth", formatYear: "formatYear", formatDayHeader: "formatDayHeader", formatDayTitle: "formatDayTitle", formatMonthTitle: "formatMonthTitle", startingDay: "startingDay", yearRange: "yearRange", onlyCurrentMonth: "onlyCurrentMonth", preserveInsignificant: "preserveInsignificant", disabledDates: "disabledDates", handleTimezone: "handleTimezone", appendToBody: "appendToBody", value: "value" }, outputs: { selectionDone: "selectionDone", valueChange: "valueChange", calendarNavigated: "calendarNavigated", inputBlurred: "inputBlurred" }, host: { properties: { "class.nui-datepicker--inline": "this.inline" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
{
provide: NG_VALIDATORS,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
{
provide: NuiFormFieldControl,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
], viewQueries: [{ propertyName: "_datePicker", first: true, predicate: DatePickerInnerComponent, descendants: true }, { propertyName: "textbox", first: true, predicate: ["date"], descendants: true }, { propertyName: "popupArea", first: true, predicate: ["popupArea"], descendants: true, static: true }, { propertyName: "overlay", first: true, predicate: OverlayComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"nui-datepicker\">\n <ng-container *ngIf=\"!inline\">\n <div\n #toggleRef\n class=\"nui-datepicker__container\"\n [class.disabled]=\"isDisabled\"\n (click)=\"!isDisabled && overlay.toggle()\"\n >\n <nui-textbox\n #date\n autocomplete=\"off\"\n [disabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorState\"\n (textChange)=\"onInputActiveDateChanged($event)\"\n (blurred)=\"updateTouchedState()\"\n [ariaLabel]=\"ariaLabel\"\n >\n </nui-textbox>\n <nui-icon\n class=\"nui-datepicker__icon\"\n icon=\"calendar\"\n aria-hidden=\"true\"\n [iconColor]=\"getIconColor()\"\n ></nui-icon>\n </div>\n <nui-overlay\n #overlay\n [toggleReference]=\"toggleRef\"\n [overlayConfig]=\"overlayConfig\"\n [customContainer]=\"customContainer\"\n >\n <ng-container *ngTemplateOutlet=\"datePickerInner\"></ng-container>\n </nui-overlay>\n </ng-container>\n\n <div *ngIf=\"inline\">\n <ng-container *ngTemplateOutlet=\"datePickerInner\"></ng-container>\n </div>\n\n <div #popupArea></div>\n</div>\n<ng-template #datePickerInner>\n <nui-date-picker-inner\n [preserveInsignificant]=\"preserveInsignificant\"\n [selectedDate]=\"selectedDate\"\n [inline]=\"inline\"\n (update)=\"onUpdate($event)\"\n (selectionDone)=\"onSelectionDone($event)\"\n [locale]=\"locale\"\n [datepickerMode]=\"datepickerMode\"\n [initDate]=\"initDate\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minMode]=\"minMode\"\n [maxMode]=\"maxMode\"\n [showWeeks]=\"showWeeks\"\n [dateFormat]=\"dateFormat\"\n [formatDay]=\"formatDay\"\n [formatMonth]=\"formatMonth\"\n [formatYear]=\"formatYear\"\n [formatDayHeader]=\"formatDayHeader\"\n [formatDayTitle]=\"formatDayTitle\"\n [formatMonthTitle]=\"formatMonthTitle\"\n [startingDay]=\"startingDay\"\n [yearRange]=\"yearRange\"\n [disabledDates]=\"disabledDates\"\n [onlyCurrentMonth]=\"onlyCurrentMonth\"\n [handleTimezone]=\"handleTimezone\"\n [value]=\"value\"\n >\n <nui-day-picker tabindex=\"0\"></nui-day-picker>\n <nui-month-picker tabindex=\"0\"></nui-month-picker>\n <nui-year-picker tabindex=\"0\"></nui-year-picker>\n </nui-date-picker-inner>\n</ng-template>\n", styles: [".nui .nui-datepicker__textbox.ng-invalid-date{border-color:var(--nui-color-line-critical,#dd2c00)}.nui .nui-datepicker{display:inline-block}.nui .nui-datepicker--inline{display:inline-flex}.nui .nui-datepicker .nui-textbox .has-feedback{width:135px}.nui .nui-datepicker .nui-textbox .has-feedback .nui-textbox__input{line-height:14px}.nui .nui-datepicker__textbox{color:var(--nui-color-active-hover,#006d99)}.nui .nui-datepicker__textbox:disabled{pointer-events:none}.nui .nui-datepicker__textbox:not(:focus){cursor:pointer}.nui .nui-datepicker__container{position:relative}.nui .nui-datepicker__container.disabled .nui-icon{cursor:not-allowed;pointer-events:auto}.nui .nui-datepicker.has-error .nui-datepicker__messages div[ng-message]{clear:both;font-size:11px;font-weight:600;line-height:18px;margin:0 0 7px}.nui .nui-datepicker__icon{cursor:pointer;pointer-events:auto;position:absolute;right:7px;top:7px;z-index:501}.nui .nui-datepicker__icon.disabled{pointer-events:none}.nui .nui-datepicker-inner{min-height:290px;min-width:230px;padding:8px 10px}.nui .nui-datepicker-inner table{outline:none;background-color:transparent}.nui .nui-datepicker-inner table button.btn.btn-action{font-size:13px;outline:none}.nui .nui-datepicker-inner table button.btn.btn-action span{display:block}.nui .nui-datepicker-inner table button.btn.btn-action span.text-info{color:#0079aa;width:100%;color:var(--nui-color-text-link,#0079aa)}.nui .nui-datepicker-inner table button.btn.btn-action span.text-muted{color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui .nui-datepicker-inner table button.btn.btn-action span.today{border-bottom:2px solid;border-bottom-color:var(--nui-color-line-active,#0079aa);font-weight:700}.nui .nui-datepicker-inner table button.btn.btn-action span.today:not(.text-info).text-muted{border-bottom-color:#b3b3b3}.nui .nui-datepicker-inner table button.btn.btn-action:disabled{color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui .nui-datepicker-inner table button.btn.btn-action:disabled span.text-muted{color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui .nui-datepicker-inner table button.btn.btn-action.selected{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;background-color:var(--nui-color-selected-contrast,#00c4d2);color:#fff}.nui .nui-datepicker-inner table button.btn.btn-action.selected:hover{background-color:var(--nui-color-selected-contrast-hover,#00b0bd);border-color:transparent}.nui .nui-datepicker-inner table button.btn.btn-action.selected span{color:#fff}.nui .nui-datepicker-inner table button.btn.btn-action.selected span.today,.nui .nui-datepicker-inner table button.btn.btn-action.selected span.today.text-muted{border-bottom-color:#fff}.nui .nui-datepicker-inner table button span{font-weight:400}.nui .nui-datepicker-inner table th button.btn.btn-action{height:30px;width:100%}.nui .nui-datepicker-inner table th button.btn.btn-action.is-empty{width:30px}.nui .nui-datepicker-inner table th>button.title{width:100%}.nui .nui-datepicker-inner table th>button.title:disabled{opacity:1;color:var(--nui-color-off,#4d4d4d)}.nui .nui-datepicker-inner table th:last-of-type{text-align:right}.nui .nui-datepicker-inner table td.day>.btn.btn-action{height:30px;min-width:30px;padding:0 7px}.nui .nui-datepicker-inner table td.day>.btn.btn-action .nui-button__content{width:100%}.nui .nui-datepicker-inner table td.month>.btn.btn-action{height:52.5px;min-width:70px;padding:0}.nui .nui-datepicker-inner table td.year>.btn.btn-action{height:52.5px;min-width:42px;padding:0}.nui .nui-datepicker-inner table td>button:disabled span.today:not(.text-info){border-bottom-color:#b3b3b3}.nui .nui-datepicker-inner table .today-button{height:30px;max-width:none;width:100%}.nui .nui-datepicker-inner table .today-button:focus{background-color:transparent}.nui .nui-datepicker-inner table .day-label{color:var(--nui-color-text-default,#111);align-items:center;display:flex;height:30px;justify-content:center;min-width:30px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.TextboxComponent, selector: "nui-textbox", inputs: ["caption", "autocomplete", "info", "customBoxWidth", "disabled", "hint", "name", "placeholder", "readonly", "rows", "type", "value", "isInErrorState", "ariaLabel", "isBusy"], outputs: ["textChange", "blurred"] }, { kind: "component", type: i3.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "component", type: i4.OverlayComponent, selector: "nui-overlay", inputs: ["overlayConfig", "toggleReference", "viewportMargin", "customContainer", "roleAttr"], outputs: ["clickOutside"] }, { kind: "component", type: i5.YearPickerComponent, selector: "nui-year-picker" }, { kind: "component", type: i6.MonthPickerComponent, selector: "nui-month-picker" }, { kind: "component", type: i7.DatePickerInnerComponent, selector: "nui-date-picker-inner", inputs: ["locale", "datepickerMode", "startingDay", "yearRange", "minDate", "maxDate", "minMode", "maxMode", "showWeeks", "dateFormat", "formatDay", "formatMonth", "formatYear", "formatDayHeader", "formatDayTitle", "formatMonthTitle", "onlyCurrentMonth", "preserveInsignificant", "disabledDates", "initDate", "inline", "selectedDate", "handleTimezone", "value"], outputs: ["selectionDone", "update"] }, { kind: "component", type: i8.DayPickerComponent, selector: "nui-day-picker" }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DatePickerComponent, decorators: [{
type: Component,
args: [{ selector: "nui-date-picker", providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
{
provide: NG_VALIDATORS,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
{
provide: NuiFormFieldControl,
useExisting: forwardRef(() => DatePickerComponent),
multi: true,
},
], encapsulation: ViewEncapsulation.None, template: "<div class=\"nui-datepicker\">\n <ng-container *ngIf=\"!inline\">\n <div\n #toggleRef\n class=\"nui-datepicker__container\"\n [class.disabled]=\"isDisabled\"\n (click)=\"!isDisabled && overlay.toggle()\"\n >\n <nui-textbox\n #date\n autocomplete=\"off\"\n [disabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorState\"\n (textChange)=\"onInputActiveDateChanged($event)\"\n (blurred)=\"updateTouchedState()\"\n [ariaLabel]=\"ariaLabel\"\n >\n </nui-textbox>\n <nui-icon\n class=\"nui-datepicker__icon\"\n icon=\"calendar\"\n aria-hidden=\"true\"\n [iconColor]=\"getIconColor()\"\n ></nui-icon>\n </div>\n <nui-overlay\n #overlay\n [toggleReference]=\"toggleRef\"\n [overlayConfig]=\"overlayConfig\"\n [customContainer]=\"customContainer\"\n >\n <ng-container *ngTemplateOutlet=\"datePickerInner\"></ng-container>\n </nui-overlay>\n </ng-container>\n\n <div *ngIf=\"inline\">\n <ng-container *ngTemplateOutlet=\"datePickerInner\"></ng-container>\n </div>\n\n <div #popupArea></div>\n</div>\n<ng-template #datePickerInner>\n <nui-date-picker-inner\n [preserveInsignificant]=\"preserveInsignificant\"\n [selectedDate]=\"selectedDate\"\n [inline]=\"inline\"\n (update)=\"onUpdate($event)\"\n (selectionDone)=\"onSelectionDone($event)\"\n [locale]=\"locale\"\n [datepickerMode]=\"datepickerMode\"\n [initDate]=\"initDate\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minMode]=\"minMode\"\n [maxMode]=\"maxMode\"\n [showWeeks]=\"showWeeks\"\n [dateFormat]=\"dateFormat\"\n [formatDay]=\"formatDay\"\n [formatMonth]=\"formatMonth\"\n [formatYear]=\"formatYear\"\n [formatDayHeader]=\"formatDayHeader\"\n [formatDayTitle]=\"formatDayTitle\"\n [formatMonthTitle]=\"formatMonthTitle\"\n [startingDay]=\"startingDay\"\n [yearRange]=\"yearRange\"\n [disabledDates]=\"disabledDates\"\n [onlyCurrentMonth]=\"onlyCurrentMonth\"\n [handleTimezone]=\"handleTimezone\"\n [value]=\"value\"\n >\n <nui-day-picker tabindex=\"0\"></nui-day-picker>\n <nui-month-picker tabindex=\"0\"></nui-month-picker>\n <nui-year-picker tabindex=\"0\"></nui-year-picker>\n </nui-date-picker-inner>\n</ng-template>\n", styles: [".nui .nui-datepicker__textbox.ng-invalid-date{border-color:var(--nui-color-line-critical,#dd2c00)}.nui .nui-datepicker{display:inline-block}.nui .nui-datepicker--inline{display:inline-flex}.nui .nui-datepicker .nui-textbox .has-feedback{width:135px}.nui .nui-datepicker .nui-textbox .has-feedback .nui-textbox__input{line-height:14px}.nui .nui-datepicker__textbox{color:var(--nui-color-active-hover,#006d99)}.nui .nui-datepicker__textbox:disabled{pointer-events:none}.nui .nui-datepicker__textbox:not(:focus){cursor:pointer}.nui .nui-datepicker__container{position:relative}.nui .nui-datepicker__container.disabled .nui-icon{cursor:not-allowed;pointer-events:auto}.nui .nui-datepicker.has-error .nui-datepicker__messages div[ng-message]{clear:both;font-size:11px;font-weight:600;line-height:18px;margin:0 0 7px}.nui .nui-datepicker__icon{cursor:pointer;pointer-events:auto;position:absolute;right:7px;top:7px;z-index:501}.nui .nui-datepicker__icon.disabled{pointer-events:none}.nui .nui-datepicker-inner{min-height:290px;min-width:230px;padding:8px 10px}.nui .nui-datepicker-inner table{outline:none;background-color:transparent}.nui .nui-datepicker-inner table button.btn.btn-action{font-size:13px;outline:none}.nui .nui-datepicker-inner table button.btn.btn-action span{display:block}.nui .nui-datepicker-inner table button.btn.btn-action span.text-info{color:#0079aa;width:100%;color:var(--nui-color-text-link,#0079aa)}.nui .nui-datepicker-inner table button.btn.btn-action span.text-muted{color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui .nui-datepicker-inner table button.btn.btn-action span.today{border-bottom:2px solid;border-bottom-color:var(--nui-color-line-active,#0079aa);font-weight:700}.nui .nui-datepicker-inner table button.btn.btn-action span.today:not(.text-info).text-muted{border-bottom-color:#b3b3b3}.nui .nui-datepicker-inner table button.btn.btn-action:disabled{color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui .nui-datepicker-inner table button.btn.btn-action:disabled span.text-muted{color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui .nui-datepicker-inner table button.btn.btn-action.selected{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;background-color:var(--nui-color-selected-contrast,#00c4d2);color:#fff}.nui .nui-datepicker-inner table button.btn.btn-action.selected:hover{background-color:var(--nui-color-selected-contrast-hover,#00b0bd);border-color:transparent}.nui .nui-datepicker-inner table button.btn.btn-action.selected span{color:#fff}.nui .nui-datepicker-inner table button.btn.btn-action.selected span.today,.nui .nui-datepicker-inner table button.btn.btn-action.selected span.today.text-muted{border-bottom-color:#fff}.nui .nui-datepicker-inner table button span{font-weight:400}.nui .nui-datepicker-inner table th button.btn.btn-action{height:30px;width:100%}.nui .nui-datepicker-inner table th button.btn.btn-action.is-empty{width:30px}.nui .nui-datepicker-inner table th>button.title{width:100%}.nui .nui-datepicker-inner table th>button.title:disabled{opacity:1;color:var(--nui-color-off,#4d4d4d)}.nui .nui-datepicker-inner table th:last-of-type{text-align:right}.nui .nui-datepicker-inner table td.day>.btn.btn-action{height:30px;min-width:30px;padding:0 7px}.nui .nui-datepicker-inner table td.day>.btn.btn-action .nui-button__content{width:100%}.nui .nui-datepicker-inner table td.month>.btn.btn-action{height:52.5px;min-width:70px;padding:0}.nui .nui-datepicker-inner table td.year>.btn.btn-action{height:52.5px;min-width:42px;padding:0}.nui .nui-datepicker-inner table td>button:disabled span.today:not(.text-info){border-bottom-color:#b3b3b3}.nui .nui-datepicker-inner table .today-button{height:30px;max-width:none;width:100%}.nui .nui-datepicker-inner table .today-button:focus{background-color:transparent}.nui .nui-datepicker-inner table .day-label{color:var(--nui-color-text-default,#111);align-items:center;display:flex;height:30px;justify-content:center;min-width:30px}\n"] }]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { inline: [{
type: HostBinding,
args: ["class.nui-datepicker--inline"]
}, {
type: Input
}], isRequired: [{
type: Input
}], isDisabled: [{
type: Input
}], isInErrorState: [{
type: Input
}], ariaLabel: [{
type: Input
}], locale: [{
type: Input
}], datepickerMode: [{
type: Input
}], minDate: [{
type: Input
}], maxDate: [{
type: Input
}], minMode: [{
type: Input
}], maxMode: [{
type: Input
}], showWeeks: [{
type: Input
}], dateFormat: [{
type: Input
}], formatDay: [{
type: Input
}], formatMonth: [{
type: Input
}], formatYear: [{
type: Input
}], formatDayHeader: [{
type: Input
}], formatDayTitle: [{
type: Input
}], formatMonthTitle: [{
type: Input
}], startingDay: [{
type: Input
}], yearRange: [{
type: Input
}], onlyCurrentMonth: [{
type: Input
}], preserveInsignificant: [{
type: Input
}], disabledDates: [{
type: Input
}], handleTimezone: [{
type: Input
}], appendToBody: [{
type: Input
}], value: [{
type: Input
}], selectionDone: [{
type: Output
}], valueChange: [{
type: Output
}], calendarNavigated: [{
type: Output
}], inputBlurred: [{
type: Output
}], _datePicker: [{
type: ViewChild,
args: [DatePickerInnerComponent]
}], textbox: [{
type: ViewChild,
args: ["date"]
}], popupArea: [{
type: ViewChild,
args: ["popupArea", { static: true }]
}], overlay: [{
type: ViewChild,
args: [OverlayComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../src/lib/date-picker/date-picker.component.ts","../../../../src/lib/date-picker/date-picker.component.html"],"names":[],"mappings":"AAqBA,OAAO,EAEH,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EAIL,MAAM,EAEN,SAAS,EACT,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAGH,aAAa,EACb,iBAAiB,GAEpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,SAAS,MAAM,iBAAiB,CAAC;AACxC,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AACtC,OAAO,MAAM,MAAM,cAAc,CAAC;AAClC,OAAO,OAAO,MAAM,eAAe,CAAC;AACpC,OAAO,MAAkB,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEzD,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,EACH,qBAAqB,EACrB,kBAAkB,GAErB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,+BAA+B,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gDAAgD,CAAC;AAClF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;;AAEhE,yEAAyE;AAwBzE,MAAM,OAAO,mBAAmB;IAkE5B,4BAA4B;IAC5B,IACI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,KAAK,CAAC,KAAa;QACnB,IAAI,CAAC,IAAI,CAAC,qBAAqB,IAAI,KAAK,EAAE;YACtC,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,CAAC,CAAC;SAChE;QACD,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE;YAChD,OAAO;SACV;QACD,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAuCD,YAAoB,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;QArGzC,mCAAmC;QACnB,cAAS,GAAW,aAAa,CAAC;QAKlD,8DAA8D;QACrD,mBAAc,GAAG,KAAK,CAAC;QAShC,2CAA2C;QAClC,cAAS,GAAG,KAAK,CAAC;QAqB3B,iEAAiE;QACxD,0BAAqB,GAAG,KAAK,CAAC;QA0BvC,kBAAa,GAAyB,IAAI,YAAY,EAAU,CAAC;QAEjE,oDAAoD;QAEpD,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QAG/D,sBAAiB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAGrE,iBAAY,GAAsB,IAAI,YAAY,EAAU,CAAC;QAUtD,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAIjC,kBAAa,GAAkB;YAClC,UAAU,EAAE,CAAC,+BAA+B,CAAC;SAChD,CAAC;QAGQ,eAAU,GAAW,MAAM,EAAE,CAAC;QAGhC,iBAAY,GAAoB,IAAI,OAAO,EAAU,CAAC;IAIlB,CAAC;IAEtC,QAAQ;QACX,SAAS,CAAC,IAAI,EAAE,kBAAkB,CAAC,CAAC;QACpC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QACjD,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;YAClE,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,EAAE,qBAAqB,EAAE,IAAI,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS,EAAE,CAAC;YAEjB,qEAAqE;YACrE,MAAM,0BAA0B,GAC5B,CAAC,IAAI,CAAC,WAAW;gBACjB,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;YACnD,MAAM,0BAA0B,GAC5B,IAAI,CAAC,WAAW;gBAChB,IAAI,CAAC,WAAW,CAAC,KAAK;gBACtB,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;YACnD,MAAM,YAAY,GACd,CAAC,0BAA0B,IAAI,0BAA0B,CAAC;gBAC1D,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;YAEtC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC1B,IAAI,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC;YAElC,IACI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;gBACpB,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,KAAK,CAAC,EAC5D;gBACE,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC7B;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACjD,CAAC;IAEM,WAAW,CAAC,OAAsB;QACrC,IAAI,OAAO,CAAC,YAAY,EAAE;YACtB,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;SAChE;IACL,CAAC;IAEM,eAAe;QAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,CAC3D,CAAC,KAAa,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CACxD,CAAC;QACF,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,YAAY;iBACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;YAE3C,yFAAyF;YACzF,qFAAqF;YACrF,mCAAmC;YAEnC,IAAI,CAAC,OAAO,CAAC,KAAK;iBACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,CAAC;YACtD,IAAI,CAAC,OAAO,CAAC,KAAK;iBACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACb,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;gBAC/C,IAAI,CAAC,gBAAgB,EAAE;oBACnB,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,SAAS,CAAC;oBACnC,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,KAAK,CAAC;iBAC3C;YACL,CAAC,CAAC,CAAC;SACV;IACL,CAAC;IAEM,kBAAkB;QACrB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC;QAChD,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAEM,QAAQ,CAAC,KAAa;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAEO,OAAO,CAAC,KAAa;QACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAEM,wBAAwB,CAAC,KAAa;QACzC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAEM,YAAY;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC;IACrD,CAAC;IAEM,QAAQ,CAAC,KAAU,IAAS,CAAC;IAE7B,SAAS,KAAU,CAAC;IAEpB,QAAQ,CAAC,OAAoB;QAChC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC;QAC3B,OAAO,aAAa,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAEM,UAAU,CAAC,KAAU;QACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAEM,gBAAgB,CAAC,EAAwB;QAC5C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAEM,iBAAiB,CAAC,EAAc;QACnC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAEM,gBAAgB,CAAC,UAAmB;QACvC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IACjC,CAAC;IAEM,aAAa,CAAC,cAAuB;QACxC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACzC,CAAC;IAEM,eAAe,CAAC,KAAa;QAChC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;IACzB,CAAC;IAEO,kBAAkB,CAAC,QAAa,IAAI,CAAC,MAAM;QAC/C,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,EAAE;YACzB,OAAO;SACV;QACD,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACzE,CAAC;IAEO,cAAc,CAAC,KAAa;QAChC,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAEO,aAAa;QACjB,MAAM,mBAAmB,GACrB,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC;YACxB,MAAM,CACF,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EACvC,qBAAqB,EACrB,IAAI,CACP,CAAC,OAAO,EAAE,CAAC;QAChB,IAAI,CAAC,gBAAgB,GAAG,mBAAmB;YACvC,CAAC,CAAC,IAAI,CAAC,UAAU;YACjB,CAAC,CAAC,kBAAkB,CAAC,UAAU,CAAC;IACxC,CAAC;IAEM,WAAW;QACd,8FAA8F;QAC9F,2DAA2D;QAC3D,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;SACtC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE;YACvB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;SACvB;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAEO,oBAAoB,CAAC,YAAqB;QAC9C,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;IACrE,CAAC;+GAtSQ,mBAAmB;mGAAnB,mBAAmB,w/BApBjB;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;gBAClD,KAAK,EAAE,IAAI;aACd;YACD;gBACI,OAAO,EAAE,aAAa;gBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;gBAClD,KAAK,EAAE,IAAI;aACd;YACD;gBACI,OAAO,EAAE,mBAAmB;gBAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;gBAClD,KAAK,EAAE,IAAI;aACd;SACJ,uEAoGU,wBAAwB,mQAMxB,gBAAgB,qEC/L/B,0nFA2EA;;4FDca,mBAAmB;kBAvB/B,SAAS;+BACI,iBAAiB,aAEhB;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;4BAClD,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,aAAa;4BACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;4BAClD,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;4BAClD,KAAK,EAAE,IAAI;yBACd;qBACJ,iBAEc,iBAAiB,CAAC,IAAI;sFAcrC,MAAM;sBAFL,WAAW;uBAAC,8BAA8B;;sBAC1C,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEU,SAAS;sBAAxB,KAAK;gBAIG,MAAM;sBAAd,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAEG,qBAAqB;sBAA7B,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAIF,KAAK;sBADR,KAAK;gBAiBN,aAAa;sBADZ,MAAM;gBAKP,WAAW;sBADV,MAAM;gBAIP,iBAAiB;sBADhB,MAAM;gBAIP,YAAY;sBADX,MAAM;gBAIP,WAAW;sBADV,SAAS;uBAAC,wBAAwB;gBAGhB,OAAO;sBAAzB,SAAS;uBAAC,MAAM;gBAEyB,SAAS;sBAAlD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACJ,OAAO;sBAA1C,SAAS;uBAAC,gBAAgB","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport { OverlayConfig } from \"@angular/cdk/overlay\";\nimport {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport {\n    ControlValueAccessor,\n    FormControl,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n    ValidationErrors,\n} from \"@angular/forms\";\nimport _defaults from \"lodash/defaults\";\nimport _isEqual from \"lodash/isEqual\";\nimport _isNil from \"lodash/isNil\";\nimport _isNull from \"lodash/isNull\";\nimport moment, { Moment } from \"moment/moment\";\nimport { Subject, Subscription } from \"rxjs\";\nimport { debounceTime, takeUntil } from \"rxjs/operators\";\n\nimport { DatePickerInnerComponent } from \"./date-picker-inner.component\";\nimport {\n    datePickerDateFormats,\n    datePickerDefaults,\n    IDatePickerDisabledDate,\n} from \"./public-api\";\nimport { NuiValidators } from \"../../validators\";\nimport { NuiFormFieldControl } from \"../form-field/public-api\";\nimport { OVERLAY_WITH_POPUP_STYLES_CLASS } from \"../overlay/constants\";\nimport { OverlayComponent } from \"../overlay/overlay-component/overlay.component\";\nimport { TextboxComponent } from \"../textbox/textbox.component\";\n\n// <example-url>./../examples/index.html#/date-picker</example-url><br />\n@Component({\n    selector: \"nui-date-picker\",\n    templateUrl: \"./date-picker.component.html\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => DatePickerComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => DatePickerComponent),\n            multi: true,\n        },\n        {\n            provide: NuiFormFieldControl,\n            useExisting: forwardRef(() => DatePickerComponent),\n            multi: true,\n        },\n    ],\n    styleUrls: [\"./date-picker.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class DatePickerComponent\n    implements\n        OnChanges,\n        OnInit,\n        ControlValueAccessor,\n        NuiFormFieldControl,\n        AfterViewInit,\n        OnDestroy\n{\n    /** sets date-picker inline mode */\n    @HostBinding(\"class.nui-datepicker--inline\")\n    @Input()\n    inline: boolean;\n    /** checks if value in datepicker is required */\n    @Input() isRequired: boolean;\n    /** Option to disabled datepicker. */\n    @Input() isDisabled: boolean;\n    /** to apply error state styles */\n    @Input() isInErrorState: boolean;\n    /** Input to set aria label text */\n    @Input() public ariaLabel: string = \"Date Picker\";\n\n    // TODO: Consider injecting locale through LOCALE_ID Injection Token\n    /** to date format locale */\n    @Input() locale: string;\n    /** sets date-picker mode, supports: `day`, `month`, `year` */\n    @Input() datepickerMode = \"day\";\n    /**  earliest selectable date */\n    @Input() minDate: Moment;\n    /** latest selectable date */\n    @Input() maxDate: Moment;\n    /** set lower date-picker mode, supports: `day`, `month`, `year` */\n    @Input() minMode: string;\n    /** sets upper date-picker mode, supports: `day`, `month`, `year` */\n    @Input() maxMode: string;\n    /** if false week numbers will be hidden */\n    @Input() showWeeks = false;\n    /** date format, used to format selected date */\n    @Input() dateFormat: string;\n    /** format of day in month */\n    @Input() formatDay: string;\n    /** format of month in year */\n    @Input() formatMonth: string;\n    /** format of year in year range */\n    @Input() formatYear: string;\n    /** format of day in week header */\n    @Input() formatDayHeader: string;\n    /** format of title when selecting day */\n    @Input() formatDayTitle: string;\n    /** format of title when selecting month */\n    @Input() formatMonthTitle: string;\n    /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n    @Input() startingDay: number;\n    /** number of years displayed in year selection */\n    @Input() yearRange: number;\n    /** if true only dates from the currently displayed month will be shown */\n    @Input() onlyCurrentMonth: boolean;\n    /** number of months displayed in a single row of month picker */\n    @Input() preserveInsignificant = false;\n    /** array of custom css classes to be applied to targeted dates */\n    @Input() disabledDates: IDatePickerDisabledDate[];\n    /** Is used to handle timezone of date value */\n    @Input() handleTimezone: boolean;\n    /** Allows popup box to be attached to document.body */\n    @Input() appendToBody: boolean;\n\n    /** currently active date */\n    @Input()\n    get value(): Moment {\n        return this._value;\n    }\n\n    set value(value: Moment) {\n        if (!this.preserveInsignificant && value) {\n            value.set({ hour: 0, minute: 0, second: 0, millisecond: 0 });\n        }\n        if (!value || (value && value.isSame(this._value))) {\n            return;\n        }\n        this.setDate(value);\n        this.updateTextboxValue();\n    }\n\n    @Output()\n    selectionDone: EventEmitter<Moment> = new EventEmitter<Moment>();\n\n    /** callback to invoke when the value is changed. */\n    @Output()\n    valueChange: EventEmitter<Moment> = new EventEmitter<Moment>();\n\n    @Output()\n    calendarNavigated: EventEmitter<Moment> = new EventEmitter<Moment>();\n\n    @Output()\n    inputBlurred: EventEmitter<any> = new EventEmitter<Moment>();\n\n    @ViewChild(DatePickerInnerComponent)\n    _datePicker: DatePickerInnerComponent;\n\n    @ViewChild(\"date\") textbox: TextboxComponent;\n\n    @ViewChild(\"popupArea\", { static: true }) popupArea: ElementRef;\n    @ViewChild(OverlayComponent) public overlay: OverlayComponent;\n\n    public onDestroy$ = new Subject<void>();\n    public customContainer: ElementRef | undefined;\n    public selectedDate: Moment;\n    public initDate: Moment;\n    public overlayConfig: OverlayConfig = {\n        panelClass: [OVERLAY_WITH_POPUP_STYLES_CLASS],\n    };\n\n    protected _value: Moment;\n    protected _todayDate: Moment = moment();\n\n    private formControl: FormControl;\n    private inputChanged: Subject<string> = new Subject<string>();\n    private momentDateFormat: string;\n    private calendarChan