variables.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /**
  2. *
  3. *
  4. * @package PhpMyAdmin
  5. */
  6. /**
  7. * Unbind all event handlers before tearing down a page
  8. */
  9. AJAX.registerTeardown('server/status/variables.js', function () {
  10. $('#filterAlert').off('change');
  11. $('#filterText').off('keyup');
  12. $('#filterCategory').off('change');
  13. $('#dontFormat').off('change');
  14. });
  15. AJAX.registerOnload('server/status/variables.js', function () {
  16. // Filters for status variables
  17. var textFilter = null;
  18. var alertFilter = $('#filterAlert').prop('checked');
  19. var categoryFilter = $('#filterCategory').find(':selected').val();
  20. var text = ''; // Holds filter text
  21. /* 3 Filtering functions */
  22. $('#filterAlert').on('change', function () {
  23. alertFilter = this.checked;
  24. filterVariables();
  25. });
  26. $('#filterCategory').on('change', function () {
  27. categoryFilter = $(this).val();
  28. filterVariables();
  29. });
  30. $('#dontFormat').on('change', function () {
  31. // Hiding the table while changing values speeds up the process a lot
  32. const serverStatusVariables = $('#serverStatusVariables');
  33. serverStatusVariables.hide();
  34. serverStatusVariables.find('td.value span.original').toggle(this.checked);
  35. serverStatusVariables.find('td.value span.formatted').toggle(!this.checked);
  36. serverStatusVariables.show();
  37. }).trigger('change');
  38. $('#filterText').on('keyup', function () {
  39. var word = $(this).val().replace(/_/g, ' ');
  40. if (word.length === 0 || word.length >= 32768) {
  41. textFilter = null;
  42. } else {
  43. try {
  44. textFilter = new RegExp('(^| )' + word, 'i');
  45. $(this).removeClass('error');
  46. } catch (e) {
  47. if (e instanceof SyntaxError) {
  48. $(this).addClass('error');
  49. textFilter = null;
  50. }
  51. }
  52. }
  53. text = word;
  54. filterVariables();
  55. }).trigger('keyup');
  56. /* Filters the status variables by name/category/alert in the variables tab */
  57. function filterVariables() {
  58. var usefulLinks = 0;
  59. var section = text;
  60. if (categoryFilter.length > 0) {
  61. section = categoryFilter;
  62. }
  63. if (section.length > 1) {
  64. $('#linkSuggestions').find('span').each(function () {
  65. if ($(this).attr('class').indexOf('status_' + section) !== -1) {
  66. usefulLinks++;
  67. $(this).css('display', '');
  68. } else {
  69. $(this).css('display', 'none');
  70. }
  71. });
  72. }
  73. if (usefulLinks > 0) {
  74. $('#linkSuggestions').css('display', '');
  75. } else {
  76. $('#linkSuggestions').css('display', 'none');
  77. }
  78. $('#serverStatusVariables').find('th.name').each(function () {
  79. if ((textFilter === null || textFilter.exec($(this).text())) && (!alertFilter || $(this).next().find('span.text-danger').length > 0) && (categoryFilter.length === 0 || $(this).parent().hasClass('s_' + categoryFilter))) {
  80. $(this).parent().css('display', '');
  81. } else {
  82. $(this).parent().css('display', 'none');
  83. }
  84. });
  85. }
  86. });