tbl_relation.js 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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 url = 'tbl_relation.php?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. url += argsep + 'server=' + $form.find('input[name="server"]').val();
  83. }
  84. $.ajax({
  85. url: url,
  86. datatype: 'json',
  87. success: function (data) {
  88. PMA_ajaxRemoveMessage($msgbox);
  89. if (typeof data !== 'undefined' && data.success) {
  90. // if the changed dropdown is a database selector
  91. if (foreignTable === null) {
  92. // set values for table and column dropdowns
  93. setDropdownValues($tableDd, data.tables);
  94. setDropdownValues($columnDd, []);
  95. } else { // if a table selector
  96. // set values for the column dropdown
  97. var primary = null;
  98. if (typeof data.primary !== 'undefined'
  99. && 1 === data.primary.length
  100. ) {
  101. primary = data.primary[0];
  102. }
  103. setDropdownValues($columnDd.first(), data.columns, primary);
  104. setDropdownValues($columnDd.slice(1), data.columns);
  105. }
  106. } else {
  107. PMA_ajaxShowMessage(data.error, false);
  108. }
  109. }
  110. });
  111. }
  112. /**
  113. * Unbind all event handlers before tearing down a page
  114. */
  115. AJAX.registerTeardown('tbl_relation.js', function () {
  116. $('body').off('change',
  117. 'select[name^="destination_db"], ' +
  118. 'select[name^="destination_table"], ' +
  119. 'select[name^="destination_foreign_db"], ' +
  120. 'select[name^="destination_foreign_table"]'
  121. );
  122. $('body').off('click', 'a.add_foreign_key_field');
  123. $('body').off('click', 'a.add_foreign_key');
  124. $('a.drop_foreign_key_anchor.ajax').off('click');
  125. });
  126. AJAX.registerOnload('tbl_relation.js', function () {
  127. /**
  128. * Ajax event handler to fetch table/column dropdown values.
  129. */
  130. $('body').on('change',
  131. 'select[name^="destination_db"], ' +
  132. 'select[name^="destination_table"], ' +
  133. 'select[name^="destination_foreign_db"], ' +
  134. 'select[name^="destination_foreign_table"]',
  135. function () {
  136. getDropdownValues($(this));
  137. }
  138. );
  139. /**
  140. * Ajax event handler to add a column to a foreign key constraint.
  141. */
  142. $('body').on('click', 'a.add_foreign_key_field', function (event) {
  143. event.preventDefault();
  144. event.stopPropagation();
  145. // Add field.
  146. $(this)
  147. .prev('span')
  148. .clone(true, true)
  149. .insertBefore($(this))
  150. .find('select')
  151. .val('');
  152. // Add foreign field.
  153. var $source_elem = $('select[name^="destination_foreign_column[' +
  154. $(this).attr('data-index') + ']"]:last').parent();
  155. $source_elem
  156. .clone(true, true)
  157. .insertAfter($source_elem)
  158. .find('select')
  159. .val('');
  160. });
  161. /**
  162. * Ajax event handler to add a foreign key constraint.
  163. */
  164. $('body').on('click', 'a.add_foreign_key', function (event) {
  165. event.preventDefault();
  166. event.stopPropagation();
  167. var $prev_row = $(this).closest('tr').prev('tr');
  168. var $newRow = $prev_row.clone(true, true);
  169. // Update serial number.
  170. var curr_index = $newRow
  171. .find('a.add_foreign_key_field')
  172. .attr('data-index');
  173. var new_index = parseInt(curr_index) + 1;
  174. $newRow.find('a.add_foreign_key_field').attr('data-index', new_index);
  175. // Update form parameter names.
  176. $newRow.find('select[name^="foreign_key_fields_name"]:not(:first), ' +
  177. 'select[name^="destination_foreign_column"]:not(:first)'
  178. ).each(function () {
  179. $(this).parent().remove();
  180. });
  181. $newRow.find('input, select').each(function () {
  182. $(this).attr('name',
  183. $(this).attr('name').replace(/\d/, new_index)
  184. );
  185. });
  186. $newRow.find('input[type="text"]').each(function () {
  187. $(this).val('');
  188. });
  189. // Finally add the row.
  190. $newRow.insertAfter($prev_row);
  191. });
  192. /**
  193. * Ajax Event handler for 'Drop Foreign key'
  194. */
  195. $('a.drop_foreign_key_anchor.ajax').on('click', function (event) {
  196. event.preventDefault();
  197. var $anchor = $(this);
  198. // Object containing reference to the current field's row
  199. var $curr_row = $anchor.parents('tr');
  200. var drop_query = escapeHtml(
  201. $curr_row.children('td')
  202. .children('.drop_foreign_key_msg')
  203. .val()
  204. );
  205. var question = PMA_sprintf(PMA_messages.strDoYouReally, drop_query);
  206. $anchor.PMA_confirm(question, $anchor.attr('href'), function (url) {
  207. var $msg = PMA_ajaxShowMessage(PMA_messages.strDroppingForeignKey, false);
  208. var params = getJSConfirmCommonParam(this, $anchor.getPostData());
  209. $.post(url, params, function (data) {
  210. if (data.success === true) {
  211. PMA_ajaxRemoveMessage($msg);
  212. PMA_commonActions.refreshMain(false, function () {
  213. // Do nothing
  214. });
  215. } else {
  216. PMA_ajaxShowMessage(PMA_messages.strErrorProcessingRequest + ' : ' + data.error, false);
  217. }
  218. }); // end $.post()
  219. }); // end $.PMA_confirm()
  220. }); // end Drop Foreign key
  221. var windowwidth = $(window).width();
  222. $('.jsresponsive').css('max-width', (windowwidth - 35) + 'px');
  223. });