Merge pull request #4259 from Icinga/feature/add-input-enrichment-behavior

Add input enrichment behavior
This commit is contained in:
Johannes Meyer 2021-01-14 12:13:49 +01:00 committed by GitHub
commit 6024e84663
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 137 additions and 6 deletions

View File

@ -40,7 +40,8 @@ class JavaScript
'js/icinga/behavior/expandable.js', 'js/icinga/behavior/expandable.js',
'js/icinga/behavior/filtereditor.js', 'js/icinga/behavior/filtereditor.js',
'js/icinga/behavior/selectable.js', 'js/icinga/behavior/selectable.js',
'js/icinga/behavior/modal.js' 'js/icinga/behavior/modal.js',
'js/icinga/behavior/input-enrichment.js'
]; ];
protected static $vendorFiles = [ protected static $vendorFiles = [

View File

@ -0,0 +1,130 @@
/* Icinga Web 2 | (c) 2020 Icinga GmbH | GPLv2+ */
/**
* InputEnrichment - Behavior for forms with enriched inputs
*/
(function(Icinga) {
"use strict";
var FilterInput = require('icinga/ipl/widget/FilterInput');
var TermInput = require('icinga/ipl/widget/TermInput');
var Completer = require('icinga/ipl/widget/Completer');
Icinga.Behaviors = Icinga.Behaviors || {};
/**
* @param icinga
* @constructor
*/
var InputEnrichment = function (icinga) {
Icinga.EventListener.call(this, icinga);
this.on('beforerender', '.container', this.onBeforeRender, this);
this.on('rendered', '.container', this.onRendered, this);
/**
* Enriched inputs
*
* @type {WeakMap<object, FilterInput|TermInput|Completer>}
* @private
*/
this._enrichments = new WeakMap();
/**
* Cached enrichments
*
* Holds values only during the time between `beforerender` and `rendered`
*
* @type {{}}
* @private
*/
this._cachedEnrichments = {};
};
InputEnrichment.prototype = new Icinga.EventListener();
/**
* @param data
*/
InputEnrichment.prototype.update = function (data) {
var input = document.querySelector(data[0]);
if (input !== null && this._enrichments.has(input)) {
this._enrichments.get(input).updateTerms(data[1]);
}
};
/**
* @param event
* @param content
* @param action
* @param autorefresh
* @param scripted
*/
InputEnrichment.prototype.onBeforeRender = function (event, content, action, autorefresh, scripted) {
if (! autorefresh) {
return;
}
let _this = event.data.self;
let inputs = event.currentTarget.querySelectorAll('input[data-enrichment-type]');
// Remember current instances
inputs.forEach(function (input) {
var enrichment = _this._enrichments.get(input);
if (enrichment) {
_this._cachedEnrichments[_this.icinga.utils.getDomPath(input).join(' ')] = enrichment;
}
});
};
/**
* @param event
* @param autorefresh
* @param scripted
*/
InputEnrichment.prototype.onRendered = function (event, autorefresh, scripted) {
let _this = event.data.self;
let container = event.currentTarget;
if (autorefresh) {
// Apply remembered instances
for (var inputPath in _this._cachedEnrichments) {
var enrichment = _this._cachedEnrichments[inputPath];
var input = container.querySelector(inputPath);
if (input !== null) {
enrichment.refresh(input);
_this._enrichments.set(input, enrichment);
} else {
enrichment.destroy();
}
delete _this._cachedEnrichments[inputPath];
}
}
// Create new instances
var inputs = container.querySelectorAll('input[data-enrichment-type]');
inputs.forEach(function (input) {
var enrichment = _this._enrichments.get(input);
if (! enrichment) {
switch (input.dataset.enrichmentType) {
case 'filter':
enrichment = (new FilterInput(input)).bind();
enrichment.restoreTerms();
break;
case 'terms':
enrichment = (new TermInput(input)).bind();
enrichment.restoreTerms();
break;
case 'completion':
enrichment = (new Completer(input)).bind();
}
_this._enrichments.set(input, enrichment);
}
});
};
Icinga.Behaviors.InputEnrichment = InputEnrichment;
})(Icinga);

View File

@ -129,8 +129,8 @@
// Disable all form controls to prevent resubmission except for our search input // Disable all form controls to prevent resubmission except for our search input
// Note that disabled form inputs will not be enabled via JavaScript again // Note that disabled form inputs will not be enabled via JavaScript again
if ($target.attr('id') === $form.closest('.container').attr('id')) { if (! $form.is('[role="search"]') && $target.attr('id') === $form.closest('.container').attr('id')) {
$form.find(':input:not(#search):not(:disabled)').prop('disabled', true); $form.find('input:not(:disabled)').prop('disabled', true);
} }
// Show a spinner depending on how the form is being submitted // Show a spinner depending on how the form is being submitted
@ -960,9 +960,9 @@
_this.icinga.loadModule(moduleName); _this.icinga.loadModule(moduleName);
} }
$(this).trigger('rendered'); $(this).trigger('rendered', [req.autorefresh, req.scripted]);
}); });
req.$target.trigger('rendered'); req.$target.trigger('rendered', [req.autorefresh, req.scripted]);
this.icinga.ui.refreshDebug(); this.icinga.ui.refreshDebug();
}, },
@ -1158,7 +1158,7 @@
} }
} }
$container.trigger('beforerender'); $container.trigger('beforerender', [content, action, autorefresh, scripted]);
var discard = false; var discard = false;
$.each(_this.icinga.behaviors, function(name, behavior) { $.each(_this.icinga.behaviors, function(name, behavior) {