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