permissions_filter.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /**
  2. * @file
  3. * Permission page behaviors.
  4. */
  5. (function ($, Drupal, debounce) {
  6. 'use strict';
  7. Drupal.behaviors.permissionTableFilterByText = {
  8. attach: function (context, settings) {
  9. var $input = $('input.table-filter-text').once('table-filter-text');
  10. var $table = $($input.attr('data-table'));
  11. var $rowsAndDetails;
  12. var $rows;
  13. var $details;
  14. var searching = false;
  15. function hidePackageDetails(index, element) {
  16. var $packDetails = $(element);
  17. var $visibleRows = $packDetails.find('tbody tr:visible');
  18. $packDetails.toggle($visibleRows.length > 0);
  19. }
  20. function filterPermissionList(e) {
  21. var query = $(e.target).val();
  22. // Case insensitive expression to find query at the beginning of a word.
  23. var re = new RegExp('\\b' + query, 'i');
  24. function showPermissionRow(index, row) {
  25. var $row = $(row);
  26. var $sources = $row.find('.table-filter-text-source, .module, .permission');
  27. var textMatch = $sources.text().search(re) !== -1;
  28. $row.closest('tr').toggle(textMatch);
  29. }
  30. // Search over all rows and packages.
  31. $rowsAndDetails.show();
  32. // Filter if the length of the query is at least 2 characters.
  33. if (query.length >= 2) {
  34. searching = true;
  35. $rows.each(showPermissionRow);
  36. $details.not('[open]').attr('data-drupal-system-state', 'forced-open');
  37. $details.attr('open', true).each(hidePackageDetails);
  38. Drupal.announce(
  39. Drupal.t(
  40. '!permissions permissions are available in the modified list.',
  41. {'!permissions': $rowsAndDetails.find('tbody tr:visible').length}
  42. )
  43. );
  44. }
  45. else if (searching) {
  46. searching = false;
  47. $rowsAndDetails.show();
  48. $details.filter('[data-drupal-system-state="forced-open"]')
  49. .removeAttr('data-drupal-system-state')
  50. .attr('open', false);
  51. }
  52. }
  53. function preventEnterKey(event) {
  54. if (event.which === 13) {
  55. event.preventDefault();
  56. event.stopPropagation();
  57. }
  58. }
  59. if ($table.length) {
  60. $rowsAndDetails = $table.find('tr, details');
  61. $rows = $table.find('tbody tr');
  62. $details = $rowsAndDetails.filter('.js-permissions');
  63. $input.on({
  64. keyup: debounce(filterPermissionList, 200),
  65. keydown: preventEnterKey
  66. });
  67. }
  68. }
  69. };
  70. }(jQuery, Drupal, Drupal.debounce));