mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 11:37:58 +00:00
94 lines
2.6 KiB
Vue
94 lines
2.6 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import { useI18n } from 'vue-i18n';
|
|
import { useMessageFormatter } from 'shared/composables/useMessageFormatter';
|
|
|
|
import Avatar from 'dashboard/components-next/avatar/Avatar.vue';
|
|
import CardLabels from 'dashboard/components-next/Conversation/ConversationCard/CardLabels.vue';
|
|
import SLACardLabel from 'dashboard/components-next/Conversation/ConversationCard/SLACardLabel.vue';
|
|
|
|
const props = defineProps({
|
|
conversation: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
accountLabels: {
|
|
type: Array,
|
|
required: true,
|
|
},
|
|
});
|
|
|
|
const { t } = useI18n();
|
|
|
|
const { getPlainText } = useMessageFormatter();
|
|
|
|
const lastNonActivityMessageContent = computed(() => {
|
|
const { lastNonActivityMessage = {}, customAttributes = {} } =
|
|
props.conversation;
|
|
const { email: { subject } = {} } = customAttributes;
|
|
return getPlainText(
|
|
subject || lastNonActivityMessage.content || t('CHAT_LIST.NO_CONTENT')
|
|
);
|
|
});
|
|
|
|
const assignee = computed(() => {
|
|
const { meta: { assignee: agent = {} } = {} } = props.conversation;
|
|
return {
|
|
name: agent.name ?? agent.availableName,
|
|
thumbnail: agent.thumbnail,
|
|
status: agent.availabilityStatus,
|
|
};
|
|
});
|
|
|
|
const unreadMessagesCount = computed(() => {
|
|
const { unreadCount } = props.conversation;
|
|
return unreadCount;
|
|
});
|
|
|
|
const hasSlaThreshold = computed(() => props.conversation?.slaPolicyId);
|
|
</script>
|
|
|
|
<template>
|
|
<div class="flex flex-col w-full gap-1">
|
|
<div class="flex items-center justify-between w-full gap-2 py-1 h-7">
|
|
<p class="mb-0 text-sm leading-7 text-n-slate-12 line-clamp-1">
|
|
{{ lastNonActivityMessageContent }}
|
|
</p>
|
|
|
|
<div
|
|
v-if="unreadMessagesCount > 0"
|
|
class="inline-flex items-center justify-center flex-shrink-0 rounded-full size-5 bg-n-brand"
|
|
>
|
|
<span class="text-xs font-semibold text-white">
|
|
{{ unreadMessagesCount }}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
|
|
<div
|
|
class="grid items-center gap-2.5 h-7"
|
|
:class="
|
|
hasSlaThreshold
|
|
? 'grid-cols-[auto_auto_1fr_20px]'
|
|
: 'grid-cols-[1fr_20px]'
|
|
"
|
|
>
|
|
<SLACardLabel v-if="hasSlaThreshold" :conversation="conversation" />
|
|
<div v-if="hasSlaThreshold" class="w-px h-3 bg-n-slate-4" />
|
|
<div class="overflow-hidden">
|
|
<CardLabels
|
|
:conversation-labels="conversation.labels"
|
|
:account-labels="accountLabels"
|
|
/>
|
|
</div>
|
|
<Avatar
|
|
:name="assignee.name"
|
|
:src="assignee.thumbnail"
|
|
:size="20"
|
|
:status="assignee.status"
|
|
rounded-full
|
|
/>
|
|
</div>
|
|
</div>
|
|
</template>
|