Welcome to mirror list, hosted at ThFree Co, Russian Federation.

sidebar_tracking.js « nav « shared « pages « javascripts « assets « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 47aae36ecbb97a34d0b8d97b0f51e902bedffed2 (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.dataset.trackAction = 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.dataset.trackExtra = 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);
  });
};