mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-19 17:46:00 +00:00
dropdown menu implementation
This commit is contained in:
19
packages/web/src/utility/contextMenu.ts
Normal file
19
packages/web/src/utility/contextMenu.ts
Normal file
@@ -0,0 +1,19 @@
|
||||
import _ from 'lodash';
|
||||
import { currentDropDownMenu } from '../stores';
|
||||
|
||||
export default function contextMenu(node, items) {
|
||||
const handleContextMenu = e => {
|
||||
e.preventDefault();
|
||||
const left = e.pageX;
|
||||
const top = e.pageY;
|
||||
currentDropDownMenu.set({ left, top, items: _.isFunction(items) ? items() : items });
|
||||
};
|
||||
|
||||
node.addEventListener('contextmenu', handleContextMenu);
|
||||
|
||||
return {
|
||||
destroy() {
|
||||
node.removeEventListener('contextmenu', handleContextMenu);
|
||||
},
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user