UNPKG

materialize-angular

Version:
275 lines 23.2 kB
/** * @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":"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","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"]}