materialize-angular
Version:
Material UI Angular library
275 lines • 23.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: app/completed-components/datepicker/datepicker.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Workylab. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE
*/
import { Component, ElementRef, forwardRef, Input, ViewChild } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { config } from '../../config';
import { INPUT_TYPE } from '../input/input.model';
export class DatePickerComponent {
constructor() {
this.className = DatePickerComponent.defaultProps.className;
this.disabled = DatePickerComponent.defaultProps.disabled;
this.displayOtherMonthDays = DatePickerComponent.defaultProps.displayOtherMonthDays;
this.floatLabel = DatePickerComponent.defaultProps.floatLabel;
this.format = DatePickerComponent.defaultProps.format;
this.fullSize = DatePickerComponent.defaultProps.fullSize;
this.id = DatePickerComponent.defaultProps.id;
this.name = DatePickerComponent.defaultProps.name;
this.placeholder = DatePickerComponent.defaultProps.placeholder;
this.required = DatePickerComponent.defaultProps.required;
this.inputValue = DatePickerComponent.defaultProps.value;
this.prefix = config.components.prefix;
this.isOpen = false;
this.close = this.close.bind(this);
}
/**
* @return {?}
*/
ngOnInit() {
// this.date = this.buildDate(this.inputValue);
}
/**
* @param {?} selectedDate
* @return {?}
*/
onSelectDay(selectedDate) {
this.isOpen = false;
this.date = selectedDate.date;
this.inputValue = this.formatDate(selectedDate.date);
this.onChange(selectedDate.date);
}
/**
* @param {?} date
* @return {?}
*/
formatDate(date) {
/** @type {?} */
const day = date.getDate();
/** @type {?} */
const month = date.getMonth() + 1;
/** @type {?} */
const dayString = day < 10
? `0${day}`
: day.toString();
/** @type {?} */
const monthString = month < 10
? `0${month}`
: month.toString();
/** @type {?} */
const yearString = date.getFullYear().toString();
/** @type {?} */
const formatedDate = this.format
.replace('dd', dayString)
.replace('mm', monthString)
.replace('yyyy', yearString);
return formatedDate;
}
/**
* @param {?} value
* @return {?}
*/
buildDate(value) {
/** @type {?} */
const dayStartPosition = this.format.indexOf(DatePickerComponent.DAY_KEY);
/** @type {?} */
const monthStartPosition = this.format.indexOf(DatePickerComponent.MONTH_KEY);
/** @type {?} */
const yearStartPosition = this.format.indexOf(DatePickerComponent.YEAR_KEY);
if (dayStartPosition >= 0 && monthStartPosition >= 0 && yearStartPosition >= 0) {
/** @type {?} */
const dayEndPosition = dayStartPosition + DatePickerComponent.DAY_KEY.length;
/** @type {?} */
const monthEndPosition = monthStartPosition + DatePickerComponent.MONTH_KEY.length;
/** @type {?} */
const yearEndPosition = yearStartPosition + DatePickerComponent.YEAR_KEY.length;
/** @type {?} */
const dayString = value.substring(dayStartPosition, dayEndPosition);
/** @type {?} */
const monthString = value.substring(monthStartPosition, monthEndPosition);
/** @type {?} */
const yearString = value.substring(yearStartPosition, yearEndPosition);
if (dayString && monthString && yearString) {
/** @type {?} */
const day = Number(dayString);
/** @type {?} */
const month = Number(monthString) - 1;
/** @type {?} */
const year = Number(yearString);
return new Date(year, month, day);
}
}
return new Date();
}
/**
* @return {?}
*/
open() {
this.isOpen = true;
setTimeout((/**
* @return {?}
*/
() => {
this.backdropRef.nativeElement.addEventListener('click', this.close);
}), 0);
}
/**
* @return {?}
*/
close() {
this.isOpen = false;
}
/**
* @param {?} value
* @return {?}
*/
onInputChange(value) {
this.date = this.buildDate(value);
this.onChange(this.date);
}
/**
* @return {?}
*/
onInputFocus() {
this.onTouched();
}
/**
* @param {?} isDisabled
* @return {?}
*/
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
this.date = value;
this.inputValue = this.formatDate(value);
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChange = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouched = fn;
}
/**
* @param {?} value
* @return {?}
*/
onChange(value) {
}
/**
* @return {?}
*/
onTouched() { }
}
DatePickerComponent.DAY_KEY = 'dd';
DatePickerComponent.MONTH_KEY = 'mm';
DatePickerComponent.YEAR_KEY = 'yyyy';
DatePickerComponent.defaultProps = {
autocomplete: 'none',
className: '',
date: new Date(),
disabled: false,
displayOtherMonthDays: true,
floatLabel: '',
format: 'dd-mm-yyyy',
fullSize: false,
hasCounter: false,
id: null,
maxLength: 500,
name: '',
placeholder: '',
required: false,
type: INPUT_TYPE.TEXT,
value: ''
};
DatePickerComponent.decorators = [
{ type: Component, args: [{
providers: [{
multi: true,
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => DatePickerComponent))
}],
selector: `${config.components.prefix}-datepicker }`,
template: "<div [ngClass]=\"[prefix + '-datepicker', className]\" [class.full-size]=\"fullSize\">\n <div #backdrop *ngIf=\"isOpen\" [ngClass]=\"prefix + '-datepicker-backdrop'\"></div>\n\n <materialize-input\n [disabled]=\"disabled\"\n [floatLabel]=\"floatLabel\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [value]=\"inputValue\"\n\n (onChange)=\"onInputChange($event)\"\n (onFocus)=\"onInputFocus()\"\n >\n <materialize-button (onClick)=\"open()\"\n materializeSuffix\n [className]=\"prefix + '-datepicker-button'\"\n [disabled]=\"disabled\"\n >\n <materialize-icon [className]=\"prefix + '-datepicker-button'\">calendar_today</materialize-icon>\n </materialize-button>\n </materialize-input>\n\n <materialize-calendar *ngIf=\"isOpen\"\n [className]=\"prefix + '-datepicker-calendar'\"\n [date]=\"date\"\n (onSelectDay)=\"onSelectDay($event)\">\n </materialize-calendar>\n</div>\n"
}] }
];
/** @nocollapse */
DatePickerComponent.ctorParameters = () => [];
DatePickerComponent.propDecorators = {
backdropRef: [{ type: ViewChild, args: ['backdrop', { static: false },] }],
className: [{ type: Input }],
disabled: [{ type: Input }],
displayOtherMonthDays: [{ type: Input }],
floatLabel: [{ type: Input }],
format: [{ type: Input }],
fullSize: [{ type: Input }],
id: [{ type: Input }],
name: [{ type: Input }],
placeholder: [{ type: Input }],
required: [{ type: Input }],
inputValue: [{ type: Input }]
};
if (false) {
/** @type {?} */
DatePickerComponent.DAY_KEY;
/** @type {?} */
DatePickerComponent.MONTH_KEY;
/** @type {?} */
DatePickerComponent.YEAR_KEY;
/** @type {?} */
DatePickerComponent.defaultProps;
/** @type {?} */
DatePickerComponent.prototype.backdropRef;
/** @type {?} */
DatePickerComponent.prototype.className;
/** @type {?} */
DatePickerComponent.prototype.disabled;
/** @type {?} */
DatePickerComponent.prototype.displayOtherMonthDays;
/** @type {?} */
DatePickerComponent.prototype.floatLabel;
/** @type {?} */
DatePickerComponent.prototype.format;
/** @type {?} */
DatePickerComponent.prototype.fullSize;
/** @type {?} */
DatePickerComponent.prototype.id;
/** @type {?} */
DatePickerComponent.prototype.name;
/** @type {?} */
DatePickerComponent.prototype.placeholder;
/** @type {?} */
DatePickerComponent.prototype.required;
/** @type {?} */
DatePickerComponent.prototype.inputValue;
/** @type {?} */
DatePickerComponent.prototype.prefix;
/** @type {?} */
DatePickerComponent.prototype.date;
/** @type {?} */
DatePickerComponent.prototype.isOpen;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/datepicker/datepicker.component.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAGtC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAWlD,MAAM,OAAO,mBAAmB;IA2C9B;QAjBS,cAAS,GAAW,mBAAmB,CAAC,YAAY,CAAC,SAAS,CAAC;QAC/D,aAAQ,GAAY,mBAAmB,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC9D,0BAAqB,GAAY,mBAAmB,CAAC,YAAY,CAAC,qBAAqB,CAAC;QACxF,eAAU,GAAW,mBAAmB,CAAC,YAAY,CAAC,UAAU,CAAC;QACjE,WAAM,GAAW,mBAAmB,CAAC,YAAY,CAAC,MAAM,CAAC;QACzD,aAAQ,GAAY,mBAAmB,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC9D,OAAE,GAAkB,mBAAmB,CAAC,YAAY,CAAC,EAAE,CAAC;QACxD,SAAI,GAAW,mBAAmB,CAAC,YAAY,CAAC,IAAI,CAAC;QACrD,gBAAW,GAAW,mBAAmB,CAAC,YAAY,CAAC,WAAW,CAAC;QACnE,aAAQ,GAAY,mBAAmB,CAAC,YAAY,CAAC,QAAQ,CAAC;QAC9D,eAAU,GAAW,mBAAmB,CAAC,YAAY,CAAC,KAAK,CAAC;QAE9D,WAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;QAMvC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;;;;IAED,QAAQ;QACN,+CAA+C;IACjD,CAAC;;;;;IAED,WAAW,CAAC,YAAuB;QACjC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC,IAAI,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;;;;;IAED,UAAU,CAAC,IAAU;;cACb,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE;;cACpB,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC;;cAE3B,SAAS,GAAG,GAAG,GAAG,EAAE;YACxB,CAAC,CAAC,IAAK,GAAI,EAAE;YACb,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE;;cAEZ,WAAW,GAAG,KAAK,GAAG,EAAE;YAC5B,CAAC,CAAC,IAAK,KAAM,EAAE;YACf,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;;cAEd,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,EAAE;;cAE1C,YAAY,GAAG,IAAI,CAAC,MAAM;aAC7B,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC;aACxB,OAAO,CAAC,IAAI,EAAE,WAAW,CAAC;aAC1B,OAAO,CAAC,MAAM,EAAE,UAAU,CAAC;QAE9B,OAAO,YAAY,CAAC;IACtB,CAAC;;;;;IAED,SAAS,CAAC,KAAa;;cACf,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC;;cACnE,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,SAAS,CAAC;;cACvE,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,CAAC;QAE3E,IAAI,gBAAgB,IAAI,CAAC,IAAI,kBAAkB,IAAI,CAAC,IAAI,iBAAiB,IAAI,CAAC,EAAE;;kBACxE,cAAc,GAAG,gBAAgB,GAAG,mBAAmB,CAAC,OAAO,CAAC,MAAM;;kBACtE,gBAAgB,GAAG,kBAAkB,GAAG,mBAAmB,CAAC,SAAS,CAAC,MAAM;;kBAC5E,eAAe,GAAG,iBAAiB,GAAG,mBAAmB,CAAC,QAAQ,CAAC,MAAM;;kBAEzE,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC,gBAAgB,EAAE,cAAc,CAAC;;kBAC7D,WAAW,GAAG,KAAK,CAAC,SAAS,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;;kBACnE,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,iBAAiB,EAAE,eAAe,CAAC;YAEtE,IAAI,SAAS,IAAI,WAAW,IAAI,UAAU,EAAE;;sBACpC,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC;;sBACvB,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC;;sBAC/B,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC;gBAE/B,OAAO,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;aACnC;SACF;QAED,OAAO,IAAI,IAAI,EAAE,CAAC;IACpB,CAAC;;;;IAED,IAAI;QACF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,UAAU;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACvE,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;;;IAED,KAAK;QACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;;;;;IAED,aAAa,CAAC,KAAa;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAElC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;;;;IAED,YAAY;QACV,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;;;;;IAED,UAAU,CAAC,KAAW;QACpB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAElB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;;;;;IAED,gBAAgB,CAAC,EAAyB;QACxC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;;;;;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IAED,QAAQ,CAAC,KAAW;IACpB,CAAC;;;;IAED,SAAS,KAAU,CAAC;;AAvJJ,2BAAO,GAAG,IAAI,CAAC;AACf,6BAAS,GAAG,IAAI,CAAC;AACjB,4BAAQ,GAAG,MAAM,CAAC;AAElB,gCAAY,GAAoB;IAC9C,YAAY,EAAE,MAAM;IACpB,SAAS,EAAE,EAAE;IACb,IAAI,EAAE,IAAI,IAAI,EAAE;IAChB,QAAQ,EAAE,KAAK;IACf,qBAAqB,EAAE,IAAI;IAC3B,UAAU,EAAE,EAAE;IACd,MAAM,EAAE,YAAY;IACpB,QAAQ,EAAE,KAAK;IACf,UAAU,EAAE,KAAK;IACjB,EAAE,EAAE,IAAI;IACR,SAAS,EAAE,GAAG;IACd,IAAI,EAAE,EAAE;IACR,WAAW,EAAE,EAAE;IACf,QAAQ,EAAE,KAAK;IACf,IAAI,EAAE,UAAU,CAAC,IAAI;IACrB,KAAK,EAAE,EAAE;CACV,CAAC;;YA/BH,SAAS,SAAC;gBACT,SAAS,EAAE,CAAC;wBACV,KAAK,EAAE,IAAI;wBACX,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU;;;wBAAC,GAAG,EAAE,CAAC,mBAAmB,EAAC;qBACnD,CAAC;gBACF,QAAQ,EAAE,GAAI,MAAM,CAAC,UAAU,CAAC,MAAO,eAAe;gBACtD,q9BAA0C;aAC3C;;;;;0BAyBE,SAAS,SAAC,UAAU,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;wBAErC,KAAK;uBACL,KAAK;oCACL,KAAK;yBACL,KAAK;qBACL,KAAK;uBACL,KAAK;iBACL,KAAK;mBACL,KAAK;0BACL,KAAK;uBACL,KAAK;yBACL,KAAK;;;;IAnCN,4BAA+B;;IAC/B,8BAAiC;;IACjC,6BAAkC;;IAElC,iCAiBE;;IAEF,0CAAgE;;IAEhE,wCAAwE;;IACxE,uCAAuE;;IACvE,oDAAiG;;IACjG,yCAA0E;;IAC1E,qCAAkE;;IAClE,uCAAuE;;IACvE,iCAAiE;;IACjE,mCAA8D;;IAC9D,0CAA4E;;IAC5E,uCAAuE;;IACvE,yCAAqE;;IAErE,qCAAyC;;IAEzC,mCAAkB;;IAClB,qCAAuB","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport { Component, ElementRef, forwardRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { config } from '../../config';\nimport { DateModel } from '../calendar/calendar.model';\nimport { DatePickerModel } from './datepicker.model';\nimport { INPUT_TYPE } from '../input/input.model';\n\n@Component({\n  providers: [{\n    multi: true,\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DatePickerComponent)\n  }],\n  selector: `${ config.components.prefix }-datepicker }`,\n  templateUrl: './datepicker.component.html'\n})\nexport class DatePickerComponent implements ControlValueAccessor, OnInit {\n  static readonly DAY_KEY = 'dd';\n  static readonly MONTH_KEY = 'mm';\n  static readonly YEAR_KEY = 'yyyy';\n\n  static readonly defaultProps: DatePickerModel = {\n    autocomplete: 'none',\n    className: '',\n    date: new Date(),\n    disabled: false,\n    displayOtherMonthDays: true,\n    floatLabel: '',\n    format: 'dd-mm-yyyy',\n    fullSize: false,\n    hasCounter: false,\n    id: null,\n    maxLength: 500,\n    name: '',\n    placeholder: '',\n    required: false,\n    type: INPUT_TYPE.TEXT,\n    value: ''\n  };\n\n  @ViewChild('backdrop', {static: false}) backdropRef: ElementRef;\n\n  @Input() className: string = DatePickerComponent.defaultProps.className;\n  @Input() disabled: boolean = DatePickerComponent.defaultProps.disabled;\n  @Input() displayOtherMonthDays: boolean = DatePickerComponent.defaultProps.displayOtherMonthDays;\n  @Input() floatLabel: string = DatePickerComponent.defaultProps.floatLabel;\n  @Input() format: string = DatePickerComponent.defaultProps.format;\n  @Input() fullSize: boolean = DatePickerComponent.defaultProps.fullSize;\n  @Input() id: string | null = DatePickerComponent.defaultProps.id;\n  @Input() name: string = DatePickerComponent.defaultProps.name;\n  @Input() placeholder: string = DatePickerComponent.defaultProps.placeholder;\n  @Input() required: boolean = DatePickerComponent.defaultProps.required;\n  @Input() inputValue: string = DatePickerComponent.defaultProps.value;\n\n  public prefix = config.components.prefix;\n\n  public date: Date;\n  public isOpen: boolean;\n\n  constructor() {\n    this.isOpen = false;\n\n    this.close = this.close.bind(this);\n  }\n\n  ngOnInit() {\n    // this.date = this.buildDate(this.inputValue);\n  }\n\n  onSelectDay(selectedDate: DateModel) {\n    this.isOpen = false;\n    this.date = selectedDate.date;\n    this.inputValue = this.formatDate(selectedDate.date);\n\n    this.onChange(selectedDate.date);\n  }\n\n  formatDate(date: Date): string {\n    const day = date.getDate();\n    const month = date.getMonth() + 1;\n\n    const dayString = day < 10\n      ? `0${ day }`\n      : day.toString();\n\n    const monthString = month < 10\n      ? `0${ month }`\n      : month.toString();\n\n    const yearString = date.getFullYear().toString();\n\n    const formatedDate = this.format\n      .replace('dd', dayString)\n      .replace('mm', monthString)\n      .replace('yyyy', yearString);\n\n    return formatedDate;\n  }\n\n  buildDate(value: string): Date {\n    const dayStartPosition = this.format.indexOf(DatePickerComponent.DAY_KEY);\n    const monthStartPosition = this.format.indexOf(DatePickerComponent.MONTH_KEY);\n    const yearStartPosition = this.format.indexOf(DatePickerComponent.YEAR_KEY);\n\n    if (dayStartPosition >= 0 && monthStartPosition >= 0 && yearStartPosition >= 0) {\n      const dayEndPosition = dayStartPosition + DatePickerComponent.DAY_KEY.length;\n      const monthEndPosition = monthStartPosition + DatePickerComponent.MONTH_KEY.length;\n      const yearEndPosition = yearStartPosition + DatePickerComponent.YEAR_KEY.length;\n\n      const dayString = value.substring(dayStartPosition, dayEndPosition);\n      const monthString = value.substring(monthStartPosition, monthEndPosition);\n      const yearString = value.substring(yearStartPosition, yearEndPosition);\n\n      if (dayString && monthString && yearString) {\n        const day = Number(dayString);\n        const month = Number(monthString) - 1;\n        const year = Number(yearString);\n\n        return new Date(year, month, day);\n      }\n    }\n\n    return new Date();\n  }\n\n  open() {\n    this.isOpen = true;\n\n    setTimeout(() => {\n      this.backdropRef.nativeElement.addEventListener('click', this.close);\n    }, 0);\n  }\n\n  close() {\n    this.isOpen = false;\n  }\n\n  onInputChange(value: string) {\n    this.date = this.buildDate(value);\n\n    this.onChange(this.date);\n  }\n\n  onInputFocus() {\n    this.onTouched();\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: Date): void {\n    this.date = value;\n\n    this.inputValue = this.formatDate(value);\n  }\n\n  registerOnChange(fn: (value: Date) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  onChange(value: Date): void {\n  }\n\n  onTouched(): void {}\n}\n"]}