summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/nav/components/top_nav_container_view.vue
blob: 21ff3ebcd7d0c352468ec37b6fe45b1e9ac59803 (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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<script>
import FrequentItemsApp from '~/frequent_items/components/app.vue';
import eventHub from '~/frequent_items/event_hub';
import VuexModuleProvider from '~/vue_shared/components/vuex_module_provider.vue';
import TopNavMenuItem from './top_nav_menu_item.vue';

export default {
  components: {
    FrequentItemsApp,
    TopNavMenuItem,
    VuexModuleProvider,
  },
  props: {
    frequentItemsVuexModule: {
      type: String,
      required: true,
    },
    frequentItemsDropdownType: {
      type: String,
      required: true,
    },
    linksPrimary: {
      type: Array,
      required: false,
      default: () => [],
    },
    linksSecondary: {
      type: Array,
      required: false,
      default: () => [],
    },
  },
  computed: {
    linkGroups() {
      return [
        { key: 'primary', links: this.linksPrimary },
        { key: 'secondary', links: this.linksSecondary },
      ].filter((x) => x.links?.length);
    },
  },
  mounted() {
    // For historic reasons, the frequent-items-app component requires this too start up.
    this.$nextTick(() => {
      eventHub.$emit(`${this.frequentItemsDropdownType}-dropdownOpen`);
    });
  },
};
</script>

<template>
  <div class="top-nav-container-view gl-display-flex gl-flex-direction-column">
    <div class="frequent-items-dropdown-container gl-w-auto">
      <div class="frequent-items-dropdown-content gl-w-full! gl-pt-0!">
        <vuex-module-provider :vuex-module="frequentItemsVuexModule">
          <frequent-items-app v-bind="$attrs" />
        </vuex-module-provider>
      </div>
    </div>
    <div
      v-for="({ key, links }, groupIndex) in linkGroups"
      :key="key"
      :class="{ 'gl-mt-3': groupIndex !== 0 }"
      class="gl-mt-auto gl-pt-3 gl-border-1 gl-border-t-solid gl-border-gray-100"
      data-testid="menu-item-group"
    >
      <top-nav-menu-item
        v-for="(link, linkIndex) in links"
        :key="link.title"
        :menu-item="link"
        :class="{ 'gl-mt-1': linkIndex !== 0 }"
      />
    </div>
  </div>
</template>