mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 12:08:01 +00:00
# Pull Request Template ## Description Added input_select message type support for LINE ## Type of change Please delete options that are not relevant. - [ ] Bug fix (non-breaking change which fixes an issue) - [X] New feature (non-breaking change which adds functionality) - [ ] Breaking change (fix or feature that would cause existing functionality not to work as expected) - [ ] This change requires a documentation update ## How Has This Been Tested? add testcase. and test manually by myself ## Checklist: - [X] My code follows the style guidelines of this project - [X] I have performed a self-review of my code - [ ] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [ ] 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>
66 lines
1.8 KiB
Vue
66 lines
1.8 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';
|
|
import { useInbox } from 'dashboard/composables/useInbox';
|
|
|
|
const { content, contentAttributes, contentType } = useMessageContext();
|
|
const { t } = useI18n();
|
|
const { isAWebWidgetInbox } = useInbox();
|
|
|
|
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-if="isAWebWidgetInbox" class="my-2 font-medium">
|
|
{{ t('CONVERSATION.NO_RESPONSE') }}
|
|
</div>
|
|
</BaseBubble>
|
|
</template>
|