mirror of
https://github.com/lingble/chatwoot.git
synced 2025-10-31 19:17:48 +00:00
To test this, set the `useNextBubble` value to `true` in the
localstorage. Here's a quick command to run in the console
```js
localStorage.setItem('useNextBubble', true)
```
```js
localStorage.setItem('useNextBubble', false)
```
---------
Co-authored-by: Pranav <pranavrajs@gmail.com>
46 lines
1.1 KiB
Vue
46 lines
1.1 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import { useI18n } from 'vue-i18n';
|
|
|
|
import { useMessageContext } from '../provider.js';
|
|
import BaseAttachmentBubble from './BaseAttachment.vue';
|
|
import FileIcon from 'next/icon/FileIcon.vue';
|
|
|
|
const { attachments } = useMessageContext();
|
|
|
|
const { t } = useI18n();
|
|
|
|
const url = computed(() => {
|
|
return attachments.value[0].dataUrl;
|
|
});
|
|
|
|
const fileName = computed(() => {
|
|
if (url.value) {
|
|
const filename = url.value.substring(url.value.lastIndexOf('/') + 1);
|
|
return filename || t('CONVERSATION.UNKNOWN_FILE_TYPE');
|
|
}
|
|
return t('CONVERSATION.UNKNOWN_FILE_TYPE');
|
|
});
|
|
|
|
const fileType = computed(() => {
|
|
return fileName.value.split('.').pop();
|
|
});
|
|
</script>
|
|
|
|
<template>
|
|
<BaseAttachmentBubble
|
|
icon="i-teenyicons-user-circle-solid"
|
|
icon-bg-color="bg-n-alpha-3 dark:bg-n-alpha-white"
|
|
sender-translation-key="CONVERSATION.SHARED_ATTACHMENT.FILE"
|
|
:content="decodeURI(fileName)"
|
|
:action="{
|
|
href: url,
|
|
label: $t('CONVERSATION.DOWNLOAD'),
|
|
}"
|
|
>
|
|
<template #icon>
|
|
<FileIcon :file-type="fileType" class="size-4" />
|
|
</template>
|
|
</BaseAttachmentBubble>
|
|
</template>
|