243 lines
8.7 KiB
JavaScript
243 lines
8.7 KiB
JavaScript
|
|
(function(Icinga) {
|
|
|
|
var Director = function(module) {
|
|
this.module = module;
|
|
|
|
this.initialize();
|
|
|
|
this.openedFieldsets = {};
|
|
|
|
this.module.icinga.logger.debug('Director module loaded');
|
|
};
|
|
|
|
Director.prototype = {
|
|
|
|
initialize: function()
|
|
{
|
|
/**
|
|
* Tell Icinga about our event handlers
|
|
*/
|
|
this.module.on('rendered', this.rendered);
|
|
this.module.on('click', 'fieldset > legend', this.toggleFieldset);
|
|
this.module.on('click', 'input.related-action', this.extensibleSetAction);
|
|
this.module.on('focus', 'form input', this.formElementFocus);
|
|
this.module.on('focus', 'form textarea', this.formElementFocus);
|
|
this.module.on('focus', 'form select', this.formElementFocus);
|
|
this.module.icinga.logger.debug('Director module initialized');
|
|
},
|
|
|
|
extensibleSetAction: function(ev)
|
|
{
|
|
var el = ev.currentTarget;
|
|
|
|
if (el.name.match(/__MOVE_UP$/)) {
|
|
var $li = $(el).closest('li');
|
|
var $prev = $li.prev()
|
|
if ($li.find('input[type=text].autosubmit')) {
|
|
if (iid = $prev.find('input[type=text]').attr('id')) {
|
|
$li.closest('.container').data('activeExtensibleEntry', iid);
|
|
}
|
|
return true;
|
|
}
|
|
if ($prev.length) {
|
|
$prev.before($li.detach());
|
|
this.fixRelatedActions($li.closest('ul'));
|
|
}
|
|
ev.preventDefault();
|
|
ev.stopPropagation();
|
|
return false;
|
|
} else if (el.name.match(/__MOVE_DOWN$/)) {
|
|
var $li = $(el).closest('li');
|
|
var $next = $li.next()
|
|
if ($li.find('input[type=text].autosubmit')) {
|
|
if (iid = $next.find('input[type=text]').attr('id')) {
|
|
$li.closest('.container').data('activeExtensibleEntry', iid);
|
|
}
|
|
return true;
|
|
}
|
|
if ($next.length && ! $next.find('.extend-set').length) {
|
|
$next.after($li.detach());
|
|
this.fixRelatedActions($li.closest('ul'));
|
|
}
|
|
ev.preventDefault();
|
|
ev.stopPropagation();
|
|
return false;
|
|
} else if (el.name.match(/__MOVE_REMOVE$/)) {
|
|
// TODO: skipping for now, wasn't able to prevent web2 form
|
|
// submission once removed
|
|
return;
|
|
|
|
var $li = $(el).closest('li').remove();
|
|
this.fixRelatedActions($li.closest('ul'));
|
|
ev.preventDefault();
|
|
ev.stopPropagation();
|
|
return false;
|
|
}
|
|
},
|
|
|
|
fixRelatedActions: function($ul)
|
|
{
|
|
var $uls = $ul.find('li');
|
|
var last = $uls.length - 1;
|
|
if ($ul.find('.extend-set').length) {
|
|
last--;
|
|
}
|
|
|
|
$uls.each(function (idx, li) {
|
|
var $li = $(li);
|
|
if (idx === 0) {
|
|
$li.find('.action-move-up').attr('disabled', 'disabled');
|
|
if (last === 0) {
|
|
$li.find('.action-move-down').attr('disabled', 'disabled');
|
|
} else {
|
|
$li.find('.action-move-down').removeAttr('disabled');
|
|
}
|
|
} else if (idx === last) {
|
|
$li.find('.action-move-up').removeAttr('disabled');
|
|
$li.find('.action-move-down').attr('disabled', 'disabled');
|
|
} else {
|
|
$li.find('.action-move-up').removeAttr('disabled');
|
|
$li.find('.action-move-down').removeAttr('disabled');
|
|
}
|
|
});
|
|
},
|
|
|
|
formElementFocus: function(ev)
|
|
{
|
|
var $input = $(ev.currentTarget);
|
|
if ($input.closest('form.editor').length) {
|
|
return;
|
|
}
|
|
var $dd = $input.closest('dd');
|
|
$dd.find('p.description').show();
|
|
if ($dd.attr('id') && $dd.attr('id').match(/button/)) {
|
|
return;
|
|
}
|
|
var $li = $input.closest('li');
|
|
var $dt = $dd.prev();
|
|
var $form = $dt.closest('form');
|
|
|
|
$form.find('dt, dd, li').removeClass('active');
|
|
$li.addClass('active');
|
|
$dt.addClass('active');
|
|
$dd.addClass('active');
|
|
$dd.find('p.description.fading-out')
|
|
.stop(true)
|
|
.removeClass('fading-out')
|
|
.fadeIn('fast');
|
|
|
|
$form.find('dd').not($dd)
|
|
.find('p.description')
|
|
.not('.fading-out')
|
|
.addClass('fading-out')
|
|
.delay(2000)
|
|
.fadeOut('slow', function() {
|
|
$(this).removeClass('fading-out').hide()
|
|
});
|
|
},
|
|
|
|
highlightFormErrors: function($container)
|
|
{
|
|
$container.find('dd ul.errors').each(function(idx, ul) {
|
|
var $ul = $(ul);
|
|
var $dd = $ul.closest('dd');
|
|
var $dt = $dd.prev();
|
|
|
|
$dt.addClass('errors');
|
|
$dd.addClass('errors');
|
|
});
|
|
},
|
|
|
|
toggleFieldset: function (ev) {
|
|
ev.stopPropagation();
|
|
var $fieldset = $(ev.currentTarget).closest('fieldset');
|
|
$fieldset.toggleClass('collapsed');
|
|
this.fixFieldsetInfo($fieldset);
|
|
this.openedFieldsets[$fieldset.attr('id')] = ! $fieldset.hasClass('collapsed');
|
|
},
|
|
|
|
hideInactiveFormDescriptions: function($container) {
|
|
$container.find('dd').not('.active').find('p.description').hide();
|
|
},
|
|
|
|
rendered: function(ev) {
|
|
var $container = $(ev.currentTarget);
|
|
this.restoreContainerFieldsets($container);
|
|
this.backupAllExtensibleSetDefaultValues($container);
|
|
this.putFocusOnFirstObjectTypeElement($container);
|
|
this.highlightFormErrors($container);
|
|
this.hideInactiveFormDescriptions($container);
|
|
if (iid = $container.data('activeExtensibleEntry')) {
|
|
$('#' + iid).focus();
|
|
$container.removeData('activeExtensibleEntry');
|
|
}
|
|
},
|
|
|
|
restoreContainerFieldsets: function($container)
|
|
{
|
|
var self = this;
|
|
$container.find('form').each(self.restoreFieldsets.bind(self));
|
|
},
|
|
|
|
putFocusOnFirstObjectTypeElement: function($container)
|
|
{
|
|
var $objectType = $container.find('form').find('select[name=object_type]');
|
|
if ($objectType.length) {
|
|
if ($objectType[0].value === '') {
|
|
$objectType.focus();
|
|
}
|
|
}
|
|
},
|
|
|
|
backupAllExtensibleSetDefaultValues: function($container) {
|
|
var self = this;
|
|
$container.find('.extensible-set').each(function (idx, eSet) {
|
|
$(eSet).find('input[type=text]').each(self.backupDefaultValue);
|
|
$(eSet).find('select').each(self.backupDefaultValue);
|
|
});
|
|
},
|
|
|
|
backupDefaultValue: function(idx, el) {
|
|
$(el).data('originalvalue', el.value);
|
|
},
|
|
|
|
restoreFieldsets: function(idx, form) {
|
|
var $form = $(form);
|
|
var formId = $form.attr('id');
|
|
var self = this;
|
|
|
|
$('fieldset', $form).each(function(idx, fieldset) {
|
|
var $fieldset = $(fieldset);
|
|
if ($fieldset.find('.required').length == 0 && (! self.fieldsetWasOpened($fieldset))) {
|
|
$fieldset.addClass('collapsed');
|
|
self.fixFieldsetInfo($fieldset);
|
|
}
|
|
});
|
|
},
|
|
|
|
fieldsetWasOpened: function($fieldset) {
|
|
var id = $fieldset.attr('id');
|
|
if (typeof this.openedFieldsets[id] === 'undefined') {
|
|
return false;
|
|
}
|
|
return this.openedFieldsets[id];
|
|
},
|
|
|
|
fixFieldsetInfo: function($fieldset) {
|
|
if ($fieldset.hasClass('collapsed')) {
|
|
if ($fieldset.find('legend span.element-count').length === 0) {
|
|
var cnt = $fieldset.find('dt, li').length;
|
|
$fieldset.find('legend').append($('<span class="element-count"> (' + cnt + ')</span>'));
|
|
}
|
|
} else {
|
|
$fieldset.find('legend span.element-count').remove();
|
|
}
|
|
}
|
|
};
|
|
|
|
Icinga.availableModules.director = Director;
|
|
|
|
}(Icinga));
|
|
|