mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 04:57:51 +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>
 |