mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 04:57:51 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<script setup>
 | 
						|
import { computed } from 'vue';
 | 
						|
import BaseBubble from './Base.vue';
 | 
						|
import { useI18n } from 'vue-i18n';
 | 
						|
import { CONTENT_TYPES } from '../constants.js';
 | 
						|
import { useMessageContext } from '../provider.js';
 | 
						|
 | 
						|
const { content, contentAttributes, contentType } = useMessageContext();
 | 
						|
const { t } = useI18n();
 | 
						|
 | 
						|
const formValues = computed(() => {
 | 
						|
  if (contentType.value === CONTENT_TYPES.FORM) {
 | 
						|
    const { items, submittedValues = [] } = contentAttributes.value;
 | 
						|
 | 
						|
    if (submittedValues.length) {
 | 
						|
      return submittedValues.map(submittedValue => {
 | 
						|
        const item = items.find(
 | 
						|
          formItem => formItem.name === submittedValue.name
 | 
						|
        );
 | 
						|
        return {
 | 
						|
          title: submittedValue.value,
 | 
						|
          value: submittedValue.value,
 | 
						|
          label: item?.label,
 | 
						|
        };
 | 
						|
      });
 | 
						|
    }
 | 
						|
 | 
						|
    return [];
 | 
						|
  }
 | 
						|
 | 
						|
  if (contentType.value === CONTENT_TYPES.INPUT_SELECT) {
 | 
						|
    const [item] = contentAttributes.value?.submittedValues ?? [];
 | 
						|
    if (!item) return [];
 | 
						|
 | 
						|
    return [
 | 
						|
      {
 | 
						|
        title: item.title,
 | 
						|
        value: item.value,
 | 
						|
        label: '',
 | 
						|
      },
 | 
						|
    ];
 | 
						|
  }
 | 
						|
 | 
						|
  return [];
 | 
						|
});
 | 
						|
</script>
 | 
						|
 | 
						|
<template>
 | 
						|
  <BaseBubble class="px-4 py-3" data-bubble-name="csat">
 | 
						|
    <span v-dompurify-html="content" :title="content" />
 | 
						|
    <dl v-if="formValues.length" class="mt-4">
 | 
						|
      <template v-for="item in formValues" :key="item.title">
 | 
						|
        <dt class="text-n-slate-11 italic mt-2">
 | 
						|
          {{ item.label || t('CONVERSATION.RESPONSE') }}
 | 
						|
        </dt>
 | 
						|
        <dd>{{ item.title }}</dd>
 | 
						|
      </template>
 | 
						|
    </dl>
 | 
						|
    <div v-else class="my-2 font-medium">
 | 
						|
      {{ t('CONVERSATION.NO_RESPONSE') }}
 | 
						|
    </div>
 | 
						|
  </BaseBubble>
 | 
						|
</template>
 |