123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- /* vim: set expandtab sw=4 ts=4 sts=4: */
- /**
- * @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.php
- *
- * 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 selected_dbs = [];
- // 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');
- selected_dbs[selected_dbs.length] = 'DROP DATABASE `' + escapeHtml($(this).val()) + '`;';
- });
- if (! selected_dbs.length) {
- PMA_ajaxShowMessage(
- $('<div class="notice" />').text(
- PMA_messages.strNoDatabasesSelected
- ),
- 2000
- );
- return;
- }
- /**
- * @var question String containing the question to be asked for confirmation
- */
- var question = PMA_messages.strDropDatabaseStrongWarning + ' ' +
- PMA_sprintf(PMA_messages.strDoYouReally, selected_dbs.join('<br />'));
- var argsep = PMA_commonParams.get('arg_separator');
- $(this).PMA_confirm(
- question,
- $form.prop('action') + '?' + $(this).serialize() +
- argsep + 'drop_selected_dbs=1',
- function (url) {
- PMA_ajaxShowMessage(PMA_messages.strProcessingRequest, false);
- var parts = url.split('?');
- var params = getJSConfirmCommonParam(this, parts[1]);
- $.post(parts[0], params, function (data) {
- if (typeof data !== 'undefined' && data.success === true) {
- PMA_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').PMA_sort_table('.name');
- if ($form.find('tbody').find('tr').length === 0) {
- // user just dropped the last db on this page
- PMA_commonActions.refreshMain();
- }
- PMA_reloadNavigation();
- } else {
- $form.find('tr.removeMe').removeClass('removeMe');
- PMA_ajaxShowMessage(data.error, false);
- }
- }); // end $.post()
- }
- ); // end $.PMA_confirm()
- }); // end of Drop Database action
- /**
- * 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.focus();
- alert(PMA_messages.strFormEmpty);
- return;
- }
- // end remove
- PMA_ajaxShowMessage(PMA_messages.strProcessingRequest);
- PMA_prepareForAjaxRequest($form);
- $.post($form.attr('action'), $form.serialize(), function (data) {
- if (typeof data !== 'undefined' && data.success === true) {
- PMA_ajaxShowMessage(data.message);
- var $databases_count_object = $('#filter-rows-count');
- var databases_count = parseInt($databases_count_object.text(), 10) + 1;
- $databases_count_object.text(databases_count);
- PMA_reloadNavigation();
- // make ajax request to load db structure page - taken from ajax.js
- var dbStruct_url = data.url_query;
- dbStruct_url = dbStruct_url.replace(/amp;/ig, '');
- var params = 'ajax_request=true' + PMA_commonParams.get('arg_separator') + 'ajax_page_request=true';
- if (! (history && history.pushState)) {
- params += PMA_MicroHistory.menus.getRequestParam();
- }
- $.get(dbStruct_url, params, AJAX.responseHandler);
- } else {
- PMA_ajaxShowMessage(data.error, false);
- }
- }); // end $.post()
- }); // end $(document).on()
- /* Don't show filter if number of databases are very few */
- var databasesCount = $('#filter-rows-count').html();
- if (databasesCount <= 10) {
- $('#tableFilter').hide();
- }
- var tableRows = $('.server_databases');
- $.each(tableRows, function (index, item) {
- $(this).click(function () {
- PMA_commonActions.setDb($(this).attr('data'));
- });
- });
- }); // end $()
|