goview_vue/src/views/chart/hooks/useContextMenu.hook.ts

62 lines
1.4 KiB
TypeScript
Raw Normal View History

2022-01-27 22:30:35 +08:00
import { reactive, ref, nextTick } from 'vue'
import { useChartEditStoreStore } from '@/store/modules/chartEditStore/chartEditStore'
2022-01-27 23:16:51 +08:00
import { loadingError } from '@/utils'
const chartEditStore = useChartEditStoreStore()
2022-01-27 22:30:35 +08:00
enum MenuEnum {
DELETE = 'delete'
}
export const useContextMenu = () => {
const targetIndex = ref<number>(0)
// * 右键选项
const menuOptions = reactive([
{
label: '删除',
key: MenuEnum.DELETE
}
])
// * 右键处理
const handleContextMenu = (e: MouseEvent, index: number) => {
e.stopPropagation()
e.preventDefault()
targetIndex.value = index
let target = e.target
while (target instanceof SVGElement) {
target = target.parentNode
}
chartEditStore.setRightMenuShow(false)
2022-01-27 22:30:35 +08:00
nextTick().then(() => {
chartEditStore.setMousePosition(e.clientX, e.clientY)
chartEditStore.setRightMenuShow(true)
2022-01-27 22:30:35 +08:00
})
}
// * 失焦
const onClickoutside = (e: MouseEvent) => {
chartEditStore.setRightMenuShow(false)
2022-01-27 22:30:35 +08:00
}
// * 事件处理
const handleMenuSelect = (key: string) => {
chartEditStore.setRightMenuShow(false)
2022-01-27 22:30:35 +08:00
switch (key) {
case MenuEnum.DELETE:
chartEditStore.removeComponentList(targetIndex.value)
break
2022-01-27 23:16:51 +08:00
default: loadingError()
2022-01-27 22:30:35 +08:00
}
}
return {
menuOptions,
handleContextMenu,
onClickoutside,
handleMenuSelect,
mousePosition: chartEditStore.getMousePosition
}
}