UNPKG

lct-components

Version:
164 lines 20.7 kB
import { Directive, HostListener, Input, Output, EventEmitter } from '@angular/core'; import { ModalTooltipComponent } from "./modal-tooltip/modal-tooltip.component"; import { ModalChangeStoreComponent } from './modal/modal-change-store/modal-change-store'; import * as i0 from "@angular/core"; export class ModalTooltipDirective { constructor(viewContainerRef, resolver) { this.viewContainerRef = viewContainerRef; this.resolver = resolver; this.tooltipText = ''; this.version = ''; this.dateVersion = ''; this.country = ''; this.nodes = []; this.stores = []; this.changeNode = new EventEmitter(); this.closeModal = new EventEmitter(); this.openModalChangeNode = new EventEmitter(); this.isMobile = false; this.userId = ''; this.componentRef2 = undefined; } ngOnInit() { const userID = sessionStorage.getItem('userId'); this.formatStore(); this.assingStore(); if (userID !== this.userId) { sessionStorage.removeItem('userId'); sessionStorage.removeItem('storeSelected'); } const storeSelected = sessionStorage.getItem('storeSelected'); this.selectedStore(storeSelected); } formatStore() { this.nodes.forEach(e => { e.node.forEach(nEl => { let obj = new LctNode(e.operator, nEl); this.stores.push(obj); }); }); } ngOnChanges(changes) { var _a, _b; if (((_a = changes.country) === null || _a === void 0 ? void 0 : _a.currentValue) !== ((_b = changes.country) === null || _b === void 0 ? void 0 : _b.previousValue)) { if (this.componentRef2 !== undefined) { console.log('ejecuta limpiza de conponente y abre el modal'); this.viewContainerRef.clear(); this.openModal(); } } } onMouseEnter() { const componentFactory = this.resolver.resolveComponentFactory(ModalTooltipComponent); const componentRef = this.viewContainerRef.createComponent(componentFactory); if (this.tooltipText) { componentRef.instance.nameStore = this.tooltipText; } if (this.version) { componentRef.instance.version = this.version; } if (this.dateVersion) { componentRef.instance.dateVersion = this.dateVersion; } if (this.stores.length > 1) { componentRef.instance.showChangeStore = true; } componentRef.instance.conditional2.subscribe(resp => { if (resp) { if (this.viewContainerRef) { this.viewContainerRef.clear(); this.closeModal.next(true); } } }); componentRef.instance.openModalStore.subscribe(reso => { if (reso) { this.openModal(); } }); } openModal() { const componentFactory = this.resolver.resolveComponentFactory(ModalChangeStoreComponent); this.componentRef2 = this.viewContainerRef.createComponent(componentFactory); if (this.openModalChangeNode) this.openModalChangeNode.next(true); this.componentRef2.instance.widthModalConfig = this.isMobile ? "100%" : '458px'; this.componentRef2.instance.heightModalConfig = this.isMobile ? "100%" : '268px'; if (this.stores) { // Filtra las tiendas en base al pais this.componentRef2.instance.tiendas = this.stores.filter(x => x.country === this.country); } if (this.userId) { this.componentRef2.instance.userId = this.userId; } this.componentRef2.instance.closeModalStore.subscribe(resp => { if (typeof resp.change === 'boolean') { if (this.viewContainerRef) { if (resp.change) { this.assingStore(); } this.changeNode.next(resp.change); this.viewContainerRef.clear(); } } }); } assingStore() { var _a; const storeSelected = sessionStorage.getItem('storeSelected'); if (storeSelected) { this.tooltipText = ((_a = JSON.parse(storeSelected)) === null || _a === void 0 ? void 0 : _a.nodeName) || ''; } } selectedStore(storeSelected) { if (this.stores.length > 1 && !storeSelected) { this.openModal(); } else if (this.stores.length === 1) { this.tooltipText = this.stores[0].nodeName; sessionStorage.setItem('storeSelected', JSON.stringify(this.stores[0])); } else { console.error('You don`t have store'); } } } ModalTooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: ModalTooltipDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive }); ModalTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.1.5", type: ModalTooltipDirective, selector: "[lctModalTooltip]", inputs: { version: "version", dateVersion: "dateVersion", country: "country", nodes: "nodes", isMobile: "isMobile", userId: "userId" }, outputs: { changeNode: "changeNode", closeModal: "closeModal", openModalChangeNode: "openModalChangeNode" }, host: { listeners: { "click": "onMouseEnter()" } }, usesOnChanges: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.5", ngImport: i0, type: ModalTooltipDirective, decorators: [{ type: Directive, args: [{ selector: '[lctModalTooltip]' }] }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { version: [{ type: Input }], dateVersion: [{ type: Input }], country: [{ type: Input }], nodes: [{ type: Input }], changeNode: [{ type: Output }], closeModal: [{ type: Output }], openModalChangeNode: [{ type: Output }], isMobile: [{ type: Input }], userId: [{ type: Input }], onMouseEnter: [{ type: HostListener, args: ["click"] }] } }); export class LctNode { constructor(_operator, _node) { this.nodeName = _node.nodeName; this.nodeId = _node.nodeId; this.country = _operator.country; this.commerce = _operator.commerce; } } ; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-tooltip.directive.js","sourceRoot":"","sources":["../../../../projects/lct-components/src/lib/modal-tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentFactoryResolver,\n  Directive, HostListener,\n  Input,\n  ViewContainerRef,\n  OnInit,\n  Output,\n  EventEmitter,\n  SimpleChanges,\n  ComponentFactory,\n  ComponentRef\n} from '@angular/core';\nimport { ModalTooltipComponent } from \"./modal-tooltip/modal-tooltip.component\";\nimport { ModalChangeStoreComponent } from './modal/modal-change-store/modal-change-store';\n\ninterface Node {\n  nodeName: string;\n  nodeId: string;\n  country: string;\n  commerce: string;\n}\n\n@Directive({\n  selector: '[lctModalTooltip]'\n})\nexport class ModalTooltipDirective implements OnInit {\n\n  constructor(\n    private viewContainerRef: ViewContainerRef,\n    private resolver: ComponentFactoryResolver,\n  ) { }\n\n  tooltipText: string = '';\n  @Input() version?: string = '';\n  @Input() dateVersion: string = '';\n  @Input() country: string = '';\n  @Input() nodes: AccessFilter[] = [];\n  stores: LctNode[] = [];\n  @Output() changeNode = new EventEmitter<boolean>()\n  @Output() closeModal = new EventEmitter<boolean>()\n  @Output() openModalChangeNode = new EventEmitter<boolean>()\n  @Input() isMobile: boolean = false;\n  @Input() userId: string = '';\n  componentRef2: ComponentRef<ModalChangeStoreComponent> | undefined = undefined;\n\n  ngOnInit(): void {\n    const userID = sessionStorage.getItem('userId');\n    this.formatStore();\n    this.assingStore();\n    if (userID !== this.userId) {\n      sessionStorage.removeItem('userId');\n      sessionStorage.removeItem('storeSelected');\n    }\n    const storeSelected = sessionStorage.getItem('storeSelected');\n    this.selectedStore(storeSelected);\n  }\n\n  formatStore() {\n    this.nodes.forEach(e => {\n      e.node.forEach(nEl => {\n        let obj = new LctNode(e.operator, nEl);\n        this.stores.push(obj);\n      });\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n\n    if (changes.country?.currentValue !== changes.country?.previousValue) {\n      if (this.componentRef2 !== undefined) {\n        console.log('ejecuta limpiza de conponente y abre el modal');\n        this.viewContainerRef.clear();\n        this.openModal();\n      }\n    }\n  }\n\n  @HostListener(\"click\") onMouseEnter(): void {\n    const componentFactory = this.resolver.resolveComponentFactory(ModalTooltipComponent);\n    const componentRef = this.viewContainerRef.createComponent(componentFactory);\n\n    if (this.tooltipText) {\n      componentRef.instance.nameStore = this.tooltipText;\n    }\n    if (this.version) {\n      componentRef.instance.version = this.version;\n    }\n    if (this.dateVersion) {\n      componentRef.instance.dateVersion = this.dateVersion;\n    }\n    if (this.stores.length > 1) {\n      componentRef.instance.showChangeStore = true;\n    }\n    componentRef.instance.conditional2.subscribe(resp => {\n      if (resp) {\n        if (this.viewContainerRef) {\n          this.viewContainerRef.clear();\n          this.closeModal.next(true);\n        }\n      }\n    });\n\n    componentRef.instance.openModalStore.subscribe(reso => {\n      if (reso) {\n        this.openModal();\n      }\n    });\n  }\n\n  openModal() {\n    const componentFactory = this.resolver.resolveComponentFactory(ModalChangeStoreComponent);\n    this.componentRef2 = this.viewContainerRef.createComponent(componentFactory);\n\n    if(this.openModalChangeNode)this.openModalChangeNode.next(true);\n    this.componentRef2.instance.widthModalConfig = this.isMobile ? \"100%\" : '458px';\n    this.componentRef2.instance.heightModalConfig = this.isMobile ? \"100%\" : '268px';\n\n    if (this.stores) {\n      // Filtra las tiendas en base al pais\n      this.componentRef2.instance.tiendas = this.stores.filter(x => x.country === this.country);\n    }\n    if (this.userId) {\n      this.componentRef2.instance.userId = this.userId;\n    }\n    this.componentRef2.instance.closeModalStore.subscribe(resp => {\n      if (typeof resp.change === 'boolean') {\n        if (this.viewContainerRef) {\n          if (resp.change) {\n            this.assingStore();\n          }\n          this.changeNode.next(resp.change);\n          this.viewContainerRef.clear();\n        }\n      }\n    })\n  }\n\n  assingStore() {\n    const storeSelected = sessionStorage.getItem('storeSelected');\n    if (storeSelected) {\n      this.tooltipText = JSON.parse(storeSelected)?.nodeName || '';\n    }\n  }\n\n  private selectedStore(storeSelected: string | null) {\n    if (this.stores.length > 1 && !storeSelected) {\n      this.openModal();\n    } else if (this.stores.length === 1) {\n      this.tooltipText = this.stores[0].nodeName;\n      sessionStorage.setItem('storeSelected', JSON.stringify(this.stores[0]));\n    } else {\n      console.error('You don`t have store');\n    }\n  }\n}\n\ninterface Operator {\n  name: string;\n  id: string;\n  country: string;\n  commerce: string;\n}\ninterface ANode {\n  nodeId: string;\n  nodeName: string;\n}\ninterface AccessFilter {\n  operator: Operator;\n  node: ANode[];\n}\n\nexport class LctNode implements Node {\n  nodeName: string;\n  nodeId: string;\n  country: string;\n  commerce: string;\n  constructor(_operator: any, _node: any) {\n    this.nodeName = _node.nodeName;\n    this.nodeId = _node.nodeId;\n    this.country = _operator.country;\n    this.commerce = _operator.commerce;\n  }\n};"]}