summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/pages/shared/nav/sidebar_tracking.js
blob: 79ce1a37d2111721db318031e40ef5c717f9b9f9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
function onSidebarLinkClick() {
  const setDataTrackAction = (element, action) => {
    element.setAttribute('data-track-action', action);
  };

  const setDataTrackExtra = (element, value) => {
    const SIDEBAR_COLLAPSED = 'Collapsed';
    const SIDEBAR_EXPANDED = 'Expanded';
    const sidebarCollapsed = document
      .querySelector('.nav-sidebar')
      .classList.contains('js-sidebar-collapsed')
      ? SIDEBAR_COLLAPSED
      : SIDEBAR_EXPANDED;

    element.setAttribute(
      'data-track-extra',
      JSON.stringify({ sidebar_display: sidebarCollapsed, menu_display: value }),
    );
  };

  const EXPANDED = 'Expanded';
  const FLY_OUT = 'Fly out';
  const CLICK_MENU_ACTION = 'click_menu';
  const CLICK_MENU_ITEM_ACTION = 'click_menu_item';
  const parentElement = this.parentNode;
  const subMenuList = parentElement.closest('.sidebar-sub-level-items');

  if (subMenuList) {
    const isFlyOut = subMenuList.classList.contains('fly-out-list') ? FLY_OUT : EXPANDED;

    setDataTrackExtra(parentElement, isFlyOut);
    setDataTrackAction(parentElement, CLICK_MENU_ITEM_ACTION);
  } else {
    const isFlyOut = parentElement.classList.contains('is-showing-fly-out') ? FLY_OUT : EXPANDED;

    setDataTrackExtra(parentElement, isFlyOut);
    setDataTrackAction(parentElement, CLICK_MENU_ACTION);
  }
}
export const initSidebarTracking = () => {
  document.querySelectorAll('.nav-sidebar li[data-track-label] > a').forEach((link) => {
    link.addEventListener('click', onSidebarLinkClick);
  });
};