mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 20:18:08 +00:00
Removes avatar from the components. **Before:** <img width="283" alt="Screenshot 2025-05-21 at 3 58 10 PM" src="https://github.com/user-attachments/assets/8f25343f-e24a-4d39-b8e8-6e10610cd8da" /> **After:** <img width="286" alt="Screenshot 2025-05-21 at 3 57 29 PM" src="https://github.com/user-attachments/assets/f3704dc9-d270-4e6e-94c5-6c7aa0903b24" />
70 lines
1.9 KiB
Vue
70 lines
1.9 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import { emitter } from 'shared/helpers/mitt';
|
|
import { useTrack } from 'dashboard/composables';
|
|
|
|
import { BUS_EVENTS } from 'shared/constants/busEvents';
|
|
import { INBOX_TYPES } from 'dashboard/helper/inbox';
|
|
import { COPILOT_EVENTS } from 'dashboard/helper/AnalyticsHelper/events';
|
|
import MessageFormatter from 'shared/helpers/MessageFormatter.js';
|
|
|
|
import Button from 'dashboard/components-next/button/Button.vue';
|
|
|
|
const props = defineProps({
|
|
message: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
conversationInboxType: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
});
|
|
|
|
const messageContent = computed(() => {
|
|
const formatter = new MessageFormatter(props.message.content);
|
|
return formatter.formattedMessage;
|
|
});
|
|
|
|
const insertIntoRichEditor = computed(() => {
|
|
return [INBOX_TYPES.WEB, INBOX_TYPES.EMAIL].includes(
|
|
props.conversationInboxType
|
|
);
|
|
});
|
|
|
|
const hasEmptyMessageContent = computed(() => !props.message?.content);
|
|
|
|
const useCopilotResponse = () => {
|
|
if (insertIntoRichEditor.value) {
|
|
emitter.emit(BUS_EVENTS.INSERT_INTO_RICH_EDITOR, props.message?.content);
|
|
} else {
|
|
emitter.emit(BUS_EVENTS.INSERT_INTO_NORMAL_EDITOR, props.message?.content);
|
|
}
|
|
useTrack(COPILOT_EVENTS.USE_CAPTAIN_RESPONSE);
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="flex flex-col gap-1 text-n-slate-12">
|
|
<div class="font-medium">{{ $t('CAPTAIN.NAME') }}</div>
|
|
<span v-if="hasEmptyMessageContent" class="text-n-ruby-11">
|
|
{{ $t('CAPTAIN.COPILOT.EMPTY_MESSAGE') }}
|
|
</span>
|
|
<div
|
|
v-else
|
|
v-dompurify-html="messageContent"
|
|
class="prose-sm break-words"
|
|
/>
|
|
<div class="flex flex-row mt-1">
|
|
<Button
|
|
v-if="!hasEmptyMessageContent"
|
|
:label="$t('CAPTAIN.COPILOT.USE')"
|
|
faded
|
|
sm
|
|
slate
|
|
@click="useCopilotResponse"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</template>
|