angular-schedule
Version:
A simple and light schedule package for angular.
147 lines • 13.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/tooltip.directive.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, Input, ElementRef, HostListener, Renderer2, } from '@angular/core';
export class TooltipDirective {
/**
* @param {?} el
* @param {?} renderer
*/
constructor(el, renderer) {
this.el = el;
this.renderer = renderer;
this.offset = 10;
}
/**
* @return {?}
*/
onMouseEnter() {
if (!this.tooltip && this.tooltipTitle !== '' && this.showTooltip) {
this.show();
}
}
/**
* @return {?}
*/
onMouseLeave() {
if (this.tooltip) {
this.hide();
}
}
/**
* @return {?}
*/
show() {
this.create();
this.setPosition();
this.renderer.addClass(this.tooltip, 'ng-tooltip-show');
}
/**
* @return {?}
*/
hide() {
this.renderer.removeClass(this.tooltip, 'ng-tooltip-show');
window.setTimeout((/**
* @return {?}
*/
() => {
this.renderer.removeChild(document.body, this.tooltip);
this.tooltip = null;
}), this.delay);
}
/**
* @return {?}
*/
create() {
this.tooltip = this.renderer.createElement('span');
this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipTitle));
this.renderer.appendChild(document.body, this.tooltip);
this.renderer.addClass(this.tooltip, 'ng-tooltip');
this.renderer.addClass(this.tooltip, `ng-tooltip-${this.placement}`);
this.renderer.setStyle(this.tooltip, '-webkit-transition', `opacity ${this.delay}ms`);
this.renderer.setStyle(this.tooltip, '-moz-transition', `opacity ${this.delay}ms`);
this.renderer.setStyle(this.tooltip, '-o-transition', `opacity ${this.delay}ms`);
this.renderer.setStyle(this.tooltip, 'transition', `opacity ${this.delay}ms`);
}
/**
* @return {?}
*/
setPosition() {
/** @type {?} */
const hostPos = this.el.nativeElement.getBoundingClientRect();
/** @type {?} */
const tooltipPos = this.tooltip.getBoundingClientRect();
/** @type {?} */
const scrollPos = window.pageYOffset ||
document.documentElement.scrollTop ||
document.body.scrollTop ||
0;
/** @type {?} */
let top;
/** @type {?} */
let left;
if (this.placement === 'top') {
top = hostPos.top - tooltipPos.height - this.offset;
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
}
if (this.placement === 'bottom') {
top = hostPos.bottom + this.offset;
left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;
}
if (this.placement === 'left') {
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
left = hostPos.left - tooltipPos.width - this.offset;
}
if (this.placement === 'right') {
top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;
left = hostPos.right + this.offset;
}
this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);
this.renderer.setStyle(this.tooltip, 'left', `${left}px`);
}
}
TooltipDirective.decorators = [
{ type: Directive, args: [{
selector: '[tooltip]',
},] }
];
/** @nocollapse */
TooltipDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 }
];
TooltipDirective.propDecorators = {
tooltipTitle: [{ type: Input, args: ['tooltip',] }],
placement: [{ type: Input }],
delay: [{ type: Input }],
showTooltip: [{ type: Input }],
onMouseEnter: [{ type: HostListener, args: ['mouseenter',] }],
onMouseLeave: [{ type: HostListener, args: ['mouseleave',] }]
};
if (false) {
/** @type {?} */
TooltipDirective.prototype.tooltipTitle;
/** @type {?} */
TooltipDirective.prototype.placement;
/** @type {?} */
TooltipDirective.prototype.delay;
/** @type {?} */
TooltipDirective.prototype.showTooltip;
/** @type {?} */
TooltipDirective.prototype.tooltip;
/** @type {?} */
TooltipDirective.prototype.offset;
/**
* @type {?}
* @private
*/
TooltipDirective.prototype.el;
/**
* @type {?}
* @private
*/
TooltipDirective.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://angular-schedule/","sources":["lib/tooltip.directive.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACN,SAAS,EACT,KAAK,EACL,UAAU,EACV,YAAY,EACZ,SAAS,GACT,MAAM,eAAe,CAAC;AAKvB,MAAM,OAAO,gBAAgB;;;;;IAQ5B,YAAoB,EAAc,EAAU,QAAmB;QAA3C,OAAE,GAAF,EAAE,CAAY;QAAU,aAAQ,GAAR,QAAQ,CAAW;QAF/D,WAAM,GAAG,EAAE,CAAC;IAEsD,CAAC;;;;IAEvC,YAAY;QACvC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,YAAY,KAAK,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE;YAClE,IAAI,CAAC,IAAI,EAAE,CAAC;SACZ;IACF,CAAC;;;;IAE2B,YAAY;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,IAAI,EAAE,CAAC;SACZ;IACF,CAAC;;;;IAED,IAAI;QACH,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IACzD,CAAC;;;;IAED,IAAI;QACH,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;QAC3D,MAAM,CAAC,UAAU;;;QAAC,GAAG,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACrB,CAAC,GAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAChB,CAAC;;;;IAED,MAAM;QACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAEnD,IAAI,CAAC,QAAQ,CAAC,WAAW,CACxB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAC3C,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAEvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,cAAc,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAErE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACrB,IAAI,CAAC,OAAO,EACZ,oBAAoB,EACpB,WAAW,IAAI,CAAC,KAAK,IAAI,CACzB,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACrB,IAAI,CAAC,OAAO,EACZ,iBAAiB,EACjB,WAAW,IAAI,CAAC,KAAK,IAAI,CACzB,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACrB,IAAI,CAAC,OAAO,EACZ,eAAe,EACf,WAAW,IAAI,CAAC,KAAK,IAAI,CACzB,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CACrB,IAAI,CAAC,OAAO,EACZ,YAAY,EACZ,WAAW,IAAI,CAAC,KAAK,IAAI,CACzB,CAAC;IACH,CAAC;;;;IAED,WAAW;;cACJ,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE;;cAEvD,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE;;cACjD,SAAS,GACd,MAAM,CAAC,WAAW;YAClB,QAAQ,CAAC,eAAe,CAAC,SAAS;YAClC,QAAQ,CAAC,IAAI,CAAC,SAAS;YACvB,CAAC;;YAEE,GAAG;;YAAE,IAAI;QAEb,IAAI,IAAI,CAAC,SAAS,KAAK,KAAK,EAAE;YAC7B,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACpD,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SAC7D;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;YAChC,GAAG,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACnC,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SAC7D;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;YAC9B,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC7D,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;SACrD;QAED,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,EAAE;YAC/B,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC7D,IAAI,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;SACnC;QAED,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,GAAG,GAAG,SAAS,IAAI,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC;IAC3D,CAAC;;;YA5GD,SAAS,SAAC;gBACV,QAAQ,EAAE,WAAW;aACrB;;;;YAPA,UAAU;YAEV,SAAS;;;2BAOR,KAAK,SAAC,SAAS;wBACf,KAAK;oBACL,KAAK;0BACL,KAAK;2BAML,YAAY,SAAC,YAAY;2BAMzB,YAAY,SAAC,YAAY;;;;IAf1B,wCAAuC;;IACvC,qCAA2B;;IAC3B,iCAAuB;;IACvB,uCAA8B;;IAC9B,mCAAqB;;IACrB,kCAAY;;;;;IAEA,8BAAsB;;;;;IAAE,oCAA2B","sourcesContent":["import {\n\tDirective,\n\tInput,\n\tElementRef,\n\tHostListener,\n\tRenderer2,\n} from '@angular/core';\n\n@Directive({\n\tselector: '[tooltip]',\n})\nexport class TooltipDirective {\n\t@Input('tooltip') tooltipTitle: string;\n\t@Input() placement: string;\n\t@Input() delay: number;\n\t@Input() showTooltip: boolean;\n\ttooltip: HTMLElement;\n\toffset = 10;\n\n\tconstructor(private el: ElementRef, private renderer: Renderer2) {}\n\n\t@HostListener('mouseenter') onMouseEnter() {\n\t\tif (!this.tooltip && this.tooltipTitle !== '' && this.showTooltip) {\n\t\t\tthis.show();\n\t\t}\n\t}\n\n\t@HostListener('mouseleave') onMouseLeave() {\n\t\tif (this.tooltip) {\n\t\t\tthis.hide();\n\t\t}\n\t}\n\n\tshow() {\n\t\tthis.create();\n\t\tthis.setPosition();\n\t\tthis.renderer.addClass(this.tooltip, 'ng-tooltip-show');\n\t}\n\n\thide() {\n\t\tthis.renderer.removeClass(this.tooltip, 'ng-tooltip-show');\n\t\twindow.setTimeout(() => {\n\t\t\tthis.renderer.removeChild(document.body, this.tooltip);\n\t\t\tthis.tooltip = null;\n\t\t}, this.delay);\n\t}\n\n\tcreate() {\n\t\tthis.tooltip = this.renderer.createElement('span');\n\n\t\tthis.renderer.appendChild(\n\t\t\tthis.tooltip,\n\t\t\tthis.renderer.createText(this.tooltipTitle)\n\t\t);\n\n\t\tthis.renderer.appendChild(document.body, this.tooltip);\n\n\t\tthis.renderer.addClass(this.tooltip, 'ng-tooltip');\n\t\tthis.renderer.addClass(this.tooltip, `ng-tooltip-${this.placement}`);\n\n\t\tthis.renderer.setStyle(\n\t\t\tthis.tooltip,\n\t\t\t'-webkit-transition',\n\t\t\t`opacity ${this.delay}ms`\n\t\t);\n\t\tthis.renderer.setStyle(\n\t\t\tthis.tooltip,\n\t\t\t'-moz-transition',\n\t\t\t`opacity ${this.delay}ms`\n\t\t);\n\t\tthis.renderer.setStyle(\n\t\t\tthis.tooltip,\n\t\t\t'-o-transition',\n\t\t\t`opacity ${this.delay}ms`\n\t\t);\n\t\tthis.renderer.setStyle(\n\t\t\tthis.tooltip,\n\t\t\t'transition',\n\t\t\t`opacity ${this.delay}ms`\n\t\t);\n\t}\n\n\tsetPosition() {\n\t\tconst hostPos = this.el.nativeElement.getBoundingClientRect();\n\n\t\tconst tooltipPos = this.tooltip.getBoundingClientRect();\n\t\tconst scrollPos =\n\t\t\twindow.pageYOffset ||\n\t\t\tdocument.documentElement.scrollTop ||\n\t\t\tdocument.body.scrollTop ||\n\t\t\t0;\n\n\t\tlet top, left;\n\n\t\tif (this.placement === 'top') {\n\t\t\ttop = hostPos.top - tooltipPos.height - this.offset;\n\t\t\tleft = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n\t\t}\n\n\t\tif (this.placement === 'bottom') {\n\t\t\ttop = hostPos.bottom + this.offset;\n\t\t\tleft = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n\t\t}\n\n\t\tif (this.placement === 'left') {\n\t\t\ttop = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n\t\t\tleft = hostPos.left - tooltipPos.width - this.offset;\n\t\t}\n\n\t\tif (this.placement === 'right') {\n\t\t\ttop = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n\t\t\tleft = hostPos.right + this.offset;\n\t\t}\n\n\t\tthis.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);\n\t\tthis.renderer.setStyle(this.tooltip, 'left', `${left}px`);\n\t}\n}\n"]}