materialize-angular
Version:
Material UI Angular library
329 lines • 25 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';
var DatePickerComponent = /** @class */ (function () {
function DatePickerComponent() {
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 {?}
*/
DatePickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
// this.date = this.buildDate(this.inputValue);
};
/**
* @param {?} selectedDate
* @return {?}
*/
DatePickerComponent.prototype.onSelectDay = /**
* @param {?} selectedDate
* @return {?}
*/
function (selectedDate) {
this.isOpen = false;
this.date = selectedDate.date;
this.inputValue = this.formatDate(selectedDate.date);
this.onChange(selectedDate.date);
};
/**
* @param {?} date
* @return {?}
*/
DatePickerComponent.prototype.formatDate = /**
* @param {?} date
* @return {?}
*/
function (date) {
/** @type {?} */
var day = date.getDate();
/** @type {?} */
var month = date.getMonth() + 1;
/** @type {?} */
var dayString = day < 10
? "0" + day
: day.toString();
/** @type {?} */
var monthString = month < 10
? "0" + month
: month.toString();
/** @type {?} */
var yearString = date.getFullYear().toString();
/** @type {?} */
var formatedDate = this.format
.replace('dd', dayString)
.replace('mm', monthString)
.replace('yyyy', yearString);
return formatedDate;
};
/**
* @param {?} value
* @return {?}
*/
DatePickerComponent.prototype.buildDate = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var dayStartPosition = this.format.indexOf(DatePickerComponent.DAY_KEY);
/** @type {?} */
var monthStartPosition = this.format.indexOf(DatePickerComponent.MONTH_KEY);
/** @type {?} */
var yearStartPosition = this.format.indexOf(DatePickerComponent.YEAR_KEY);
if (dayStartPosition >= 0 && monthStartPosition >= 0 && yearStartPosition >= 0) {
/** @type {?} */
var dayEndPosition = dayStartPosition + DatePickerComponent.DAY_KEY.length;
/** @type {?} */
var monthEndPosition = monthStartPosition + DatePickerComponent.MONTH_KEY.length;
/** @type {?} */
var yearEndPosition = yearStartPosition + DatePickerComponent.YEAR_KEY.length;
/** @type {?} */
var dayString = value.substring(dayStartPosition, dayEndPosition);
/** @type {?} */
var monthString = value.substring(monthStartPosition, monthEndPosition);
/** @type {?} */
var yearString = value.substring(yearStartPosition, yearEndPosition);
if (dayString && monthString && yearString) {
/** @type {?} */
var day = Number(dayString);
/** @type {?} */
var month = Number(monthString) - 1;
/** @type {?} */
var year = Number(yearString);
return new Date(year, month, day);
}
}
return new Date();
};
/**
* @return {?}
*/
DatePickerComponent.prototype.open = /**
* @return {?}
*/
function () {
var _this = this;
this.isOpen = true;
setTimeout((/**
* @return {?}
*/
function () {
_this.backdropRef.nativeElement.addEventListener('click', _this.close);
}), 0);
};
/**
* @return {?}
*/
DatePickerComponent.prototype.close = /**
* @return {?}
*/
function () {
this.isOpen = false;
};
/**
* @param {?} value
* @return {?}
*/
DatePickerComponent.prototype.onInputChange = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.date = this.buildDate(value);
this.onChange(this.date);
};
/**
* @return {?}
*/
DatePickerComponent.prototype.onInputFocus = /**
* @return {?}
*/
function () {
this.onTouched();
};
/**
* @param {?} isDisabled
* @return {?}
*/
DatePickerComponent.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
};
/**
* @param {?} value
* @return {?}
*/
DatePickerComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.date = value;
this.inputValue = this.formatDate(value);
};
/**
* @param {?} fn
* @return {?}
*/
DatePickerComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
DatePickerComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @param {?} value
* @return {?}
*/
DatePickerComponent.prototype.onChange = /**
* @param {?} value
* @return {?}
*/
function (value) {
};
/**
* @return {?}
*/
DatePickerComponent.prototype.onTouched = /**
* @return {?}
*/
function () { };
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 {?}
*/
function () { 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 = function () { return []; };
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 }]
};
return DatePickerComponent;
}());
export { DatePickerComponent };
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;AAElD;IAoDE;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,sCAAQ;;;IAAR;QACE,+CAA+C;IACjD,CAAC;;;;;IAED,yCAAW;;;;IAAX,UAAY,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,wCAAU;;;;IAAV,UAAW,IAAU;;YACb,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE;;YACpB,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC;;YAE3B,SAAS,GAAG,GAAG,GAAG,EAAE;YACxB,CAAC,CAAC,MAAK,GAAM;YACb,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE;;YAEZ,WAAW,GAAG,KAAK,GAAG,EAAE;YAC5B,CAAC,CAAC,MAAK,KAAQ;YACf,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;;YAEd,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,EAAE;;YAE1C,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,uCAAS;;;;IAAT,UAAU,KAAa;;YACf,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC;;YACnE,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,SAAS,CAAC;;YACvE,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;;gBACxE,cAAc,GAAG,gBAAgB,GAAG,mBAAmB,CAAC,OAAO,CAAC,MAAM;;gBACtE,gBAAgB,GAAG,kBAAkB,GAAG,mBAAmB,CAAC,SAAS,CAAC,MAAM;;gBAC5E,eAAe,GAAG,iBAAiB,GAAG,mBAAmB,CAAC,QAAQ,CAAC,MAAM;;gBAEzE,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC,gBAAgB,EAAE,cAAc,CAAC;;gBAC7D,WAAW,GAAG,KAAK,CAAC,SAAS,CAAC,kBAAkB,EAAE,gBAAgB,CAAC;;gBACnE,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,iBAAiB,EAAE,eAAe,CAAC;YAEtE,IAAI,SAAS,IAAI,WAAW,IAAI,UAAU,EAAE;;oBACpC,GAAG,GAAG,MAAM,CAAC,SAAS,CAAC;;oBACvB,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC;;oBAC/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,kCAAI;;;IAAJ;QAAA,iBAMC;QALC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,UAAU;;;QAAC;YACT,KAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAI,CAAC,KAAK,CAAC,CAAC;QACvE,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;;;IAED,mCAAK;;;IAAL;QACE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;;;;;IAED,2CAAa;;;;IAAb,UAAc,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,0CAAY;;;IAAZ;QACE,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IAED,8CAAgB;;;;IAAhB,UAAiB,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;;;;;IAED,wCAAU;;;;IAAV,UAAW,KAAW;QACpB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAElB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;;;;;IAED,8CAAgB;;;;IAAhB,UAAiB,EAAyB;QACxC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;;;;;IAED,+CAAiB;;;;IAAjB,UAAkB,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IAED,sCAAQ;;;;IAAR,UAAS,KAAW;IACpB,CAAC;;;;IAED,uCAAS;;;IAAT,cAAmB,CAAC;IAvJJ,2BAAO,GAAG,IAAI,CAAC;IACf,6BAAS,GAAG,IAAI,CAAC;IACjB,4BAAQ,GAAG,MAAM,CAAC;IAElB,gCAAY,GAAoB;QAC9C,YAAY,EAAE,MAAM;QACpB,SAAS,EAAE,EAAE;QACb,IAAI,EAAE,IAAI,IAAI,EAAE;QAChB,QAAQ,EAAE,KAAK;QACf,qBAAqB,EAAE,IAAI;QAC3B,UAAU,EAAE,EAAE;QACd,MAAM,EAAE,YAAY;QACpB,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,KAAK;QACjB,EAAE,EAAE,IAAI;QACR,SAAS,EAAE,GAAG;QACd,IAAI,EAAE,EAAE;QACR,WAAW,EAAE,EAAE;QACf,QAAQ,EAAE,KAAK;QACf,IAAI,EAAE,UAAU,CAAC,IAAI;QACrB,KAAK,EAAE,EAAE;KACV,CAAC;;gBA/BH,SAAS,SAAC;oBACT,SAAS,EAAE,CAAC;4BACV,KAAK,EAAE,IAAI;4BACX,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU;;;4BAAC,cAAM,OAAA,mBAAmB,EAAnB,CAAmB,EAAC;yBACnD,CAAC;oBACF,QAAQ,EAAM,MAAM,CAAC,UAAU,CAAC,MAAM,kBAAgB;oBACtD,q9BAA0C;iBAC3C;;;;;8BAyBE,SAAS,SAAC,UAAU,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC;4BAErC,KAAK;2BACL,KAAK;wCACL,KAAK;6BACL,KAAK;yBACL,KAAK;2BACL,KAAK;qBACL,KAAK;uBACL,KAAK;8BACL,KAAK;2BACL,KAAK;6BACL,KAAK;;IAqHR,0BAAC;CAAA,AAlKD,IAkKC;SAzJY,mBAAmB;;;IAC9B,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"]}