HEX
Server: nginx/1.18.0
System: Linux test-ipsremont 5.4.0-214-generic #234-Ubuntu SMP Fri Mar 14 23:50:27 UTC 2025 x86_64
User: ips (1000)
PHP: 8.0.30
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/innodrive/src/js/modules/menu-list.js
export const menuList = () => {
  const list = document.getElementById('menu-list');
  const listItem = list.querySelectorAll('.main-nav__item');
  const listItemA = list.querySelectorAll('.main-nav__item > a');
  const listItemB = list.querySelectorAll('.main-nav__item > ul > li');
  const listItemC = list.querySelectorAll('.main-nav__item > ul > li > a');

  listItemA.forEach(item => {
    item.addEventListener('click', (e) => {
      if (item.classList.contains('hide')) {
        item.classList.toggle('show');
        item.classList.toggle('hide');
        item.parentNode.querySelector('ul').hidden = false;

        e.stopPropagation();
        e.preventDefault();
        return false;
      }
    });
  });

  listItemC.forEach(item => {
    item.addEventListener('click', (e) => {
      if (item.classList.contains('hide')) {
        item.classList.toggle('show');
        item.classList.toggle('hide');
        item.parentNode.querySelector('ul').hidden = false;

        e.stopPropagation();
        e.preventDefault();
        return false;
      }
    });
  });

  let click = false;

  listItemB.forEach(item => {
    item.addEventListener('click', (e) => {
      click = true;

      const ul = item.querySelector('ul');
      const a = item.querySelector('a');

      if (item.classList.contains('show')) {
        item.classList.remove('show');
        a.classList.remove('show');
        ul.hidden = true;
      } else {
        item.classList.add('show');
        a.classList.add('show');
        ul.hidden = false;
      }

      setTimeout(() => {
        click = false;
      }, 100);
    });
  });

  listItem.forEach((item) => {
    item.addEventListener('click', (e) => {
      const currentTarget = e.currentTarget;

      const elUl = currentTarget.querySelector('ul');
      const elA = currentTarget.querySelector('a');

      if (currentTarget.classList.contains('show') && !click) {
        currentTarget.classList.remove('show');
        elA.classList.remove('show');
        elUl.hidden = true;
      } else {
        currentTarget.classList.add('show');
        elA.classList.add('show');
        elUl.hidden = false;
      }
    });
  });
};