js: Add method `identifyLinkTarget()` to the loader

This commit is contained in:
Johannes Meyer 2021-02-24 16:54:56 +01:00
parent 4f57aa68cd
commit 6e8ca9cdda
1 changed files with 33 additions and 19 deletions

View File

@ -1076,8 +1076,7 @@
} }
// If everything else fails, our target is the first column... // If everything else fails, our target is the first column...
var $col1 = $('#col1'); var $target = $('#col1');
var $target = $col1;
// ...but usually we will use our own container... // ...but usually we will use our own container...
var $container = $el.closest('.container'); var $container = $el.closest('.container');
@ -1089,25 +1088,11 @@
if ($el.closest('[data-base-target]').length) { if ($el.closest('[data-base-target]').length) {
var targetId = $el.closest('[data-base-target]').data('baseTarget'); var targetId = $el.closest('[data-base-target]').data('baseTarget');
// Simulate _next to prepare migration to dynamic column layout $target = this.identifyLinkTarget(targetId, $el);
// YES, there are duplicate lines right now.
if (targetId === '_next') {
if (this.icinga.ui.hasOnlyOneColumn()) {
$target = $col1;
} else {
$target = $('#col2');
}
} else if (targetId === '_self') {
$target = $el.closest('.container');
} else if (targetId === '_main') {
$target = $col1;
} else {
$target = $('#' + targetId);
if (! $target.length) { if (! $target.length) {
this.icinga.logger.warn('Link target "#' + targetId + '" does not exist in DOM.'); this.icinga.logger.warn('Link target "#' + targetId + '" does not exist in DOM.');
} }
} }
}
if (prepare) { if (prepare) {
this.icinga.ui.prepareColumnFor($el, $target); this.icinga.ui.prepareColumnFor($el, $target);
@ -1116,6 +1101,35 @@
return $target; return $target;
}, },
/**
* Identify link target by the given id
*
* The id may also be one of the column aliases: `_next`, `_self` and `_main`
*
* @param {string} id
* @param {object} $of
* @return {object}
*/
identifyLinkTarget: function (id, $of) {
var $target;
if (id === '_next') {
if (this.icinga.ui.hasOnlyOneColumn()) {
$target = $('#col1');
} else {
$target = $('#col2');
}
} else if (id === '_self') {
$target = $of.closest('.container');
} else if (id === '_main') {
$target = $('#col1');
} else {
$target = $('#' + id);
}
return $target;
},
/** /**
* Smoothly render given HTML to given container * Smoothly render given HTML to given container
*/ */