/*! Icinga Web 2 | (c) 2013-2015 Icinga Development Team | http://www.gnu.org/licenses/gpl-2.0.txt */ (function(Icinga, $) { "use strict"; Icinga.Behaviors = Icinga.Behaviors || {}; var Tooltip = function (icinga) { Icinga.EventListener.call(this, icinga); this.mouseX = 0; this.mouseY = 0; this.on('mousemove', this.onMousemove, this); this.on('rendered', this.onRendered, this); }; Tooltip.prototype = new Icinga.EventListener(); Tooltip.prototype.onMousemove = function(event) { event.data.self.mouseX = event.pageX; event.data.self.mouseY = event.pageY; }; Tooltip.prototype.onRendered = function(evt) { var self = evt.data.self, icinga = evt.data.icinga, el = evt.target; $('[title]', el).each(function () { var $el = $(this); $el.attr('title', $el.data('title-rich') || $el.attr('title')); }); $('svg rect.chart-data[title]', el).tipsy({ gravity: 'se', html: true }); $('.historycolorgrid a[title]', el).tipsy({ gravity: 's', offset: 2 }); $('img.icon[title]', el).tipsy({ gravity: $.fn.tipsy.autoNS, offset: 2 }); $('[title]', el).tipsy({ gravity: $.fn.tipsy.autoNS, delayIn: 500 }); // migrate or remove all orphaned tooltips $('.tipsy').each(function () { var arrow = $('.tipsy-arrow', this)[0]; if (!icinga.utils.elementsOverlap(arrow, $('#main')[0])) { $(this).remove(); return; } if (!icinga.utils.elementsOverlap(arrow, el)) { return; } var title = $(this).find('.tipsy-inner').html(); var atMouse = document.elementFromPoint(self.mouseX, self.mouseY); var nearestTip = $(atMouse).closest('[original-title="' + title + '"]')[0]; if (nearestTip) { var tipsy = $.data(nearestTip, 'tipsy'); tipsy.$tip = $(this); $.data(this, 'tipsy-pointee', nearestTip); } else { // doesn't match delete $(this).remove(); } }); }; // Export Icinga.Behaviors.Tooltip = Tooltip; }) (Icinga, jQuery);