mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 19:48:08 +00:00
Both the Copilot and the conversation sidebar were open at the same time, which shouldn’t be possible.
63 lines
1.8 KiB
Vue
63 lines
1.8 KiB
Vue
<script setup>
|
|
import { computed } from 'vue';
|
|
import { useRoute } from 'vue-router';
|
|
import Button from 'dashboard/components-next/button/Button.vue';
|
|
import { useUISettings } from 'dashboard/composables/useUISettings';
|
|
import { useMapGetter } from 'dashboard/composables/store';
|
|
import { FEATURE_FLAGS } from 'dashboard/featureFlags';
|
|
const route = useRoute();
|
|
|
|
const { uiSettings, updateUISettings } = useUISettings();
|
|
|
|
const isConversationRoute = computed(() => {
|
|
const CONVERSATION_ROUTES = [
|
|
'inbox_conversation',
|
|
'conversation_through_inbox',
|
|
'conversations_through_label',
|
|
'team_conversations_through_label',
|
|
'conversations_through_folders',
|
|
'conversation_through_mentions',
|
|
'conversation_through_unattended',
|
|
'conversation_through_participating',
|
|
];
|
|
return CONVERSATION_ROUTES.includes(route.name);
|
|
});
|
|
|
|
const currentAccountId = useMapGetter('getCurrentAccountId');
|
|
const isFeatureEnabledonAccount = useMapGetter(
|
|
'accounts/isFeatureEnabledonAccount'
|
|
);
|
|
|
|
const showCopilotLauncher = computed(() => {
|
|
const isCaptainEnabled = isFeatureEnabledonAccount.value(
|
|
currentAccountId.value,
|
|
FEATURE_FLAGS.CAPTAIN
|
|
);
|
|
return (
|
|
isCaptainEnabled &&
|
|
!uiSettings.value.is_copilot_panel_open &&
|
|
!isConversationRoute.value
|
|
);
|
|
});
|
|
const toggleSidebar = () => {
|
|
updateUISettings({
|
|
is_copilot_panel_open: !uiSettings.value.is_copilot_panel_open,
|
|
is_contact_sidebar_open: false,
|
|
});
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div v-if="showCopilotLauncher" class="fixed bottom-4 right-4 z-50">
|
|
<div class="rounded-full bg-n-alpha-2 p-1">
|
|
<Button
|
|
icon="i-woot-captain"
|
|
class="!rounded-full !bg-n-solid-3 dark:!bg-n-alpha-2 !text-n-slate-12 text-xl"
|
|
lg
|
|
@click="toggleSidebar"
|
|
/>
|
|
</div>
|
|
</div>
|
|
<template v-else />
|
|
</template>
|