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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
<script>
import {
GlAvatarLabeled,
GlAvatarLink,
GlLoadingIcon,
GlPagination,
GlEmptyState,
} from '@gitlab/ui';
import { DEFAULT_PER_PAGE } from '~/api';
import { NEXT, PREV } from '~/vue_shared/components/pagination/constants';
import { isCurrentUser } from '~/lib/utils/common_utils';
export default {
i18n: {
prev: PREV,
next: NEXT,
},
components: {
GlAvatarLabeled,
GlAvatarLink,
GlLoadingIcon,
GlPagination,
GlEmptyState,
},
inject: ['followEmptyState', 'userId'],
props: {
/**
* Expected format:
*
* {
* avatar_url: string;
* id: number;
* name: string;
* state: string;
* username: string;
* web_url: string;
* }[]
*/
users: {
type: Array,
required: true,
},
loading: {
type: Boolean,
required: true,
},
page: {
type: Number,
required: true,
},
totalItems: {
type: Number,
required: true,
},
perPage: {
type: Number,
required: false,
default: DEFAULT_PER_PAGE,
},
currentUserEmptyStateTitle: {
type: String,
required: true,
},
visitorEmptyStateTitle: {
type: String,
required: true,
},
},
computed: {
emptyStateTitle() {
return isCurrentUser(this.userId)
? this.currentUserEmptyStateTitle
: this.visitorEmptyStateTitle;
},
},
};
</script>
<template>
<gl-loading-icon v-if="loading" class="gl-mt-5" size="md" />
<gl-empty-state
v-else-if="!users.length"
class="gl-mt-5"
:svg-path="followEmptyState"
:svg-height="144"
:title="emptyStateTitle"
/>
<div v-else>
<div class="gl-my-n3 gl-mx-n3 gl-display-flex gl-flex-wrap">
<div v-for="user in users" :key="user.id" class="gl-p-3 gl-w-full gl-md-w-half gl-lg-w-25p">
<gl-avatar-link
:href="user.web_url"
class="js-user-link gl-border gl-rounded-base gl-w-full gl-p-5"
:data-user-id="user.id"
:data-username="user.username"
>
<gl-avatar-labeled
:src="user.avatar_url"
:size="48"
:entity-id="user.id"
:entity-name="user.name"
:label="user.name"
:sub-label="user.username"
/>
</gl-avatar-link>
</div>
</div>
<gl-pagination
align="center"
class="gl-mt-5"
:value="page"
:total-items="totalItems"
:per-page="perPage"
:prev-text="$options.i18n.prev"
:next-text="$options.i18n.next"
@input="$emit('pagination-input', $event)"
/>
</div>
</template>
|