tbl_relation.js 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. /* vim: set expandtab sw=4 ts=4 sts=4: */
  2. /**
  3. * for tbl_relation.php
  4. *
  5. */
  6. function show_hide_clauses ($thisDropdown) {
  7. if ($thisDropdown.val() === '') {
  8. $thisDropdown.parent().nextAll('span').hide();
  9. } else {
  10. if ($thisDropdown.is('select[name^="destination_foreign_column"]')) {
  11. $thisDropdown.parent().nextAll('span').show();
  12. }
  13. }
  14. }
  15. /**
  16. * Sets dropdown options to values
  17. */
  18. function setDropdownValues ($dropdown, values, selectedValue) {
  19. $dropdown.empty();
  20. var optionsAsString = '';
  21. // add an empty string to the beginning for empty selection
  22. values.unshift('');
  23. $.each(values, function () {
  24. optionsAsString += '<option value=\'' + escapeHtml(this) + '\'' + (selectedValue === escapeHtml(this) ? ' selected=\'selected\'' : '') + '>' + escapeHtml(this) + '</option>';
  25. });
  26. $dropdown.append($(optionsAsString));
  27. }
  28. /**
  29. * Retrieves and populates dropdowns to the left based on the selected value
  30. *
  31. * @param $dropdown the dropdown whose value got changed
  32. */
  33. function getDropdownValues ($dropdown) {
  34. var foreignDb = null;
  35. var foreignTable = null;
  36. var $databaseDd;
  37. var $tableDd;
  38. var $columnDd;
  39. var foreign = '';
  40. // if the changed dropdown is for foreign key constraints
  41. if ($dropdown.is('select[name^="destination_foreign"]')) {
  42. $databaseDd = $dropdown.parent().parent().parent().find('select[name^="destination_foreign_db"]');
  43. $tableDd = $dropdown.parent().parent().parent().find('select[name^="destination_foreign_table"]');
  44. $columnDd = $dropdown.parent().parent().parent().find('select[name^="destination_foreign_column"]');
  45. foreign = '_foreign';
  46. } else { // internal relations
  47. $databaseDd = $dropdown.parent().find('select[name^="destination_db"]');
  48. $tableDd = $dropdown.parent().find('select[name^="destination_table"]');
  49. $columnDd = $dropdown.parent().find('select[name^="destination_column"]');
  50. }
  51. // if the changed dropdown is a database selector
  52. if ($dropdown.is('select[name^="destination' + foreign + '_db"]')) {
  53. foreignDb = $dropdown.val();
  54. // if no database is selected empty table and column dropdowns
  55. if (foreignDb === '') {
  56. setDropdownValues($tableDd, []);
  57. setDropdownValues($columnDd, []);
  58. return;
  59. }
  60. } else { // if a table selector
  61. foreignDb = $databaseDd.val();
  62. foreignTable = $dropdown.val();
  63. // if no table is selected empty the column dropdown
  64. if (foreignTable === '') {
  65. setDropdownValues($columnDd, []);
  66. return;
  67. }
  68. }
  69. var $msgbox = PMA_ajaxShowMessage();
  70. var $form = $dropdown.parents('form');
  71. var argsep = PMA_commonParams.get('arg_separator');
  72. var params = 'getDropdownValues=true' + argsep + 'ajax_request=true' +
  73. argsep + 'db=' + $form.find('input[name="db"]').val() +
  74. argsep + 'table=' + $form.find('input[name="table"]').val() +
  75. argsep + 'foreign=' + (foreign !== '') +
  76. argsep + 'foreignDb=' + encodeURIComponent(foreignDb) +
  77. (foreignTable !== null ?
  78. argsep + 'foreignTable=' + encodeURIComponent(foreignTable) : ''
  79. );
  80. var $server = $form.find('input[name="server"]');
  81. if ($server.length > 0) {
  82. params += argsep + 'server=' + $form.find('input[name="server"]').val();
  83. }
  84. $.ajax({
  85. type: 'POST',
  86. url: 'tbl_relation.php',
  87. data: params,
  88. dataType: 'json',
  89. success: function (data) {
  90. PMA_ajaxRemoveMessage($msgbox);
  91. if (typeof data !== 'undefined' && data.success) {
  92. // if the changed dropdown is a database selector
  93. if (foreignTable === null) {
  94. // set values for table and column dropdowns
  95. setDropdownValues($tableDd, data.tables);
  96. setDropdownValues($columnDd, []);
  97. } else { // if a table selector
  98. // set values for the column dropdown
  99. var primary = null;
  100. if (typeof data.primary !== 'undefined'
  101. && 1 === data.primary.length
  102. ) {
  103. primary = data.primary[0];
  104. }
  105. setDropdownValues($columnDd.first(), data.columns, primary);
  106. setDropdownValues($columnDd.slice(1), data.columns);
  107. }
  108. } else {
  109. PMA_ajaxShowMessage(data.error, false);
  110. }
  111. }
  112. });
  113. }
  114. /**
  115. * Unbind all event handlers before tearing down a page
  116. */
  117. AJAX.registerTeardown('tbl_relation.js', function () {
  118. $('body').off('change',
  119. 'select[name^="destination_db"], ' +
  120. 'select[name^="destination_table"], ' +
  121. 'select[name^="destination_foreign_db"], ' +
  122. 'select[name^="destination_foreign_table"]'
  123. );
  124. $('body').off('click', 'a.add_foreign_key_field');
  125. $('body').off('click', 'a.add_foreign_key');
  126. $('a.drop_foreign_key_anchor.ajax').off('click');
  127. });
  128. AJAX.registerOnload('tbl_relation.js', function () {
  129. /**
  130. * Ajax event handler to fetch table/column dropdown values.
  131. */
  132. $('body').on('change',
  133. 'select[name^="destination_db"], ' +
  134. 'select[name^="destination_table"], ' +
  135. 'select[name^="destination_foreign_db"], ' +
  136. 'select[name^="destination_foreign_table"]',
  137. function () {
  138. getDropdownValues($(this));
  139. }
  140. );
  141. /**
  142. * Ajax event handler to add a column to a foreign key constraint.
  143. */
  144. $('body').on('click', 'a.add_foreign_key_field', function (event) {
  145. event.preventDefault();
  146. event.stopPropagation();
  147. // Add field.
  148. $(this)
  149. .prev('span')
  150. .clone(true, true)
  151. .insertBefore($(this))
  152. .find('select')
  153. .val('');
  154. // Add foreign field.
  155. var $source_elem = $('select[name^="destination_foreign_column[' +
  156. $(this).attr('data-index') + ']"]:last').parent();
  157. $source_elem
  158. .clone(true, true)
  159. .insertAfter($source_elem)
  160. .find('select')
  161. .val('');
  162. });
  163. /**
  164. * Ajax event handler to add a foreign key constraint.
  165. */
  166. $('body').on('click', 'a.add_foreign_key', function (event) {
  167. event.preventDefault();
  168. event.stopPropagation();
  169. var $prev_row = $(this).closest('tr').prev('tr');
  170. var $newRow = $prev_row.clone(true, true);
  171. // Update serial number.
  172. var curr_index = $newRow
  173. .find('a.add_foreign_key_field')
  174. .attr('data-index');
  175. var new_index = parseInt(curr_index) + 1;
  176. $newRow.find('a.add_foreign_key_field').attr('data-index', new_index);
  177. // Update form parameter names.
  178. $newRow.find('select[name^="foreign_key_fields_name"]:not(:first), ' +
  179. 'select[name^="destination_foreign_column"]:not(:first)'
  180. ).each(function () {
  181. $(this).parent().remove();
  182. });
  183. $newRow.find('input, select').each(function () {
  184. $(this).attr('name',
  185. $(this).attr('name').replace(/\d/, new_index)
  186. );
  187. });
  188. $newRow.find('input[type="text"]').each(function () {
  189. $(this).val('');
  190. });
  191. // Finally add the row.
  192. $newRow.insertAfter($prev_row);
  193. });
  194. /**
  195. * Ajax Event handler for 'Drop Foreign key'
  196. */
  197. $('a.drop_foreign_key_anchor.ajax').on('click', function (event) {
  198. event.preventDefault();
  199. var $anchor = $(this);
  200. // Object containing reference to the current field's row
  201. var $curr_row = $anchor.parents('tr');
  202. var drop_query = escapeHtml(
  203. $curr_row.children('td')
  204. .children('.drop_foreign_key_msg')
  205. .val()
  206. );
  207. var question = PMA_sprintf(PMA_messages.strDoYouReally, drop_query);
  208. $anchor.PMA_confirm(question, $anchor.attr('href'), function (url) {
  209. var $msg = PMA_ajaxShowMessage(PMA_messages.strDroppingForeignKey, false);
  210. var params = getJSConfirmCommonParam(this, $anchor.getPostData());
  211. $.post(url, params, function (data) {
  212. if (data.success === true) {
  213. PMA_ajaxRemoveMessage($msg);
  214. PMA_commonActions.refreshMain(false, function () {
  215. // Do nothing
  216. });
  217. } else {
  218. PMA_ajaxShowMessage(PMA_messages.strErrorProcessingRequest + ' : ' + data.error, false);
  219. }
  220. }); // end $.post()
  221. }); // end $.PMA_confirm()
  222. }); // end Drop Foreign key
  223. var windowwidth = $(window).width();
  224. $('.jsresponsive').css('max-width', (windowwidth - 35) + 'px');
  225. });