UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

236 lines (235 loc) 16.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { AsiCalendarComponent } from './../asi-calendar/asi-calendar.component'; import { DefaultControlValueAccessor } from './../common/default-control-value-accessor'; import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms'; import { Component, forwardRef, Input, ElementRef, ViewChild, Renderer2 } from '@angular/core'; import moment from 'moment'; var AsiDatePickerComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiDatePickerComponent, _super); function AsiDatePickerComponent(renderer, elementRef) { var _this = _super.call(this) || this; _this.renderer = renderer; _this.elementRef = elementRef; /** * Label position */ _this.labelPosition = 'top'; /** * placeholder if not null else will be the date display pattern */ _this.placeholder = null; /** * date display pattern */ _this.pattern = 'DD/MM/YYYY'; /** * min year selectable */ _this.minYear = 1900; /** * max year selectable */ _this.maxYear = new Date().getFullYear() + 1; /** * open automatically when the input is focused */ _this.autoOpen = true; _this.inputControl = new FormControl(); return _this; } /** * @return {?} */ AsiDatePickerComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.placeholder == null) { this.placeholder = this.pattern.toLowerCase(); } }; /** * @return {?} */ AsiDatePickerComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; this.inputControl.valueChanges.subscribe(function (val) { if (val === '' || val == null) { _this.value = null; } else { /** @type {?} */ var momentTest = moment.utc(val, _this.pattern); if (momentTest.isValid()) { if (val.length === _this.pattern.length) { _this.value = momentTest.toDate(); } else { _this.value = { error: 'Invalid_Date', value: val }; } } else { _this.value = { error: 'Invalid_Date', value: val }; } } }); }; /** * @return {?} */ AsiDatePickerComponent.prototype.openCalendar = /** * @return {?} */ function () { if (this.autoOpen) { this.calendarElement.openCalendar(); } }; /** * @param {?} date * @return {?} */ AsiDatePickerComponent.prototype.onDatePicked = /** * @param {?} date * @return {?} */ function (date) { /** @type {?} */ var formattedValue = moment(date).format(this.pattern); this.inputControl.setValue(formattedValue); }; /** * @param {?} value * @return {?} */ AsiDatePickerComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { if (value != null) { /** @type {?} */ var momentValue = moment.utc(value); this._value = momentValue.toDate(); /** @type {?} */ var formattedValue = momentValue.format(this.pattern); this.inputControl.setValue(formattedValue, { emitEvent: false }); } else { this._value = value; this.inputControl.setValue(null, { emitEvent: false }); } }; AsiDatePickerComponent.decorators = [ { type: Component, args: [{ selector: 'asi-datepicker', host: { class: 'asi-component asi-datepicker' }, template: "<label class=\"input-label\" *ngIf=\"label != null\">{{ label | translate }}</label>\n<div class=\"asi-datepicker-container\">\n <input\n #input\n [attr.disabled]=\"disabled ? '' : null\"\n class=\"asi-focus-error\"\n [placeholder]=\"placeholder\"\n (click)=\"openCalendar()\"\n [formControl]=\"inputControl\"\n />\n <asi-calendar\n #calendar\n [relativeTo]=\"inputElement\"\n [disableDayOfWeek]=\"disableDayOfWeek\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"value\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minYear]=\"minYear\"\n [maxYear]=\"maxYear\"\n (onDatePicked)=\"onDatePicked($event)\"\n ></asi-calendar>\n</div>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(function () { return AsiDatePickerComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiDatePickerComponent.ctorParameters = function () { return [ { type: Renderer2 }, { type: ElementRef } ]; }; AsiDatePickerComponent.propDecorators = { label: [{ type: Input }], labelPosition: [{ type: Input }], placeholder: [{ type: Input }], pattern: [{ type: Input }], minDate: [{ type: Input }], maxDate: [{ type: Input }], minYear: [{ type: Input }], maxYear: [{ type: Input }], autoOpen: [{ type: Input }], disableDayOfWeek: [{ type: Input }], inputElement: [{ type: ViewChild, args: ['input',] }], calendarElement: [{ type: ViewChild, args: ['calendar',] }] }; return AsiDatePickerComponent; }(DefaultControlValueAccessor)); export { AsiDatePickerComponent }; if (false) { /** * Label to display (is translated) * @type {?} */ AsiDatePickerComponent.prototype.label; /** * Label position * @type {?} */ AsiDatePickerComponent.prototype.labelPosition; /** * placeholder if not null else will be the date display pattern * @type {?} */ AsiDatePickerComponent.prototype.placeholder; /** * date display pattern * @type {?} */ AsiDatePickerComponent.prototype.pattern; /** * min date available * @type {?} */ AsiDatePickerComponent.prototype.minDate; /** * max date available * @type {?} */ AsiDatePickerComponent.prototype.maxDate; /** * min year selectable * @type {?} */ AsiDatePickerComponent.prototype.minYear; /** * max year selectable * @type {?} */ AsiDatePickerComponent.prototype.maxYear; /** * open automatically when the input is focused * @type {?} */ AsiDatePickerComponent.prototype.autoOpen; /** * allow you to disable day of week exemple [disableDayOfWeek]="[1, 2]"" while disabled monday and tusday * @type {?} */ AsiDatePickerComponent.prototype.disableDayOfWeek; /** @type {?} */ AsiDatePickerComponent.prototype.inputControl; /** @type {?} */ AsiDatePickerComponent.prototype.inputElement; /** @type {?} */ AsiDatePickerComponent.prototype.calendarElement; /** @type {?} */ AsiDatePickerComponent.prototype.renderer; /** @type {?} */ AsiDatePickerComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-datepicker.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-datepicker/asi-datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsiCalendarComponent } from './../asi-calendar/asi-calendar.component';\r\nimport { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\r\nimport { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\r\nimport { Component, forwardRef, Input, ElementRef, OnInit, AfterViewInit, ViewChild, Renderer2 } from '@angular/core';\r\n\r\nimport moment from 'moment';\r\n\r\n@Component({\r\n  selector: 'asi-datepicker',\r\n  host: { class: 'asi-component asi-datepicker' },\r\n  templateUrl: 'asi-datepicker.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => AsiDatePickerComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class AsiDatePickerComponent extends DefaultControlValueAccessor implements OnInit, AfterViewInit {\r\n  /** Label to display (is translated) */\r\n  @Input() label: string;\r\n  /** Label position */\r\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\r\n  /** placeholder if not null else will be the date display pattern */\r\n  @Input() placeholder = null;\r\n\r\n  /** date display pattern */\r\n  @Input() pattern = 'DD/MM/YYYY';\r\n\r\n  /** min date available */\r\n  @Input() minDate: Date;\r\n  /** max date available */\r\n  @Input() maxDate: Date;\r\n\r\n  /** min year selectable */\r\n  @Input() minYear: number = 1900;\r\n\r\n  /** max year selectable */\r\n  @Input() maxYear: number = new Date().getFullYear() + 1;\r\n\r\n  /** open automatically when the input is focused*/\r\n  @Input() autoOpen = true;\r\n\r\n  /** allow you to disable day of week exemple [disableDayOfWeek]=\"[1, 2]\"\" while disabled monday and tusday */\r\n  @Input() disableDayOfWeek: number | Array<number>;\r\n\r\n  inputControl = new FormControl();\r\n\r\n  @ViewChild('input') inputElement: ElementRef;\r\n  @ViewChild('calendar') calendarElement: AsiCalendarComponent;\r\n\r\n  constructor(private renderer: Renderer2, private elementRef: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\r\n    if (this.placeholder == null) {\r\n      this.placeholder = this.pattern.toLowerCase();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.inputControl.valueChanges.subscribe((val) => {\r\n      if (val === '' || val == null) {\r\n        this.value = null;\r\n      } else {\r\n        let momentTest = moment.utc(val, this.pattern);\r\n        if (momentTest.isValid()) {\r\n          if (val.length === this.pattern.length) {\r\n            this.value = momentTest.toDate();\r\n          } else {\r\n            this.value = {\r\n              error: 'Invalid_Date',\r\n              value: val\r\n            };\r\n          }\r\n        } else {\r\n          this.value = {\r\n            error: 'Invalid_Date',\r\n            value: val\r\n          };\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  openCalendar() {\r\n    if (this.autoOpen) {\r\n      this.calendarElement.openCalendar();\r\n    }\r\n  }\r\n\r\n  onDatePicked(date: Date) {\r\n    let formattedValue = moment(date).format(this.pattern);\r\n    this.inputControl.setValue(formattedValue);\r\n  }\r\n\r\n  writeValue(value: Date) {\r\n    if (value != null) {\r\n      let momentValue = moment.utc(value);\r\n      this._value = momentValue.toDate();\r\n      let formattedValue = momentValue.format(this.pattern);\r\n      this.inputControl.setValue(formattedValue, { emitEvent: false });\r\n    } else {\r\n      this._value = value;\r\n      this.inputControl.setValue(null, { emitEvent: false });\r\n    }\r\n  }\r\n}\r\n"]}