UNPKG

@asi-ngtools/lib

Version:

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

220 lines (219 loc) 18.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { DefaultControlValueAccessor } from './../common/default-control-value-accessor'; import { Component, forwardRef, Input, Inject, PLATFORM_ID, Injector, Renderer2, ElementRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as dmyConstants from './asi-dmypicker-constants'; import * as nh from '../../native-helper'; import { isPlatformBrowser } from '@angular/common'; export class AsiDmyPickerComponent extends DefaultControlValueAccessor { /** * @param {?} platformId * @param {?} injector * @param {?} renderer * @param {?} elementRef */ constructor(platformId, injector, renderer, elementRef) { super(); this.platformId = platformId; this.injector = injector; this.renderer = renderer; this.elementRef = elementRef; /** * Label position */ this.labelPosition = 'top'; /** * hide day list */ this.dayHidden = false; this.days = []; this.months = []; this.years = []; } /** * @return {?} */ ngOnInit() { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.isFr()) { this.months = dmyConstants.months_fr; this.dayLabel = 'Jour'; this.monthLabel = 'Mois'; this.yearLabel = 'Annee'; } else { this.months = dmyConstants.months_en; this.dayLabel = 'Day'; this.monthLabel = 'Month'; this.yearLabel = 'Year'; } this.initDays(); this.initYears(); } /** * @return {?} */ isFr() { if (isPlatformBrowser(this.platformId)) { return navigator.language === 'fr' || navigator.language === 'fr-FR'; } else { /** @type {?} */ const request = this.injector.get('request'); if (request && request.asiNgtools) { /** @type {?} */ const language = request.asiNgtools.language; if (language) { return language.substring(0, 2) === 'fr'; } } return false; } } /** * @return {?} */ initDays() { nh.times(31, (time) => { this.days.push(time + 1); }); } /** * @return {?} */ initYears() { /** @type {?} */ let results = new Array(); /** @type {?} */ let currentYear = new Date().getFullYear(); for (let year = currentYear; year >= 1900; year--) { results.push(year); } this.years = results; } /** * @param {?} month * @return {?} */ onMonthChange(month) { this.value = { day: this.day, month: month != null ? month.num : null, year: this.year }; } /** * @param {?} year * @return {?} */ onYearChange(year) { this.value = { day: this.day, month: this.month != null ? this.month.num : null, year: year }; } /** * @param {?} day * @return {?} */ onDayChange(day) { this.value = { day: day, month: this.month != null ? this.month.num : null, year: this.year }; } /** * @param {?} value * @return {?} */ writeValue(value) { if (value != null) { this.day = value.day; this.month = this.getMontFromNum(value.month); this.year = value.year; } else { this.day = null; this.month = null; this.year = null; } this._value = { day: this.day, month: this.month, year: this.year }; } /** * @param {?} monthNum * @return {?} */ getMontFromNum(monthNum) { if (monthNum == null) { return null; } return nh.find(this.months, (month) => { return month.num === monthNum; }); } } AsiDmyPickerComponent.decorators = [ { type: Component, args: [{ selector: 'asi-dmypicker', host: { 'class': 'asi-component asi-dmypicker' }, template: "<label class=\"input-label\" [translate]=\"label\"></label>\r\n<div class=\"asi-dmypicker-container\">\r\n <asi-select class=\"asi-dmy-days\" [disabled]=\"disabled\" [withEmptyValue]=\"true\" [hidden]=\"dayHidden\" [data]=\"days\" [(ngModel)]=\"day\"\r\n (ngModelChange)=\"onDayChange($event)\">\r\n <asi-empty *asiEmptyDef>{{dayLabel}}</asi-empty>\r\n <asi-selected *asiSelectedDef=\"let data\">{{data}}</asi-selected>\r\n <asi-option *asiOptionDef=\"let data\">{{data}}</asi-option>\r\n </asi-select>\r\n <asi-select class=\"asi-dmy-months\" [disabled]=\"disabled\" [withEmptyValue]=\"true\" [data]=\"months\" [(ngModel)]=\"month\" (ngModelChange)=\"onMonthChange($event)\">\r\n <asi-empty *asiEmptyDef>{{monthLabel}}</asi-empty>\r\n <asi-selected *asiSelectedDef=\"let data\">{{data.num + \" - \" + data.libelle}}</asi-selected>\r\n <asi-option *asiOptionDef=\"let data\">{{data.num + \" - \" + data.libelle}}</asi-option>\r\n </asi-select>\r\n <asi-select class=\"asi-dmy-years\" [disabled]=\"disabled\" [withEmptyValue]=\"true\" [data]=\"years\" [(ngModel)]=\"year\" (ngModelChange)=\"onYearChange($event)\">\r\n <asi-empty *asiEmptyDef>{{yearLabel}}</asi-empty>\r\n <asi-selected *asiSelectedDef=\"let data\">{{data}}</asi-selected>\r\n <asi-option *asiOptionDef=\"let data\">{{data}}</asi-option>\r\n </asi-select>\r\n</div>", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AsiDmyPickerComponent), multi: true } ] }] } ]; /** @nocollapse */ AsiDmyPickerComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }, { type: Injector }, { type: Renderer2 }, { type: ElementRef } ]; AsiDmyPickerComponent.propDecorators = { label: [{ type: Input }], labelPosition: [{ type: Input }], dayHidden: [{ type: Input }] }; if (false) { /** * Label to display (is translated) * @type {?} */ AsiDmyPickerComponent.prototype.label; /** * Label position * @type {?} */ AsiDmyPickerComponent.prototype.labelPosition; /** * hide day list * @type {?} */ AsiDmyPickerComponent.prototype.dayHidden; /** @type {?} */ AsiDmyPickerComponent.prototype.day; /** @type {?} */ AsiDmyPickerComponent.prototype.month; /** @type {?} */ AsiDmyPickerComponent.prototype.year; /** @type {?} */ AsiDmyPickerComponent.prototype.dayLabel; /** @type {?} */ AsiDmyPickerComponent.prototype.monthLabel; /** @type {?} */ AsiDmyPickerComponent.prototype.yearLabel; /** @type {?} */ AsiDmyPickerComponent.prototype.days; /** @type {?} */ AsiDmyPickerComponent.prototype.months; /** @type {?} */ AsiDmyPickerComponent.prototype.years; /** @type {?} */ AsiDmyPickerComponent.prototype.language; /** @type {?} */ AsiDmyPickerComponent.prototype.platformId; /** @type {?} */ AsiDmyPickerComponent.prototype.injector; /** @type {?} */ AsiDmyPickerComponent.prototype.renderer; /** @type {?} */ AsiDmyPickerComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-dmypicker.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-dmypicker/asi-dmypicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Month } from './asi-dmypicker-constants';\nimport { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\nimport { Component, forwardRef, Input, Inject, PLATFORM_ID, Injector, OnInit, Renderer2, ElementRef } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport * as dmyConstants from './asi-dmypicker-constants';\nimport * as nh from '../../native-helper';\n\nimport { isPlatformBrowser } from '@angular/common';\n\n@Component({\n  selector: 'asi-dmypicker',\n  host: { 'class': 'asi-component asi-dmypicker' },\n  templateUrl: './asi-dmypicker.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiDmyPickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiDmyPickerComponent extends DefaultControlValueAccessor implements OnInit {\n\n  /** Label to display (is translated) */\n  @Input() label: string;\n\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n\n  /** hide day list */\n  @Input() dayHidden = false;\n\n  day: number;\n  month: Month;\n  year: number;\n\n  dayLabel: string;\n  monthLabel: string;\n  yearLabel: string;\n\n  days: Array<Number> = [];\n  months: Array<dmyConstants.Month> = [];\n  years: Array<Number> = [];\n\n  language: any;\n\n  constructor(@Inject(PLATFORM_ID) private platformId: any, private injector: Injector,\n    private renderer: Renderer2, private elementRef: ElementRef) {\n    super();\n  }\n\n  ngOnInit() {\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n    if (this.isFr()) {\n      this.months = dmyConstants.months_fr;\n      this.dayLabel = 'Jour';\n      this.monthLabel = 'Mois';\n      this.yearLabel = 'Annee';\n    } else {\n      this.months = dmyConstants.months_en;\n      this.dayLabel = 'Day';\n      this.monthLabel = 'Month';\n      this.yearLabel = 'Year';\n    }\n    this.initDays();\n    this.initYears();\n  }\n\n  private isFr(): boolean {\n    if (isPlatformBrowser(this.platformId)) {\n      return navigator.language === 'fr' || navigator.language === 'fr-FR';\n    } else {\n\n      const request = this.injector.get('request');\n      if (request && request.asiNgtools) {\n        const language = request.asiNgtools.language;\n        if (language) {\n          return language.substring(0, 2) === 'fr';\n        }\n      }\n      return false;\n    }\n  }\n\n  initDays() {\n    nh.times(31, (time) => {\n      this.days.push(time + 1);\n    });\n  }\n\n  initYears() {\n    let results = new Array<number>();\n    let currentYear = new Date().getFullYear();\n    for (let year = currentYear; year >= 1900; year--) {\n      results.push(year);\n    }\n    this.years = results;\n  }\n\n  public onMonthChange(month: Month): void {\n    this.value = { day: this.day, month: month != null ? month.num : null, year: this.year };\n  }\n\n  public onYearChange(year: number): void {\n    this.value = { day: this.day, month: this.month != null ? this.month.num : null, year: year };\n  }\n\n  public onDayChange(day: number): void {\n    this.value = { day: day, month: this.month != null ? this.month.num : null, year: this.year };\n  }\n\n  // Controle value accessor\n  writeValue(value: any) {\n    if (value != null) {\n      this.day = value.day;\n      this.month = this.getMontFromNum(value.month);\n      this.year = value.year;\n    } else {\n      this.day = null;\n      this.month = null;\n      this.year = null;\n    }\n    this._value = { day: this.day, month: this.month, year: this.year };\n  }\n\n  private getMontFromNum(monthNum: number): Month {\n    if (monthNum == null) {\n      return null;\n    }\n    return nh.find(this.months, (month) => {\n      return month.num === monthNum;\n    });\n  }\n}\n"]}