57 lines
1.3 KiB
Vue
57 lines
1.3 KiB
Vue
<script>
|
|
import { GlIcon } from '@gitlab/ui';
|
|
import { IssuableType } from '~/issues/constants';
|
|
import { __, sprintf } from '~/locale';
|
|
|
|
export default {
|
|
components: {
|
|
GlIcon,
|
|
},
|
|
props: {
|
|
user: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
imgSize: {
|
|
type: Number,
|
|
required: true,
|
|
},
|
|
issuableType: {
|
|
type: String,
|
|
required: false,
|
|
default: 'issue',
|
|
},
|
|
},
|
|
computed: {
|
|
assigneeAlt() {
|
|
return sprintf(__("%{userName}'s avatar"), { userName: this.user.name });
|
|
},
|
|
avatarUrl() {
|
|
return (
|
|
this.user.avatarUrl || this.user.avatar || this.user.avatar_url || gon.default_avatar_url
|
|
);
|
|
},
|
|
isMergeRequest() {
|
|
return this.issuableType === IssuableType.MergeRequest;
|
|
},
|
|
hasMergeIcon() {
|
|
const canMerge = this.user.mergeRequestInteraction?.canMerge || this.user.can_merge;
|
|
return this.isMergeRequest && !canMerge;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<span class="position-relative">
|
|
<img
|
|
:alt="assigneeAlt"
|
|
:src="avatarUrl"
|
|
:width="imgSize"
|
|
:class="`s${imgSize}`"
|
|
class="avatar avatar-inline m-0"
|
|
data-qa-selector="avatar_image"
|
|
/>
|
|
<gl-icon v-if="hasMergeIcon" name="warning-solid" aria-hidden="true" class="merge-icon" />
|
|
</span>
|
|
</template>
|