annotate core/themes/seven/js/nav-tabs.es6.js @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents 129ea1e6d783
children
rev   line source
Chris@0 1 /**
Chris@0 2 * @file
Chris@0 3 * Responsive navigation tabs.
Chris@0 4 *
Chris@0 5 * This also supports collapsible navigable is the 'is-collapsible' class is
Chris@0 6 * added to the main element, and a target element is included.
Chris@0 7 */
Chris@17 8 (function($, Drupal) {
Chris@0 9 function init(i, tab) {
Chris@0 10 const $tab = $(tab);
Chris@0 11 const $target = $tab.find('[data-drupal-nav-tabs-target]');
Chris@0 12 const isCollapsible = $tab.hasClass('is-collapsible');
Chris@0 13
Chris@0 14 function openMenu(e) {
Chris@0 15 $target.toggleClass('is-open');
Chris@0 16 }
Chris@0 17
Chris@0 18 function handleResize(e) {
Chris@0 19 $tab.addClass('is-horizontal');
Chris@0 20 const $tabs = $tab.find('.tabs');
Chris@17 21 const isHorizontal =
Chris@17 22 $tabs.outerHeight() <= $tabs.find('.tabs__tab').outerHeight();
Chris@0 23 $tab.toggleClass('is-horizontal', isHorizontal);
Chris@0 24 if (isCollapsible) {
Chris@0 25 $tab.toggleClass('is-collapse-enabled', !isHorizontal);
Chris@0 26 }
Chris@0 27 if (isHorizontal) {
Chris@0 28 $target.removeClass('is-open');
Chris@0 29 }
Chris@0 30 }
Chris@0 31
Chris@0 32 $tab.addClass('position-container is-horizontal-enabled');
Chris@0 33
Chris@0 34 $tab.on('click.tabs', '[data-drupal-nav-tabs-trigger]', openMenu);
Chris@17 35 $(window)
Chris@17 36 .on('resize.tabs', Drupal.debounce(handleResize, 150))
Chris@17 37 .trigger('resize.tabs');
Chris@0 38 }
Chris@0 39
Chris@0 40 /**
Chris@0 41 * Initialise the tabs JS.
Chris@0 42 */
Chris@0 43 Drupal.behaviors.navTabs = {
Chris@0 44 attach(context, settings) {
Chris@0 45 const $tabs = $(context).find('[data-drupal-nav-tabs]');
Chris@0 46 if ($tabs.length) {
Chris@0 47 const notSmartPhone = window.matchMedia('(min-width: 300px)');
Chris@0 48 if (notSmartPhone.matches) {
Chris@0 49 $tabs.once('nav-tabs').each(init);
Chris@0 50 }
Chris@0 51 }
Chris@0 52 },
Chris@0 53 };
Chris@17 54 })(jQuery, Drupal);