/** * @file * Language admin behavior. */ (function($, Drupal) { /** * Makes language negotiation inherit user interface negotiation. * * @type {Drupal~behavior} * * @prop {Drupal~behaviorAttach} attach * Attach behavior to language negotiation admin user interface. */ Drupal.behaviors.negotiationLanguage = { attach() { const $configForm = $('#language-negotiation-configure-form'); const inputSelector = 'input[name$="[configurable]"]'; // Given a customization checkbox derive the language type being changed. function toggleTable(checkbox) { const $checkbox = $(checkbox); // Get the language detection type such as Interface text language // detection or Content language detection. $checkbox .closest('.table-language-group') .find('table, .tabledrag-toggle-weight') .toggle($checkbox.prop('checked')); } // Bind hide/show and rearrange customization checkboxes. $configForm .once('negotiation-language-admin-bind') .on('change', inputSelector, event => { toggleTable(event.target); }); // Initially, hide language detection types that are not customized. $configForm .find(`${inputSelector}:not(:checked)`) .each((index, element) => { toggleTable(element); }); }, }; })(jQuery, Drupal);