UNPKG

angular-schedule

Version:

A simple and light schedule package for angular.

164 lines 14.1 kB
/** * @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'; var TooltipDirective = /** @class */ (function () { function TooltipDirective(el, renderer) { this.el = el; this.renderer = renderer; this.offset = 10; } /** * @return {?} */ TooltipDirective.prototype.onMouseEnter = /** * @return {?} */ function () { if (!this.tooltip && this.tooltipTitle !== '' && this.showTooltip) { this.show(); } }; /** * @return {?} */ TooltipDirective.prototype.onMouseLeave = /** * @return {?} */ function () { if (this.tooltip) { this.hide(); } }; /** * @return {?} */ TooltipDirective.prototype.show = /** * @return {?} */ function () { this.create(); this.setPosition(); this.renderer.addClass(this.tooltip, 'ng-tooltip-show'); }; /** * @return {?} */ TooltipDirective.prototype.hide = /** * @return {?} */ function () { var _this = this; this.renderer.removeClass(this.tooltip, 'ng-tooltip-show'); window.setTimeout((/** * @return {?} */ function () { _this.renderer.removeChild(document.body, _this.tooltip); _this.tooltip = null; }), this.delay); }; /** * @return {?} */ TooltipDirective.prototype.create = /** * @return {?} */ function () { 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 {?} */ TooltipDirective.prototype.setPosition = /** * @return {?} */ function () { /** @type {?} */ var hostPos = this.el.nativeElement.getBoundingClientRect(); /** @type {?} */ var tooltipPos = this.tooltip.getBoundingClientRect(); /** @type {?} */ var scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0; /** @type {?} */ var top; /** @type {?} */ var 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 = function () { return [ { 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',] }] }; return TooltipDirective; }()); export { TooltipDirective }; 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":"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","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"]}