summaryrefslogtreecommitdiffstatshomepage
path: root/core/misc/active-link.js
diff options
context:
space:
mode:
Diffstat (limited to 'core/misc/active-link.js')
-rw-r--r--core/misc/active-link.js61
1 files changed, 45 insertions, 16 deletions
diff --git a/core/misc/active-link.js b/core/misc/active-link.js
index 2151d47124a..d6bd9e4095c 100644
--- a/core/misc/active-link.js
+++ b/core/misc/active-link.js
@@ -1,43 +1,72 @@
/**
-* DO NOT EDIT THIS FILE.
-* See the following change record for more information,
-* https://www.drupal.org/node/2815083
-* @preserve
-**/
+ * @file
+ * Attaches behaviors for Drupal's active link marking.
+ */
(function (Drupal, drupalSettings) {
+ /**
+ * Append is-active class.
+ *
+ * The link is only active if its path corresponds to the current path, the
+ * language of the linked path is equal to the current language, and if the
+ * query parameters of the link equal those of the current request, since the
+ * same request with different query parameters may yield a different page
+ * (e.g. pagers, exposed View filters).
+ *
+ * Does not discriminate based on element type, so allows you to set the
+ * is-active class on any element: a, li…
+ *
+ * @type {Drupal~behavior}
+ */
Drupal.behaviors.activeLinks = {
attach(context) {
+ // Start by finding all potentially active links.
const path = drupalSettings.path;
const queryString = JSON.stringify(path.currentQuery);
- const querySelector = path.currentQuery ? `[data-drupal-link-query='${queryString}']` : ':not([data-drupal-link-query])';
- const originalSelectors = [`[data-drupal-link-system-path="${path.currentPath}"]`];
+ const querySelector = path.currentQuery
+ ? `[data-drupal-link-query='${queryString}']`
+ : ':not([data-drupal-link-query])';
+ const originalSelectors = [
+ `[data-drupal-link-system-path="${path.currentPath}"]`,
+ ];
let selectors;
+ // If this is the front page, we have to check for the <front> path as
+ // well.
if (path.isFront) {
originalSelectors.push('[data-drupal-link-system-path="<front>"]');
}
- selectors = [].concat(originalSelectors.map(selector => `${selector}:not([hreflang])`), originalSelectors.map(selector => `${selector}[hreflang="${path.currentLanguage}"]`));
- selectors = selectors.map(current => current + querySelector);
+ // Add language filtering.
+ selectors = [].concat(
+ // Links without any hreflang attributes (most of them).
+ originalSelectors.map((selector) => `${selector}:not([hreflang])`),
+ // Links with hreflang equals to the current language.
+ originalSelectors.map(
+ (selector) => `${selector}[hreflang="${path.currentLanguage}"]`,
+ ),
+ );
+
+ // Add query string selector for pagers, exposed filters.
+ selectors = selectors.map((current) => current + querySelector);
+
+ // Query the DOM.
const activeLinks = context.querySelectorAll(selectors.join(','));
const il = activeLinks.length;
-
for (let i = 0; i < il; i++) {
activeLinks[i].classList.add('is-active');
}
},
-
detach(context, settings, trigger) {
if (trigger === 'unload') {
- const activeLinks = context.querySelectorAll('[data-drupal-link-system-path].is-active');
+ const activeLinks = context.querySelectorAll(
+ '[data-drupal-link-system-path].is-active',
+ );
const il = activeLinks.length;
-
for (let i = 0; i < il; i++) {
activeLinks[i].classList.remove('is-active');
}
}
- }
-
+ },
};
-})(Drupal, drupalSettings); \ No newline at end of file
+})(Drupal, drupalSettings);