UNPKG

@asi-ngtools/lib

Version:

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

253 lines (252 loc) 19.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var AsiDmyPickerComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiDmyPickerComponent, _super); function AsiDmyPickerComponent(platformId, injector, renderer, elementRef) { var _this = _super.call(this) || this; _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 _this; } /** * @return {?} */ AsiDmyPickerComponent.prototype.ngOnInit = /** * @return {?} */ function () { 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 {?} */ AsiDmyPickerComponent.prototype.isFr = /** * @return {?} */ function () { if (isPlatformBrowser(this.platformId)) { return navigator.language === 'fr' || navigator.language === 'fr-FR'; } else { /** @type {?} */ var request = this.injector.get('request'); if (request && request.asiNgtools) { /** @type {?} */ var language = request.asiNgtools.language; if (language) { return language.substring(0, 2) === 'fr'; } } return false; } }; /** * @return {?} */ AsiDmyPickerComponent.prototype.initDays = /** * @return {?} */ function () { var _this = this; nh.times(31, function (time) { _this.days.push(time + 1); }); }; /** * @return {?} */ AsiDmyPickerComponent.prototype.initYears = /** * @return {?} */ function () { /** @type {?} */ var results = new Array(); /** @type {?} */ var currentYear = new Date().getFullYear(); for (var year = currentYear; year >= 1900; year--) { results.push(year); } this.years = results; }; /** * @param {?} month * @return {?} */ AsiDmyPickerComponent.prototype.onMonthChange = /** * @param {?} month * @return {?} */ function (month) { this.value = { day: this.day, month: month != null ? month.num : null, year: this.year }; }; /** * @param {?} year * @return {?} */ AsiDmyPickerComponent.prototype.onYearChange = /** * @param {?} year * @return {?} */ function (year) { this.value = { day: this.day, month: this.month != null ? this.month.num : null, year: year }; }; /** * @param {?} day * @return {?} */ AsiDmyPickerComponent.prototype.onDayChange = /** * @param {?} day * @return {?} */ function (day) { this.value = { day: day, month: this.month != null ? this.month.num : null, year: this.year }; }; // Controle value accessor /** * @param {?} value * @return {?} */ AsiDmyPickerComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (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 {?} */ AsiDmyPickerComponent.prototype.getMontFromNum = /** * @param {?} monthNum * @return {?} */ function (monthNum) { if (monthNum == null) { return null; } return nh.find(this.months, function (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(function () { return AsiDmyPickerComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiDmyPickerComponent.ctorParameters = function () { return [ { 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 }] }; return AsiDmyPickerComponent; }(DefaultControlValueAccessor)); export { AsiDmyPickerComponent }; 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"]}