ngx-slice-kit
Version:
[](https://badge.fury.io/js/ngx-slice-kit)
182 lines • 24 kB
JavaScript
import { Directive, HostListener, Input } from '@angular/core';
import { timer } from 'rxjs';
import { first } from 'rxjs/operators';
import * as i0 from "@angular/core";
export class TooltipDirective {
constructor(el, renderer) {
this.el = el;
this.renderer = renderer;
this.showOnClick = false;
this.position = 'top';
this.offset = 12;
}
onMouseEnter() {
if (!this.tooltip && !this.showOnClick) {
this.show();
}
}
onClick() {
if (!this.tooltip && this.showOnClick) {
this.show();
}
}
onMouseLeave() {
if (this.tooltip) {
this.hide();
}
else {
if (this.sub && !this.sub.closed) {
this.sub.unsubscribe();
}
}
}
show() {
this.showTimeout = timer(Number(this.delay));
this.sub = this.showTimeout.pipe(first()).subscribe(() => {
this.create();
this.setPosition();
this.renderer.addClass(this.tooltip, 'sdk-tooltip-show');
this.showTimeout = null;
});
}
hide() {
this.renderer.removeClass(this.tooltip, 'sdk-tooltip-show');
this.renderer.removeChild(document.body, this.tooltip);
this.tooltip = null;
// window.setTimeout(() => {
// this.renderer.removeChild(document.body, this.tooltip);
// this.tooltip = null;
// }, Number(this.delay));
}
create() {
this.tooltip = this.renderer.createElement('div');
this.tooltipContent = this.renderer.createElement('p');
this.renderer.appendChild(this.tooltipContent, this.renderer.createText(this.message));
this.renderer.appendChild(this.tooltip, this.tooltipContent);
this.renderer.appendChild(document.body, this.tooltip);
this.renderer.addClass(this.tooltip, 'sdk-tooltip');
this.renderer.addClass(this.tooltip, `sdk-tooltip--${this.position}`);
this.renderer.addClass(this.tooltipContent, 'sdk-tooltip__content');
}
setPosition() {
const hostPos = this.triggerElement.getBoundingClientRect();
const tooltipPos = this.tooltip.getBoundingClientRect();
const tooltipHeight = this.tooltip.offsetHeight;
const tooltipWidth = this.tooltip.offsetWidth;
const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
let top;
let left;
this.offset = Number(this.offset);
if (this.position === 'top') {
const options = {
hostPosition: hostPos.top,
hostSize: hostPos.height,
tooltipSize: tooltipHeight
};
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
if (this.checkOversize(options, 'height', false)) {
top = hostPos.top - tooltipHeight - this.offset;
}
else {
this.changePosition('top', 'bottom');
this.setPosition();
}
}
if (this.position === 'bottom') {
const options = {
hostPosition: hostPos.top,
hostSize: hostPos.height,
tooltipSize: tooltipHeight
};
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
if (this.checkOversize(options, 'height')) {
top = hostPos.bottom + this.offset;
}
else {
this.changePosition('bottom', 'top');
this.setPosition();
}
}
if (this.position === 'left') {
const options = {
hostPosition: hostPos.left,
hostSize: hostPos.width,
tooltipSize: tooltipWidth
};
top = hostPos.top + (hostPos.height - tooltipHeight) / 2;
if (this.checkOversize(options, 'width', false)) {
left = hostPos.left - tooltipWidth - this.offset;
}
else {
this.changePosition('left', 'right');
this.setPosition();
}
}
if (this.position === 'right') {
const options = {
hostPosition: hostPos.left,
hostSize: hostPos.width,
tooltipSize: tooltipWidth
};
top = hostPos.top + (hostPos.height - tooltipHeight) / 2;
if (this.checkOversize(options, 'width')) {
left = hostPos.right + this.offset;
}
else {
this.changePosition('right', 'left');
this.setPosition();
}
}
this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);
this.renderer.setStyle(this.tooltip, 'left', `${left}px`);
}
changePosition(oldPosition, newPosition) {
this.position = newPosition;
this.renderer.removeClass(this.tooltip, `sdk-tooltip--${oldPosition}`);
this.renderer.addClass(this.tooltip, `sdk-tooltip--${newPosition}`);
}
checkOversize(options, dimension, isDirectionForward = true) {
const documentPos = document.body.getBoundingClientRect();
if (isDirectionForward) {
return options.hostPosition + options.hostSize + options.tooltipSize + this.offset <= documentPos[dimension];
}
else {
return options.hostPosition - options.hostSize - options.tooltipSize - this.offset > 0;
}
}
ngOnInit() {
this.triggerElement = this.el.nativeElement || this.el;
}
}
TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.3", type: TooltipDirective, selector: "[sdkTooltip]", inputs: { showOnClick: "showOnClick", delay: "delay", message: ["sdkTooltip", "message"], position: "position", offset: "offset" }, host: { listeners: { "mouseenter": "onMouseEnter()", "click": "onClick()", "mousewheel": "onMouseLeave()", "mouseleave": "onMouseLeave()" } }, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: TooltipDirective, decorators: [{
type: Directive,
args: [{
selector: '[sdkTooltip]'
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { showOnClick: [{
type: Input
}], delay: [{
type: Input
}], message: [{
type: Input,
args: ['sdkTooltip']
}], position: [{
type: Input
}], offset: [{
type: Input
}], onMouseEnter: [{
type: HostListener,
args: ['mouseenter']
}], onClick: [{
type: HostListener,
args: ['click']
}], onMouseLeave: [{
type: HostListener,
args: ['mousewheel']
}, {
type: HostListener,
args: ['mouseleave']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/modals/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, HostListener, Input, OnInit, Renderer2} from '@angular/core';\nimport {Subscription, timer} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\n@Directive({\n    selector: '[sdkTooltip]'\n})\nexport class TooltipDirective implements OnInit {\n    @Input() public showOnClick: boolean = false;\n    @Input() public delay: string | number;\n    @Input('sdkTooltip') public message: string;\n    @Input() public position: string = 'top';\n    @Input() public offset: number = 12;\n\n    public tooltip: HTMLElement;\n    public tooltipContent: HTMLElement;\n    public triggerElement: HTMLElement;\n\n    public showTimeout;\n\n    public sub: Subscription;\n\n    constructor(\n        private el: ElementRef,\n        private renderer: Renderer2\n    ) {\n    }\n\n    @HostListener('mouseenter')\n    public onMouseEnter(): void {\n        if (!this.tooltip && !this.showOnClick) {\n            this.show();\n        }\n    }\n\n    @HostListener('click')\n    public onClick(): void {\n        if (!this.tooltip && this.showOnClick) {\n            this.show();\n        }\n    }\n\n    @HostListener('mousewheel')\n    @HostListener('mouseleave')\n    public onMouseLeave(): void {\n        if (this.tooltip) {\n            this.hide();\n        } else {\n            if (this.sub && !this.sub.closed) {\n                this.sub.unsubscribe();\n            }\n        }\n    }\n\n    public show(): void {\n        this.showTimeout = timer(Number(this.delay));\n\n        this.sub = this.showTimeout.pipe(first()).subscribe(() => {\n            this.create();\n            this.setPosition();\n            this.renderer.addClass(this.tooltip, 'sdk-tooltip-show');\n            this.showTimeout = null;\n        });\n    }\n\n    public hide(): void {\n        this.renderer.removeClass(this.tooltip, 'sdk-tooltip-show');\n        this.renderer.removeChild(document.body, this.tooltip);\n        this.tooltip = null;\n        // window.setTimeout(() => {\n        //     this.renderer.removeChild(document.body, this.tooltip);\n        //     this.tooltip = null;\n        // }, Number(this.delay));\n    }\n\n    public create(): void {\n        this.tooltip = this.renderer.createElement('div');\n        this.tooltipContent = this.renderer.createElement('p');\n        this.renderer.appendChild(\n            this.tooltipContent,\n            this.renderer.createText(this.message)\n        );\n\n        this.renderer.appendChild(this.tooltip, this.tooltipContent);\n        this.renderer.appendChild(document.body, this.tooltip);\n\n        this.renderer.addClass(this.tooltip, 'sdk-tooltip');\n        this.renderer.addClass(this.tooltip, `sdk-tooltip--${this.position}`);\n        this.renderer.addClass(this.tooltipContent, 'sdk-tooltip__content');\n    }\n\n    public setPosition(): void {\n        const hostPos = this.triggerElement.getBoundingClientRect();\n        const tooltipPos = this.tooltip.getBoundingClientRect();\n        const tooltipHeight = this.tooltip.offsetHeight;\n        const tooltipWidth = this.tooltip.offsetWidth;\n        const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;\n\n        let top;\n        let left;\n\n        this.offset = Number(this.offset);\n\n        if (this.position === 'top') {\n            const options = {\n                hostPosition: hostPos.top,\n                hostSize: hostPos.height,\n                tooltipSize: tooltipHeight\n            };\n\n            left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n            if (this.checkOversize(options, 'height', false)) {\n                top = hostPos.top - tooltipHeight - this.offset;\n            } else {\n                this.changePosition('top', 'bottom');\n                this.setPosition();\n            }\n        }\n\n        if (this.position === 'bottom') {\n            const options = {\n                hostPosition: hostPos.top,\n                hostSize: hostPos.height,\n                tooltipSize: tooltipHeight\n            };\n            left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n            if (this.checkOversize(options, 'height')) {\n                top = hostPos.bottom + this.offset;\n            } else {\n                this.changePosition('bottom', 'top');\n                this.setPosition();\n            }\n        }\n\n        if (this.position === 'left') {\n            const options = {\n                hostPosition: hostPos.left,\n                hostSize: hostPos.width,\n                tooltipSize: tooltipWidth\n            };\n            top = hostPos.top + (hostPos.height - tooltipHeight) / 2;\n            if (this.checkOversize(options, 'width', false)) {\n                left = hostPos.left - tooltipWidth - this.offset;\n            } else {\n                this.changePosition('left', 'right');\n                this.setPosition();\n            }\n        }\n\n        if (this.position === 'right') {\n            const options = {\n                hostPosition: hostPos.left,\n                hostSize: hostPos.width,\n                tooltipSize: tooltipWidth\n            };\n            top = hostPos.top + (hostPos.height - tooltipHeight) / 2;\n            if (this.checkOversize(options, 'width')) {\n                left = hostPos.right + this.offset;\n            } else {\n                this.changePosition('right', 'left');\n                this.setPosition();\n            }\n        }\n\n        this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);\n        this.renderer.setStyle(this.tooltip, 'left', `${left}px`);\n    }\n\n    public changePosition(oldPosition, newPosition): void {\n        this.position = newPosition;\n        this.renderer.removeClass(this.tooltip, `sdk-tooltip--${oldPosition}`);\n        this.renderer.addClass(this.tooltip, `sdk-tooltip--${newPosition}`);\n    }\n\n    public checkOversize(options, dimension, isDirectionForward = true): boolean {\n        const documentPos = document.body.getBoundingClientRect();\n        if (isDirectionForward) {\n            return options.hostPosition + options.hostSize + options.tooltipSize + this.offset <= documentPos[dimension];\n        } else {\n            return options.hostPosition - options.hostSize - options.tooltipSize - this.offset > 0;\n        }\n    }\n\n    public ngOnInit(): void {\n        this.triggerElement = this.el.nativeElement || this.el;\n    }\n}\n"]}