UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

222 lines 35.1 kB
// © 2022 SolarWinds Worldwide, LLC. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, Output, Renderer2, ViewChild, ViewEncapsulation, } from "@angular/core"; import { NG_VALUE_ACCESSOR } from "@angular/forms"; import moment from "moment/moment"; import { NuiFormFieldControl } from "../form-field/public-api"; import * as i0 from "@angular/core"; import * as i1 from "../date-picker/date-picker.component"; import * as i2 from "../time-picker/time-picker.component"; // <example-url>./../examples/index.html#/date-time-picker</example-url><br /> export class DateTimePickerComponent { /** * Input to set aria label text */ get ariaLabel() { return this._ariaLabel; } // changing the value with regular @Input doesn't trigger change detection // so we need to do that manually in the setter set ariaLabel(value) { if (value !== this._ariaLabel) { this._ariaLabel = value; this.cd.markForCheck(); } } /** model of picker */ get model() { return this._model; } set model(value) { if (moment(value).isValid()) { this._model = value; } this.updateChildrenModels(); } constructor(renderer, cd) { this.renderer = renderer; this.cd = cd; /** Callback to invoke on model change */ this.modelChanged = new EventEmitter(); this.isInErrorStateDate = false; this.isInErrorStateTime = false; this._ariaLabel = ""; this.onTouched = () => { }; this.onChange = (value) => { }; } ngOnInit() { if (!this.initEmpty && !this.model) { this.model = moment(); this.onChange(this.model); this.cd.markForCheck(); } } ngAfterViewInit() { if (this.displayMode === "inline") { this.renderer.addClass(this.codeElement.nativeElement, "nui-datetime-picker--inline"); this.renderer.addClass(this.codeElement.nativeElement.querySelector(".nui-timepicker"), "nui-dropdown--inline"); } } writeValue(value) { this.model = value; this.updateChildrenModels(); } registerOnTouched(fn) { this.onTouched = fn; } registerOnChange(fn) { this.onChange = fn; } setDisabledState(isDisabled) { this.isDisabled = isDisabled; this.cd.markForCheck(); // This is needed to update "disabled" state for child date and time pickers } onTimeChanged(event) { this.updateTime(event); this.modelChanged.emit(moment(this.model)); this.onChange(this.model); this.onTouched(); } onDateChanged(event) { const isDateTheSame = moment.isMoment(this.date) && this.date.isSame(event); if (isDateTheSame) { return; } this.updateDate(event); this.modelChanged.emit(moment(this.model)); this.onChange(this.model); this.onTouched(); } onInputBlurred() { this.onTouched(); if (!this.model) { this.isInErrorStateDate = !this.date || (this.date && !moment(this.date).isValid()); this.isInErrorStateTime = !this.time || (this.time && !moment(this.time).isValid()); } } updateChildrenModels() { if (this.model) { this.date = this.model.clone(); this.time = this.model.clone(); } else if (!this.model && this.initEmpty) { // TODO: Replace with undefined // @ts-ignore this.date = null; // @ts-ignore this.time = null; } } updateDate(newValue) { if (!moment.isMoment(newValue) || !moment(newValue).isValid()) { // TODO: Replace with undefined // @ts-ignore this._model = null; // @ts-ignore this.date = null; return; } // In case 'date' is not set, this._model is set from 'time' model if 'time' model exists this._model = this._model || (this.time && this.time.clone()); if (this._model) { this._model.set({ year: newValue.year(), month: newValue.month(), date: newValue.date(), }); } this.date = newValue.clone(); } updateTime(newValue) { if (!moment.isMoment(newValue)) { // TODO: Replace with undefined // @ts-ignore this._model = null; // @ts-ignore this.time = null; return; } // In case 'time' is not set, this._model is set from 'date' model if 'date' model exists this._model = this._model || (this.date && this.date.clone()); if (this._model) { this._model.set({ hours: newValue.hours(), minutes: newValue.minutes(), seconds: newValue.seconds(), milliseconds: newValue.millisecond(), }); } this.time = newValue.clone(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DateTimePickerComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DateTimePickerComponent, selector: "nui-date-time-picker", inputs: { maxDate: "maxDate", minDate: "minDate", displayMode: "displayMode", isDisabled: "isDisabled", initEmpty: "initEmpty", handleTimezone: "handleTimezone", appendToBody: "appendToBody", ariaLabel: "ariaLabel", model: "model" }, outputs: { modelChanged: "modelChanged" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateTimePickerComponent), multi: true, }, { provide: NuiFormFieldControl, useExisting: forwardRef(() => DateTimePickerComponent), multi: true, }, ], viewQueries: [{ propertyName: "codeElement", first: true, predicate: ["nuiDatetimePicker"], descendants: true, static: true }], ngImport: i0, template: "<div\n #nuiDatetimePicker\n class=\"nui-datetime-picker\"\n [attr.aria-label]=\"ariaLabel\"\n>\n <div class=\"nui-datetime-picker__group\">\n <nui-date-picker\n class=\"nui-datepicker--justified\"\n [value]=\"date\"\n (valueChange)=\"onDateChanged($event)\"\n (inputBlurred)=\"onInputBlurred()\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [isDisabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorStateDate\"\n [handleTimezone]=\"handleTimezone\"\n [appendToBody]=\"appendToBody\"\n [ariaLabel]=\"ariaLabel + ' date'\"\n ></nui-date-picker>\n </div>\n <div class=\"nui-datetime-picker__group nui-datetime-picker__group--last\">\n <nui-time-picker\n class=\"nui-dropdown--justified\"\n [initEmpty]=\"initEmpty\"\n [model]=\"time\"\n (timeChanged)=\"onTimeChanged($event)\"\n (inputBlurred)=\"onInputBlurred()\"\n [isDisabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorStateTime\"\n [appendToBody]=\"appendToBody\"\n [ariaLabel]=\"ariaLabel + ' time'\"\n ></nui-time-picker>\n </div>\n</div>\n", styles: [".nui .nui-datetime-picker{display:flex;flex-direction:column}.nui .nui-datetime-picker .nui-timepicker,.nui .nui-datetime-picker .nui-timepicker__input-group,.nui .nui-datetime-picker .nui-datepicker{width:100%}.nui .nui-datetime-picker__group{width:135px;margin-bottom:10px}.nui .nui-datetime-picker__group--last{margin-bottom:0}.nui .nui-datetime-picker--inline{width:auto;flex-direction:row;max-width:none}.nui .nui-datetime-picker--inline .nui-datetime-picker__label{display:inline-block;line-height:30px}.nui .nui-datetime-picker--inline .nui-datetime-picker__group,.nui .nui-datetime-picker--inline .nui-datetime-picker__label{margin-bottom:0}.nui .nui-datetime-picker--inline .nui-datetime-picker__group:not(:last-child),.nui .nui-datetime-picker--inline .nui-datetime-picker__label:not(:last-child){margin-right:10px}\n"], dependencies: [{ kind: "component", type: i1.DatePickerComponent, selector: "nui-date-picker", inputs: ["inline", "isRequired", "isDisabled", "isInErrorState", "ariaLabel", "locale", "datepickerMode", "minDate", "maxDate", "minMode", "maxMode", "showWeeks", "dateFormat", "formatDay", "formatMonth", "formatYear", "formatDayHeader", "formatDayTitle", "formatMonthTitle", "startingDay", "yearRange", "onlyCurrentMonth", "preserveInsignificant", "disabledDates", "handleTimezone", "appendToBody", "value"], outputs: ["selectionDone", "valueChange", "calendarNavigated", "inputBlurred"] }, { kind: "component", type: i2.TimePickerComponent, selector: "nui-time-picker", inputs: ["timeStep", "isDisabled", "timeFormat", "preserveInsignificant", "isInErrorState", "ariaLabel", "initEmpty", "appendToBody", "model"], outputs: ["timeChanged", "inputBlurred"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DateTimePickerComponent, decorators: [{ type: Component, args: [{ selector: "nui-date-time-picker", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DateTimePickerComponent), multi: true, }, { provide: NuiFormFieldControl, useExisting: forwardRef(() => DateTimePickerComponent), multi: true, }, ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n #nuiDatetimePicker\n class=\"nui-datetime-picker\"\n [attr.aria-label]=\"ariaLabel\"\n>\n <div class=\"nui-datetime-picker__group\">\n <nui-date-picker\n class=\"nui-datepicker--justified\"\n [value]=\"date\"\n (valueChange)=\"onDateChanged($event)\"\n (inputBlurred)=\"onInputBlurred()\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [isDisabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorStateDate\"\n [handleTimezone]=\"handleTimezone\"\n [appendToBody]=\"appendToBody\"\n [ariaLabel]=\"ariaLabel + ' date'\"\n ></nui-date-picker>\n </div>\n <div class=\"nui-datetime-picker__group nui-datetime-picker__group--last\">\n <nui-time-picker\n class=\"nui-dropdown--justified\"\n [initEmpty]=\"initEmpty\"\n [model]=\"time\"\n (timeChanged)=\"onTimeChanged($event)\"\n (inputBlurred)=\"onInputBlurred()\"\n [isDisabled]=\"isDisabled\"\n [isInErrorState]=\"isInErrorStateTime\"\n [appendToBody]=\"appendToBody\"\n [ariaLabel]=\"ariaLabel + ' time'\"\n ></nui-time-picker>\n </div>\n</div>\n", styles: [".nui .nui-datetime-picker{display:flex;flex-direction:column}.nui .nui-datetime-picker .nui-timepicker,.nui .nui-datetime-picker .nui-timepicker__input-group,.nui .nui-datetime-picker .nui-datepicker{width:100%}.nui .nui-datetime-picker__group{width:135px;margin-bottom:10px}.nui .nui-datetime-picker__group--last{margin-bottom:0}.nui .nui-datetime-picker--inline{width:auto;flex-direction:row;max-width:none}.nui .nui-datetime-picker--inline .nui-datetime-picker__label{display:inline-block;line-height:30px}.nui .nui-datetime-picker--inline .nui-datetime-picker__group,.nui .nui-datetime-picker--inline .nui-datetime-picker__label{margin-bottom:0}.nui .nui-datetime-picker--inline .nui-datetime-picker__group:not(:last-child),.nui .nui-datetime-picker--inline .nui-datetime-picker__label:not(:last-child){margin-right:10px}\n"] }] }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { maxDate: [{ type: Input }], minDate: [{ type: Input }], displayMode: [{ type: Input }], isDisabled: [{ type: Input }], initEmpty: [{ type: Input }], handleTimezone: [{ type: Input }], appendToBody: [{ type: Input }], ariaLabel: [{ type: Input }], codeElement: [{ type: ViewChild, args: ["nuiDatetimePicker", { static: true }] }], modelChanged: [{ type: Output }], model: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-picker.component.js","sourceRoot":"","sources":["../../../../src/lib/date-time-picker/date-time-picker.component.ts","../../../../src/lib/date-time-picker/date-time-picker.component.html"],"names":[],"mappings":"AAAA,yDAAyD;AACzD,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,8EAA8E;AAC9E,+EAA+E;AAC/E,8EAA8E;AAC9E,4DAA4D;AAC5D,EAAE;AACF,6EAA6E;AAC7E,uDAAuD;AACvD,EAAE;AACF,6EAA6E;AAC7E,4EAA4E;AAC5E,+EAA+E;AAC/E,0EAA0E;AAC1E,iFAAiF;AACjF,6EAA6E;AAC7E,iBAAiB;AAEjB,OAAO,EAEH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,KAAK,EAEL,MAAM,EACN,SAAS,EACT,SAAS,EACT,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,MAAM,MAAM,eAAe,CAAC;AAGnC,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;;;;AAE/D,8EAA8E;AAqB9E,MAAM,OAAO,uBAAuB;IAkBhC;;OAEG;IACH,IAAoB,SAAS;QACzB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,0EAA0E;IAC1E,+CAA+C;IAC/C,IAAW,SAAS,CAAC,KAAa;QAC9B,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;SAC1B;IACL,CAAC;IAQD,sBAAsB;IACtB,IACI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,KAAK,CAAC,KAAyB;QAC/B,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE;YACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACvB;QACD,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAaD,YAAoB,QAAmB,EAAU,EAAqB;QAAlD,aAAQ,GAAR,QAAQ,CAAW;QAAU,OAAE,GAAF,EAAE,CAAmB;QA5BtE,yCAAyC;QAEzC,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QAkBzD,uBAAkB,GAAG,KAAK,CAAC;QAC3B,uBAAkB,GAAG,KAAK,CAAC;QAE1B,eAAU,GAAW,EAAE,CAAC;QAEhC,cAAS,GAAG,GAAS,EAAE,GAAE,CAAC,CAAC;QAC3B,aAAQ,GAAG,CAAC,KAAU,EAAQ,EAAE,GAAE,CAAC,CAAC;IAEqC,CAAC;IAEnE,QAAQ;QACX,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YAChC,IAAI,CAAC,KAAK,GAAG,MAAM,EAAE,CAAC;YACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;SAC1B;IACL,CAAC;IAEM,eAAe;QAClB,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;YAC/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,IAAI,CAAC,WAAW,CAAC,aAAa,EAC9B,6BAA6B,CAChC,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,EAC/D,sBAAsB,CACzB,CAAC;SACL;IACL,CAAC;IAED,UAAU,CAAC,KAAa;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC5B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,EAAc;QAC3B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAChC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC,4EAA4E;IACxG,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,MAAM,aAAa,GACf,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAE1D,IAAI,aAAa,EAAE;YACf,OAAO;SACV;QAED,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,cAAc;QACV,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,IAAI,CAAC,kBAAkB;gBACnB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YAC9D,IAAI,CAAC,kBAAkB;gBACnB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;SACjE;IACL,CAAC;IAEO,oBAAoB;QACxB,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;SAClC;aAAM,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE;YACtC,+BAA+B;YAC/B,aAAa;YACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,aAAa;YACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAEO,UAAU,CAAC,QAAuB;QACtC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,EAAE;YAC3D,+BAA+B;YAC/B,aAAa;YACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,aAAa;YACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,OAAO;SACV;QAED,yFAAyF;QACzF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC9D,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACZ,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;gBACrB,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE;gBACvB,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE;aACxB,CAAC,CAAC;SACN;QAED,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAEO,UAAU,CAAC,QAAgB;QAC/B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAC5B,+BAA+B;YAC/B,aAAa;YACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,aAAa;YACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,OAAO;SACV;QAED,yFAAyF;QACzF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC9D,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACZ,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE;gBACvB,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE;gBAC3B,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE;gBAC3B,YAAY,EAAE,QAAQ,CAAC,WAAW,EAAE;aACvC,CAAC,CAAC;SACN;QAED,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;+GAlMQ,uBAAuB;mGAAvB,uBAAuB,oUAhBrB;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACd;YACD;gBACI,OAAO,EAAE,mBAAmB;gBAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACd;SACJ,0JCzDL,wvCAkCA;;4FD4Ba,uBAAuB;kBAnBnC,SAAS;+BACI,sBAAsB,aAErB;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACd;qBACJ,iBAEc,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;8GAMtC,OAAO;sBAAf,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAKc,SAAS;sBAA5B,KAAK;gBAcC,WAAW;sBADjB,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIhD,YAAY;sBADX,MAAM;gBAKH,KAAK;sBADR,KAAK","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 {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport moment from \"moment/moment\";\nimport { Moment } from \"moment/moment\";\n\nimport { NuiFormFieldControl } from \"../form-field/public-api\";\n\n// <example-url>./../examples/index.html#/date-time-picker</example-url><br />\n\n@Component({\n    selector: \"nui-date-time-picker\",\n    templateUrl: \"./date-time-picker.component.html\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => DateTimePickerComponent),\n            multi: true,\n        },\n        {\n            provide: NuiFormFieldControl, // this allows our form control to use run-time type checking\n            useExisting: forwardRef(() => DateTimePickerComponent),\n            multi: true,\n        },\n    ],\n    styleUrls: [\"./date-time-picker.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DateTimePickerComponent\n    implements AfterViewInit, OnInit, ControlValueAccessor\n{\n    /** latest available date */\n    @Input() maxDate: Moment;\n    /** earliest available date */\n    @Input() minDate: Moment;\n    /** sets mode of showing date-time-picker */\n    @Input() displayMode: string;\n\n    @Input() isDisabled: boolean;\n\n    @Input() initEmpty: boolean;\n    /** Is used to handle timezone of date value, passed to DatePickerComponent */\n    @Input() handleTimezone: boolean;\n    /** Allows popup box to be attached to document.body */\n    @Input() appendToBody: boolean;\n\n    /**\n     * Input to set aria label text\n     */\n    @Input() public get ariaLabel(): string {\n        return this._ariaLabel;\n    }\n\n    // changing the value with regular @Input doesn't trigger change detection\n    // so we need to do that manually in the setter\n    public set ariaLabel(value: string) {\n        if (value !== this._ariaLabel) {\n            this._ariaLabel = value;\n            this.cd.markForCheck();\n        }\n    }\n\n    @ViewChild(\"nuiDatetimePicker\", { static: true })\n    public codeElement: ElementRef;\n    /** Callback to invoke on model change */\n    @Output()\n    modelChanged: EventEmitter<Moment> = new EventEmitter<Moment>();\n\n    /** model of picker */\n    @Input()\n    get model(): Moment | undefined {\n        return this._model;\n    }\n\n    set model(value: Moment | undefined) {\n        if (moment(value).isValid()) {\n            this._model = value;\n        }\n        this.updateChildrenModels();\n    }\n\n    public date?: Moment;\n    public time?: Moment;\n    private _model?: Moment;\n    public isInErrorStateDate = false;\n    public isInErrorStateTime = false;\n\n    private _ariaLabel: string = \"\";\n\n    onTouched = (): void => {};\n    onChange = (value: any): void => {};\n\n    constructor(private renderer: Renderer2, private cd: ChangeDetectorRef) {}\n\n    public ngOnInit(): void {\n        if (!this.initEmpty && !this.model) {\n            this.model = moment();\n            this.onChange(this.model);\n            this.cd.markForCheck();\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        if (this.displayMode === \"inline\") {\n            this.renderer.addClass(\n                this.codeElement.nativeElement,\n                \"nui-datetime-picker--inline\"\n            );\n            this.renderer.addClass(\n                this.codeElement.nativeElement.querySelector(\".nui-timepicker\"),\n                \"nui-dropdown--inline\"\n            );\n        }\n    }\n\n    writeValue(value: Moment): void {\n        this.model = value;\n        this.updateChildrenModels();\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    registerOnChange(fn: () => void): void {\n        this.onChange = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this.isDisabled = isDisabled;\n        this.cd.markForCheck(); // This is needed to update \"disabled\" state for child date and time pickers\n    }\n\n    onTimeChanged(event: Moment): void {\n        this.updateTime(event);\n        this.modelChanged.emit(moment(this.model));\n        this.onChange(this.model);\n        this.onTouched();\n    }\n\n    onDateChanged(event: Moment): void {\n        const isDateTheSame =\n            moment.isMoment(this.date) && this.date.isSame(event);\n\n        if (isDateTheSame) {\n            return;\n        }\n\n        this.updateDate(event);\n        this.modelChanged.emit(moment(this.model));\n        this.onChange(this.model);\n        this.onTouched();\n    }\n\n    onInputBlurred(): void {\n        this.onTouched();\n        if (!this.model) {\n            this.isInErrorStateDate =\n                !this.date || (this.date && !moment(this.date).isValid());\n            this.isInErrorStateTime =\n                !this.time || (this.time && !moment(this.time).isValid());\n        }\n    }\n\n    private updateChildrenModels() {\n        if (this.model) {\n            this.date = this.model.clone();\n            this.time = this.model.clone();\n        } else if (!this.model && this.initEmpty) {\n            // TODO: Replace with undefined\n            // @ts-ignore\n            this.date = null;\n            // @ts-ignore\n            this.time = null;\n        }\n    }\n\n    private updateDate(newValue: Moment | null) {\n        if (!moment.isMoment(newValue) || !moment(newValue).isValid()) {\n            // TODO: Replace with undefined\n            // @ts-ignore\n            this._model = null;\n            // @ts-ignore\n            this.date = null;\n            return;\n        }\n\n        // In case 'date' is not set, this._model is set from 'time' model if 'time' model exists\n        this._model = this._model || (this.time && this.time.clone());\n        if (this._model) {\n            this._model.set({\n                year: newValue.year(),\n                month: newValue.month(),\n                date: newValue.date(),\n            });\n        }\n\n        this.date = newValue.clone();\n    }\n\n    private updateTime(newValue: Moment) {\n        if (!moment.isMoment(newValue)) {\n            // TODO: Replace with undefined\n            // @ts-ignore\n            this._model = null;\n            // @ts-ignore\n            this.time = null;\n            return;\n        }\n\n        // In case 'time' is not set, this._model is set from 'date' model if 'date' model exists\n        this._model = this._model || (this.date && this.date.clone());\n        if (this._model) {\n            this._model.set({\n                hours: newValue.hours(),\n                minutes: newValue.minutes(),\n                seconds: newValue.seconds(),\n                milliseconds: newValue.millisecond(),\n            });\n        }\n\n        this.time = newValue.clone();\n    }\n}\n","<div\n    #nuiDatetimePicker\n    class=\"nui-datetime-picker\"\n    [attr.aria-label]=\"ariaLabel\"\n>\n    <div class=\"nui-datetime-picker__group\">\n        <nui-date-picker\n            class=\"nui-datepicker--justified\"\n            [value]=\"date\"\n            (valueChange)=\"onDateChanged($event)\"\n            (inputBlurred)=\"onInputBlurred()\"\n            [maxDate]=\"maxDate\"\n            [minDate]=\"minDate\"\n            [isDisabled]=\"isDisabled\"\n            [isInErrorState]=\"isInErrorStateDate\"\n            [handleTimezone]=\"handleTimezone\"\n            [appendToBody]=\"appendToBody\"\n            [ariaLabel]=\"ariaLabel + ' date'\"\n        ></nui-date-picker>\n    </div>\n    <div class=\"nui-datetime-picker__group nui-datetime-picker__group--last\">\n        <nui-time-picker\n            class=\"nui-dropdown--justified\"\n            [initEmpty]=\"initEmpty\"\n            [model]=\"time\"\n            (timeChanged)=\"onTimeChanged($event)\"\n            (inputBlurred)=\"onInputBlurred()\"\n            [isDisabled]=\"isDisabled\"\n            [isInErrorState]=\"isInErrorStateTime\"\n            [appendToBody]=\"appendToBody\"\n            [ariaLabel]=\"ariaLabel + ' time'\"\n        ></nui-time-picker>\n    </div>\n</div>\n"]}