UNPKG

@asi-ngtools/lib

Version:

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

223 lines (222 loc) 15.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { DefaultControlValueAccessor } from './../common/default-control-value-accessor'; import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms'; import { debounceTime } from 'rxjs/operators'; import { Component, forwardRef, Input, Output, EventEmitter, ElementRef, ViewChild, Renderer2 } from '@angular/core'; import * as nh from '../../native-helper'; export class AsiInputIconComponent extends DefaultControlValueAccessor { /** * @param {?} renderer * @param {?} elementRef */ constructor(renderer, elementRef) { super(); this.renderer = renderer; this.elementRef = elementRef; /** * html input type */ this.type = 'text'; /** * Label position */ this.labelPosition = 'top'; /** * Placeholder to display */ this.placeholder = ''; /** * Icon position */ this.iconPosition = 'left'; /** * Max length of the text */ this.maxlength = -1; /** * Delay before the component change value */ this.delay = 0; /** * Must be a number (internaly set the regex to ^-*[0-9,\.]*$ */ this.number = false; /** * Event emitted when the icon is clicked */ this.iconClicked = new EventEmitter(); this.inputControl = new FormControl(); } /** * @return {?} */ ngOnInit() { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.number === true) { this.pattern = new RegExp('^-*[0-9,\.]*$'); } } /** * @return {?} */ ngAfterViewInit() { this.inputControl.valueChanges.pipe(debounceTime(this.delay)).subscribe((value) => { if (value === '') { this.value = null; } else if (this.isValide(value)) { this.value = value; } else if (this.maxlength !== -1 && value.length > this.maxlength) { // if value is too long, we truncate this.value = value.substr(0, this.maxlength); } this.inputElm.nativeElement.value = this._value; }); } /** * @param {?} value * @return {?} */ isValide(value) { return value == null || ((this.maxlength === -1 || value.length <= this.maxlength) && (this.pattern == null || this.pattern.test(value))); } /** * @param {?} value * @return {?} */ writeValue(value) { if (this.isValide(value)) { this.inputControl.setValue(value, { emitEvent: false }); } else if (this.maxlength !== -1 && value.length > this.maxlength) { // Length incorrect on truncate this.inputControl.setValue(nh.truncate(value, this.maxlength), { emitEvent: false }); } else { // Pattern incorrect this.inputElm.nativeElement.value = 'Incorrect value'; } } /** * @return {?} */ handleIconClick() { this.iconClicked.emit(); } } AsiInputIconComponent.decorators = [ { type: Component, args: [{ selector: 'asi-input-icon', host: { 'class': 'asi-component asi-input-icon' }, template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\n<div class=\"input-panel\" [ngClass]=\"{'icon-left': iconPosition=='left', 'icon-right': iconPosition=='right'}\">\n <asi-button (click)=\"handleIconClick()\" [disabled]=\"iconClicked.observers.length === 0\">\n <asi-fa-icon [icon]=\"icon\" [disabled]=\"iconClicked.observers.length === 0\"></asi-fa-icon>\n </asi-button>\n <input #asiInputIcon \n [attr.id]=\"id\" \n [attr.name]=\"name\"\n [attr.type]=\"type\" \n [attr.disabled]=\"disabled ? '' : null\" \n class=\"asi-focus-error\" \n [placeholder]=\"placeholder\"\n [formControl]=\"inputControl\" />\n</div>", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AsiInputIconComponent), multi: true } ] }] } ]; /** @nocollapse */ AsiInputIconComponent.ctorParameters = () => [ { type: Renderer2 }, { type: ElementRef } ]; AsiInputIconComponent.propDecorators = { id: [{ type: Input }], name: [{ type: Input }], type: [{ type: Input }], label: [{ type: Input }], labelPosition: [{ type: Input }], placeholder: [{ type: Input }], icon: [{ type: Input }], iconPosition: [{ type: Input }], pattern: [{ type: Input }], maxlength: [{ type: Input }], delay: [{ type: Input }], number: [{ type: Input }], iconClicked: [{ type: Output, args: ['iconClicked',] }], inputElm: [{ type: ViewChild, args: ['asiInputIcon',] }] }; if (false) { /** * html id * @type {?} */ AsiInputIconComponent.prototype.id; /** * html name * @type {?} */ AsiInputIconComponent.prototype.name; /** * html input type * @type {?} */ AsiInputIconComponent.prototype.type; /** * Label to display (is translated) * @type {?} */ AsiInputIconComponent.prototype.label; /** * Label position * @type {?} */ AsiInputIconComponent.prototype.labelPosition; /** * Placeholder to display * @type {?} */ AsiInputIconComponent.prototype.placeholder; /** * Icon to display * @type {?} */ AsiInputIconComponent.prototype.icon; /** * Icon position * @type {?} */ AsiInputIconComponent.prototype.iconPosition; /** * Allow you to define a regex that the input must respect * @type {?} */ AsiInputIconComponent.prototype.pattern; /** * Max length of the text * @type {?} */ AsiInputIconComponent.prototype.maxlength; /** * Delay before the component change value * @type {?} */ AsiInputIconComponent.prototype.delay; /** * Must be a number (internaly set the regex to ^-*[0-9,\.]*$ * @type {?} */ AsiInputIconComponent.prototype.number; /** * Event emitted when the icon is clicked * @type {?} */ AsiInputIconComponent.prototype.iconClicked; /** @type {?} */ AsiInputIconComponent.prototype.inputControl; /** @type {?} */ AsiInputIconComponent.prototype.inputElm; /** @type {?} */ AsiInputIconComponent.prototype.renderer; /** @type {?} */ AsiInputIconComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-input-icon.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-input-icon/asi-input-icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\nimport { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\nimport { debounceTime } from 'rxjs/operators';\nimport {\n  Component, forwardRef, Input, Output, OnInit, EventEmitter,\n  ElementRef, ViewChild, AfterViewInit, Renderer2\n} from '@angular/core';\n\nimport * as nh from '../../native-helper';\n\n@Component({\n  selector: 'asi-input-icon',\n  host: { 'class': 'asi-component asi-input-icon' },\n  templateUrl: 'asi-input-icon.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiInputIconComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiInputIconComponent extends DefaultControlValueAccessor implements OnInit, AfterViewInit {\n\n  /** html id */\n  @Input() id: string;\n  /** html name */\n  @Input() name: string;\n  /** html input type */\n  @Input() type: 'password' | 'text' = 'text';\n\n  /** Label to display (is translated) */\n  @Input() label: string;\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n  /** Placeholder to display */\n  @Input() placeholder = '';\n\n  /** Icon to display */\n  @Input() icon: string;\n  /** Icon position */\n  @Input() iconPosition: 'left' | 'right' = 'left';\n\n  /** Allow you to define a regex that the input must respect */\n  @Input() pattern: RegExp;\n\n  /** Max length of the text */\n  @Input() maxlength = -1;\n\n  /** Delay before the component change value */\n  @Input() delay = 0;\n\n  /** Must be a number (internaly set the regex to ^-*[0-9,\\.]*$ */\n  @Input() number = false;\n\n  /** Event emitted when the icon is clicked */\n  @Output('iconClicked') iconClicked = new EventEmitter<any>();\n\n  inputControl = new FormControl();\n\n  @ViewChild('asiInputIcon') inputElm: ElementRef;\n\n  constructor(private renderer: Renderer2,\n    private elementRef: ElementRef) {\n    super();\n  }\n\n  ngOnInit() {\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n    if (this.number === true) {\n      this.pattern = new RegExp('^-*[0-9,\\.]*$');\n    }\n  }\n\n  ngAfterViewInit() {\n    this.inputControl.valueChanges.pipe(debounceTime(this.delay)).subscribe((value: string) => {\n      if (value === '') {\n        this.value = null;\n      } else if (this.isValide(value)) {\n        this.value = value;\n      } else if (this.maxlength !== -1 && value.length > this.maxlength) {\n        // if value is too long, we truncate\n        this.value = value.substr(0, this.maxlength);\n      }\n      this.inputElm.nativeElement.value = this._value;\n    });\n  }\n\n  private isValide(value: string): boolean {\n    return value == null || ((this.maxlength === -1 || value.length <= this.maxlength)\n      && (this.pattern == null || this.pattern.test(value)))\n  }\n\n  writeValue(value: string) {\n    if (this.isValide(value)) {\n      this.inputControl.setValue(value, { emitEvent: false });\n    } else if (this.maxlength !== -1 && value.length > this.maxlength) {\n      // Length incorrect on truncate\n      this.inputControl.setValue(nh.truncate(value, this.maxlength), { emitEvent: false });\n    } else {\n      // Pattern incorrect\n      this.inputElm.nativeElement.value = 'Incorrect value';\n    }\n  }\n\n  public handleIconClick() {\n    this.iconClicked.emit();\n  }\n}\n"]}