summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/badges/components/badge_list.vue
blob: 811ec6d333b6dd603c9cf8d6a0015dc82042bdca (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
<script>
import { mapState } from 'vuex';
import { GlLoadingIcon } from '@gitlab/ui';
import { GROUP_BADGE } from '../constants';
import BadgeListRow from './badge_list_row.vue';

export default {
  name: 'BadgeList',
  components: {
    BadgeListRow,
    GlLoadingIcon,
  },
  computed: {
    ...mapState(['badges', 'isLoading', 'kind']),
    hasNoBadges() {
      return !this.isLoading && (!this.badges || !this.badges.length);
    },
    isGroupBadge() {
      return this.kind === GROUP_BADGE;
    },
  },
};
</script>

<template>
  <div class="card">
    <div class="card-header">
      {{ s__('Badges|Your badges') }}
      <span v-show="!isLoading" class="badge badge-pill">{{ badges.length }}</span>
    </div>
    <gl-loading-icon v-show="isLoading" size="lg" class="card-body" />
    <div v-if="hasNoBadges" class="card-body">
      <span v-if="isGroupBadge">{{ s__('Badges|This group has no badges') }}</span>
      <span v-else>{{ s__('Badges|This project has no badges') }}</span>
    </div>
    <div v-else class="card-body">
      <badge-list-row v-for="badge in badges" :key="badge.id" :badge="badge" />
    </div>
  </div>
</template>