158 lines
5.7 KiB
JavaScript
158 lines
5.7 KiB
JavaScript
|
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
||
|
|
||
|
/**
|
||
|
* Unbind all event handlers before tearing down a page
|
||
|
*/
|
||
|
AJAX.registerTeardown('server_variables.js', function () {
|
||
|
$('#serverVariables .var-row').unbind('hover');
|
||
|
$('#filterText').unbind('keyup');
|
||
|
$('a.editLink').die('click');
|
||
|
$('#serverVariables').find('.var-name').find('a img').remove();
|
||
|
});
|
||
|
|
||
|
AJAX.registerOnload('server_variables.js', function () {
|
||
|
var $editLink = $('a.editLink');
|
||
|
var $saveLink = $('a.saveLink');
|
||
|
var $cancelLink = $('a.cancelLink');
|
||
|
var $filterField = $('#filterText');
|
||
|
|
||
|
/* Show edit link on hover */
|
||
|
$('#serverVariables').delegate('.var-row', 'hover', function (event) {
|
||
|
if (event.type === 'mouseenter') {
|
||
|
var $elm = $(this).find('.var-value');
|
||
|
// Only add edit element if the element is not being edited
|
||
|
if ($elm.hasClass('editable') && ! $elm.hasClass('edit')) {
|
||
|
$elm.prepend($editLink.clone().show());
|
||
|
}
|
||
|
} else {
|
||
|
$(this).find('a.editLink').remove();
|
||
|
}
|
||
|
}).find('.var-name').find('a').append(
|
||
|
$('#docImage').clone().show()
|
||
|
);
|
||
|
|
||
|
/* Launches the variable editor */
|
||
|
$editLink.live('click', function (event) {
|
||
|
event.preventDefault();
|
||
|
editVariable(this);
|
||
|
});
|
||
|
|
||
|
/* Event handler for variables filter */
|
||
|
$filterField.keyup(function () {
|
||
|
var textFilter = null, val = $(this).val();
|
||
|
if (val.length !== 0) {
|
||
|
textFilter = new RegExp("(^| )" + val.replace(/_/g, ' '), 'i');
|
||
|
}
|
||
|
filterVariables(textFilter);
|
||
|
});
|
||
|
|
||
|
/* Trigger filtering of the list based on incoming variable name */
|
||
|
if ($filterField.val()) {
|
||
|
$filterField.trigger('keyup').select();
|
||
|
}
|
||
|
|
||
|
/* Filters the rows by the user given regexp */
|
||
|
function filterVariables(textFilter) {
|
||
|
var mark_next = false, $row, odd_row = false;
|
||
|
$('#serverVariables .var-row').not('.var-header').each(function () {
|
||
|
$row = $(this);
|
||
|
if (mark_next || textFilter === null ||
|
||
|
textFilter.exec($row.find('.var-name').text())
|
||
|
) {
|
||
|
// If current global value is different from session value
|
||
|
// (has class diffSession), then display that one too
|
||
|
mark_next = $row.hasClass('diffSession') && ! mark_next;
|
||
|
|
||
|
odd_row = ! odd_row;
|
||
|
$row.css('display', '');
|
||
|
if (odd_row) {
|
||
|
$row.addClass('odd').removeClass('even');
|
||
|
} else {
|
||
|
$row.addClass('even').removeClass('odd');
|
||
|
}
|
||
|
} else {
|
||
|
$row.css('display', 'none');
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
/* Allows the user to edit a server variable */
|
||
|
function editVariable(link) {
|
||
|
var $cell = $(link).parent();
|
||
|
var varName = $cell.parent().find('.var-name').text().replace(/ /g, '_');
|
||
|
var $mySaveLink = $saveLink.clone().show();
|
||
|
var $myCancelLink = $cancelLink.clone().show();
|
||
|
var $msgbox = PMA_ajaxShowMessage();
|
||
|
|
||
|
$cell
|
||
|
.addClass('edit') // variable is being edited
|
||
|
.find('a.editLink')
|
||
|
.remove(); // remove edit link
|
||
|
|
||
|
$mySaveLink.click(function () {
|
||
|
var $msgbox = PMA_ajaxShowMessage(PMA_messages.strProcessingRequest);
|
||
|
$.get($(this).attr('href'), {
|
||
|
ajax_request: true,
|
||
|
type: 'setval',
|
||
|
varName: varName,
|
||
|
varValue: $cell.find('input').val()
|
||
|
}, function (data) {
|
||
|
if (data.success) {
|
||
|
$cell
|
||
|
.html(data.variable)
|
||
|
.data('content', data.variable);
|
||
|
PMA_ajaxRemoveMessage($msgbox);
|
||
|
} else {
|
||
|
PMA_ajaxShowMessage(data.error, false);
|
||
|
$cell.html($cell.data('content'));
|
||
|
}
|
||
|
$cell.removeClass('edit');
|
||
|
});
|
||
|
return false;
|
||
|
});
|
||
|
|
||
|
$myCancelLink.click(function () {
|
||
|
$cell
|
||
|
.html($cell.data('content'))
|
||
|
.removeClass('edit');
|
||
|
return false;
|
||
|
});
|
||
|
|
||
|
$.get($mySaveLink.attr('href'), {
|
||
|
ajax_request: true,
|
||
|
type: 'getval',
|
||
|
varName: varName
|
||
|
}, function (data) {
|
||
|
if (data.success === true) {
|
||
|
var $editor = $('<div />', {'class': 'serverVariableEditor'})
|
||
|
.append($myCancelLink)
|
||
|
.append(' ')
|
||
|
.append($mySaveLink)
|
||
|
.append(' ')
|
||
|
.append(
|
||
|
$('<div/>').append(
|
||
|
$('<input />', {type: 'text'}).val(data.message)
|
||
|
)
|
||
|
);
|
||
|
// Save and replace content
|
||
|
$cell
|
||
|
.data('content', $cell.html())
|
||
|
.html($editor)
|
||
|
.find('input')
|
||
|
.focus()
|
||
|
.keydown(function (event) { // Keyboard shortcuts
|
||
|
if (event.keyCode === 13) { // Enter key
|
||
|
$mySaveLink.trigger('click');
|
||
|
} else if (event.keyCode === 27) { // Escape key
|
||
|
$myCancelLink.trigger('click');
|
||
|
}
|
||
|
});
|
||
|
PMA_ajaxRemoveMessage($msgbox);
|
||
|
} else {
|
||
|
$cell.removeClass('edit');
|
||
|
PMA_ajaxShowMessage(data.error);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|