@agorapulse/ui-components 13.1.9 → 13.1.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,9 +4,9 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "./tooltip-neo.service";
5
5
  import * as i2 from "@angular/common";
6
6
  export class TooltipNeoComponent {
7
- constructor(_elementRef, _tooltipNeoService) {
8
- this._elementRef = _elementRef;
9
- this._tooltipNeoService = _tooltipNeoService;
7
+ constructor(elementRef, tooltipNeoService) {
8
+ this.elementRef = elementRef;
9
+ this.tooltipNeoService = tooltipNeoService;
10
10
  }
11
11
  ngOnInit() {
12
12
  this.params.borderColor
@@ -14,8 +14,8 @@ export class TooltipNeoComponent {
14
14
  : this.border = undefined;
15
15
  }
16
16
  onClickOutside(event) {
17
- if (!this._elementRef.nativeElement.contains(event.target)) {
18
- this._tooltipNeoService.clickOutside$.next();
17
+ if (!this.elementRef.nativeElement.contains(event.target)) {
18
+ this.tooltipNeoService.dispose$.next();
19
19
  }
20
20
  }
21
21
  }
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
46
46
  type: HostListener,
47
47
  args: ['document:click', ['$event']]
48
48
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvdG9vbHRpcC1uZW8vdG9vbHRpcC1uZW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvdG9vbHRpcC1uZW8vdG9vbHRpcC1uZW8uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxLQUFLLEVBQ0wsdUJBQXVCLEVBQ3ZCLFlBQVksR0FHZixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7QUFtQjFFLE1BQU0sT0FBTyxtQkFBbUI7SUFLNUIsWUFDWSxXQUF1QixFQUN2QixrQkFBcUM7UUFEckMsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFDdkIsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFtQjtJQUVqRCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVztZQUNuQixDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxhQUFhLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFO1lBQ3RELENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLFNBQVMsQ0FBQztJQUNsQyxDQUFDO0lBR0QsY0FBYyxDQUFDLEtBQUs7UUFDaEIsSUFBRyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdkQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNoRDtJQUNMLENBQUM7O3NKQXRCUSxtQkFBbUI7MElBQW5CLG1CQUFtQix5SkMzQmhDLDg4QkF5QkEsNDZPRFJnQjtRQUNSLE9BQU8sQ0FBQyxZQUFZLEVBQUU7WUFDbEIsVUFBVSxDQUFDLFFBQVEsRUFBRTtnQkFDakIsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUNyQixPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO2FBQ3RDLENBQUM7WUFDRixVQUFVLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDOUQsQ0FBQztLQUNMOzJGQUVRLG1CQUFtQjtrQkFmL0IsU0FBUzsrQkFDSSxnQkFBZ0IsbUJBQ1QsdUJBQXVCLENBQUMsTUFBTSxjQUduQzt3QkFDUixPQUFPLENBQUMsWUFBWSxFQUFFOzRCQUNsQixVQUFVLENBQUMsUUFBUSxFQUFFO2dDQUNqQixLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7Z0NBQ3JCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7NkJBQ3RDLENBQUM7NEJBQ0YsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO3lCQUM5RCxDQUFDO3FCQUNMO2lJQUdRLE1BQU07c0JBQWQsS0FBSztnQkFpQk4sY0FBYztzQkFEYixZQUFZO3VCQUFDLGdCQUFnQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgSW5wdXQsXG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgSG9zdExpc3RlbmVyLFxuICAgIEVsZW1lbnRSZWYsXG4gICAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGFuaW1hdGUsIHN0eWxlLCB0cmFuc2l0aW9uLCB0cmlnZ2VyIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBUb29sdGlwTmVvUGFyYW1zIH0gZnJvbSAnLi90b29sdGlwLW5lby5tb2RlbCc7XG5pbXBvcnQge1Rvb2x0aXBOZW9TZXJ2aWNlfSBmcm9tIFwiLi90b29sdGlwLW5lby5zZXJ2aWNlXCI7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYXAtdG9vbHRpcC1uZW8nLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHN0eWxlVXJsczogWycuL3Rvb2x0aXAtbmVvLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Rvb2x0aXAtbmVvLmNvbXBvbmVudC5odG1sJyxcbiAgICBhbmltYXRpb25zOiBbXG4gICAgICAgIHRyaWdnZXIoJ25lb1Rvb2x0aXAnLCBbXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbXG4gICAgICAgICAgICAgICAgc3R5bGUoeyBvcGFjaXR5OiAwIH0pLFxuICAgICAgICAgICAgICAgIGFuaW1hdGUoMjAwLCBzdHlsZSh7IG9wYWNpdHk6IDEgfSkpXG4gICAgICAgICAgICBdKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFthbmltYXRlKDIwMCwgc3R5bGUoeyBvcGFjaXR5OiAwIH0pKV0pXG4gICAgICAgIF0pXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwTmVvQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBwYXJhbXM6IFRvb2x0aXBOZW9QYXJhbXM7XG5cbiAgICBib3JkZXI6IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgICAgICBwcml2YXRlIF90b29sdGlwTmVvU2VydmljZTogVG9vbHRpcE5lb1NlcnZpY2UsXG4gICAgKSB7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMucGFyYW1zLmJvcmRlckNvbG9yXG4gICAgICAgICAgICA/IHRoaXMuYm9yZGVyID0gYHNvbGlkIDFweCAke3RoaXMucGFyYW1zLmJvcmRlckNvbG9yfWBcbiAgICAgICAgICAgIDogdGhpcy5ib3JkZXIgPSB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignZG9jdW1lbnQ6Y2xpY2snLCBbJyRldmVudCddKVxuICAgIG9uQ2xpY2tPdXRzaWRlKGV2ZW50KSB7XG4gICAgICAgIGlmKCF0aGlzLl9lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0KSkge1xuICAgICAgICAgICAgdGhpcy5fdG9vbHRpcE5lb1NlcnZpY2UuY2xpY2tPdXRzaWRlJC5uZXh0KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2IEBuZW9Ub29sdGlwIFtuZ1N3aXRjaF09XCJwYXJhbXMuY29udGVudFR5cGVcIlxuICAgICBjbGFzcz1cInRvb2x0aXAge3twYXJhbXMubWF4V2lkdGh9fVwiXG4gICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cInBhcmFtcy5iYWNrZ3JvdW5kQ29sb3JcIlxuICAgICBbc3R5bGUuYm9yZGVyXT1cImJvcmRlclwiXG4gICAgPlxuICAgIDxkaXYgKm5nSWY9XCJwYXJhbXMuZGlzcGxheUFycm93XCJcbiAgICAgICAgIGNsYXNzPVwiYXJyb3ctdG9vbHRpcCB7e3BhcmFtcy5wb3NpdGlvbn19XCJcbiAgICAgICAgIFtjbGFzcy5ib3JkZXJdPVwiISFwYXJhbXMuYm9yZGVyQ29sb3JcIlxuICAgICAgICAgW3N0eWxlLmJhY2tncm91bmRdPVwicGFyYW1zLmJhY2tncm91bmRDb2xvclwiXG4gICAgICAgICBbc3R5bGUuYm9yZGVyVG9wXT1cImJvcmRlclwiXG4gICAgICAgICBbc3R5bGUuYm9yZGVyUmlnaHRdPVwiYm9yZGVyXCJcbiAgICA+PC9kaXY+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInBhcmFtcy50aXRsZVwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dCB0aXRsZVwiPnt7cGFyYW1zLnRpdGxlfX08L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCIndGV4dCdcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInBhcmFtcy5jb250ZW50XCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dCBjb250ZW50XCI+e3twYXJhbXMuY29udGVudH19PC9kaXY+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIid0ZW1wbGF0ZSdcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInBhcmFtcy5jb250ZW50XCI+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvdG9vbHRpcC1uZW8vdG9vbHRpcC1uZW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvdG9vbHRpcC1uZW8vdG9vbHRpcC1uZW8uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxLQUFLLEVBQ0wsdUJBQXVCLEVBQ3ZCLFlBQVksR0FHZixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7QUFtQjFFLE1BQU0sT0FBTyxtQkFBbUI7SUFLNUIsWUFDWSxVQUFzQixFQUN0QixpQkFBb0M7UUFEcEMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUN0QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO0lBRWhELENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXO1lBQ25CLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLGFBQWEsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUU7WUFDdEQsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO0lBQ2xDLENBQUM7SUFHRCxjQUFjLENBQUMsS0FBSztRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN2RCxJQUFJLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQzFDO0lBQ0wsQ0FBQzs7c0pBdEJRLG1CQUFtQjswSUFBbkIsbUJBQW1CLHlKQzNCaEMsODhCQXlCQSw0Nk9EUmdCO1FBQ1IsT0FBTyxDQUFDLFlBQVksRUFBRTtZQUNsQixVQUFVLENBQUMsUUFBUSxFQUFFO2dCQUNqQixLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7Z0JBQ3JCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7YUFDdEMsQ0FBQztZQUNGLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUM5RCxDQUFDO0tBQ0w7MkZBRVEsbUJBQW1CO2tCQWYvQixTQUFTOytCQUNJLGdCQUFnQixtQkFDVCx1QkFBdUIsQ0FBQyxNQUFNLGNBR25DO3dCQUNSLE9BQU8sQ0FBQyxZQUFZLEVBQUU7NEJBQ2xCLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0NBQ2pCLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQztnQ0FDckIsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQzs2QkFDdEMsQ0FBQzs0QkFDRixVQUFVLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzlELENBQUM7cUJBQ0w7aUlBR1EsTUFBTTtzQkFBZCxLQUFLO2dCQWlCTixjQUFjO3NCQURiLFlBQVk7dUJBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbXBvbmVudCxcbiAgICBJbnB1dCxcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBIb3N0TGlzdGVuZXIsXG4gICAgRWxlbWVudFJlZixcbiAgICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgYW5pbWF0ZSwgc3R5bGUsIHRyYW5zaXRpb24sIHRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IFRvb2x0aXBOZW9QYXJhbXMgfSBmcm9tICcuL3Rvb2x0aXAtbmVvLm1vZGVsJztcbmltcG9ydCB7VG9vbHRpcE5lb1NlcnZpY2V9IGZyb20gJy4vdG9vbHRpcC1uZW8uc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYXAtdG9vbHRpcC1uZW8nLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHN0eWxlVXJsczogWycuL3Rvb2x0aXAtbmVvLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Rvb2x0aXAtbmVvLmNvbXBvbmVudC5odG1sJyxcbiAgICBhbmltYXRpb25zOiBbXG4gICAgICAgIHRyaWdnZXIoJ25lb1Rvb2x0aXAnLCBbXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbXG4gICAgICAgICAgICAgICAgc3R5bGUoeyBvcGFjaXR5OiAwIH0pLFxuICAgICAgICAgICAgICAgIGFuaW1hdGUoMjAwLCBzdHlsZSh7IG9wYWNpdHk6IDEgfSkpXG4gICAgICAgICAgICBdKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFthbmltYXRlKDIwMCwgc3R5bGUoeyBvcGFjaXR5OiAwIH0pKV0pXG4gICAgICAgIF0pXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwTmVvQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBwYXJhbXM6IFRvb2x0aXBOZW9QYXJhbXM7XG5cbiAgICBib3JkZXI6IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXG4gICAgICAgIHByaXZhdGUgdG9vbHRpcE5lb1NlcnZpY2U6IFRvb2x0aXBOZW9TZXJ2aWNlLFxuICAgICkge1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnBhcmFtcy5ib3JkZXJDb2xvclxuICAgICAgICAgICAgPyB0aGlzLmJvcmRlciA9IGBzb2xpZCAxcHggJHt0aGlzLnBhcmFtcy5ib3JkZXJDb2xvcn1gXG4gICAgICAgICAgICA6IHRoaXMuYm9yZGVyID0gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmNsaWNrJywgWyckZXZlbnQnXSlcbiAgICBvbkNsaWNrT3V0c2lkZShldmVudCk6IHZvaWR7XG4gICAgICAgIGlmICghdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0KSkge1xuICAgICAgICAgICAgdGhpcy50b29sdGlwTmVvU2VydmljZS5kaXNwb3NlJC5uZXh0KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2IEBuZW9Ub29sdGlwIFtuZ1N3aXRjaF09XCJwYXJhbXMuY29udGVudFR5cGVcIlxuICAgICBjbGFzcz1cInRvb2x0aXAge3twYXJhbXMubWF4V2lkdGh9fVwiXG4gICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cInBhcmFtcy5iYWNrZ3JvdW5kQ29sb3JcIlxuICAgICBbc3R5bGUuYm9yZGVyXT1cImJvcmRlclwiXG4gICAgPlxuICAgIDxkaXYgKm5nSWY9XCJwYXJhbXMuZGlzcGxheUFycm93XCJcbiAgICAgICAgIGNsYXNzPVwiYXJyb3ctdG9vbHRpcCB7e3BhcmFtcy5wb3NpdGlvbn19XCJcbiAgICAgICAgIFtjbGFzcy5ib3JkZXJdPVwiISFwYXJhbXMuYm9yZGVyQ29sb3JcIlxuICAgICAgICAgW3N0eWxlLmJhY2tncm91bmRdPVwicGFyYW1zLmJhY2tncm91bmRDb2xvclwiXG4gICAgICAgICBbc3R5bGUuYm9yZGVyVG9wXT1cImJvcmRlclwiXG4gICAgICAgICBbc3R5bGUuYm9yZGVyUmlnaHRdPVwiYm9yZGVyXCJcbiAgICA+PC9kaXY+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInBhcmFtcy50aXRsZVwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dCB0aXRsZVwiPnt7cGFyYW1zLnRpdGxlfX08L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ1N3aXRjaENhc2U9XCIndGV4dCdcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInBhcmFtcy5jb250ZW50XCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dCBjb250ZW50XCI+e3twYXJhbXMuY29udGVudH19PC9kaXY+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIid0ZW1wbGF0ZSdcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInBhcmFtcy5jb250ZW50XCI+XG4gICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
@@ -1,6 +1,6 @@
1
1
  import { Directive, HostListener, Input, } from '@angular/core';
2
2
  import { ComponentPortal } from '@angular/cdk/portal';
3
- import { fromEvent, merge, of, Subject } from 'rxjs';
3
+ import { fromEvent, of, Subject } from 'rxjs';
4
4
  import { delay, switchMap, takeUntil } from 'rxjs/operators';
5
5
  import { tooltipNeoPositions } from './tooltip-neo.const';
6
6
  import { TooltipNeoComponent } from './tooltip-neo.component';
@@ -14,24 +14,35 @@ export class TooltipNeoDirective {
14
14
  this.overlayPositionBuilder = overlayPositionBuilder;
15
15
  this.tooltipNeoService = tooltipNeoService;
16
16
  this.destroy$ = new Subject();
17
- this.hide$ = new Subject();
17
+ this.display$ = new Subject();
18
18
  this.mouseEntered = false;
19
- this.show$ = new Subject();
20
19
  }
21
20
  static enableTooltip(content, contentType, display) {
22
21
  return !!content && !!contentType && !!display;
23
22
  }
23
+ /**
24
+ * To fix issue on inbox virtual scroller, it's a manual cleaner at DOM level
25
+ * @private
26
+ */
27
+ static cleanUpPersistentTooltip() {
28
+ const tooltips = document.getElementsByTagName('ap-tooltip-neo');
29
+ if (tooltips) {
30
+ Array.from(tooltips).forEach(tooltip => {
31
+ tooltip.parentElement.parentElement.remove();
32
+ });
33
+ }
34
+ }
24
35
  ngOnChanges(changes) {
25
36
  if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {
26
37
  this.setSettings();
27
- this.allowDisplay ? this.show$.next(true) : this.hide$.next(false);
38
+ this.display$.next(this.allowDisplay);
28
39
  }
29
40
  }
30
41
  ngOnInit() {
31
42
  this.initiateTooltip();
32
43
  }
33
44
  ngOnDestroy() {
34
- this.detach();
45
+ this.dispose();
35
46
  this.destroy$.next();
36
47
  this.destroy$.complete();
37
48
  }
@@ -51,12 +62,12 @@ export class TooltipNeoDirective {
51
62
  const maxWidth = 'full';
52
63
  const position = 'top';
53
64
  const title = '';
54
- this.params = { content, backgroundColor, borderColor, contentType, position, display, displayArrow, title, maxWidth };
65
+ this.params = { content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title };
55
66
  this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);
56
67
  }
57
68
  }
58
69
  initiateTooltip() {
59
- merge(this.hide$, this.show$)
70
+ this.display$
60
71
  .pipe(switchMap(bool => {
61
72
  if (!bool) {
62
73
  return of(bool);
@@ -66,7 +77,8 @@ export class TooltipNeoDirective {
66
77
  .subscribe(bool => {
67
78
  if (bool) {
68
79
  this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')
69
- .subscribe(() => this.detach());
80
+ .subscribe(() => this.dispose());
81
+ TooltipNeoDirective.cleanUpPersistentTooltip();
70
82
  const positionStrategy = this.overlayPositionBuilder
71
83
  .flexibleConnectedTo(this.elementRef)
72
84
  .withPositions([tooltipNeoPositions[this.params.position]]);
@@ -76,29 +88,40 @@ export class TooltipNeoDirective {
76
88
  tooltipRef.instance.params = this.params;
77
89
  }
78
90
  else {
79
- this.detach();
91
+ this.dispose();
80
92
  }
81
93
  });
82
- this.tooltipNeoService.clickOutside$
94
+ this.tooltipNeoService.dispose$
83
95
  .pipe(takeUntil(this.destroy$))
84
- .subscribe(() => this.hide$.next(false));
96
+ .subscribe(() => {
97
+ this.display$.next(false);
98
+ });
85
99
  }
86
- detach() {
87
- this.overlayRef && this.overlayRef.hasAttached() && this.overlayRef.detach();
88
- this.elementRefMouseLeave$ && this.elementRefMouseLeave$.unsubscribe();
100
+ dispose() {
101
+ if (this.overlayRef) {
102
+ this.overlayRef.dispose();
103
+ }
104
+ if (this.elementRefMouseLeave$) {
105
+ this.elementRefMouseLeave$.unsubscribe();
106
+ }
89
107
  }
90
108
  onMouseEnter() {
91
109
  this.setSettings();
92
110
  this.mouseEntered = true;
93
- this.allowDisplay && this.params && this.show$.next(true);
111
+ if (this.allowDisplay && this.params) {
112
+ this.display$.next(true);
113
+ }
94
114
  }
95
115
  onMouseLeave() {
96
116
  this.mouseEntered = false;
97
- this.hide$.next(false);
117
+ this.display$.next(false);
118
+ }
119
+ onClick() {
120
+ this.display$.next(false);
98
121
  }
99
122
  }
100
123
  /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, deps: [{ token: i0.ElementRef }, { token: i1.Overlay }, { token: i1.OverlayPositionBuilder }, { token: i2.TooltipNeoService }], target: i0.ɵɵFactoryTarget.Directive });
101
- /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, usesOnChanges: true, ngImport: i0 });
124
+ /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
102
125
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, decorators: [{
103
126
  type: Directive,
104
127
  args: [{ selector: '[apTooltipNeo]' }]
@@ -110,5 +133,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
110
133
  }], onMouseLeave: [{
111
134
  type: HostListener,
112
135
  args: ['mouseleave']
136
+ }], onClick: [{
137
+ type: HostListener,
138
+ args: ['click']
113
139
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-neo.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/tooltip-neo/tooltip-neo.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Input, OnChanges,\n    OnDestroy,\n    OnInit, SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport {ComponentPortal} from '@angular/cdk/portal';\nimport {Overlay, OverlayPositionBuilder, OverlayRef} from '@angular/cdk/overlay';\nimport {fromEvent, merge, of, Subject, Subscription} from 'rxjs';\nimport {delay, switchMap, takeUntil} from 'rxjs/operators';\nimport {tooltipNeoPositions} from './tooltip-neo.const';\nimport {TooltipNeoParams} from './tooltip-neo.model';\nimport {TooltipNeoService} from './tooltip-neo.service';\nimport {TooltipNeoComponent} from './tooltip-neo.component';\n\n@Directive({selector: '[apTooltipNeo]'})\nexport class TooltipNeoDirective implements OnInit, OnDestroy, OnChanges {\n    @Input() apTooltipNeo: string | TooltipNeoParams;\n\n    private allowDisplay: boolean;\n    private destroy$: Subject<void> = new Subject<void>();\n    private hide$: Subject<boolean> = new Subject<boolean>();\n    private mouseEntered = false;\n    private overlayRef: OverlayRef;\n    private params: TooltipNeoParams;\n    private show$: Subject<boolean> = new Subject<boolean>();\n    private elementRefMouseLeave$: Subscription;\n\n    static enableTooltip(content: string | TemplateRef<any>, contentType: string, display: boolean): boolean {\n        return !!content && !!contentType && !!display;\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private tooltipNeoService: TooltipNeoService,\n    ) {\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {\n            this.setSettings();\n            this.allowDisplay ? this.show$.next(true) : this.hide$.next(false);\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateTooltip();\n    }\n\n    ngOnDestroy(): void {\n        this.detach();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private setSettings(): void {\n        if (typeof this.apTooltipNeo === 'object') {\n            const {\n                content,\n                backgroundColor = '#ffffff',\n                borderColor,\n                contentType = 'text',\n                display = true,\n                displayArrow = true,\n                maxWidth = 'full',\n                position = 'top',\n                title = ''\n            } = this.apTooltipNeo as TooltipNeoParams;\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n        if (typeof this.apTooltipNeo === 'string') {\n            const content = this.apTooltipNeo as string;\n            const backgroundColor = '#ffffff';\n            const borderColor = undefined;\n            const contentType = 'text';\n            const display = true;\n            const displayArrow = true;\n            const maxWidth = 'full';\n            const position = 'top';\n            const title = '';\n            this.params = {content, backgroundColor, borderColor, contentType, position, display, displayArrow, title, maxWidth};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n    }\n\n    private initiateTooltip(): void {\n        merge(this.hide$, this.show$)\n            .pipe(\n                switchMap(bool => {\n                    if (!bool) {\n                        return of(bool);\n                    }\n                    return of(bool).pipe(delay(200));\n                }),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(bool => {\n                if (bool) {\n                    this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')\n                        .subscribe(() => this.detach());\n                    const positionStrategy = this.overlayPositionBuilder\n                        .flexibleConnectedTo(this.elementRef)\n                        .withPositions([tooltipNeoPositions[this.params.position]]);\n                    const scrollStrategy = this.overlay.scrollStrategies.close();\n                    this.overlayRef = this.overlay.create({positionStrategy, scrollStrategy});\n                    const tooltipRef: ComponentRef<TooltipNeoComponent> = this.overlayRef.attach(new ComponentPortal(TooltipNeoComponent));\n                    tooltipRef.instance.params = this.params;\n                } else {\n                    this.detach();\n                }\n            });\n        this.tooltipNeoService.clickOutside$\n            .pipe(\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => this.hide$.next(false));\n    }\n\n    private detach(): void {\n        this.overlayRef && this.overlayRef.hasAttached() && this.overlayRef.detach();\n        this.elementRefMouseLeave$ && this.elementRefMouseLeave$.unsubscribe();\n    }\n\n    @HostListener('mouseenter')\n    onMouseEnter(): void {\n        this.setSettings();\n        this.mouseEntered = true;\n        this.allowDisplay && this.params && this.show$.next(true);\n    }\n\n    @HostListener('mouseleave')\n    onMouseLeave(): void {\n        this.mouseEntered = false;\n        this.hide$.next(false);\n    }\n}\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-neo.directive.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/tooltip-neo/tooltip-neo.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentRef,\n    Directive,\n    ElementRef,\n    HostListener,\n    Input, OnChanges,\n    OnDestroy,\n    OnInit, SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport {ComponentPortal} from '@angular/cdk/portal';\nimport {Overlay, OverlayPositionBuilder, OverlayRef} from '@angular/cdk/overlay';\nimport {fromEvent, of, Subject, Subscription} from 'rxjs';\nimport {delay, switchMap, takeUntil} from 'rxjs/operators';\nimport {tooltipNeoPositions} from './tooltip-neo.const';\nimport {TooltipNeoParams} from './tooltip-neo.model';\nimport {TooltipNeoService} from './tooltip-neo.service';\nimport {TooltipNeoComponent} from './tooltip-neo.component';\n\n@Directive({selector: '[apTooltipNeo]'})\nexport class TooltipNeoDirective implements OnInit, OnDestroy, OnChanges {\n\n    @Input() apTooltipNeo: string | TooltipNeoParams;\n\n    private allowDisplay: boolean;\n    private destroy$: Subject<void> = new Subject<void>();\n    private display$: Subject<boolean> = new Subject<boolean>();\n    private mouseEntered = false;\n    private overlayRef: OverlayRef;\n    private params: TooltipNeoParams;\n    private elementRefMouseLeave$: Subscription;\n\n    static enableTooltip(content: string | TemplateRef<any>, contentType: string, display: boolean): boolean {\n        return !!content && !!contentType && !!display;\n    }\n\n    /**\n     * To fix issue on inbox virtual scroller, it's a manual cleaner at DOM level\n     * @private\n     */\n    private static cleanUpPersistentTooltip(): void {\n        const tooltips = document.getElementsByTagName('ap-tooltip-neo');\n        if (tooltips) {\n            Array.from(tooltips).forEach(tooltip => {\n                tooltip.parentElement.parentElement.remove();\n            });\n        }\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private overlay: Overlay,\n        private overlayPositionBuilder: OverlayPositionBuilder,\n        private tooltipNeoService: TooltipNeoService,\n    ) {\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if ((changes?.apTooltipNeo?.currentValue?.display || changes?.apTooltipNeo?.currentValue?.position) && this.mouseEntered) {\n            this.setSettings();\n            this.display$.next(this.allowDisplay);\n        }\n    }\n\n    ngOnInit(): void {\n        this.initiateTooltip();\n    }\n\n    ngOnDestroy(): void {\n        this.dispose();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private setSettings(): void {\n        if (typeof this.apTooltipNeo === 'object') {\n            const {\n                content,\n                backgroundColor = '#ffffff',\n                borderColor,\n                contentType = 'text',\n                display = true,\n                displayArrow = true,\n                maxWidth = 'full',\n                position = 'top',\n                title = ''\n            } = this.apTooltipNeo as TooltipNeoParams;\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n        if (typeof this.apTooltipNeo === 'string') {\n            const content = this.apTooltipNeo as string;\n            const backgroundColor = '#ffffff';\n            const borderColor = undefined;\n            const contentType = 'text';\n            const display = true;\n            const displayArrow = true;\n            const maxWidth = 'full';\n            const position = 'top';\n            const title = '';\n            this.params = {content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title};\n            this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);\n        }\n    }\n\n    private initiateTooltip(): void {\n        this.display$\n            .pipe(\n                switchMap(bool => {\n                    if (!bool) {\n                        return of(bool);\n                    }\n                    return of(bool).pipe(delay(200));\n                }),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(bool => {\n                if (bool) {\n                    this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')\n                        .subscribe(() => this.dispose());\n                    TooltipNeoDirective.cleanUpPersistentTooltip();\n                    const positionStrategy = this.overlayPositionBuilder\n                        .flexibleConnectedTo(this.elementRef)\n                        .withPositions([tooltipNeoPositions[this.params.position]]);\n                    const scrollStrategy = this.overlay.scrollStrategies.close();\n                    this.overlayRef = this.overlay.create({positionStrategy, scrollStrategy});\n                    const tooltipRef: ComponentRef<TooltipNeoComponent> = this.overlayRef.attach(new ComponentPortal(TooltipNeoComponent));\n                    tooltipRef.instance.params = this.params;\n                } else {\n                    this.dispose();\n                }\n            });\n        this.tooltipNeoService.dispose$\n            .pipe(\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.display$.next(false);\n            });\n    }\n\n    private dispose(): void {\n        if (this.overlayRef) {\n            this.overlayRef.dispose();\n        }\n        if (this.elementRefMouseLeave$) {\n            this.elementRefMouseLeave$.unsubscribe();\n        }\n    }\n\n    @HostListener('mouseenter')\n    onMouseEnter(): void {\n        this.setSettings();\n        this.mouseEntered = true;\n        if (this.allowDisplay && this.params) {\n            this.display$.next(true);\n        }\n    }\n\n    @HostListener('mouseleave')\n    onMouseLeave(): void {\n        this.mouseEntered = false;\n        this.display$.next(false);\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        this.display$.next(false);\n    }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi90b29sdGlwLW5lby90b29sdGlwLW5lby5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUZW1wbGF0ZVJlZn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUb29sdGlwTmVvUGFyYW1zIHtcbiAgICBjb250ZW50OiBzdHJpbmcgfCBUZW1wbGF0ZVJlZjxhbnk+O1xuICAgIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgICBib3JkZXJDb2xvcj86IHN0cmluZztcbiAgICBjb250ZW50VHlwZT86ICd0ZXh0JyB8ICd0ZW1wbGF0ZSdcbiAgICBkaXNwbGF5PzogYm9vbGVhbjtcbiAgICBkaXNwbGF5QXJyb3c/OiBib29sZWFuO1xuICAgIG1heFdpZHRoPzogJ21lZGl1bScgfCAnZnVsbCc7XG4gICAgcG9zaXRpb24/OiAndG9wTGVmdCcgfCAndG9wJyB8ICd0b3BSaWdodCcgfCAnbGVmdCcgfCAncmlnaHQnIHwgJ2JvdHRvbUxlZnQnIHwgJ2JvdHRvbScgfCAnYm90dG9tUmlnaHQnO1xuICAgIHRpdGxlPzogc3RyaW5nO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8ubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi90b29sdGlwLW5lby90b29sdGlwLW5lby5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUZW1wbGF0ZVJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVG9vbHRpcE5lb1BhcmFtcyB7XG4gICAgY29udGVudDogc3RyaW5nIHwgVGVtcGxhdGVSZWY8YW55PjtcbiAgICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gICAgYm9yZGVyQ29sb3I/OiBzdHJpbmc7XG4gICAgY29udGVudFR5cGU/OiAndGV4dCcgfCAndGVtcGxhdGUnO1xuICAgIGRpc3BsYXk/OiBib29sZWFuO1xuICAgIGRpc3BsYXlBcnJvdz86IGJvb2xlYW47XG4gICAgbWF4V2lkdGg/OiAnbWVkaXVtJyB8ICdmdWxsJztcbiAgICBwb3NpdGlvbj86ICd0b3BMZWZ0JyB8ICd0b3AnIHwgJ3RvcFJpZ2h0JyB8ICdsZWZ0JyB8ICdyaWdodCcgfCAnYm90dG9tTGVmdCcgfCAnYm90dG9tJyB8ICdib3R0b21SaWdodCc7XG4gICAgdGl0bGU/OiBzdHJpbmc7XG59XG4iXX0=
@@ -3,7 +3,7 @@ import { Subject } from 'rxjs';
3
3
  import * as i0 from "@angular/core";
4
4
  export class TooltipNeoService {
5
5
  constructor() {
6
- this.clickOutside$ = new Subject();
6
+ this.dispose$ = new Subject();
7
7
  }
8
8
  }
9
9
  /** @nocollapse */ /** @nocollapse */ TooltipNeoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
@@ -14,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
14
14
  providedIn: 'root'
15
15
  }]
16
16
  }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9zcmMvbGliL3Rvb2x0aXAtbmVvL3Rvb2x0aXAtbmVvLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUs3QixNQUFNLE9BQU8saUJBQWlCO0lBSDlCO1FBSVcsa0JBQWEsR0FBa0IsSUFBSSxPQUFPLEVBQVEsQ0FBQztLQUM3RDs7b0pBRlksaUJBQWlCO3dKQUFqQixpQkFBaUIsY0FGZCxNQUFNOzJGQUVULGlCQUFpQjtrQkFIN0IsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTdWJqZWN0fSBmcm9tICdyeGpzJztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwTmVvU2VydmljZSB7XG4gICAgcHVibGljIGNsaWNrT3V0c2lkZSQ6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdDx2b2lkPigpO1xufVxuIl19
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC1uZW8uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9zcmMvbGliL3Rvb2x0aXAtbmVvL3Rvb2x0aXAtbmVvLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUs3QixNQUFNLE9BQU8saUJBQWlCO0lBSDlCO1FBSVcsYUFBUSxHQUFrQixJQUFJLE9BQU8sRUFBUSxDQUFDO0tBQ3hEOztvSkFGWSxpQkFBaUI7d0pBQWpCLGlCQUFpQixjQUZkLE1BQU07MkZBRVQsaUJBQWlCO2tCQUg3QixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFRvb2x0aXBOZW9TZXJ2aWNlIHtcbiAgICBwdWJsaWMgZGlzcG9zZSQ6IFN1YmplY3Q8dm9pZD4gPSBuZXcgU3ViamVjdDx2b2lkPigpO1xufVxuIl19
@@ -47,7 +47,7 @@ import { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';
47
47
  import * as i1$3 from '@angular/animations';
48
48
  import { animate, style, trigger, transition } from '@angular/animations';
49
49
  import { ComponentPortal, PortalInjector } from '@angular/cdk/portal';
50
- import { Subject, merge, of, fromEvent, BehaviorSubject } from 'rxjs';
50
+ import { Subject, of, fromEvent, BehaviorSubject } from 'rxjs';
51
51
  import { switchMap, delay, takeUntil, debounceTime, distinctUntilChanged, tap, catchError, map } from 'rxjs/operators';
52
52
  import * as i2$3 from '@angular/cdk/scrolling';
53
53
  import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
@@ -1072,7 +1072,7 @@ const tooltipNeoPositions = {
1072
1072
 
1073
1073
  class TooltipNeoService {
1074
1074
  constructor() {
1075
- this.clickOutside$ = new Subject();
1075
+ this.dispose$ = new Subject();
1076
1076
  }
1077
1077
  }
1078
1078
  /** @nocollapse */ /** @nocollapse */ TooltipNeoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
@@ -1085,9 +1085,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
1085
1085
  }] });
1086
1086
 
1087
1087
  class TooltipNeoComponent {
1088
- constructor(_elementRef, _tooltipNeoService) {
1089
- this._elementRef = _elementRef;
1090
- this._tooltipNeoService = _tooltipNeoService;
1088
+ constructor(elementRef, tooltipNeoService) {
1089
+ this.elementRef = elementRef;
1090
+ this.tooltipNeoService = tooltipNeoService;
1091
1091
  }
1092
1092
  ngOnInit() {
1093
1093
  this.params.borderColor
@@ -1095,8 +1095,8 @@ class TooltipNeoComponent {
1095
1095
  : this.border = undefined;
1096
1096
  }
1097
1097
  onClickOutside(event) {
1098
- if (!this._elementRef.nativeElement.contains(event.target)) {
1099
- this._tooltipNeoService.clickOutside$.next();
1098
+ if (!this.elementRef.nativeElement.contains(event.target)) {
1099
+ this.tooltipNeoService.dispose$.next();
1100
1100
  }
1101
1101
  }
1102
1102
  }
@@ -1135,25 +1135,36 @@ class TooltipNeoDirective {
1135
1135
  this.overlayPositionBuilder = overlayPositionBuilder;
1136
1136
  this.tooltipNeoService = tooltipNeoService;
1137
1137
  this.destroy$ = new Subject();
1138
- this.hide$ = new Subject();
1138
+ this.display$ = new Subject();
1139
1139
  this.mouseEntered = false;
1140
- this.show$ = new Subject();
1141
1140
  }
1142
1141
  static enableTooltip(content, contentType, display) {
1143
1142
  return !!content && !!contentType && !!display;
1144
1143
  }
1144
+ /**
1145
+ * To fix issue on inbox virtual scroller, it's a manual cleaner at DOM level
1146
+ * @private
1147
+ */
1148
+ static cleanUpPersistentTooltip() {
1149
+ const tooltips = document.getElementsByTagName('ap-tooltip-neo');
1150
+ if (tooltips) {
1151
+ Array.from(tooltips).forEach(tooltip => {
1152
+ tooltip.parentElement.parentElement.remove();
1153
+ });
1154
+ }
1155
+ }
1145
1156
  ngOnChanges(changes) {
1146
1157
  var _a, _b, _c, _d;
1147
1158
  if ((((_b = (_a = changes === null || changes === void 0 ? void 0 : changes.apTooltipNeo) === null || _a === void 0 ? void 0 : _a.currentValue) === null || _b === void 0 ? void 0 : _b.display) || ((_d = (_c = changes === null || changes === void 0 ? void 0 : changes.apTooltipNeo) === null || _c === void 0 ? void 0 : _c.currentValue) === null || _d === void 0 ? void 0 : _d.position)) && this.mouseEntered) {
1148
1159
  this.setSettings();
1149
- this.allowDisplay ? this.show$.next(true) : this.hide$.next(false);
1160
+ this.display$.next(this.allowDisplay);
1150
1161
  }
1151
1162
  }
1152
1163
  ngOnInit() {
1153
1164
  this.initiateTooltip();
1154
1165
  }
1155
1166
  ngOnDestroy() {
1156
- this.detach();
1167
+ this.dispose();
1157
1168
  this.destroy$.next();
1158
1169
  this.destroy$.complete();
1159
1170
  }
@@ -1173,12 +1184,12 @@ class TooltipNeoDirective {
1173
1184
  const maxWidth = 'full';
1174
1185
  const position = 'top';
1175
1186
  const title = '';
1176
- this.params = { content, backgroundColor, borderColor, contentType, position, display, displayArrow, title, maxWidth };
1187
+ this.params = { content, backgroundColor, borderColor, contentType, display, displayArrow, maxWidth, position, title };
1177
1188
  this.allowDisplay = TooltipNeoDirective.enableTooltip(content, contentType, display);
1178
1189
  }
1179
1190
  }
1180
1191
  initiateTooltip() {
1181
- merge(this.hide$, this.show$)
1192
+ this.display$
1182
1193
  .pipe(switchMap(bool => {
1183
1194
  if (!bool) {
1184
1195
  return of(bool);
@@ -1188,7 +1199,8 @@ class TooltipNeoDirective {
1188
1199
  .subscribe(bool => {
1189
1200
  if (bool) {
1190
1201
  this.elementRefMouseLeave$ = fromEvent(this.elementRef.nativeElement, 'mouseleave')
1191
- .subscribe(() => this.detach());
1202
+ .subscribe(() => this.dispose());
1203
+ TooltipNeoDirective.cleanUpPersistentTooltip();
1192
1204
  const positionStrategy = this.overlayPositionBuilder
1193
1205
  .flexibleConnectedTo(this.elementRef)
1194
1206
  .withPositions([tooltipNeoPositions[this.params.position]]);
@@ -1198,29 +1210,40 @@ class TooltipNeoDirective {
1198
1210
  tooltipRef.instance.params = this.params;
1199
1211
  }
1200
1212
  else {
1201
- this.detach();
1213
+ this.dispose();
1202
1214
  }
1203
1215
  });
1204
- this.tooltipNeoService.clickOutside$
1216
+ this.tooltipNeoService.dispose$
1205
1217
  .pipe(takeUntil(this.destroy$))
1206
- .subscribe(() => this.hide$.next(false));
1218
+ .subscribe(() => {
1219
+ this.display$.next(false);
1220
+ });
1207
1221
  }
1208
- detach() {
1209
- this.overlayRef && this.overlayRef.hasAttached() && this.overlayRef.detach();
1210
- this.elementRefMouseLeave$ && this.elementRefMouseLeave$.unsubscribe();
1222
+ dispose() {
1223
+ if (this.overlayRef) {
1224
+ this.overlayRef.dispose();
1225
+ }
1226
+ if (this.elementRefMouseLeave$) {
1227
+ this.elementRefMouseLeave$.unsubscribe();
1228
+ }
1211
1229
  }
1212
1230
  onMouseEnter() {
1213
1231
  this.setSettings();
1214
1232
  this.mouseEntered = true;
1215
- this.allowDisplay && this.params && this.show$.next(true);
1233
+ if (this.allowDisplay && this.params) {
1234
+ this.display$.next(true);
1235
+ }
1216
1236
  }
1217
1237
  onMouseLeave() {
1218
1238
  this.mouseEntered = false;
1219
- this.hide$.next(false);
1239
+ this.display$.next(false);
1240
+ }
1241
+ onClick() {
1242
+ this.display$.next(false);
1220
1243
  }
1221
1244
  }
1222
1245
  /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, deps: [{ token: i0.ElementRef }, { token: i1$4.Overlay }, { token: i1$4.OverlayPositionBuilder }, { token: TooltipNeoService }], target: i0.ɵɵFactoryTarget.Directive });
1223
- /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, usesOnChanges: true, ngImport: i0 });
1246
+ /** @nocollapse */ /** @nocollapse */ TooltipNeoDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.3", type: TooltipNeoDirective, selector: "[apTooltipNeo]", inputs: { apTooltipNeo: "apTooltipNeo" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
1224
1247
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: TooltipNeoDirective, decorators: [{
1225
1248
  type: Directive,
1226
1249
  args: [{ selector: '[apTooltipNeo]' }]
@@ -1232,6 +1255,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
1232
1255
  }], onMouseLeave: [{
1233
1256
  type: HostListener,
1234
1257
  args: ['mouseleave']
1258
+ }], onClick: [{
1259
+ type: HostListener,
1260
+ args: ['click']
1235
1261
  }] } });
1236
1262
 
1237
1263
  class LabelComponent {