/** * @fileoverview functions used on the server databases list page * @name Server Databases * * @requires jQuery * @requires jQueryUI * @required js/functions.js */ /** * Unbind all event handlers before tearing down a page */ AJAX.registerTeardown('server/databases.js', function () { $(document).off('submit', '#dbStatsForm'); $(document).off('submit', '#create_database_form.ajax'); }); /** * AJAX scripts for /server/databases * * Actions ajaxified here: * Drop Databases * */ AJAX.registerOnload('server/databases.js', function () { /** * Attach Event Handler for 'Drop Databases' */ $(document).on('submit', '#dbStatsForm', function (event) { event.preventDefault(); var $form = $(this); /** * @var selected_dbs Array containing the names of the checked databases */ var selectedDbs = []; // loop over all checked checkboxes, except the .checkall_box checkbox $form.find('input:checkbox:checked:not(.checkall_box)').each(function () { $(this).closest('tr').addClass('removeMe'); selectedDbs[selectedDbs.length] = 'DROP DATABASE `' + Functions.escapeHtml($(this).val()) + '`;'; }); if (!selectedDbs.length) { Functions.ajaxShowMessage($('').text(Messages.strNoDatabasesSelected), 2000); return; } /** * @var question String containing the question to be asked for confirmation */ var question = Messages.strDropDatabaseStrongWarning + ' ' + Functions.sprintf(Messages.strDoYouReally, selectedDbs.join('
')); const modal = $('#dropDatabaseModal'); modal.find('.modal-body').html(question); modal.modal('show'); const url = 'index.php?route=/server/databases/destroy&' + $(this).serialize(); $('#dropDatabaseModalDropButton').on('click', function () { Functions.ajaxShowMessage(Messages.strProcessingRequest, false); var parts = url.split('?'); var params = Functions.getJsConfirmCommonParam(this, parts[1]); $.post(parts[0], params, function (data) { if (typeof data !== 'undefined' && data.success === true) { Functions.ajaxShowMessage(data.message); var $rowsToRemove = $form.find('tr.removeMe'); var $databasesCount = $('#filter-rows-count'); var newCount = parseInt($databasesCount.text(), 10) - $rowsToRemove.length; $databasesCount.text(newCount); $rowsToRemove.remove(); $form.find('tbody').sortTable('.name'); if ($form.find('tbody').find('tr').length === 0) { // user just dropped the last db on this page CommonActions.refreshMain(); } Navigation.reload(); } else { $form.find('tr.removeMe').removeClass('removeMe'); Functions.ajaxShowMessage(data.error, false); } }); modal.modal('hide'); $('#dropDatabaseModalDropButton').off('click'); }); }); /** * Attach Ajax event handlers for 'Create Database'. */ $(document).on('submit', '#create_database_form.ajax', function (event) { event.preventDefault(); var $form = $(this); // TODO Remove this section when all browsers support HTML5 "required" property var newDbNameInput = $form.find('input[name=new_db]'); if (newDbNameInput.val() === '') { newDbNameInput.trigger('focus'); alert(Messages.strFormEmpty); return; } // end remove Functions.ajaxShowMessage(Messages.strProcessingRequest); Functions.prepareForAjaxRequest($form); $.post($form.attr('action'), $form.serialize(), function (data) { if (typeof data !== 'undefined' && data.success === true) { Functions.ajaxShowMessage(data.message); var $databasesCountObject = $('#filter-rows-count'); var databasesCount = parseInt($databasesCountObject.text(), 10) + 1; $databasesCountObject.text(databasesCount); Navigation.reload(); // make ajax request to load db structure page - taken from ajax.js var dbStructUrl = data.url; dbStructUrl = dbStructUrl.replace(/amp;/ig, ''); var params = 'ajax_request=true' + CommonParams.get('arg_separator') + 'ajax_page_request=true'; $.get(dbStructUrl, params, AJAX.responseHandler); } else { Functions.ajaxShowMessage(data.error, false); } }); // end $.post() }); // end $(document).on() var tableRows = $('.server_databases'); $.each(tableRows, function () { $(this).on('click', function () { CommonActions.setDb($(this).attr('data')); }); }); }); // end $()