lct-components
Version:
LCT basic components
225 lines • 32.5 kB
JavaScript
import { __awaiter } from "tslib";
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { Subject } from "rxjs";
import { debounceTime } from "rxjs/operators";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "@angular/common";
export class InputTextComponent {
constructor(render) {
this.render = render;
this.disabled = false;
this.icon = '';
this.iconPosition = 'right';
this.pdaAutoEnter = false;
this.placeholder = '';
this.showIcon = false;
this.title = 'Insert Title';
this.type = 'text';
this.error = false;
this.id = ''; // ID en Button Opcional
this.transparent = false; // transparent style
this.enterEmitted = new EventEmitter();
this.iconClick = new EventEmitter();
this.inputClick = new EventEmitter();
this.inputValue = '';
this.selectionStart = 0;
this.selectionEnd = 0;
this.lpnUpdate = new Subject();
this.propagateChange = (_) => { };
this.lpnUpdate
.pipe(debounceTime(200)
/* distinctUntilChanged() */ // esto previene que el valor ser repita
)
.subscribe((value) => __awaiter(this, void 0, void 0, function* () {
if (value && this.pdaAutoEnter) {
this.enterEmit();
}
else {
if (!value) {
this.selectionStart = 0;
this.selectionEnd = 0;
}
return;
}
}));
}
// Propiedad calculada para generar el id dinámico
get inputId() {
return this.id ? `input-${this.id}` : null;
}
ngAfterViewInit() {
var _a, _b, _c, _d, _e, _f;
if (this.iconPosition === "left" && this.showIcon) {
this.render.addClass((_a = this.inputScan) === null || _a === void 0 ? void 0 : _a.nativeElement, 'iconLeft');
this.render.addClass((_b = this.iconDiv) === null || _b === void 0 ? void 0 : _b.nativeElement, 'iconLeft');
}
if (this.error) {
this.render.addClass((_c = this.inputScan) === null || _c === void 0 ? void 0 : _c.nativeElement, 'error');
this.render.addClass((_d = this.titleRef) === null || _d === void 0 ? void 0 : _d.nativeElement, 'error');
}
if (this.transparent) {
this.render.addClass((_e = this.inputScan) === null || _e === void 0 ? void 0 : _e.nativeElement, 'transparent');
this.render.addClass((_f = this.titleRef) === null || _f === void 0 ? void 0 : _f.nativeElement, 'transparent');
}
}
ngOnInit() {
}
ngOnChanges(changes) {
var _a, _b, _c, _d, _e, _f, _g, _h;
if (changes['pdaAutoEnter'] && !changes['pdaAutoEnter'].firstChange) {
this.pdaAutoEnter = changes['pdaAutoEnter'].currentValue;
}
if (changes['error'] && !changes['error'].firstChange) {
if (changes.error.currentValue) {
this.render.addClass((_a = this.inputScan) === null || _a === void 0 ? void 0 : _a.nativeElement, 'error');
this.render.addClass((_b = this.titleRef) === null || _b === void 0 ? void 0 : _b.nativeElement, 'error');
}
else {
this.render.removeClass((_c = this.inputScan) === null || _c === void 0 ? void 0 : _c.nativeElement, 'error');
this.render.removeClass((_d = this.titleRef) === null || _d === void 0 ? void 0 : _d.nativeElement, 'error');
}
}
if (changes['transparent'] && !changes['transparent'].firstChange) {
if (changes.error.currentValue) {
this.render.addClass((_e = this.inputScan) === null || _e === void 0 ? void 0 : _e.nativeElement, 'transparent');
this.render.addClass((_f = this.titleRef) === null || _f === void 0 ? void 0 : _f.nativeElement, 'transparent');
}
else {
this.render.addClass((_g = this.inputScan) === null || _g === void 0 ? void 0 : _g.nativeElement, 'transparent');
this.render.addClass((_h = this.titleRef) === null || _h === void 0 ? void 0 : _h.nativeElement, 'transparent');
}
}
}
writeValue(value) {
if (typeof value !== 'undefined') {
this.onKeyUpHandler(value);
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched(fn) {
// console.log('reg touch', fn)
}
onKeyUpHandler(event) {
if (!this.inputValue && typeof event === 'string') {
this.inputValue = event;
}
if (this.inputValue && event === null) {
this.inputValue = '';
}
if (this.inputValue && typeof event === 'string' && event === '') {
this.inputValue = '';
}
this.propagateChange(this.inputValue);
}
click() {
if (!this.disabled) {
this.iconClick.emit('iconClick');
}
}
clickInput() {
if (!this.disabled) {
this.inputClick.emit('inputClick');
}
}
enterEmit() {
if (this.inputValue) {
this.enterEmitted.emit(this.inputValue);
}
}
onPaste(ev) {
var _a, _b, _c, _d;
ev.preventDefault();
const clipboard = (_a = ev.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('Text');
if (clipboard) {
if (this.selectionEnd && this.selectionStart === ((_b = this.inputScan) === null || _b === void 0 ? void 0 : _b.nativeElement.selectionStart)) {
const slice1 = this.inputValue.slice(0, this.selectionStart);
const slice2 = this.inputValue.slice(this.selectionEnd);
this.inputValue = slice1 + clipboard + slice2;
setTimeout(() => {
var _a;
(_a = this.inputScan) === null || _a === void 0 ? void 0 : _a.nativeElement.setSelectionRange(slice1.length + clipboard.length, slice1.length + clipboard.length);
}, 20);
this.selectionStart = 0;
this.selectionEnd = 0;
}
else {
const slice1 = this.inputValue.slice(0, (_c = this.inputScan) === null || _c === void 0 ? void 0 : _c.nativeElement.selectionStart);
const slice2 = this.inputValue.slice((_d = this.inputScan) === null || _d === void 0 ? void 0 : _d.nativeElement.selectionStart);
this.inputValue = slice1 + clipboard + slice2;
setTimeout(() => {
var _a;
(_a = this.inputScan) === null || _a === void 0 ? void 0 : _a.nativeElement.setSelectionRange(slice1.length + clipboard.length, slice1.length + clipboard.length);
}, 20);
// this.inputValue = this.inputValue+clipboard;
}
}
}
selectionChange(ev) {
// console.log('selection asdf:', ev.target.value.substring(ev.target.selectionStart, ev.target.selectionEnd));
// console.log('start: ',ev.target.selectionStart, 'end:', ev.target.selectionEnd)
// this.selectedText = ev.target.value.substring(ev.target.selectionStart, ev.target.selectionEnd);
this.selectionStart = ev.target.selectionStart;
this.selectionEnd = ev.target.selectionEnd;
}
}
InputTextComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
InputTextComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: InputTextComponent, selector: "lct-input-text", inputs: { disabled: "disabled", icon: "icon", iconPosition: "iconPosition", pdaAutoEnter: "pdaAutoEnter", placeholder: "placeholder", showIcon: "showIcon", title: "title", type: "type", error: "error", id: "id", transparent: "transparent" }, outputs: { enterEmitted: "enterEmitted", iconClick: "iconClick", inputClick: "inputClick" }, providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}], viewQueries: [{ propertyName: "inputScan", first: true, predicate: ["inputScan"], descendants: true }, { propertyName: "titleRef", first: true, predicate: ["titleRef"], descendants: true }, { propertyName: "iconDiv", first: true, predicate: ["iconDiv"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div>\n <div #titleRef class=\"title\">\n {{title}}\n </div>\n <div class=\"input-with-icon iconLeft\">\n <input [attr.id]=\"inputId\"\n [type]=\"type\"\n class=\"form-control-lct\"\n #inputScan\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"inputValue\"\n (keydown.enter)=\"enterEmit()\"\n (keydown.tab)=\"enterEmit()\"\n (keyup)=\"onKeyUpHandler($event)\"\n (click)=\"clickInput()\"\n (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n (paste)=\"onPaste($event)\"\n (select)=\"selectionChange($event)\"\n >\n <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n </div>\n </div>\n</div>\n", styles: ["*{font-family:\"Barlow\",\"Open Sans\",\"Helvetica Neue\",\"Segoe UI\",\"Calibri\",\"Arial\",sans-serif}.title{color:#3c4149;font-size:12px;letter-spacing:0;line-height:15px;margin-left:2px;margin-bottom:5px}.title.error{color:#c60e4c}.input-with-icon{box-sizing:border-box;position:relative;height:40px}.form-control-lct::placeholder{color:#3c4149}.input-with-icon .form-control-lct{height:100%;width:100%;border:0;border-radius:4px;background-color:#e0e5ee;box-sizing:border-box;color:#3c4149;font-size:14px;font-weight:400;letter-spacing:0;line-height:17px;padding:12px 20px 12px 15px}.input-with-icon .form-control-lct.error{color:#c60e4c;border:1px solid #C60E4C}.input-with-icon .form-control-lct.iconLeft{padding:12px 20px 12px 60px}.input-with-icon .form-control-lct:disabled{cursor:not-allowed;background-color:#f5f7fa;color:#c8ccd4}.input-with-icon .form-control-lct:focus-visible{outline:unset}.input-with-icon .form-control-lct.transparent{background-color:#fff;color:#fff}.input-with-icon .icon{position:absolute;right:1%;top:.01rem;width:2.6rem;height:2.6rem;border-radius:.3rem;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.input-with-icon .icon :hover{cursor:pointer}@media (max-width: 375px){.input-with-icon .icon{top:.3rem}}.input-with-icon .icon.iconLeft{left:15px}\n"], directives: [{ type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: InputTextComponent, decorators: [{
type: Component,
args: [{
selector: 'lct-input-text',
templateUrl: './input-text.component.html',
styleUrls: ['./input-text.component.scss'],
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: InputTextComponent,
multi: true
}]
}]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { disabled: [{
type: Input
}], icon: [{
type: Input
}], iconPosition: [{
type: Input
}], pdaAutoEnter: [{
type: Input
}], placeholder: [{
type: Input
}], showIcon: [{
type: Input
}], title: [{
type: Input
}], type: [{
type: Input
}], error: [{
type: Input
}], id: [{
type: Input
}], transparent: [{
type: Input
}], enterEmitted: [{
type: Output
}], iconClick: [{
type: Output
}], inputClick: [{
type: Output
}], inputScan: [{
type: ViewChild,
args: ['inputScan']
}], titleRef: [{
type: ViewChild,
args: ['titleRef']
}], iconDiv: [{
type: ViewChild,
args: ['iconDiv']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../projects/lct-components/src/lib/input-text/input-text.component.ts","../../../../../projects/lct-components/src/lib/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input, OnChanges,\n  OnInit,\n  Output,\n  Renderer2, SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Subject } from \"rxjs\";\nimport { debounceTime, distinctUntilChanged } from \"rxjs/operators\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { SafeResourceUrl } from '@angular/platform-browser';\n\n@Component({\n  selector: 'lct-input-text',\n  templateUrl: './input-text.component.html',\n  styleUrls: ['./input-text.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputTextComponent,\n    multi: true\n  }]\n})\nexport class InputTextComponent implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges {\n\n  @Input() disabled = false;\n  @Input() icon: string | SafeResourceUrl = ''\n  @Input() iconPosition: 'left' | 'right' = 'right';\n  @Input() pdaAutoEnter = false;\n  @Input() placeholder = '';\n  @Input() showIcon = false;\n  @Input() title = 'Insert Title';\n  @Input() type: 'email' | 'number' | 'text' = 'text';\n  @Input() error: boolean = false;\n  @Input() id?: string = ''; // ID en Button Opcional\n  @Input() transparent?: boolean = false; // transparent style\n  @Output() enterEmitted = new EventEmitter<string>()\n  @Output() iconClick = new EventEmitter();\n  @Output() inputClick = new EventEmitter();\n  @ViewChild('inputScan') inputScan: ElementRef | undefined;\n  @ViewChild('titleRef') titleRef: ElementRef | undefined;\n  @ViewChild('iconDiv') iconDiv: ElementRef | undefined;\n\n  inputValue = '';\n  private selectionStart = 0;\n  private selectionEnd = 0;\n  public lpnUpdate = new Subject<string>();\n\n  public propagateChange = (_: any) => { };\n  \n  // Propiedad calculada para generar el id dinámico\n  get inputId(): string | null {\n    return this.id ? `input-${this.id}` : null;\n  }\n\n  constructor(private render: Renderer2) {\n    this.lpnUpdate\n      .pipe(\n        debounceTime(200)\n     /*    distinctUntilChanged() */ // esto previene que el valor ser repita\n      )\n      .subscribe(async value => {\n        if (value && this.pdaAutoEnter) {\n          this.enterEmit();\n        } else {\n          if (!value) {\n            this.selectionStart = 0\n            this.selectionEnd = 0;\n          }\n          return;\n        }\n      });\n  }\n\n  ngAfterViewInit() {\n    if (this.iconPosition === \"left\" && this.showIcon) {\n      this.render.addClass(this.inputScan?.nativeElement, 'iconLeft')\n      this.render.addClass(this.iconDiv?.nativeElement, 'iconLeft')\n    }\n    if (this.error) {\n      this.render.addClass(this.inputScan?.nativeElement, 'error');\n      this.render.addClass(this.titleRef?.nativeElement, 'error');\n    }\n    if(this.transparent){\n      this.render.addClass(this.inputScan?.nativeElement, 'transparent');\n      this.render.addClass(this.titleRef?.nativeElement, 'transparent');\n    }\n\n  }\n\n  ngOnInit(): void {\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['pdaAutoEnter'] && !changes['pdaAutoEnter'].firstChange) {      \n      this.pdaAutoEnter = changes['pdaAutoEnter'].currentValue;\n    }\n    if (changes['error'] && !changes['error'].firstChange) {\n      if (changes.error.currentValue) {\n        this.render.addClass(this.inputScan?.nativeElement, 'error');\n        this.render.addClass(this.titleRef?.nativeElement, 'error');\n      } else {\n        this.render.removeClass(this.inputScan?.nativeElement, 'error');\n        this.render.removeClass(this.titleRef?.nativeElement, 'error');\n      }\n    }\n    \n    if (changes['transparent'] && !changes['transparent'].firstChange) {\n      if (changes.error.currentValue) {\n        this.render.addClass(this.inputScan?.nativeElement, 'transparent');\n        this.render.addClass(this.titleRef?.nativeElement, 'transparent');\n      } else {\n        this.render.addClass(this.inputScan?.nativeElement, 'transparent');\n        this.render.addClass(this.titleRef?.nativeElement, 'transparent');\n      }\n    }\n\n\n  }\n\n  writeValue(value: any): void {\n    if (typeof value !== 'undefined') {\n      this.onKeyUpHandler(value);\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    // console.log('reg touch', fn)\n  }\n\n  onKeyUpHandler(event?: KeyboardEvent | string) {\n    if (!this.inputValue && typeof event === 'string') {\n      this.inputValue = event;\n    }\n    if (this.inputValue && event === null) {\n      this.inputValue = '';\n    }\n    if (this.inputValue && typeof event === 'string' && event === '') {\n      this.inputValue = '';\n    }\n    this.propagateChange(this.inputValue);\n  }\n\n  click() {\n    if (!this.disabled) {\n      this.iconClick.emit('iconClick')\n    }\n  }\n\n  clickInput() {\n    if (!this.disabled) {\n      this.inputClick.emit('inputClick')\n    }\n  }\n\n  enterEmit() {\n    if (this.inputValue) {\n      this.enterEmitted.emit(this.inputValue);\n    }\n  }\n\n  onPaste(ev: ClipboardEvent) {\n    ev.preventDefault();\n    const clipboard = ev.clipboardData?.getData('Text');\n    if (clipboard) {\n      if (this.selectionEnd && this.selectionStart === this.inputScan?.nativeElement.selectionStart) {\n        const slice1 = this.inputValue.slice(0, this.selectionStart);\n        const slice2 = this.inputValue.slice(this.selectionEnd);\n        this.inputValue = slice1 + clipboard + slice2;\n        setTimeout(() => {\n          this.inputScan?.nativeElement.setSelectionRange(slice1.length + clipboard.length, slice1.length + clipboard.length)\n        }, 20)\n        this.selectionStart = 0;\n        this.selectionEnd = 0;\n      } else {\n        const slice1 = this.inputValue.slice(0, this.inputScan?.nativeElement.selectionStart);\n        const slice2 = this.inputValue.slice(this.inputScan?.nativeElement.selectionStart);\n        this.inputValue = slice1 + clipboard + slice2;\n        setTimeout(() => {\n          this.inputScan?.nativeElement.setSelectionRange(slice1.length + clipboard.length, slice1.length + clipboard.length)\n        }, 20)\n        // this.inputValue = this.inputValue+clipboard;\n      }\n    }\n  }\n\n  selectionChange(ev: any) {\n    // console.log('selection asdf:', ev.target.value.substring(ev.target.selectionStart, ev.target.selectionEnd));\n    // console.log('start: ',ev.target.selectionStart, 'end:', ev.target.selectionEnd)\n    // this.selectedText = ev.target.value.substring(ev.target.selectionStart, ev.target.selectionEnd);\n    this.selectionStart = ev.target.selectionStart;\n    this.selectionEnd = ev.target.selectionEnd;\n  }\n\n\n}\n","<div>\n  <div #titleRef class=\"title\">\n    {{title}}\n  </div>\n  <div class=\"input-with-icon iconLeft\">\n    <input [attr.id]=\"inputId\"\n           [type]=\"type\"\n           class=\"form-control-lct\"\n           #inputScan\n           [disabled]=\"disabled\"\n           [placeholder]=\"placeholder\"\n           [(ngModel)]=\"inputValue\"\n           (keydown.enter)=\"enterEmit()\"\n           (keydown.tab)=\"enterEmit()\"\n           (keyup)=\"onKeyUpHandler($event)\"\n           (click)=\"clickInput()\"\n           (ngModelChange)=\"lpnUpdate.next(inputScan.value);\"\n           (paste)=\"onPaste($event)\"\n           (select)=\"selectionChange($event)\"\n    >\n    <div class=\"icon\" #iconDiv *ngIf=\"showIcon\">\n      <img [src]=\"icon\" [ngStyle]=\"{'cursor': disabled ? 'not-allowed' : 'pointer'}\" alt=\"\" (click)=\"click()\">\n    </div>\n  </div>\n</div>\n"]}