UNPKG

@n8d/htwoo-core

Version:

hTWOo is a Fluent Design Framework purely in HTML and CSS

45 lines (29 loc) 1.44 kB
define(['exports'], (function (exports) { 'use strict'; const elemPivotBar = '.hoo-pivotbar'; const elemPivotButton = '.hoo-button-pivot'; const dropDownPivotButton = '.hoo-navitem-text'; const stateIsActive = 'is-active'; const changePivot = (event) => { event.preventDefault(); console.log(event.target); let currentButton = event.target.classList.contains(elemPivotButton.substr(1)) ? event.target : event.target.closest(elemPivotButton); if (!currentButton) { currentButton = event.target.classList.contains(dropDownPivotButton.substr(1)) ? event.target : event.target.closest(dropDownPivotButton); } const currentPivotBar = event.target.closest(elemPivotBar); const allButtons = currentPivotBar.querySelectorAll(elemPivotButton); allButtons.forEach(item => { item.classList.remove(stateIsActive); }); currentButton.classList.add(stateIsActive); }; const initPivot = () => { // register event on regular buttons const pivotBarsButtons = document.querySelectorAll(`${elemPivotBar} ${elemPivotButton}`); pivotBarsButtons.forEach(pivotBarsButton => { pivotBarsButton.dataset.ref = pivotBarsButton.textContent.trim(); pivotBarsButton.addEventListener('click', changePivot); }); }; exports.initPivot = initPivot; }));