icingaweb2/public/js/icinga/behavior/flyover.js

78 lines
2.2 KiB
JavaScript
Raw Normal View History

2017-11-21 14:05:12 +01:00
/* Icinga Web 2 | (c) 2017 Icinga Development Team | GPLv2+ */
/**
* Icinga.Behavior.Flyover
*
* A toggleable flyover
*/
(function(Icinga, $) {
'use strict';
var expandedFlyovers = {};
function Flyover(icinga) {
Icinga.EventListener.call(this, icinga);
this.on('rendered', this.onRendered, this);
this.on('click', this.onClick, this);
this.on('click', '.flyover-toggle', this.onClickFlyoverToggle, this);
2017-11-21 14:05:12 +01:00
}
Flyover.prototype = new Icinga.EventListener();
Flyover.prototype.onRendered = function(event) {
// Re-expand expanded containers after an auto-refresh
$(event.target).find('.flyover').each(function() {
var $this = $(this);
if (typeof expandedFlyovers['#' + $this.attr('id')] !== 'undefined') {
2017-11-21 18:10:50 +01:00
var $container = $this.closest('.container');
if ($this.offset().left - $container.offset().left > $container.innerWidth() / 2) {
$this.addClass('flyover-right');
}
2017-11-21 14:05:12 +01:00
$this.toggleClass('flyover-expanded');
}
});
};
Flyover.prototype.onClick = function(event) {
var $target = $(event.target);
if (! $target.closest('.flyover').length) {
var _this = event.data.self;
$target.closest('.container').find('.flyover.flyover-expanded .flyover-toggle').each(function() {
_this.onClickFlyoverToggle({target: this});
});
}
};
Flyover.prototype.onClickFlyoverToggle = function(event) {
2017-11-21 14:05:12 +01:00
var $flyover = $(event.target).closest('.flyover');
$flyover.toggleClass('flyover-expanded');
if ($flyover.hasClass('flyover-expanded')) {
2017-11-21 18:10:50 +01:00
var $container = $flyover.closest('.container');
if ($flyover.offset().left - $container.offset().left > $container.innerWidth() / 2) {
$flyover.addClass('flyover-right');
}
2017-11-21 14:05:12 +01:00
expandedFlyovers['#' + $flyover.attr('id')] = null;
} else {
2017-11-21 18:10:50 +01:00
$flyover.removeClass('flyover-right');
2017-11-21 14:05:12 +01:00
delete expandedFlyovers['#' + $flyover.attr('id')];
}
};
Icinga.Behaviors = Icinga.Behaviors || {};
Icinga.Behaviors.Flyover = Flyover;
})(Icinga, jQuery);