lct-components
Version:
LCT basic components
180 lines • 28.8 kB
JavaScript
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { ModalManualInputAlertComponent } from '../modal/modal-manual-input-alert/modal-manual-input-alert';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class ButtonComponent {
constructor(renderer, resolver, viewContainerRef) {
this.renderer = renderer;
this.resolver = resolver;
this.viewContainerRef = viewContainerRef;
this.title = 'Insert Title';
this.buttonType = 'primary';
this.disabled = 'false';
this.shape = 'normal';
this.icon = '';
this.width = '';
this.height = '';
this.bold = 'false';
this.iconWidth = 30;
this.iconHeight = 30;
this.counter = -1;
this.isMobile = false;
this.id = ''; // ID en Button Opcional
this.userId = '';
this.alertIconPath = ''; // Ruta del ícono de alerta para el modal
this.alertManualInput = new EventEmitter();
this.disabledValue = false;
this.boldValue = false;
this.componentRef2 = undefined;
}
// Propiedad calculada para generar el id dinámico
get buttonId() {
return this.id ? `btn-${this.id}` : null;
}
ngAfterViewInit() {
var _a, _b;
this.renderButtonType();
if (this.width) {
this.renderer.setStyle((_a = this.button) === null || _a === void 0 ? void 0 : _a.nativeElement, 'width', this.width);
}
if (this.height) {
this.renderer.setStyle((_b = this.button) === null || _b === void 0 ? void 0 : _b.nativeElement, 'height', this.height);
}
}
ngOnInit() {
if (this.disabled === true || this.disabled == 'true' || this.disabled === '') {
this.disabledValue = true;
}
else {
this.disabledValue = false;
}
if (this.bold === true || this.bold == 'true') {
this.boldValue = true;
}
else {
this.boldValue = false;
}
}
ngOnChanges(changes) {
var _a, _b, _c;
if (changes['buttonType'] && !changes['buttonType'].firstChange) {
this.buttonType = (_a = changes.buttonType) === null || _a === void 0 ? void 0 : _a.currentValue;
this.renderer.removeClass((_b = this.button) === null || _b === void 0 ? void 0 : _b.nativeElement, (_c = changes.buttonType) === null || _c === void 0 ? void 0 : _c.previousValue);
this.renderButtonType();
}
else if (changes['disabled'] && !changes['disabled'].firstChange) {
if (changes['disabled'].currentValue === true || changes['disabled'].currentValue == 'true' || changes['disabled'].currentValue === '') {
this.disabledValue = true;
}
else {
this.disabledValue = false;
}
}
}
renderButtonType() {
var _a;
this.renderer.addClass((_a = this.button) === null || _a === void 0 ? void 0 : _a.nativeElement, this.buttonType);
}
openModalInputAlert() {
if (!this.userId || this.userId === '') {
console.log("No es posible configurar modal manual input alert sin parámetro userId");
}
const sessionData = localStorage.getItem('alert-manual-input') || '[]';
const usersAlertData = sessionData ? JSON.parse(sessionData) : [];
const currentUser = usersAlertData.find(user => user.userId === this.userId);
// Si el usuario existe y su timestamp es menor a 4 horas, no mostrar el modal
if (currentUser && currentUser.timestamp > new Date().getTime() - 1000 * 60 * 60 * 4) {
this.alertManualInput.emit('keyboard');
return;
}
// Si ya pasaron al menos 4 horas o es un usuario nuevo, ejecutar el modal y actualizar/agregar el timestamp
const currentTimestamp = new Date().getTime();
if (currentUser) {
// Actualizar el timestamp del usuario existente
currentUser.timestamp = currentTimestamp;
}
else {
// Agregar el nuevo usuario al array
usersAlertData.push({
userId: this.userId || '',
timestamp: currentTimestamp,
});
}
localStorage.setItem('alert-manual-input', JSON.stringify(usersAlertData));
const componentFactory = this.resolver.resolveComponentFactory(ModalManualInputAlertComponent);
this.componentRef2 = this.viewContainerRef.createComponent(componentFactory);
this.componentRef2.instance.widthModalConfig = this.isMobile ? "100%" : '600px';
this.componentRef2.instance.heightModalConfig = this.isMobile ? "100%" : '320px';
this.componentRef2.instance.alertIconPath = "src/svg/ico-tit-alerta.svg";
if (this.alertIconPath) {
this.componentRef2.instance.alertIconPath = this.alertIconPath;
}
this.componentRef2.instance.closeModalStore.subscribe(resp => {
if (resp.finish) {
this.alertManualInput.emit(resp.type);
this.closeModal();
}
});
}
onButtonClick() {
var _a, _b;
// Verificar si el EventEmitter tiene suscriptores (observers)
// Esto indica si hay un listener en el template padre: (buttonClickAlert)="..."
const hasSubscribers = ((_b = (_a = this.alertManualInput) === null || _a === void 0 ? void 0 : _a.observers) === null || _b === void 0 ? void 0 : _b.length) > 0;
if (this.buttonType === 'enabled' && hasSubscribers) {
this.openModalInputAlert();
}
}
closeModal() {
if (this.componentRef2) {
this.componentRef2.destroy();
this.componentRef2 = undefined;
}
}
}
ButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: ButtonComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component });
ButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.1.5", type: ButtonComponent, selector: "lct-button", inputs: { title: "title", buttonType: "buttonType", disabled: "disabled", shape: "shape", icon: "icon", width: "width", height: "height", bold: "bold", iconWidth: "iconWidth", iconHeight: "iconHeight", counter: "counter", isMobile: "isMobile", id: "id", userId: "userId", alertIconPath: "alertIconPath" }, outputs: { alertManualInput: "alertManualInput" }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div [ngClass]=\"{'containerBtnRound': shape==='round'}\">\n <button [attr.id]=\"buttonId\" \n [disabled]=\"disabledValue\" #button \n (click)=\"onButtonClick()\"\n [ngClass]=\"{'button-round': shape==='round'}\" [ngStyle]=\"{'padding': title && shape==='normal' ? '0px 14px': ''}\" >\n <img\n *ngIf=\"icon\" [ngClass]=\"{'counterAndIconImg': counter >= 0 && icon}\"\n [width]=\"iconWidth\"\n [height]=\"iconHeight\"\n [ngStyle]=\"{'margin-right': title ? '8px': ''}\" [src]=\"icon\" alt=\"icon\">\n <span *ngIf=\"title\"\n [ngClass]=\"{'counterOn': counter >= 0 && !icon, 'counterAndIconTxt': counter >= 0 && icon}\"\n >{{shape==='normal' ? title : ''}}</span>\n <span *ngIf=\"counter >= 0\" class=\"btnCounter\">{{counter}}</span>\n </button>\n <span *ngIf=\"shape==='round'\"\n [class.fw-bold]=\"boldValue\"\n class=\"titleBtnRound\"\n >{{title}}</span>\n</div>\n", styles: [".containerBtnRound{display:flex;flex-direction:column;justify-content:center;align-items:center}button{width:100%;height:40px;border-radius:8px;border:1px solid #C2C2C2;background-color:#c8ccd4;font-size:14px;letter-spacing:0;line-height:18px;font-family:\"Barlow\",serif;cursor:pointer}button:disabled{cursor:not-allowed;background-color:#c8ccd4;color:#fff;font-weight:unset}button:not([disabled]):active img{filter:hue-rotate(10deg) saturate(.5) brightness(390%) saturate(4)}.button-round{height:44px;width:44px;border-radius:22px;padding:0!important}.button-round img{margin:0!important;width:28px;height:28px}.titleBtnRound{color:#3c4149;font-size:13px;font-style:normal;font-weight:400;line-height:14px;margin-top:6px}.primary{background-color:#2649b6;color:#fff;font-weight:bold}.primary:not([disabled]):active{background:#2A5AED}@media (hover: hover){.primary:not([disabled]):hover{background:#2A5AED}}.secondary{box-sizing:border-box;border:1px solid #2649B6;background-color:#fff;color:#2649b6}.secondary:disabled{border:0}.secondary:not([disabled]):active{background:#2A5AED;color:#fff}@media (hover: hover){.secondary:not([disabled]):hover{border:1px solid #2A5AED;color:#2a5aed}.secondary:active{color:#fff!important}}.counterOn{position:relative;float:left;left:12px}.btnCounter{background-color:#fff;color:#2649b6;position:relative;right:12px;float:right;padding:.1rem .4rem;border:1px solid #2649B6;border-radius:2px}.counterAndIconTxt{position:relative;vertical-align:middle}.counterAndIconImg{vertical-align:middle;position:relative;float:left;left:12px}.tertiary{box-sizing:border-box;background-color:#6a80b1;color:#fff}.tertiary:disabled{border:0}.tertiary:not([disabled]):hover{border:1px solid #2649B6}.tertiary:not([disabled]):active{background:#809AD2}.quaternary{box-sizing:border-box;border:1px solid #2649B6;background-color:#223359;color:#fff}.quaternary:disabled{border:0}.quaternary:not([disabled]):active{background-color:#2a5aed;color:#fff}@media (hover: hover){.quaternary:not([disabled]):hover{background-color:#fff;border:1px solid #223359;color:#223359}}.quintary{box-sizing:border-box;border:1px solid #a2a2a2;background-color:#fff;color:#000;font-weight:bold}.quintary:disabled{border:0}.quintary:not([disabled]):active{background:#a2a2a2;color:#fff}@media (hover: hover){.quintary:not([disabled]):hover{border:1px solid #a2a2a2;color:#000}.quintary:active{color:#fff!important}}.sextary{box-sizing:border-box;border:1px solid #F1F2F4;background-color:#f1f2f4;color:#151618;font-weight:bold}.sextary:disabled{border:0}.sextary:not([disabled]):active{background:#a2a2a2;color:#fff}@media (hover: hover){.sextary:not([disabled]):hover{border:1px solid #a2a2a2;color:#000}.sextary:active{color:#fff!important}}.enabled{background-color:#747474;box-sizing:border-box;color:#fff}.enabled:disabled{border:0}.enabled:not([disabled]):hover{border:1px solid #747474}.enabled:not([disabled]):enabled{background-color:#747474}.error{background-color:#c60e4c;color:#fff}.success{background-color:#8cba37;color:#fff}\n"], directives: [{ type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: ButtonComponent, decorators: [{
type: Component,
args: [{
selector: 'lct-button',
templateUrl: './button.component.html',
styleUrls: ['./button.component.scss']
}]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }]; }, propDecorators: { title: [{
type: Input
}], buttonType: [{
type: Input
}], disabled: [{
type: Input
}], shape: [{
type: Input
}], icon: [{
type: Input
}], width: [{
type: Input
}], height: [{
type: Input
}], bold: [{
type: Input
}], iconWidth: [{
type: Input
}], iconHeight: [{
type: Input
}], counter: [{
type: Input
}], isMobile: [{
type: Input
}], id: [{
type: Input
}], userId: [{
type: Input
}], alertIconPath: [{
type: Input
}], alertManualInput: [{
type: Output
}], button: [{
type: ViewChild,
args: ['button']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/lct-components/src/lib/button/button.component.ts","../../../../../projects/lct-components/src/lib/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { ModalManualInputAlertComponent } from '../modal/modal-manual-input-alert/modal-manual-input-alert';\nimport { ManualInputAlertType } from '../modal/modal-manual-input-alert/modal-manual-input-alert.types';\n\n@Component({\n  selector: 'lct-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss']\n})\nexport class ButtonComponent implements OnInit, AfterViewInit, OnChanges {\n  @Input() title = 'Insert Title'\n  @Input() buttonType: 'primary' | 'enabled' | 'secondary' | 'tertiary' | 'quaternary' | 'quintary' | 'sextary' | 'error' | 'success' = 'primary'\n  @Input() disabled: 'true' | 'false' | 'disabled'| boolean | '' = 'false';\n  @Input() shape: 'normal' | 'round' = 'normal';\n  @Input() icon = '';\n  @Input() width = '';\n  @Input() height = '';\n  @Input() bold: 'true' | 'false' | boolean = 'false';\n  @Input() iconWidth: number = 30;\n  @Input() iconHeight: number = 30;\n  @Input() counter: number = -1;\n  @Input() isMobile: boolean = false;\n  @Input() id?: string = ''; // ID en Button Opcional\n  @Input() userId?: string = '';\n  @Input() alertIconPath?: string = ''; // Ruta del ícono de alerta para el modal\n  @Output() alertManualInput: EventEmitter<ManualInputAlertType> = new EventEmitter<ManualInputAlertType>();\n  @ViewChild('button') button: ElementRef | undefined;\n  disabledValue = false;\n  boldValue = false;\n  componentRef2: ComponentRef<ModalManualInputAlertComponent> | undefined = undefined;\n\n  // Propiedad calculada para generar el id dinámico\n  get buttonId(): string | null {\n    return this.id ? `btn-${this.id}` : null;\n  }\n\n  constructor(private renderer: Renderer2,\n    private resolver: ComponentFactoryResolver,\n    private viewContainerRef: ViewContainerRef) { }\n\n  ngAfterViewInit() {\n   this.renderButtonType();\n    if (this.width) {\n      this.renderer.setStyle(this.button?.nativeElement, 'width', this.width);\n    }\n\n    if (this.height) {\n      this.renderer.setStyle(this.button?.nativeElement, 'height', this.height);\n    }\n  }\n\n  ngOnInit(): void {\n    if (this.disabled=== true || this.disabled == 'true' || this.disabled === ''){\n      this.disabledValue = true;\n    } else {\n      this.disabledValue = false;\n    }\n    if (this.bold=== true || this.bold == 'true'){\n      this.boldValue = true;\n    } else {\n      this.boldValue = false;\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['buttonType'] && !changes['buttonType'].firstChange) {\n      this.buttonType = changes.buttonType?.currentValue;\n      this.renderer.removeClass(this.button?.nativeElement, changes.buttonType?.previousValue);\n      this.renderButtonType();\n    } else if (changes['disabled'] && !changes['disabled'].firstChange) {\n      if (changes['disabled'].currentValue === true || changes['disabled'].currentValue == 'true' || changes['disabled'].currentValue === ''){\n        this.disabledValue = true;\n      } else {\n        this.disabledValue = false;\n      }\n    }\n  }\n\n  renderButtonType() {\n    this.renderer.addClass(this.button?.nativeElement, this.buttonType);\n  }\n\n  openModalInputAlert() {\n    if(!this.userId || this.userId === ''){\n      console.log(\"No es posible configurar modal manual input alert sin parámetro userId\");\n    }\n    const sessionData = localStorage.getItem('alert-manual-input') || '[]';\n    const usersAlertData: Array<{ userId: string, timestamp: number }> = sessionData ? JSON.parse(sessionData) : [];\n    const currentUser = usersAlertData.find(user => user.userId === this.userId);\n    \n    // Si el usuario existe y su timestamp es menor a 4 horas, no mostrar el modal\n    if(currentUser && currentUser.timestamp > new Date().getTime() - 1000 * 60 * 60 * 4){\n      this.alertManualInput.emit('keyboard');\n      return;\n    }\n    \n    // Si ya pasaron al menos 4 horas o es un usuario nuevo, ejecutar el modal y actualizar/agregar el timestamp\n    const currentTimestamp = new Date().getTime();\n    \n    if(currentUser) {\n      // Actualizar el timestamp del usuario existente\n      currentUser.timestamp = currentTimestamp;\n    } else {\n      // Agregar el nuevo usuario al array\n      usersAlertData.push({\n        userId: this.userId || '',\n        timestamp: currentTimestamp,\n      });\n    }\n    localStorage.setItem('alert-manual-input', JSON.stringify(usersAlertData));\n\n    const componentFactory = this.resolver.resolveComponentFactory(ModalManualInputAlertComponent);\n    this.componentRef2 = this.viewContainerRef.createComponent(componentFactory);\n    this.componentRef2.instance.widthModalConfig = this.isMobile ? \"100%\" : '600px';\n    this.componentRef2.instance.heightModalConfig = this.isMobile ? \"100%\" : '320px';\n    this.componentRef2.instance.alertIconPath = \"src/svg/ico-tit-alerta.svg\";\n    if (this.alertIconPath) {\n      this.componentRef2.instance.alertIconPath = this.alertIconPath;\n    }\n    \n    this.componentRef2.instance.closeModalStore.subscribe(resp => {\n      if(resp.finish){\n        this.alertManualInput.emit(resp.type);\n        this.closeModal();\n      }\n    })\n  }\n\n  onButtonClick(): void {\n    // Verificar si el EventEmitter tiene suscriptores (observers)\n    // Esto indica si hay un listener en el template padre: (buttonClickAlert)=\"...\"\n    const hasSubscribers = this.alertManualInput?.observers?.length > 0;\n    \n    if(this.buttonType === 'enabled' && hasSubscribers){\n      this.openModalInputAlert();\n    }\n  }\n  closeModal(): void {\n    if (this.componentRef2) {\n      this.componentRef2.destroy();\n      this.componentRef2 = undefined;\n    }\n  }\n\n}\n","<div [ngClass]=\"{'containerBtnRound': shape==='round'}\">\n  <button [attr.id]=\"buttonId\" \n  [disabled]=\"disabledValue\" #button \n  (click)=\"onButtonClick()\"\n  [ngClass]=\"{'button-round': shape==='round'}\" [ngStyle]=\"{'padding': title && shape==='normal' ? '0px 14px': ''}\" >\n    <img\n      *ngIf=\"icon\" [ngClass]=\"{'counterAndIconImg': counter >= 0 && icon}\"\n      [width]=\"iconWidth\"\n      [height]=\"iconHeight\"\n      [ngStyle]=\"{'margin-right': title ? '8px': ''}\" [src]=\"icon\" alt=\"icon\">\n    <span *ngIf=\"title\"\n          [ngClass]=\"{'counterOn': counter >= 0 && !icon, 'counterAndIconTxt': counter >= 0 && icon}\"\n    >{{shape==='normal' ? title : ''}}</span>\n    <span *ngIf=\"counter >= 0\" class=\"btnCounter\">{{counter}}</span>\n  </button>\n  <span *ngIf=\"shape==='round'\"\n        [class.fw-bold]=\"boldValue\"\n        class=\"titleBtnRound\"\n  >{{title}}</span>\n</div>\n"]}