mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-10-31 19:17:48 +00:00 
			
		
		
		
	 d45527b851
			
		
	
	d45527b851
	
	
	
		
			
			Fixes [CW-5540](https://linear.app/chatwoot/issue/CW-5540/feat-allow-retry-a-failed-message-sendout), https://github.com/chatwoot/chatwoot/issues/12333 ## Type of change - [x] New feature (non-breaking change which adds functionality) ## How Has This Been Tested? ### Screenshot <img width="196" height="113" alt="image" src="https://github.com/user-attachments/assets/8b4a1aa9-c75c-4169-b4a2-e89148647e91" /> ## Checklist: - [x] My code follows the style guidelines of this project - [x] I have performed a self-review of my code - [x] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [x] My changes generate no new warnings - [x] I have added tests that prove my fix is effective or that my feature works - [x] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules --------- Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <script setup>
 | |
| import { computed } from 'vue';
 | |
| import Icon from 'next/icon/Icon.vue';
 | |
| import { useI18n } from 'vue-i18n';
 | |
| import { useMessageContext } from './provider.js';
 | |
| import { hasOneDayPassed } from 'shared/helpers/timeHelper';
 | |
| import { ORIENTATION, MESSAGE_STATUS } from './constants';
 | |
| 
 | |
| defineProps({
 | |
|   error: { type: String, required: true },
 | |
| });
 | |
| 
 | |
| const emit = defineEmits(['retry']);
 | |
| 
 | |
| const { orientation, status, createdAt } = useMessageContext();
 | |
| 
 | |
| const { t } = useI18n();
 | |
| 
 | |
| const canRetry = computed(() => !hasOneDayPassed(createdAt.value));
 | |
| </script>
 | |
| 
 | |
| <template>
 | |
|   <div class="text-xs text-n-ruby-11 flex items-center gap-1.5">
 | |
|     <span>{{ t('CHAT_LIST.FAILED_TO_SEND') }}</span>
 | |
|     <div class="relative group">
 | |
|       <div
 | |
|         class="bg-n-alpha-2 rounded-md size-5 grid place-content-center cursor-pointer"
 | |
|       >
 | |
|         <Icon
 | |
|           icon="i-lucide-alert-triangle"
 | |
|           class="text-n-ruby-11 size-[14px]"
 | |
|         />
 | |
|       </div>
 | |
|       <div
 | |
|         class="absolute bg-n-alpha-3 px-4 py-3 border rounded-xl border-n-strong text-n-slate-12 bottom-6 w-52 text-xs backdrop-blur-[100px] shadow-[0px_0px_24px_0px_rgba(0,0,0,0.12)] opacity-0 invisible group-hover:opacity-100 group-hover:visible transition-all break-all"
 | |
|         :class="{
 | |
|           'ltr:left-0 rtl:right-0': orientation === ORIENTATION.LEFT,
 | |
|           'ltr:right-0 rtl:left-0': orientation === ORIENTATION.RIGHT,
 | |
|         }"
 | |
|       >
 | |
|         {{ error }}
 | |
|       </div>
 | |
|     </div>
 | |
|     <button
 | |
|       v-if="canRetry"
 | |
|       type="button"
 | |
|       :disabled="status !== MESSAGE_STATUS.FAILED"
 | |
|       class="bg-n-alpha-2 rounded-md size-5 grid place-content-center cursor-pointer"
 | |
|       @click="emit('retry')"
 | |
|     >
 | |
|       <Icon icon="i-lucide-refresh-ccw" class="text-n-ruby-11 size-[14px]" />
 | |
|     </button>
 | |
|   </div>
 | |
| </template>
 |