UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

312 lines 61.4 kB
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":"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","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