mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 12:08:01 +00:00
80 lines
2.3 KiB
Vue
80 lines
2.3 KiB
Vue
<script setup>
|
|
import { ref } from 'vue';
|
|
import Button from 'dashboard/components-next/button/Button.vue';
|
|
import DropdownContainer from './base/DropdownContainer.vue';
|
|
import DropdownBody from './base/DropdownBody.vue';
|
|
import DropdownSection from './base/DropdownSection.vue';
|
|
import DropdownItem from './base/DropdownItem.vue';
|
|
import DropdownSeparator from './base/DropdownSeparator.vue';
|
|
import ToggleSwitch from 'dashboard/components-next/switch/Switch.vue';
|
|
|
|
const currentUserAutoOffline = ref(false);
|
|
|
|
const menuItems = ref([
|
|
{
|
|
label: 'Contact Support',
|
|
icon: 'i-lucide-life-buoy',
|
|
click: () => console.log('Contact Support'),
|
|
},
|
|
{
|
|
label: 'Keyboard Shortcuts',
|
|
icon: 'i-lucide-keyboard',
|
|
click: () => console.log('Keyboard Shortcuts'),
|
|
},
|
|
{
|
|
label: 'Profile Settings',
|
|
icon: 'i-lucide-user-pen',
|
|
click: () => console.log('Profile Settings'),
|
|
},
|
|
{
|
|
label: 'Change Appearance',
|
|
icon: 'i-lucide-swatch-book',
|
|
click: () => console.log('Change Appearance'),
|
|
},
|
|
{
|
|
label: 'Open SuperAdmin',
|
|
icon: 'i-lucide-castle',
|
|
link: '/super_admin',
|
|
target: '_blank',
|
|
},
|
|
{
|
|
label: 'Log Out',
|
|
icon: 'i-lucide-log-out',
|
|
click: () => console.log('Log Out'),
|
|
},
|
|
]);
|
|
</script>
|
|
|
|
<template>
|
|
<Story
|
|
title="Components/DropdownPrimitives"
|
|
:layout="{ type: 'grid', width: 400, height: 800 }"
|
|
>
|
|
<Variant title="Profile Menu">
|
|
<div class="p-4 bg-n-background h-[500px]">
|
|
<DropdownContainer>
|
|
<template #trigger="{ toggle }">
|
|
<Button label="Open Menu" size="sm" @click="toggle" />
|
|
</template>
|
|
<DropdownBody class="w-80">
|
|
<DropdownSection title="Profile Options">
|
|
<DropdownItem label="Contact Support" class="justify-between">
|
|
<span>{{ $t('SIDEBAR.SET_AUTO_OFFLINE.TEXT') }}</span>
|
|
<div class="flex-shrink-0">
|
|
<ToggleSwitch v-model="currentUserAutoOffline" />
|
|
</div>
|
|
</DropdownItem>
|
|
</DropdownSection>
|
|
<DropdownSeparator />
|
|
<DropdownItem
|
|
v-for="item in menuItems"
|
|
:key="item.label"
|
|
v-bind="item"
|
|
/>
|
|
</DropdownBody>
|
|
</DropdownContainer>
|
|
</div>
|
|
</Variant>
|
|
</Story>
|
|
</template>
|