More things work now
All checks were successful
Build and Deploy Nuxt / build (push) Successful in 34s
All checks were successful
Build and Deploy Nuxt / build (push) Successful in 34s
This commit is contained in:
148
frontend/app/services/ContextMenu.js
Normal file
148
frontend/app/services/ContextMenu.js
Normal file
@@ -0,0 +1,148 @@
|
||||
// You should hide the context menu when the element that has the
|
||||
// event gets removed
|
||||
|
||||
let margin = -3;
|
||||
|
||||
let cursorX = 0;
|
||||
let cursorY = 0;
|
||||
|
||||
let arrowIcon = "icons/iconoir/regular/nav-arrow-right.svg";
|
||||
|
||||
import { animate } from 'motion'
|
||||
|
||||
function Show(){
|
||||
let contextMenu = document.getElementById('context-menu');
|
||||
contextMenu.style.display = "flex";
|
||||
contextMenu.style.top = (cursorY + margin) + "px";
|
||||
contextMenu.style.left = (cursorX + margin) + "px";
|
||||
}
|
||||
|
||||
function HideContextMenu(){
|
||||
let contextMenu = document.getElementById('context-menu');
|
||||
contextMenu.style.display = "none";
|
||||
}
|
||||
|
||||
function PopulateContext(val){
|
||||
let children = [];
|
||||
|
||||
let elementNum = 0;
|
||||
val.forEach(element => {
|
||||
let contextMenuElement = document.createElement('div');
|
||||
contextMenuElement.classList.add("context-menu-element");
|
||||
if(element.action)
|
||||
contextMenuElement.addEventListener("click", element.action);
|
||||
|
||||
let spanInfo = document.createElement('span');
|
||||
spanInfo.innerHTML = element.name;
|
||||
contextMenuElement.appendChild(spanInfo);
|
||||
|
||||
if(element.icon){
|
||||
let iconContextElement = document.createElement('img');
|
||||
iconContextElement.src = element.icon;
|
||||
contextMenuElement.appendChild(iconContextElement);
|
||||
}
|
||||
|
||||
if(element.context){
|
||||
let iconContextElement = document.createElement('img');
|
||||
iconContextElement.src = arrowIcon;
|
||||
contextMenuElement.appendChild(iconContextElement);
|
||||
|
||||
let childContextMenuElement = document.createElement('div');
|
||||
childContextMenuElement.classList.add("context-menu");
|
||||
childContextMenuElement.style.left = "100%";
|
||||
childContextMenuElement.style.top = "0";
|
||||
childContextMenuElement.style.display = "none";
|
||||
|
||||
let childChildren = PopulateContext(element.context);
|
||||
childChildren.forEach((child) => childContextMenuElement.appendChild(child));
|
||||
|
||||
contextMenuElement.addEventListener("mouseenter", () => {
|
||||
childContextMenuElement.style.display = "flex";
|
||||
});
|
||||
|
||||
contextMenuElement.addEventListener("mouseleave", () => {
|
||||
childContextMenuElement.style.display = "none";
|
||||
})
|
||||
|
||||
contextMenuElement.appendChild(childContextMenuElement);
|
||||
}
|
||||
|
||||
children.push(contextMenuElement);
|
||||
|
||||
animate(contextMenuElement, {
|
||||
opacity: [0, 1],
|
||||
translateY: [-20, -2]
|
||||
}, {duration: 0.15}).finished.then(() => {
|
||||
|
||||
});
|
||||
elementNum++;
|
||||
});
|
||||
|
||||
return children;
|
||||
}
|
||||
|
||||
function PopulateContextMenu(val){
|
||||
let contextMenu = document.getElementById('context-menu');
|
||||
let children = PopulateContext(val);
|
||||
|
||||
contextMenu.replaceChildren();
|
||||
children.forEach((el) => contextMenu.appendChild(el));
|
||||
}
|
||||
|
||||
function AddContextMenu(element, val, options = {}){
|
||||
element._dr_context = val;
|
||||
|
||||
function show(e){
|
||||
e.preventDefault();
|
||||
PopulateContextMenu(val);
|
||||
Show();
|
||||
if(options.dropdown){
|
||||
let rect = element.getBoundingClientRect();
|
||||
let contextMenu = document.getElementById('context-menu');
|
||||
contextMenu.style.top = rect.bottom + "px";
|
||||
contextMenu.style.left = rect.left + "px";
|
||||
}
|
||||
}
|
||||
|
||||
element.addEventListener('contextmenu', show);
|
||||
if(options.dropdown) element.addEventListener('click', show);
|
||||
}
|
||||
|
||||
|
||||
|
||||
function UpdateVisibility(){
|
||||
let contextMenu = document.getElementById('context-menu');
|
||||
let element = document.elementFromPoint(cursorX, cursorY);
|
||||
let mustHide = true;
|
||||
while(element){
|
||||
if(element == contextMenu){
|
||||
mustHide = false;
|
||||
break;
|
||||
}
|
||||
element = element.parentElement;
|
||||
}
|
||||
if(mustHide) HideContextMenu();
|
||||
}
|
||||
|
||||
function SetupContextMenu(){
|
||||
HideContextMenu();
|
||||
|
||||
document.addEventListener('mousemove', (e) => {
|
||||
cursorX = e.clientX;
|
||||
cursorY = e.clientY;
|
||||
});
|
||||
|
||||
document.addEventListener('mousedown', UpdateVisibility);
|
||||
}
|
||||
|
||||
function ShowContextMenu(val){
|
||||
PopulateContextMenu(val);
|
||||
Show();
|
||||
}
|
||||
|
||||
export {
|
||||
SetupContextMenu,
|
||||
AddContextMenu,
|
||||
ShowContextMenu,
|
||||
HideContextMenu
|
||||
};
|
||||
Reference in New Issue
Block a user