source: trip-planner-front/node_modules/primeng/esm2020/tooltip/tooltip.mjs@ 76712b2

Last change on this file since 76712b2 was 59329aa, checked in by Ema <ema_spirova@…>, 3 years ago

adding photos

  • Property mode set to 100644
File size: 64.1 KB
Line 
1import { NgModule, Directive, Input } from '@angular/core';
2import { CommonModule } from '@angular/common';
3import { DomHandler, ConnectedOverlayScrollHandler } from 'primeng/dom';
4import { ZIndexUtils } from 'primeng/utils';
5import * as i0 from "@angular/core";
6import * as i1 from "primeng/api";
7export class Tooltip {
8 constructor(el, zone, config) {
9 this.el = el;
10 this.zone = zone;
11 this.config = config;
12 this.escape = true;
13 this._tooltipOptions = {
14 tooltipPosition: 'right',
15 tooltipEvent: 'hover',
16 appendTo: 'body',
17 tooltipZIndex: 'auto',
18 escape: false,
19 positionTop: 0,
20 positionLeft: 0
21 };
22 }
23 get disabled() {
24 return this._disabled;
25 }
26 set disabled(val) {
27 this._disabled = val;
28 this.deactivate();
29 }
30 ngAfterViewInit() {
31 this.zone.runOutsideAngular(() => {
32 if (this.getOption('tooltipEvent') === 'hover') {
33 this.mouseEnterListener = this.onMouseEnter.bind(this);
34 this.mouseLeaveListener = this.onMouseLeave.bind(this);
35 this.clickListener = this.onClick.bind(this);
36 this.el.nativeElement.addEventListener('mouseenter', this.mouseEnterListener);
37 this.el.nativeElement.addEventListener('mouseleave', this.mouseLeaveListener);
38 this.el.nativeElement.addEventListener('click', this.clickListener);
39 }
40 else if (this.getOption('tooltipEvent') === 'focus') {
41 this.focusListener = this.onFocus.bind(this);
42 this.blurListener = this.onBlur.bind(this);
43 this.el.nativeElement.addEventListener('focus', this.focusListener);
44 this.el.nativeElement.addEventListener('blur', this.blurListener);
45 }
46 });
47 }
48 ngOnChanges(simpleChange) {
49 if (simpleChange.tooltipPosition) {
50 this.setOption({ tooltipPosition: simpleChange.tooltipPosition.currentValue });
51 }
52 if (simpleChange.tooltipEvent) {
53 this.setOption({ tooltipEvent: simpleChange.tooltipEvent.currentValue });
54 }
55 if (simpleChange.appendTo) {
56 this.setOption({ appendTo: simpleChange.appendTo.currentValue });
57 }
58 if (simpleChange.positionStyle) {
59 this.setOption({ positionStyle: simpleChange.positionStyle.currentValue });
60 }
61 if (simpleChange.tooltipStyleClass) {
62 this.setOption({ tooltipStyleClass: simpleChange.tooltipStyleClass.currentValue });
63 }
64 if (simpleChange.tooltipZIndex) {
65 this.setOption({ tooltipZIndex: simpleChange.tooltipZIndex.currentValue });
66 }
67 if (simpleChange.escape) {
68 this.setOption({ escape: simpleChange.escape.currentValue });
69 }
70 if (simpleChange.showDelay) {
71 this.setOption({ showDelay: simpleChange.showDelay.currentValue });
72 }
73 if (simpleChange.hideDelay) {
74 this.setOption({ hideDelay: simpleChange.hideDelay.currentValue });
75 }
76 if (simpleChange.life) {
77 this.setOption({ life: simpleChange.life.currentValue });
78 }
79 if (simpleChange.positionTop) {
80 this.setOption({ positionTop: simpleChange.positionTop.currentValue });
81 }
82 if (simpleChange.positionLeft) {
83 this.setOption({ positionLeft: simpleChange.positionLeft.currentValue });
84 }
85 if (simpleChange.disabled) {
86 this.setOption({ disabled: simpleChange.disabled.currentValue });
87 }
88 if (simpleChange.text) {
89 this.setOption({ tooltipLabel: simpleChange.text.currentValue });
90 if (this.active) {
91 if (simpleChange.text.currentValue) {
92 if (this.container && this.container.offsetParent) {
93 this.updateText();
94 this.align();
95 }
96 else {
97 this.show();
98 }
99 }
100 else {
101 this.hide();
102 }
103 }
104 }
105 if (simpleChange.tooltipOptions) {
106 this._tooltipOptions = { ...this._tooltipOptions, ...simpleChange.tooltipOptions.currentValue };
107 this.deactivate();
108 if (this.active) {
109 if (this.getOption('tooltipLabel')) {
110 if (this.container && this.container.offsetParent) {
111 this.updateText();
112 this.align();
113 }
114 else {
115 this.show();
116 }
117 }
118 else {
119 this.hide();
120 }
121 }
122 }
123 }
124 onMouseEnter(e) {
125 if (!this.container && !this.showTimeout) {
126 this.activate();
127 }
128 }
129 onMouseLeave(e) {
130 this.deactivate();
131 }
132 onFocus(e) {
133 this.activate();
134 }
135 onBlur(e) {
136 this.deactivate();
137 }
138 onClick(e) {
139 this.deactivate();
140 }
141 activate() {
142 this.active = true;
143 this.clearHideTimeout();
144 if (this.getOption('showDelay'))
145 this.showTimeout = setTimeout(() => { this.show(); }, this.getOption('showDelay'));
146 else
147 this.show();
148 if (this.getOption('life')) {
149 let duration = this.getOption('showDelay') ? this.getOption('life') + this.getOption('showDelay') : this.getOption('life');
150 this.hideTimeout = setTimeout(() => { this.hide(); }, duration);
151 }
152 }
153 deactivate() {
154 this.active = false;
155 this.clearShowTimeout();
156 if (this.getOption('hideDelay')) {
157 this.clearHideTimeout(); //life timeout
158 this.hideTimeout = setTimeout(() => { this.hide(); }, this.getOption('hideDelay'));
159 }
160 else {
161 this.hide();
162 }
163 }
164 create() {
165 if (this.container) {
166 this.clearHideTimeout();
167 this.remove();
168 }
169 this.container = document.createElement('div');
170 let tooltipArrow = document.createElement('div');
171 tooltipArrow.className = 'p-tooltip-arrow';
172 this.container.appendChild(tooltipArrow);
173 this.tooltipText = document.createElement('div');
174 this.tooltipText.className = 'p-tooltip-text';
175 this.updateText();
176 if (this.getOption('positionStyle')) {
177 this.container.style.position = this.getOption('positionStyle');
178 }
179 this.container.appendChild(this.tooltipText);
180 if (this.getOption('appendTo') === 'body')
181 document.body.appendChild(this.container);
182 else if (this.getOption('appendTo') === 'target')
183 DomHandler.appendChild(this.container, this.el.nativeElement);
184 else
185 DomHandler.appendChild(this.container, this.getOption('appendTo'));
186 this.container.style.display = 'inline-block';
187 }
188 show() {
189 if (!this.getOption('tooltipLabel') || this.getOption('disabled')) {
190 return;
191 }
192 this.create();
193 this.align();
194 DomHandler.fadeIn(this.container, 250);
195 if (this.getOption('tooltipZIndex') === 'auto')
196 ZIndexUtils.set('tooltip', this.container, this.config.zIndex.tooltip);
197 else
198 this.container.style.zIndex = this.getOption('tooltipZIndex');
199 this.bindDocumentResizeListener();
200 this.bindScrollListener();
201 }
202 hide() {
203 if (this.getOption('tooltipZIndex') === 'auto') {
204 ZIndexUtils.clear(this.container);
205 }
206 this.remove();
207 }
208 updateText() {
209 if (this.getOption('escape')) {
210 this.tooltipText.innerHTML = '';
211 this.tooltipText.appendChild(document.createTextNode(this.getOption('tooltipLabel')));
212 }
213 else {
214 this.tooltipText.innerHTML = this.getOption('tooltipLabel');
215 }
216 }
217 align() {
218 let position = this.getOption('tooltipPosition');
219 switch (position) {
220 case 'top':
221 this.alignTop();
222 if (this.isOutOfBounds()) {
223 this.alignBottom();
224 if (this.isOutOfBounds()) {
225 this.alignRight();
226 if (this.isOutOfBounds()) {
227 this.alignLeft();
228 }
229 }
230 }
231 break;
232 case 'bottom':
233 this.alignBottom();
234 if (this.isOutOfBounds()) {
235 this.alignTop();
236 if (this.isOutOfBounds()) {
237 this.alignRight();
238 if (this.isOutOfBounds()) {
239 this.alignLeft();
240 }
241 }
242 }
243 break;
244 case 'left':
245 this.alignLeft();
246 if (this.isOutOfBounds()) {
247 this.alignRight();
248 if (this.isOutOfBounds()) {
249 this.alignTop();
250 if (this.isOutOfBounds()) {
251 this.alignBottom();
252 }
253 }
254 }
255 break;
256 case 'right':
257 this.alignRight();
258 if (this.isOutOfBounds()) {
259 this.alignLeft();
260 if (this.isOutOfBounds()) {
261 this.alignTop();
262 if (this.isOutOfBounds()) {
263 this.alignBottom();
264 }
265 }
266 }
267 break;
268 }
269 }
270 getHostOffset() {
271 if (this.getOption('appendTo') === 'body' || this.getOption('appendTo') === 'target') {
272 let offset = this.el.nativeElement.getBoundingClientRect();
273 let targetLeft = offset.left + DomHandler.getWindowScrollLeft();
274 let targetTop = offset.top + DomHandler.getWindowScrollTop();
275 return { left: targetLeft, top: targetTop };
276 }
277 else {
278 return { left: 0, top: 0 };
279 }
280 }
281 alignRight() {
282 this.preAlign('right');
283 let hostOffset = this.getHostOffset();
284 let left = hostOffset.left + DomHandler.getOuterWidth(this.el.nativeElement);
285 let top = hostOffset.top + (DomHandler.getOuterHeight(this.el.nativeElement) - DomHandler.getOuterHeight(this.container)) / 2;
286 this.container.style.left = left + this.getOption('positionLeft') + 'px';
287 this.container.style.top = top + this.getOption('positionTop') + 'px';
288 }
289 alignLeft() {
290 this.preAlign('left');
291 let hostOffset = this.getHostOffset();
292 let left = hostOffset.left - DomHandler.getOuterWidth(this.container);
293 let top = hostOffset.top + (DomHandler.getOuterHeight(this.el.nativeElement) - DomHandler.getOuterHeight(this.container)) / 2;
294 this.container.style.left = left + this.getOption('positionLeft') + 'px';
295 this.container.style.top = top + this.getOption('positionTop') + 'px';
296 }
297 alignTop() {
298 this.preAlign('top');
299 let hostOffset = this.getHostOffset();
300 let left = hostOffset.left + (DomHandler.getOuterWidth(this.el.nativeElement) - DomHandler.getOuterWidth(this.container)) / 2;
301 let top = hostOffset.top - DomHandler.getOuterHeight(this.container);
302 this.container.style.left = left + this.getOption('positionLeft') + 'px';
303 this.container.style.top = top + this.getOption('positionTop') + 'px';
304 }
305 alignBottom() {
306 this.preAlign('bottom');
307 let hostOffset = this.getHostOffset();
308 let left = hostOffset.left + (DomHandler.getOuterWidth(this.el.nativeElement) - DomHandler.getOuterWidth(this.container)) / 2;
309 let top = hostOffset.top + DomHandler.getOuterHeight(this.el.nativeElement);
310 this.container.style.left = left + this.getOption('positionLeft') + 'px';
311 this.container.style.top = top + this.getOption('positionTop') + 'px';
312 }
313 setOption(option) {
314 this._tooltipOptions = { ...this._tooltipOptions, ...option };
315 }
316 getOption(option) {
317 return this._tooltipOptions[option];
318 }
319 preAlign(position) {
320 this.container.style.left = -999 + 'px';
321 this.container.style.top = -999 + 'px';
322 let defaultClassName = 'p-tooltip p-component p-tooltip-' + position;
323 this.container.className = this.getOption('tooltipStyleClass') ? defaultClassName + ' ' + this.getOption('tooltipStyleClass') : defaultClassName;
324 }
325 isOutOfBounds() {
326 let offset = this.container.getBoundingClientRect();
327 let targetTop = offset.top;
328 let targetLeft = offset.left;
329 let width = DomHandler.getOuterWidth(this.container);
330 let height = DomHandler.getOuterHeight(this.container);
331 let viewport = DomHandler.getViewport();
332 return (targetLeft + width > viewport.width) || (targetLeft < 0) || (targetTop < 0) || (targetTop + height > viewport.height);
333 }
334 onWindowResize(e) {
335 this.hide();
336 }
337 bindDocumentResizeListener() {
338 this.zone.runOutsideAngular(() => {
339 this.resizeListener = this.onWindowResize.bind(this);
340 window.addEventListener('resize', this.resizeListener);
341 });
342 }
343 unbindDocumentResizeListener() {
344 if (this.resizeListener) {
345 window.removeEventListener('resize', this.resizeListener);
346 this.resizeListener = null;
347 }
348 }
349 bindScrollListener() {
350 if (!this.scrollHandler) {
351 this.scrollHandler = new ConnectedOverlayScrollHandler(this.el.nativeElement, () => {
352 if (this.container) {
353 this.hide();
354 }
355 });
356 }
357 this.scrollHandler.bindScrollListener();
358 }
359 unbindScrollListener() {
360 if (this.scrollHandler) {
361 this.scrollHandler.unbindScrollListener();
362 }
363 }
364 unbindEvents() {
365 if (this.getOption('tooltipEvent') === 'hover') {
366 this.el.nativeElement.removeEventListener('mouseenter', this.mouseEnterListener);
367 this.el.nativeElement.removeEventListener('mouseleave', this.mouseLeaveListener);
368 this.el.nativeElement.removeEventListener('click', this.clickListener);
369 }
370 else if (this.getOption('tooltipEvent') === 'focus') {
371 this.el.nativeElement.removeEventListener('focus', this.focusListener);
372 this.el.nativeElement.removeEventListener('blur', this.blurListener);
373 }
374 this.unbindDocumentResizeListener();
375 }
376 remove() {
377 if (this.container && this.container.parentElement) {
378 if (this.getOption('appendTo') === 'body')
379 document.body.removeChild(this.container);
380 else if (this.getOption('appendTo') === 'target')
381 this.el.nativeElement.removeChild(this.container);
382 else
383 DomHandler.removeChild(this.container, this.getOption('appendTo'));
384 }
385 this.unbindDocumentResizeListener();
386 this.unbindScrollListener();
387 this.clearTimeouts();
388 this.container = null;
389 this.scrollHandler = null;
390 }
391 clearShowTimeout() {
392 if (this.showTimeout) {
393 clearTimeout(this.showTimeout);
394 this.showTimeout = null;
395 }
396 }
397 clearHideTimeout() {
398 if (this.hideTimeout) {
399 clearTimeout(this.hideTimeout);
400 this.hideTimeout = null;
401 }
402 }
403 clearTimeouts() {
404 this.clearShowTimeout();
405 this.clearHideTimeout();
406 }
407 ngOnDestroy() {
408 this.unbindEvents();
409 if (this.container) {
410 ZIndexUtils.clear(this.container);
411 }
412 this.remove();
413 if (this.scrollHandler) {
414 this.scrollHandler.destroy();
415 this.scrollHandler = null;
416 }
417 }
418}
419Tooltip.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Tooltip, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.PrimeNGConfig }], target: i0.ɵɵFactoryTarget.Directive });
420Tooltip.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.0", type: Tooltip, selector: "[pTooltip]", inputs: { tooltipPosition: "tooltipPosition", tooltipEvent: "tooltipEvent", appendTo: "appendTo", positionStyle: "positionStyle", tooltipStyleClass: "tooltipStyleClass", tooltipZIndex: "tooltipZIndex", escape: "escape", showDelay: "showDelay", hideDelay: "hideDelay", life: "life", positionTop: "positionTop", positionLeft: "positionLeft", text: ["pTooltip", "text"], disabled: ["tooltipDisabled", "disabled"], tooltipOptions: "tooltipOptions" }, host: { classAttribute: "p-element" }, usesOnChanges: true, ngImport: i0 });
421i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: Tooltip, decorators: [{
422 type: Directive,
423 args: [{
424 selector: '[pTooltip]',
425 host: {
426 'class': 'p-element'
427 }
428 }]
429 }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.PrimeNGConfig }]; }, propDecorators: { tooltipPosition: [{
430 type: Input
431 }], tooltipEvent: [{
432 type: Input
433 }], appendTo: [{
434 type: Input
435 }], positionStyle: [{
436 type: Input
437 }], tooltipStyleClass: [{
438 type: Input
439 }], tooltipZIndex: [{
440 type: Input
441 }], escape: [{
442 type: Input
443 }], showDelay: [{
444 type: Input
445 }], hideDelay: [{
446 type: Input
447 }], life: [{
448 type: Input
449 }], positionTop: [{
450 type: Input
451 }], positionLeft: [{
452 type: Input
453 }], text: [{
454 type: Input,
455 args: ['pTooltip']
456 }], disabled: [{
457 type: Input,
458 args: ["tooltipDisabled"]
459 }], tooltipOptions: [{
460 type: Input
461 }] } });
462export class TooltipModule {
463}
464TooltipModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TooltipModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
465TooltipModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TooltipModule, declarations: [Tooltip], imports: [CommonModule], exports: [Tooltip] });
466TooltipModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TooltipModule, imports: [[CommonModule]] });
467i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: TooltipModule, decorators: [{
468 type: NgModule,
469 args: [{
470 imports: [CommonModule],
471 exports: [Tooltip],
472 declarations: [Tooltip]
473 }]
474 }] });
475//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.js","sourceRoot":"","sources":["../../../src/app/components/tooltip/tooltip.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, Directive, ElementRef, AfterViewInit, OnDestroy, Input, NgZone, SimpleChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { DomHandler, ConnectedOverlayScrollHandler } from 'primeng/dom';\nimport { ZIndexUtils } from 'primeng/utils'\nimport { PrimeNGConfig } from 'primeng/api';\n\nexport interface TooltipOptions {\n    tooltipLabel?: string;\n    tooltipPosition?: string;\n    tooltipEvent?: string;\n    appendTo?: any;\n    positionStyle?: string;\n    tooltipStyleClass?: string;\n    tooltipZIndex?: string;\n    escape?: boolean;\n    disabled?: boolean;\n    showDelay?: number;\n    hideDelay?: number;\n    positionTop?: number;\n    positionLeft?: number;\n    life?: number;\n}\n\n@Directive({\n    selector: '[pTooltip]',\n    host: {\n        'class': 'p-element'\n    }\n})\nexport class Tooltip implements AfterViewInit, OnDestroy {\n\n    @Input() tooltipPosition: string;\n\n    @Input() tooltipEvent: string;\n\n    @Input() appendTo: any;\n\n    @Input() positionStyle: string;\n\n    @Input() tooltipStyleClass: string;\n\n    @Input() tooltipZIndex: string;\n\n    @Input() escape: boolean = true;\n\n    @Input() showDelay: number;\n\n    @Input() hideDelay: number;\n\n    @Input() life: number;\n\n    @Input() positionTop: number;\n\n    @Input() positionLeft: number;\n\n    @Input('pTooltip') text: string;\n\n    @Input(\"tooltipDisabled\") get disabled(): boolean {\n        return this._disabled;\n    }\n    set disabled(val:boolean) {\n        this._disabled = val;\n        this.deactivate();\n    }\n\n    @Input() tooltipOptions: TooltipOptions;\n\n    _tooltipOptions: TooltipOptions = {\n        tooltipPosition: 'right',\n        tooltipEvent: 'hover',\n        appendTo: 'body',\n        tooltipZIndex: 'auto',\n        escape: false,\n        positionTop: 0,\n        positionLeft: 0\n    }\n\n    _disabled: boolean;\n\n    container: any;\n\n    styleClass: string;\n\n    tooltipText: any;\n\n    showTimeout: any;\n\n    hideTimeout: any;\n\n    active: boolean;\n\n    mouseEnterListener: Function;\n\n    mouseLeaveListener: Function;\n\n    clickListener: Function;\n\n    focusListener: Function;\n\n    blurListener: Function;\n\n    scrollHandler: any;\n\n    resizeListener: any;\n\n    constructor(public el: ElementRef, public zone: NgZone, public config: PrimeNGConfig) { }\n\n    ngAfterViewInit() {\n        this.zone.runOutsideAngular(() => {\n            if (this.getOption('tooltipEvent') === 'hover') {\n                this.mouseEnterListener = this.onMouseEnter.bind(this);\n                this.mouseLeaveListener = this.onMouseLeave.bind(this);\n                this.clickListener = this.onClick.bind(this);\n                this.el.nativeElement.addEventListener('mouseenter', this.mouseEnterListener);\n                this.el.nativeElement.addEventListener('mouseleave', this.mouseLeaveListener);\n                this.el.nativeElement.addEventListener('click', this.clickListener);\n            }\n            else if (this.getOption('tooltipEvent') === 'focus') {\n                this.focusListener = this.onFocus.bind(this);\n                this.blurListener = this.onBlur.bind(this);\n                this.el.nativeElement.addEventListener('focus', this.focusListener);\n                this.el.nativeElement.addEventListener('blur', this.blurListener);\n            }\n        });\n    }\n\n    ngOnChanges(simpleChange: SimpleChanges) {\n        if (simpleChange.tooltipPosition) {\n            this.setOption({tooltipPosition: simpleChange.tooltipPosition.currentValue});\n        }\n\n        if (simpleChange.tooltipEvent) {\n            this.setOption({tooltipEvent: simpleChange.tooltipEvent.currentValue});\n        }\n\n        if (simpleChange.appendTo) {\n            this.setOption({appendTo: simpleChange.appendTo.currentValue});\n        }\n\n        if (simpleChange.positionStyle) {\n            this.setOption({positionStyle: simpleChange.positionStyle.currentValue});\n        }\n\n        if (simpleChange.tooltipStyleClass) {\n            this.setOption({tooltipStyleClass: simpleChange.tooltipStyleClass.currentValue});\n        }\n\n        if (simpleChange.tooltipZIndex) {\n            this.setOption({tooltipZIndex: simpleChange.tooltipZIndex.currentValue});\n        }\n\n        if (simpleChange.escape) {\n            this.setOption({escape: simpleChange.escape.currentValue});\n        }\n\n        if (simpleChange.showDelay) {\n            this.setOption({showDelay: simpleChange.showDelay.currentValue});\n        }\n\n        if (simpleChange.hideDelay) {\n            this.setOption({hideDelay: simpleChange.hideDelay.currentValue});\n        }\n\n        if (simpleChange.life) {\n            this.setOption({life: simpleChange.life.currentValue});\n        }\n\n        if (simpleChange.positionTop) {\n            this.setOption({positionTop: simpleChange.positionTop.currentValue});\n        }\n\n        if (simpleChange.positionLeft) {\n            this.setOption({positionLeft: simpleChange.positionLeft.currentValue});\n        }\n\n        if (simpleChange.disabled) {\n            this.setOption({disabled: simpleChange.disabled.currentValue});\n        }\n\n        if (simpleChange.text) {\n            this.setOption({tooltipLabel: simpleChange.text.currentValue});\n\n            if (this.active) {\n                if (simpleChange.text.currentValue) {\n                    if (this.container && this.container.offsetParent) {\n                        this.updateText();\n                        this.align();\n                    }\n                    else {\n                        this.show();\n                    }\n                }\n                else {\n                    this.hide();\n                }\n            }\n        }\n\n        if (simpleChange.tooltipOptions) {\n            this._tooltipOptions = {...this._tooltipOptions, ...simpleChange.tooltipOptions.currentValue};\n            this.deactivate();\n\n            if (this.active) {\n                if (this.getOption('tooltipLabel')) {\n                    if (this.container && this.container.offsetParent) {\n                        this.updateText();\n                        this.align();\n                    }\n                    else {\n                        this.show();\n                    }\n                }\n                else {\n                    this.hide();\n                }\n            }\n        }\n    }\n\n    onMouseEnter(e: Event) {\n        if (!this.container && !this.showTimeout) {\n            this.activate();\n        }\n    }\n\n    onMouseLeave(e: Event) {\n        this.deactivate();\n    }\n\n    onFocus(e: Event) {\n        this.activate();\n    }\n\n    onBlur(e: Event) {\n        this.deactivate();\n    }\n\n    onClick(e: Event) {\n        this.deactivate();\n    }\n\n    activate() {\n        this.active = true;\n        this.clearHideTimeout();\n\n        if (this.getOption('showDelay'))\n            this.showTimeout = setTimeout(() => { this.show() }, this.getOption('showDelay'));\n        else\n            this.show();\n\n        if (this.getOption('life')) {\n            let duration = this.getOption('showDelay') ? this.getOption('life') + this.getOption('showDelay') : this.getOption('life');\n            this.hideTimeout = setTimeout(() => { this.hide() }, duration);\n        }\n    }\n\n    deactivate() {\n        this.active = false;\n        this.clearShowTimeout();\n\n        if (this.getOption('hideDelay')) {\n            this.clearHideTimeout();    //life timeout\n            this.hideTimeout = setTimeout(() => { this.hide() }, this.getOption('hideDelay'));\n        }\n        else {\n            this.hide();\n        }\n    }\n\n    create() {\n        if (this.container) {\n            this.clearHideTimeout();\n            this.remove();\n        }\n\n        this.container = document.createElement('div');\n\n        let tooltipArrow = document.createElement('div');\n        tooltipArrow.className = 'p-tooltip-arrow';\n        this.container.appendChild(tooltipArrow);\n\n        this.tooltipText = document.createElement('div');\n        this.tooltipText.className = 'p-tooltip-text';\n\n        this.updateText();\n\n        if (this.getOption('positionStyle')) {\n            this.container.style.position = this.getOption('positionStyle');\n        }\n\n        this.container.appendChild(this.tooltipText);\n\n        if (this.getOption('appendTo') === 'body')\n            document.body.appendChild(this.container);\n        else if (this.getOption('appendTo') === 'target')\n            DomHandler.appendChild(this.container, this.el.nativeElement);\n        else\n            DomHandler.appendChild(this.container, this.getOption('appendTo'));\n\n        this.container.style.display = 'inline-block';\n    }\n\n    show() {\n        if (!this.getOption('tooltipLabel') || this.getOption('disabled')) {\n            return;\n        }\n\n        this.create();\n        this.align();\n        DomHandler.fadeIn(this.container, 250);\n\n        if (this.getOption('tooltipZIndex') === 'auto')\n            ZIndexUtils.set('tooltip', this.container, this.config.zIndex.tooltip);\n        else\n            this.container.style.zIndex = this.getOption('tooltipZIndex');\n\n        this.bindDocumentResizeListener();\n        this.bindScrollListener();\n    }\n\n    hide() {\n        if (this.getOption('tooltipZIndex') === 'auto') {\n            ZIndexUtils.clear(this.container);\n        }\n\n        this.remove();\n    }\n\n    updateText() {\n        if (this.getOption('escape')) {\n            this.tooltipText.innerHTML = '';\n            this.tooltipText.appendChild(document.createTextNode(this.getOption('tooltipLabel')));\n        }\n        else {\n            this.tooltipText.innerHTML = this.getOption('tooltipLabel');\n        }\n    }\n\n    align() {\n        let position = this.getOption('tooltipPosition');\n\n        switch (position) {\n            case 'top':\n                this.alignTop();\n                if (this.isOutOfBounds()) {\n                    this.alignBottom();\n                    if (this.isOutOfBounds()) {\n                        this.alignRight();\n\n                        if (this.isOutOfBounds()) {\n                            this.alignLeft();\n                        }\n                    }\n                }\n                break;\n\n            case 'bottom':\n                this.alignBottom();\n                if (this.isOutOfBounds()) {\n                    this.alignTop();\n                    if (this.isOutOfBounds()) {\n                        this.alignRight();\n\n                        if (this.isOutOfBounds()) {\n                            this.alignLeft();\n                        }\n                    }\n                }\n                break;\n\n            case 'left':\n                this.alignLeft();\n                if (this.isOutOfBounds()) {\n                    this.alignRight();\n\n                    if (this.isOutOfBounds()) {\n                        this.alignTop();\n\n                        if (this.isOutOfBounds()) {\n                            this.alignBottom();\n                        }\n                    }\n                }\n                break;\n\n            case 'right':\n                this.alignRight();\n                if (this.isOutOfBounds()) {\n                    this.alignLeft();\n\n                    if (this.isOutOfBounds()) {\n                        this.alignTop();\n\n                        if (this.isOutOfBounds()) {\n                            this.alignBottom();\n                        }\n                    }\n                }\n                break;\n        }\n    }\n\n    getHostOffset() {\n        if (this.getOption('appendTo') === 'body' || this.getOption('appendTo') === 'target') {\n            let offset = this.el.nativeElement.getBoundingClientRect();\n            let targetLeft = offset.left + DomHandler.getWindowScrollLeft();\n            let targetTop = offset.top + DomHandler.getWindowScrollTop();\n\n            return { left: targetLeft, top: targetTop };\n        }\n        else {\n            return { left: 0, top: 0 };\n        }\n    }\n\n    alignRight() {\n        this.preAlign('right');\n        let hostOffset = this.getHostOffset();\n        let left = hostOffset.left + DomHandler.getOuterWidth(this.el.nativeElement);\n        let top = hostOffset.top + (DomHandler.getOuterHeight(this.el.nativeElement) - DomHandler.getOuterHeight(this.container)) / 2;\n        this.container.style.left = left + this.getOption('positionLeft') + 'px';\n        this.container.style.top = top + this.getOption('positionTop') + 'px';\n    }\n\n    alignLeft() {\n        this.preAlign('left');\n        let hostOffset = this.getHostOffset();\n        let left = hostOffset.left - DomHandler.getOuterWidth(this.container);\n        let top = hostOffset.top + (DomHandler.getOuterHeight(this.el.nativeElement) - DomHandler.getOuterHeight(this.container)) / 2;\n        this.container.style.left = left + this.getOption('positionLeft') + 'px';\n        this.container.style.top = top + this.getOption('positionTop') + 'px';\n    }\n\n    alignTop() {\n        this.preAlign('top');\n        let hostOffset = this.getHostOffset();\n        let left = hostOffset.left + (DomHandler.getOuterWidth(this.el.nativeElement) - DomHandler.getOuterWidth(this.container)) / 2;\n        let top = hostOffset.top - DomHandler.getOuterHeight(this.container);\n        this.container.style.left = left + this.getOption('positionLeft') + 'px';\n        this.container.style.top = top + this.getOption('positionTop') + 'px';\n    }\n\n    alignBottom() {\n        this.preAlign('bottom');\n        let hostOffset = this.getHostOffset();\n        let left = hostOffset.left + (DomHandler.getOuterWidth(this.el.nativeElement) - DomHandler.getOuterWidth(this.container)) / 2;\n        let top = hostOffset.top + DomHandler.getOuterHeight(this.el.nativeElement);\n        this.container.style.left = left + this.getOption('positionLeft') + 'px';\n        this.container.style.top = top + this.getOption('positionTop') + 'px';\n    }\n\n    setOption(option: TooltipOptions) {\n        this._tooltipOptions = {...this._tooltipOptions, ...option}\n    }\n\n    getOption(option: string) {\n        return this._tooltipOptions[option];\n    }\n\n    preAlign(position: string) {\n        this.container.style.left = -999 + 'px';\n        this.container.style.top = -999 + 'px';\n\n        let defaultClassName = 'p-tooltip p-component p-tooltip-' + position;\n        this.container.className = this.getOption('tooltipStyleClass') ? defaultClassName + ' ' + this.getOption('tooltipStyleClass') : defaultClassName;\n    }\n\n    isOutOfBounds(): boolean {\n        let offset = this.container.getBoundingClientRect();\n        let targetTop = offset.top;\n        let targetLeft = offset.left;\n        let width = DomHandler.getOuterWidth(this.container);\n        let height = DomHandler.getOuterHeight(this.container);\n        let viewport = DomHandler.getViewport();\n\n        return (targetLeft + width > viewport.width) || (targetLeft < 0) || (targetTop < 0) || (targetTop + height > viewport.height);\n    }\n\n    onWindowResize(e: Event) {\n        this.hide();\n    }\n\n    bindDocumentResizeListener() {\n        this.zone.runOutsideAngular(() => {\n            this.resizeListener = this.onWindowResize.bind(this);\n            window.addEventListener('resize', this.resizeListener);\n        });\n    }\n\n    unbindDocumentResizeListener() {\n        if (this.resizeListener) {\n            window.removeEventListener('resize', this.resizeListener);\n            this.resizeListener = null;\n        }\n    }\n\n    bindScrollListener() {\n        if (!this.scrollHandler) {\n            this.scrollHandler = new ConnectedOverlayScrollHandler(this.el.nativeElement, () => {\n                if (this.container) {\n                    this.hide();\n                }\n            });\n        }\n\n        this.scrollHandler.bindScrollListener();\n    }\n\n    unbindScrollListener() {\n        if (this.scrollHandler) {\n            this.scrollHandler.unbindScrollListener();\n        }\n    }\n\n    unbindEvents() {\n        if (this.getOption('tooltipEvent') === 'hover') {\n            this.el.nativeElement.removeEventListener('mouseenter', this.mouseEnterListener);\n            this.el.nativeElement.removeEventListener('mouseleave', this.mouseLeaveListener);\n            this.el.nativeElement.removeEventListener('click', this.clickListener);\n        }\n        else if (this.getOption('tooltipEvent') === 'focus') {\n            this.el.nativeElement.removeEventListener('focus', this.focusListener);\n            this.el.nativeElement.removeEventListener('blur', this.blurListener);\n        }\n\n        this.unbindDocumentResizeListener();\n    }\n\n    remove() {\n        if (this.container && this.container.parentElement) {\n            if (this.getOption('appendTo') === 'body')\n                document.body.removeChild(this.container);\n            else if (this.getOption('appendTo') === 'target')\n                this.el.nativeElement.removeChild(this.container);\n            else\n                DomHandler.removeChild(this.container, this.getOption('appendTo'));\n        }\n\n        this.unbindDocumentResizeListener();\n        this.unbindScrollListener();\n        this.clearTimeouts();\n        this.container = null;\n        this.scrollHandler = null;\n    }\n\n    clearShowTimeout() {\n        if (this.showTimeout) {\n            clearTimeout(this.showTimeout);\n            this.showTimeout = null;\n        }\n    }\n\n    clearHideTimeout() {\n        if (this.hideTimeout) {\n            clearTimeout(this.hideTimeout);\n            this.hideTimeout = null;\n        }\n    }\n\n    clearTimeouts() {\n        this.clearShowTimeout();\n        this.clearHideTimeout();\n    }\n\n    ngOnDestroy() {\n        this.unbindEvents();\n\n        if (this.container) {\n            ZIndexUtils.clear(this.container);\n        }\n\n        this.remove();\n\n        if (this.scrollHandler) {\n            this.scrollHandler.destroy();\n            this.scrollHandler = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [Tooltip],\n    declarations: [Tooltip]\n})\nexport class TooltipModule { }\n"]}
Note: See TracBrowser for help on using the repository browser.