From dd162d3327856a39ca7ec51e0662a6eaa1ca7883 Mon Sep 17 00:00:00 2001 From: Alexander Kislov Date: Sat, 30 Apr 2022 17:50:47 +0300 Subject: [PATCH] Fix logic related to tooltip identifier * Fix class names changes --- .../src/lib/ngx-tippy.directive.ts | 36 ++++++++++++------- 1 file changed, 23 insertions(+), 13 deletions(-) diff --git a/projects/ngx-tippy-wrapper/src/lib/ngx-tippy.directive.ts b/projects/ngx-tippy-wrapper/src/lib/ngx-tippy.directive.ts index 8bb6d29..4117e2f 100644 --- a/projects/ngx-tippy-wrapper/src/lib/ngx-tippy.directive.ts +++ b/projects/ngx-tippy-wrapper/src/lib/ngx-tippy.directive.ts @@ -27,7 +27,6 @@ export class NgxTippyDirective implements OnInit, OnDestroy { @Input() tippyClassName?: string; private tippyInstance: NgxTippyInstance | undefined; - private uniqueId!: string; private cachedInstances = new Map(); constructor( @@ -65,13 +64,16 @@ export class NgxTippyDirective implements OnInit, OnDestroy { const viewRef = this.ngxViewService.getViewRefInstance(this.ngxTippy, this.tippyName); const tippyElement = viewRef.getElement(); - const ti = tippy(tippyTarget, { ...(this.tippyProps || {}), ...(tippyElement && { content: tippyElement }) }); - const tippyName = this.tippyName || `tippy-${ti.id}`; + const tInstance = tippy(tippyTarget, { + ...(this.tippyProps || {}), + ...(tippyElement && { content: tippyElement }), + }); + this.tippyName = this.tippyName || `tippy-${tInstance.id}`; setTemplateVisible(tippyElement, this.renderer); - this.setTippyInstance({ tippyTarget, tippyName, viewRef }); + this.setTippyInstance({ tippyTarget, tippyName: this.tippyName, viewRef }); this.setClassName(this.tippyInstance, this.tippyClassName); - this.writeInstancesToStorage(this.tippyInstance, tippyName); + this.writeInstancesToStorage(this.tippyInstance, this.tippyName); } private setTippyInstance({ @@ -96,6 +98,16 @@ export class NgxTippyDirective implements OnInit, OnDestroy { }); } + private removeClassName(tippyInstance: NgxTippyInstance | undefined, className: string | undefined) { + if (!className || !tippyInstance) return; + const classNames = className.split(' '); + + classNames.length && + classNames.forEach(className => { + this.renderer.removeClass(tippyInstance.popper.firstElementChild, className); + }); + } + /** * To manipulate tooltips, write all instances to storage * `tippyName` used as unique key @@ -119,14 +131,15 @@ export class NgxTippyDirective implements OnInit, OnDestroy { if (!tippyInstances || !this.tippyInstance) return; this.deleteEntryInStorage(tippyInstances, previousValue); + this.tippyInstance = { ...this.tippyInstance, tippyName: currentValue }; tippyInstances.set(currentValue, this.tippyInstance); } private handleContentChanges({ currentValue }: SimpleChange) { const tippyInstances = this.cachedTippyInstances(); - if (this.tippyInstance) { - this.ngxTippyService.setContent(this.tippyUniqueIdentifier, currentValue); + if (this.tippyInstance && this.tippyName) { + this.ngxTippyService.setContent(this.tippyName, currentValue); } else { this.initTippy(); } @@ -137,17 +150,14 @@ export class NgxTippyDirective implements OnInit, OnDestroy { } private handlePropsChanges({ currentValue }: SimpleChange) { - this.ngxTippyService.setProps(this.tippyUniqueIdentifier, currentValue); + this.tippyName && this.ngxTippyService.setProps(this.tippyName, currentValue); } - private handleClassChanges({ currentValue }: SimpleChange) { + private handleClassChanges({ previousValue, currentValue }: SimpleChange) { + this.removeClassName(this.tippyInstance, previousValue); this.setClassName(this.tippyInstance, currentValue); } - private get tippyUniqueIdentifier(): string { - return this.tippyName || this.uniqueId; - } - private cachedTippyInstances(): Map | null { const tippyInstances = this.ngxTippyService.getInstances();