1
0
forked from test/crm
jcrm/frontend/src/components/SidebarLink.vue

93 lines
2.4 KiB
Vue

<template>
<button
class="flex h-7 cursor-pointer items-center rounded text-ink-gray-7 duration-300 ease-in-out focus:outline-none focus:transition-none focus-visible:rounded focus-visible:ring-2 focus-visible:ring-outline-gray-3"
:class="isActive ? 'bg-surface-selected shadow-sm' : 'hover:bg-surface-gray-2'"
@click="handleClick"
>
<div
class="flex w-full items-center justify-between duration-300 ease-in-out"
:class="isCollapsed ? 'ml-[3px] p-1' : 'px-2 py-1'"
>
<div class="flex items-center truncate">
<Tooltip :text="label" placement="right" :disabled="!isCollapsed">
<slot name="icon">
<span class="grid flex-shrink-0 place-items-center">
<FeatherIcon
v-if="typeof icon == 'string'"
:name="icon"
class="size-4 text-ink-gray-7"
/>
<component v-else :is="icon" class="size-4 text-ink-gray-7" />
</span>
</slot>
</Tooltip>
<Tooltip
:text="label"
placement="right"
:disabled="isCollapsed"
:hoverDelay="1.5"
>
<span
class="flex-1 flex-shrink-0 truncate text-sm duration-300 ease-in-out"
:class="
isCollapsed
? 'ml-0 w-0 overflow-hidden opacity-0'
: 'ml-2 w-auto opacity-100'
"
>
{{ label }}
</span>
</Tooltip>
</div>
<slot name="right" />
</div>
</button>
</template>
<script setup>
import { Tooltip } from 'frappe-ui'
import { computed } from 'vue'
import { useRouter, useRoute } from 'vue-router'
import { isMobileView, mobileSidebarOpened } from '@/composables/settings'
const router = useRouter()
const route = useRoute()
const props = defineProps({
icon: {
type: [Object, String, Function],
},
label: {
type: String,
default: '',
},
to: {
type: [Object, String],
default: '',
},
isCollapsed: {
type: Boolean,
default: false,
},
})
function handleClick() {
if (!props.to) return
if (typeof props.to === 'object') {
router.push(props.to)
} else {
router.push({ name: props.to })
}
if (isMobileView.value) {
mobileSidebarOpened.value = false
}
}
let isActive = computed(() => {
if (route.query.view) {
return route.query.view == props.to?.query?.view
}
return route.name === props.to
})
</script>