@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
JavaScript
/**
* @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"]}