UNPKG

materialize-angular

Version:
329 lines 25 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'; 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":"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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"]}