@junte/ui
Version:
Quality Angular UI components kit
328 lines • 44.7 kB
JavaScript
import { __decorate, __metadata, __values } from "tslib";
import { Component, forwardRef, HostBinding, HostListener, Input } from '@angular/core';
import { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';
import { format as formatDate, parse } from 'date-fns';
import { NGXLogger } from 'ngx-logger';
import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
import { Feature } from '../../core/enums/feature';
import { JunteUIConfig } from '../../config';
import { PropertyApi } from '../../core/decorators/api';
import { Breakpoint } from '../../core/enums/breakpoint';
import { UI } from '../../core/enums/ui';
import { Width } from '../../core/enums/width';
import { isEqual } from '../../core/utils/equal';
import { BreakpointService } from '../../layout/responsive/breakpoint.service';
import { DatePickerType } from './enums';
var INPUT_DELAY = 500;
var DIGIT_MASK_CHAR = '_';
var HOURS_MAX = 23;
var MINUTES_MAX = 59;
var Meridian;
(function (Meridian) {
Meridian["am"] = " AM";
Meridian["pm"] = " PM";
})(Meridian || (Meridian = {}));
var DatePickerComponent = /** @class */ (function () {
function DatePickerComponent(logger, fb, breakpoint, config) {
var _this = this;
this.logger = logger;
this.fb = fb;
this.breakpoint = breakpoint;
this.config = config;
this.host = 'jnt-date-picker-host';
this.ui = UI;
this.datePickerType = DatePickerType;
this.meridians = Meridian;
this._type = DatePickerType.date;
this.reference = { popover: null };
this._width = Width.default;
this.dateControl = this.fb.control(null);
this.timeControl = this.fb.control(null);
this.hoursControl = this.fb.control(null);
this.minutesControl = this.fb.control(null);
this.calendarControl = this.fb.control(new Date());
this.form = this.fb.group({
date: this.dateControl,
time: this.timeControl,
hours: this.hoursControl,
minutes: this.minutesControl,
calendar: this.calendarControl
});
this.calendarOpened = false;
this.timeOpened = false;
this.placeholder = '';
this.features = [];
this.onChange = function () { return _this.logger.error('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.error('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
}
DatePickerComponent_1 = DatePickerComponent;
Object.defineProperty(DatePickerComponent.prototype, "mobile", {
get: function () {
return this.breakpoint.current === Breakpoint.mobile;
},
enumerable: true,
configurable: true
});
Object.defineProperty(DatePickerComponent.prototype, "type", {
get: function () {
return this._type;
},
set: function (type) {
this.clear();
this._type = type || DatePickerType.date;
},
enumerable: true,
configurable: true
});
Object.defineProperty(DatePickerComponent.prototype, "width", {
set: function (width) {
this._width = width || Width.default;
},
enumerable: true,
configurable: true
});
DatePickerComponent.prototype.ngOnInit = function () {
var _this = this;
this.calendarControl.valueChanges.pipe(distinctUntilChanged())
.subscribe(function (date) {
_this.dateControl.setValue(!!date ? formatDate(date, 'P', { locale: _this.config.locale.dfns }).replace(/\D/gi, '') : null);
_this.calendarOpened = false;
if (!!_this.reference.popover) {
_this.reference.popover.hide();
_this.reference.popover = null;
}
});
this.hoursControl.valueChanges
.pipe(distinctUntilChanged(function (val1, val2) { return isEqual(val1, val2); }))
.subscribe(function () { return _this.setTime(); });
this.minutesControl.valueChanges
.pipe(distinctUntilChanged(function (val1, val2) { return isEqual(val1, val2); }))
.subscribe(function () { return _this.setTime(); });
this.dateControl.valueChanges.pipe(debounceTime(INPUT_DELAY), distinctUntilChanged())
.subscribe(function (date) { return _this.update(date, true); });
this.timeControl.valueChanges.pipe(debounceTime(INPUT_DELAY), distinctUntilChanged())
.subscribe(function (time) { return _this.update(time); });
};
DatePickerComponent.prototype.close = function () {
if (!!this.reference.popover) {
this.reference.popover.hide();
this.reference.popover = null;
}
};
DatePickerComponent.prototype.clear = function () {
this.dateControl.setValue(null, { emitEvent: false });
this.timeControl.setValue(null, { emitEvent: false });
this.hoursControl.setValue(null, { emitEvent: false });
this.minutesControl.setValue(null, { emitEvent: false });
};
DatePickerComponent.prototype.update = function (value, close) {
var e_1, _a, e_2, _b, e_3, _c;
if (close === void 0) { close = false; }
if (!!value || this.type === DatePickerType.dateTime) {
if (this.type !== DatePickerType.dateTime) {
var output = this.type === DatePickerType.date
? this.config.locale.ui.masks.date
: this.config.locale.ui.masks.time + (this.meridian || '');
try {
for (var value_1 = __values(value), value_1_1 = value_1.next(); !value_1_1.done; value_1_1 = value_1.next()) {
var char = value_1_1.value;
output = output.replace(DIGIT_MASK_CHAR, char);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (value_1_1 && !value_1_1.done && (_a = value_1.return)) _a.call(value_1);
}
finally { if (e_1) throw e_1.error; }
}
var parsed = parse(output, this.type === DatePickerType.date
? 'P' : 'p', new Date(0), { locale: this.config.locale.dfns });
if (parsed instanceof Date && !isNaN(parsed.getTime())) {
if (this.type === DatePickerType.date) {
this.calendarControl.setValue(parsed);
}
else {
this.hoursControl.setValue(parsed.getHours());
this.minutesControl.setValue(parsed.getMinutes());
}
this.onChange(parsed);
if (close) {
this.close();
}
}
}
else if (!!this.dateControl.value && !!this.timeControl.value) {
var output = this.config.locale.ui.masks.datetime + (this.meridian || '');
try {
for (var _d = __values(this.dateControl.value), _e = _d.next(); !_e.done; _e = _d.next()) {
var char = _e.value;
output = output.replace(DIGIT_MASK_CHAR, char);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_e && !_e.done && (_b = _d.return)) _b.call(_d);
}
finally { if (e_2) throw e_2.error; }
}
try {
for (var _f = __values(this.timeControl.value), _g = _f.next(); !_g.done; _g = _f.next()) {
var char = _g.value;
output = output.replace(DIGIT_MASK_CHAR, char);
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_g && !_g.done && (_c = _f.return)) _c.call(_f);
}
finally { if (e_3) throw e_3.error; }
}
var parsed = parse(output, 'Pp', new Date(), { locale: this.config.locale.dfns });
if (parsed instanceof Date && !isNaN(parsed.getTime())) {
this.onChange(parsed);
if (close) {
this.close();
}
}
}
}
else {
this.onChange(null);
if (!this.dateControl.value) {
this.calendarControl.setValue(null, { emitEvent: false });
this.close();
}
else {
this.hoursControl.setValue(null, { emitEvent: false });
this.minutesControl.setValue(null, { emitEvent: false });
this.close();
}
}
};
DatePickerComponent.prototype.setTime = function () {
var hours = '00';
var minutes = '00';
if (this.hoursControl.value !== null) {
hours = Math.min(Math.max(+this.hoursControl.value, 0), HOURS_MAX).toString();
this.hoursControl.setValue(+hours, { emitEvent: false });
hours = hours.length === 1 ? "0" + hours : hours;
}
else {
this.hoursControl.setValue(0, { emitEvent: false });
}
if (this.minutesControl.value !== null) {
minutes = Math.min(Math.max(+this.minutesControl.value, 0), MINUTES_MAX).toString();
this.minutesControl.setValue(+minutes, { emitEvent: false });
minutes = minutes.length === 1 ? "0" + minutes : minutes;
}
else {
this.minutesControl.setValue(0, { emitEvent: false });
}
this.timeControl.setValue("" + hours + minutes);
};
DatePickerComponent.prototype.writeValue = function (date) {
if (date instanceof Date && !isNaN(date.getTime())) {
this.calendarControl.setValue(date, { emitEvent: false });
this.dateControl.setValue(formatDate(date, 'P', { locale: this.config.locale.dfns }), { emitEvent: false });
}
else {
this.clear();
}
};
DatePickerComponent.prototype.setDisabledState = function (disabled) {
disabled ? this.dateControl.disable({ emitEvent: false })
: this.dateControl.enable({ emitEvent: false });
};
var DatePickerComponent_1;
DatePickerComponent.ctorParameters = function () { return [
{ type: NGXLogger },
{ type: FormBuilder },
{ type: BreakpointService },
{ type: JunteUIConfig }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], DatePickerComponent.prototype, "host", void 0);
__decorate([
HostBinding('attr.data-width'),
__metadata("design:type", String)
], DatePickerComponent.prototype, "_width", void 0);
__decorate([
HostBinding('attr.calendar-opened'),
__metadata("design:type", Object)
], DatePickerComponent.prototype, "calendarOpened", void 0);
__decorate([
HostBinding('attr.time-opened'),
__metadata("design:type", Object)
], DatePickerComponent.prototype, "timeOpened", void 0);
__decorate([
PropertyApi({
description: 'Placeholder for date picker',
type: 'string'
}),
Input(),
__metadata("design:type", Object)
], DatePickerComponent.prototype, "placeholder", void 0);
__decorate([
PropertyApi({
description: 'Button for reset input',
path: 'ui.feature',
options: [Feature.allowEmpty],
}),
HostBinding('attr.data-features'),
Input(),
__metadata("design:type", Array)
], DatePickerComponent.prototype, "features", void 0);
__decorate([
PropertyApi({
description: 'Date picker type',
path: 'ui.type',
options: [DatePickerType.date, DatePickerType.time, DatePickerType.dateTime]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], DatePickerComponent.prototype, "type", null);
__decorate([
PropertyApi({
description: 'Input width',
path: 'ui.width',
default: Width.default,
options: [Width.default, Width.fluid]
}),
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], DatePickerComponent.prototype, "width", null);
__decorate([
HostListener('blur'),
__metadata("design:type", Object)
], DatePickerComponent.prototype, "onBlur", void 0);
DatePickerComponent = DatePickerComponent_1 = __decorate([
Component({
selector: 'jnt-date-picker',
template: "<jnt-form child-of=\"jnt-date-picker-host\" [formGroup]=\"form\">\n <jnt-stack child-of=\"jnt-date-picker-host\" [orientation]=\"ui.orientation.horizontal\" [gutter]=\"mobile ? ui.gutter.none : ui.gutter.normal\">\n <ng-container *ngIf=\"type === datePickerType.date || type === datePickerType.dateTime\">\n <jnt-input child-of=\"jnt-date-picker-host\" *jntMinFor=\"ui.breakpoint.tablet\"\n data-input data-date\n formControlName=\"date\"\n [placeholder]=\"placeholder || ''\"\n [jntPopover]=\"{\n contentTemplate: calendarTemplate,\n trigger: ui.trigger.click,\n behaviour: ui.behaviour.dropdown,\n minWidth: '300px'\n }\"\n (attached)=\"reference.popover = $event\"\n [icon]=\"ui.icons.calendar\"\n [mask]=\"config.locale.ui.masks.date\"\n [width]=\"ui.width.fluid\"\n [features]=\"features\">\n </jnt-input>\n\n <jnt-input child-of=\"jnt-date-picker-host\" *jntFor=\"ui.breakpoint.mobile\" data-input\n formControlName=\"date\"\n [placeholder]=\"placeholder || ''\"\n [icon]=\"ui.icons.calendar\"\n (click)=\"calendarOpened = !calendarOpened\"\n [mask]=\"config.locale.ui.masks.date\"\n [width]=\"ui.width.fluid\"\n [features]=\"features\">\n </jnt-input>\n </ng-container>\n\n <ng-container *ngIf=\"type === datePickerType.time || type === datePickerType.dateTime\">\n <jnt-input child-of=\"jnt-date-picker-host\" *jntMinFor=\"ui.breakpoint.tablet\"\n data-input data-time\n formControlName=\"time\"\n [icon]=\"ui.icons.time\"\n [jntPopover]=\"{\n contentTemplate: timeTemplate,\n trigger: ui.trigger.click,\n behaviour: ui.behaviour.dropdown,\n features: [ui.feature.smarty],\n minWidth: '150px'\n }\"\n (attached)=\"reference.popover = $event\"\n [mask]=\"config.locale.ui.masks.time + (meridian || '')\"\n [features]=\"features\">\n </jnt-input>\n\n <jnt-input child-of=\"jnt-date-picker-host\" *jntFor=\"ui.breakpoint.mobile\" data-input\n formControlName=\"time\"\n [icon]=\"ui.icons.time\"\n (click)=\"timeOpened = !timeOpened\"\n [mask]=\"config.locale.ui.masks.time + (meridian || '')\"\n [features]=\"features\">\n </jnt-input>\n </ng-container>\n </jnt-stack>\n\n <ng-template #calendarTemplate>\n <jnt-stack child-of=\"jnt-date-picker-host\" data-calendar-dropdown [align]=\"ui.align.stretch\">\n <jnt-calendar child-of=\"jnt-date-picker-host\" data-calendar [features]=\"[ui.feature.today]\" formControlName=\"calendar\"></jnt-calendar>\n </jnt-stack>\n </ng-template>\n\n <ng-template #timeTemplate>\n <jnt-stack child-of=\"jnt-date-picker-host\" data-time-dropdown [orientation]=\"ui.orientation.horizontal\"\n [align]=\"ui.align.center\">\n\n <jnt-stack child-of=\"jnt-date-picker-host\" [align]=\"ui.align.stretch\" [gutter]=\"ui.gutter.small\" data-time-col>\n <jnt-button child-of=\"jnt-date-picker-host\" [icon]=\"ui.icons.chevronUp\"\n [size]=\"ui.size.small\"\n (click)=\"hoursControl.setValue(+hoursControl.value + 1)\">\n </jnt-button>\n <jnt-input child-of=\"jnt-date-picker-host\" data-input\n formControlName=\"hours\"\n [type]=\"ui.input.type.number\">\n </jnt-input>\n <jnt-button child-of=\"jnt-date-picker-host\" [icon]=\"ui.icons.chevronDown\"\n [size]=\"ui.size.small\"\n (click)=\"hoursControl.setValue(+hoursControl.value - 1)\">\n </jnt-button>\n </jnt-stack>\n\n <jnt-stack child-of=\"jnt-date-picker-host\" [align]=\"ui.align.stretch\" [gutter]=\"ui.gutter.small\" data-time-col>\n <jnt-button child-of=\"jnt-date-picker-host\" [icon]=\"ui.icons.chevronUp\"\n [size]=\"ui.size.small\"\n (click)=\"minutesControl.setValue(+minutesControl.value + 1)\">\n </jnt-button>\n <jnt-input child-of=\"jnt-date-picker-host\" data-input\n formControlName=\"minutes\"\n [type]=\"ui.input.type.number\">\n </jnt-input>\n <jnt-button child-of=\"jnt-date-picker-host\" [icon]=\"ui.icons.chevronDown\"\n [size]=\"ui.size.small\"\n (click)=\"minutesControl.setValue(+minutesControl.value - 1)\">\n </jnt-button>\n </jnt-stack>\n\n <jnt-stack child-of=\"jnt-date-picker-host\" *ngIf=\"config.locale.dfns.code !== 'ru'\"\n [align]=\"ui.align.stretch\"\n [gutter]=\"ui.gutter.small\" data-time-col>\n <jnt-button child-of=\"jnt-date-picker-host\" [text]=\"meridians.am\" (click)=\"meridian = meridians.am\"></jnt-button>\n <jnt-button child-of=\"jnt-date-picker-host\" [text]=\"meridians.pm\" (click)=\"meridian = meridians.pm\"></jnt-button>\n </jnt-stack>\n </jnt-stack>\n </ng-template>\n\n <ng-container *ngIf=\"mobile\">\n <ng-container *ngTemplateOutlet=\"calendarTemplate\"></ng-container>\n <ng-container *ngTemplateOutlet=\"timeTemplate\"></ng-container>\n </ng-container>\n</jnt-form>",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return DatePickerComponent_1; }),
multi: true
}
]
}),
__metadata("design:paramtypes", [NGXLogger,
FormBuilder,
BreakpointService,
JunteUIConfig])
], DatePickerComponent);
return DatePickerComponent;
}());
export { DatePickerComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/forms/date-picker/date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, HostBinding, HostListener, Input, OnInit } from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { format as formatDate, parse } from 'date-fns';\nimport { NGXLogger } from 'ngx-logger';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { Feature } from '../../core/enums/feature';\nimport { JunteUIConfig } from '../../config';\nimport { PropertyApi } from '../../core/decorators/api';\nimport { Breakpoint } from '../../core/enums/breakpoint';\nimport { UI } from '../../core/enums/ui';\nimport { Width } from '../../core/enums/width';\nimport { isEqual } from '../../core/utils/equal';\nimport { BreakpointService } from '../../layout/responsive/breakpoint.service';\nimport { PopoverInstance } from '../../overlays/popover/popover.service';\nimport { DatePickerType } from './enums';\n\nconst INPUT_DELAY = 500;\nconst DIGIT_MASK_CHAR = '_';\nconst HOURS_MAX = 23;\nconst MINUTES_MAX = 59;\n\nenum Meridian {\n  am = ' AM',\n  pm = ' PM'\n}\n\n@Component({\n  selector: 'jnt-date-picker',\n  templateUrl: './date-picker.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class DatePickerComponent implements OnInit, ControlValueAccessor {\n\n  @HostBinding('attr.host') readonly host = 'jnt-date-picker-host';\n\n  ui = UI;\n  datePickerType = DatePickerType;\n  meridians = Meridian;\n  private _type: DatePickerType = DatePickerType.date;\n\n  reference: { popover: PopoverInstance } = {popover: null};\n  meridian: Meridian;\n\n  @HostBinding('attr.data-width')\n  _width: Width = Width.default;\n\n  dateControl = this.fb.control(null);\n  timeControl = this.fb.control(null);\n  hoursControl = this.fb.control(null);\n  minutesControl = this.fb.control(null);\n  calendarControl = this.fb.control(new Date());\n  form = this.fb.group({\n    date: this.dateControl,\n    time: this.timeControl,\n    hours: this.hoursControl,\n    minutes: this.minutesControl,\n    calendar: this.calendarControl\n  });\n\n  get mobile() {\n    return this.breakpoint.current === Breakpoint.mobile;\n  }\n\n  @HostBinding('attr.calendar-opened')\n  calendarOpened = false;\n\n  @HostBinding('attr.time-opened')\n  timeOpened = false;\n\n  @PropertyApi({\n    description: 'Placeholder for date picker',\n    type: 'string'\n  })\n  @Input()\n  placeholder = '';\n\n  @PropertyApi({\n    description: 'Button for reset input',\n    path: 'ui.feature',\n    options: [Feature.allowEmpty],\n  })\n  @HostBinding('attr.data-features')\n  @Input()\n  features: Feature[] = [];\n\n  @PropertyApi({\n    description: 'Date picker type',\n    path: 'ui.type',\n    options: [DatePickerType.date, DatePickerType.time, DatePickerType.dateTime]\n  })\n  @Input()\n  set type(type: DatePickerType) {\n    this.clear();\n    this._type = type || DatePickerType.date;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  @PropertyApi({\n    description: 'Input width',\n    path: 'ui.width',\n    default: Width.default,\n    options: [Width.default, Width.fluid]\n  })\n  @Input() set width(width: Width) {\n    this._width = width || Width.default;\n  }\n\n  onChange: (value: any) => void = () => this.logger.error('value accessor is not registered');\n  onTouched: () => void = () => this.logger.error('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private logger: NGXLogger,\n              private fb: FormBuilder,\n              private breakpoint: BreakpointService,\n              public config: JunteUIConfig) {\n  }\n\n  ngOnInit() {\n    this.calendarControl.valueChanges.pipe(distinctUntilChanged())\n      .subscribe(date => {\n        this.dateControl.setValue(!!date ? formatDate(date, 'P',\n          {locale: this.config.locale.dfns}).replace(/\\D/gi, '') : null);\n        this.calendarOpened = false;\n        if (!!this.reference.popover) {\n          this.reference.popover.hide();\n          this.reference.popover = null;\n        }\n      });\n\n    this.hoursControl.valueChanges\n      .pipe(distinctUntilChanged((val1, val2) => isEqual(val1, val2)))\n      .subscribe(() => this.setTime());\n\n    this.minutesControl.valueChanges\n      .pipe(distinctUntilChanged((val1, val2) => isEqual(val1, val2)))\n      .subscribe(() => this.setTime());\n\n    this.dateControl.valueChanges.pipe(debounceTime(INPUT_DELAY), distinctUntilChanged())\n      .subscribe(date => this.update(date, true));\n\n    this.timeControl.valueChanges.pipe(debounceTime(INPUT_DELAY), distinctUntilChanged())\n      .subscribe(time => this.update(time));\n  }\n\n  close() {\n    if (!!this.reference.popover) {\n      this.reference.popover.hide();\n      this.reference.popover = null;\n    }\n  }\n\n  clear() {\n    this.dateControl.setValue(null, {emitEvent: false});\n    this.timeControl.setValue(null, {emitEvent: false});\n    this.hoursControl.setValue(null, {emitEvent: false});\n    this.minutesControl.setValue(null, {emitEvent: false});\n  }\n\n  update(value: string, close = false) {\n    if (!!value || this.type === DatePickerType.dateTime) {\n      if (this.type !== DatePickerType.dateTime) {\n        let output = this.type === DatePickerType.date\n          ? this.config.locale.ui.masks.date\n          : this.config.locale.ui.masks.time + (this.meridian || '');\n        for (const char of value) {\n          output = output.replace(DIGIT_MASK_CHAR, char);\n        }\n        const parsed = parse(output, this.type === DatePickerType.date\n          ? 'P' : 'p', new Date(0),\n          {locale: this.config.locale.dfns});\n        if (parsed instanceof Date && !isNaN(parsed.getTime())) {\n          if (this.type === DatePickerType.date) {\n            this.calendarControl.setValue(parsed);\n          } else {\n            this.hoursControl.setValue(parsed.getHours());\n            this.minutesControl.setValue(parsed.getMinutes());\n          }\n          this.onChange(parsed);\n          if (close) {\n            this.close();\n          }\n        }\n      } else if (!!this.dateControl.value && !!this.timeControl.value) {\n        let output = this.config.locale.ui.masks.datetime + (this.meridian || '');\n        for (const char of this.dateControl.value) {\n          output = output.replace(DIGIT_MASK_CHAR, char);\n        }\n        for (const char of this.timeControl.value) {\n          output = output.replace(DIGIT_MASK_CHAR, char);\n        }\n        const parsed = parse(output, 'Pp', new Date(),\n          {locale: this.config.locale.dfns});\n        if (parsed instanceof Date && !isNaN(parsed.getTime())) {\n          this.onChange(parsed);\n          if (close) {\n            this.close();\n          }\n        }\n      }\n    } else {\n      this.onChange(null);\n      if (!this.dateControl.value) {\n        this.calendarControl.setValue(null, {emitEvent: false});\n        this.close();\n      } else {\n        this.hoursControl.setValue(null, {emitEvent: false});\n        this.minutesControl.setValue(null, {emitEvent: false});\n        this.close();\n      }\n    }\n  }\n\n  setTime() {\n    let hours = '00';\n    let minutes = '00';\n\n    if (this.hoursControl.value !== null) {\n      hours = Math.min(Math.max(+this.hoursControl.value, 0), HOURS_MAX).toString();\n      this.hoursControl.setValue(+hours, {emitEvent: false});\n      hours = hours.length === 1 ? `0${hours}` : hours;\n    } else {\n      this.hoursControl.setValue(0, {emitEvent: false});\n    }\n\n    if (this.minutesControl.value !== null) {\n      minutes = Math.min(Math.max(+this.minutesControl.value, 0), MINUTES_MAX).toString();\n      this.minutesControl.setValue(+minutes, {emitEvent: false});\n      minutes = minutes.length === 1 ? `0${minutes}` : minutes;\n    } else {\n      this.minutesControl.setValue(0, {emitEvent: false});\n    }\n\n    this.timeControl.setValue(`${hours}${minutes}`);\n  }\n\n  writeValue(date: Date) {\n    if (date instanceof Date && !isNaN(date.getTime())) {\n      this.calendarControl.setValue(date, {emitEvent: false});\n      this.dateControl.setValue(formatDate(date, 'P',\n        {locale: this.config.locale.dfns}), {emitEvent: false});\n    } else {\n      this.clear();\n    }\n  }\n\n  setDisabledState(disabled: boolean) {\n    disabled ? this.dateControl.disable({emitEvent: false})\n      : this.dateControl.enable({emitEvent: false});\n  }\n}\n"]}