mirror of
https://github.com/lingble/chatwoot.git
synced 2025-10-30 18:47:51 +00:00
88 lines
1.8 KiB
Vue
88 lines
1.8 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import ChannelSelector from '../ChannelSelector.vue';
|
|
|
|
const props = defineProps({
|
|
channel: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
enabledFeatures: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
});
|
|
|
|
const emit = defineEmits(['channelItemClick']);
|
|
|
|
const hasFbConfigured = computed(() => {
|
|
return window.chatwootConfig?.fbAppId;
|
|
});
|
|
|
|
const hasInstagramConfigured = computed(() => {
|
|
return window.chatwootConfig?.instagramAppId;
|
|
});
|
|
|
|
const isActive = computed(() => {
|
|
const { key } = props.channel;
|
|
if (Object.keys(props.enabledFeatures).length === 0) {
|
|
return false;
|
|
}
|
|
if (key === 'website') {
|
|
return props.enabledFeatures.channel_website;
|
|
}
|
|
if (key === 'facebook') {
|
|
return props.enabledFeatures.channel_facebook && hasFbConfigured.value;
|
|
}
|
|
if (key === 'email') {
|
|
return props.enabledFeatures.channel_email;
|
|
}
|
|
|
|
if (key === 'instagram') {
|
|
return (
|
|
props.enabledFeatures.channel_instagram && hasInstagramConfigured.value
|
|
);
|
|
}
|
|
|
|
if (key === 'voice') {
|
|
return props.enabledFeatures.channel_voice;
|
|
}
|
|
|
|
return [
|
|
'website',
|
|
'twilio',
|
|
'api',
|
|
'whatsapp',
|
|
'sms',
|
|
'telegram',
|
|
'line',
|
|
'instagram',
|
|
'voice',
|
|
].includes(key);
|
|
});
|
|
|
|
const isComingSoon = computed(() => {
|
|
const { key } = props.channel;
|
|
// Show "Coming Soon" only if the channel is marked as coming soon
|
|
// and the corresponding feature flag is not enabled yet.
|
|
return ['voice'].includes(key) && !isActive.value;
|
|
});
|
|
|
|
const onItemClick = () => {
|
|
if (isActive.value) {
|
|
emit('channelItemClick', props.channel.key);
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<ChannelSelector
|
|
:title="channel.title"
|
|
:description="channel.description"
|
|
:icon="channel.icon"
|
|
:is-coming-soon="isComingSoon"
|
|
:disabled="!isActive"
|
|
@click="onItemClick"
|
|
/>
|
|
</template>
|