server_databases.js 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /* vim: set expandtab sw=4 ts=4 sts=4: */
  2. /**
  3. * @fileoverview functions used on the server databases list page
  4. * @name Server Databases
  5. *
  6. * @requires jQuery
  7. * @requires jQueryUI
  8. * @required js/functions.js
  9. */
  10. /**
  11. * Unbind all event handlers before tearing down a page
  12. */
  13. AJAX.registerTeardown('server_databases.js', function () {
  14. $(document).off('submit', '#dbStatsForm');
  15. $(document).off('submit', '#create_database_form.ajax');
  16. });
  17. /**
  18. * AJAX scripts for server_databases.php
  19. *
  20. * Actions ajaxified here:
  21. * Drop Databases
  22. *
  23. */
  24. AJAX.registerOnload('server_databases.js', function () {
  25. /**
  26. * Attach Event Handler for 'Drop Databases'
  27. */
  28. $(document).on('submit', '#dbStatsForm', function (event) {
  29. event.preventDefault();
  30. var $form = $(this);
  31. /**
  32. * @var selected_dbs Array containing the names of the checked databases
  33. */
  34. var selected_dbs = [];
  35. // loop over all checked checkboxes, except the .checkall_box checkbox
  36. $form.find('input:checkbox:checked:not(.checkall_box)').each(function () {
  37. $(this).closest('tr').addClass('removeMe');
  38. selected_dbs[selected_dbs.length] = 'DROP DATABASE `' + escapeHtml($(this).val()) + '`;';
  39. });
  40. if (! selected_dbs.length) {
  41. PMA_ajaxShowMessage(
  42. $('<div class="notice" />').text(
  43. PMA_messages.strNoDatabasesSelected
  44. ),
  45. 2000
  46. );
  47. return;
  48. }
  49. /**
  50. * @var question String containing the question to be asked for confirmation
  51. */
  52. var question = PMA_messages.strDropDatabaseStrongWarning + ' ' +
  53. PMA_sprintf(PMA_messages.strDoYouReally, selected_dbs.join('<br />'));
  54. var argsep = PMA_commonParams.get('arg_separator');
  55. $(this).PMA_confirm(
  56. question,
  57. $form.prop('action') + '?' + $(this).serialize() +
  58. argsep + 'drop_selected_dbs=1' + argsep + 'is_js_confirmed=1' + argsep + 'ajax_request=true',
  59. function (url) {
  60. PMA_ajaxShowMessage(PMA_messages.strProcessingRequest, false);
  61. var params = getJSConfirmCommonParam(this);
  62. $.post(url, params, function (data) {
  63. if (typeof data !== 'undefined' && data.success === true) {
  64. PMA_ajaxShowMessage(data.message);
  65. var $rowsToRemove = $form.find('tr.removeMe');
  66. var $databasesCount = $('#filter-rows-count');
  67. var newCount = parseInt($databasesCount.text(), 10) - $rowsToRemove.length;
  68. $databasesCount.text(newCount);
  69. $rowsToRemove.remove();
  70. $form.find('tbody').PMA_sort_table('.name');
  71. if ($form.find('tbody').find('tr').length === 0) {
  72. // user just dropped the last db on this page
  73. PMA_commonActions.refreshMain();
  74. }
  75. PMA_reloadNavigation();
  76. } else {
  77. $form.find('tr.removeMe').removeClass('removeMe');
  78. PMA_ajaxShowMessage(data.error, false);
  79. }
  80. }); // end $.post()
  81. }
  82. ); // end $.PMA_confirm()
  83. }); // end of Drop Database action
  84. /**
  85. * Attach Ajax event handlers for 'Create Database'.
  86. */
  87. $(document).on('submit', '#create_database_form.ajax', function (event) {
  88. event.preventDefault();
  89. var $form = $(this);
  90. // TODO Remove this section when all browsers support HTML5 "required" property
  91. var newDbNameInput = $form.find('input[name=new_db]');
  92. if (newDbNameInput.val() === '') {
  93. newDbNameInput.focus();
  94. alert(PMA_messages.strFormEmpty);
  95. return;
  96. }
  97. // end remove
  98. PMA_ajaxShowMessage(PMA_messages.strProcessingRequest);
  99. PMA_prepareForAjaxRequest($form);
  100. $.post($form.attr('action'), $form.serialize(), function (data) {
  101. if (typeof data !== 'undefined' && data.success === true) {
  102. PMA_ajaxShowMessage(data.message);
  103. var $databases_count_object = $('#filter-rows-count');
  104. var databases_count = parseInt($databases_count_object.text(), 10) + 1;
  105. $databases_count_object.text(databases_count);
  106. PMA_reloadNavigation();
  107. // make ajax request to load db structure page - taken from ajax.js
  108. var dbStruct_url = data.url_query;
  109. dbStruct_url = dbStruct_url.replace(/amp;/ig, '');
  110. var params = 'ajax_request=true' + PMA_commonParams.get('arg_separator') + 'ajax_page_request=true';
  111. if (! (history && history.pushState)) {
  112. params += PMA_MicroHistory.menus.getRequestParam();
  113. }
  114. $.get(dbStruct_url, params, AJAX.responseHandler);
  115. } else {
  116. PMA_ajaxShowMessage(data.error, false);
  117. }
  118. }); // end $.post()
  119. }); // end $(document).on()
  120. /* Don't show filter if number of databases are very few */
  121. var databasesCount = $('#filter-rows-count').html();
  122. if (databasesCount <= 10) {
  123. $('#tableFilter').hide();
  124. }
  125. var tableRows = $('.server_databases');
  126. $.each(tableRows, function (index, item) {
  127. $(this).click(function () {
  128. PMA_commonActions.setDb($(this).attr('data'));
  129. });
  130. });
  131. }); // end $()