Merge pull request #4259 from Icinga/feature/add-input-enrichment-behavior
Add input enrichment behavior
This commit is contained in:
commit
6024e84663
|
@ -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 = [
|
||||||
|
|
|
@ -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);
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue