|
|
| contextMenuInit = function(){
|
| let eventListenerApplied=false;
|
| let menuSpecs = new Map();
|
|
|
| const uid = function(){
|
| return Date.now().toString(36) + Math.random().toString(36).substring(2);
|
| }
|
|
|
| function showContextMenu(event,element,menuEntries){
|
| let posx = event.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
|
| let posy = event.clientY + document.body.scrollTop + document.documentElement.scrollTop;
|
|
|
| let oldMenu = gradioApp().querySelector('#context-menu')
|
| if(oldMenu){
|
| oldMenu.remove()
|
| }
|
|
|
| let baseStyle = window.getComputedStyle(uiCurrentTab)
|
|
|
| const contextMenu = document.createElement('nav')
|
| contextMenu.id = "context-menu"
|
| contextMenu.style.background = baseStyle.background
|
| contextMenu.style.color = baseStyle.color
|
| contextMenu.style.fontFamily = baseStyle.fontFamily
|
| contextMenu.style.top = posy+'px'
|
| contextMenu.style.left = posx+'px'
|
|
|
|
|
|
|
| const contextMenuList = document.createElement('ul')
|
| contextMenuList.className = 'context-menu-items';
|
| contextMenu.append(contextMenuList);
|
|
|
| menuEntries.forEach(function(entry){
|
| let contextMenuEntry = document.createElement('a')
|
| contextMenuEntry.innerHTML = entry['name']
|
| contextMenuEntry.addEventListener("click", function() {
|
| entry['func']();
|
| })
|
| contextMenuList.append(contextMenuEntry);
|
|
|
| })
|
|
|
| gradioApp().appendChild(contextMenu)
|
|
|
| let menuWidth = contextMenu.offsetWidth + 4;
|
| let menuHeight = contextMenu.offsetHeight + 4;
|
|
|
| let windowWidth = window.innerWidth;
|
| let windowHeight = window.innerHeight;
|
|
|
| if ( (windowWidth - posx) < menuWidth ) {
|
| contextMenu.style.left = windowWidth - menuWidth + "px";
|
| }
|
|
|
| if ( (windowHeight - posy) < menuHeight ) {
|
| contextMenu.style.top = windowHeight - menuHeight + "px";
|
| }
|
|
|
| }
|
|
|
| function appendContextMenuOption(targetElementSelector,entryName,entryFunction){
|
|
|
| var currentItems = menuSpecs.get(targetElementSelector)
|
|
|
| if(!currentItems){
|
| currentItems = []
|
| menuSpecs.set(targetElementSelector,currentItems);
|
| }
|
| let newItem = {'id':targetElementSelector+'_'+uid(),
|
| 'name':entryName,
|
| 'func':entryFunction,
|
| 'isNew':true}
|
|
|
| currentItems.push(newItem)
|
| return newItem['id']
|
| }
|
|
|
| function removeContextMenuOption(uid){
|
| menuSpecs.forEach(function(v) {
|
| let index = -1
|
| v.forEach(function(e,ei){if(e['id']==uid){index=ei}})
|
| if(index>=0){
|
| v.splice(index, 1);
|
| }
|
| })
|
| }
|
|
|
| function addContextMenuEventListener(){
|
| if(eventListenerApplied){
|
| return;
|
| }
|
| gradioApp().addEventListener("click", function(e) {
|
| if(! e.isTrusted){
|
| return
|
| }
|
|
|
| let oldMenu = gradioApp().querySelector('#context-menu')
|
| if(oldMenu){
|
| oldMenu.remove()
|
| }
|
| });
|
| gradioApp().addEventListener("contextmenu", function(e) {
|
| let oldMenu = gradioApp().querySelector('#context-menu')
|
| if(oldMenu){
|
| oldMenu.remove()
|
| }
|
| menuSpecs.forEach(function(v,k) {
|
| if(e.composedPath()[0].matches(k)){
|
| showContextMenu(e,e.composedPath()[0],v)
|
| e.preventDefault()
|
| }
|
| })
|
| });
|
| eventListenerApplied=true
|
|
|
| }
|
|
|
| return [appendContextMenuOption, removeContextMenuOption, addContextMenuEventListener]
|
| }
|
|
|
| initResponse = contextMenuInit();
|
| appendContextMenuOption = initResponse[0];
|
| removeContextMenuOption = initResponse[1];
|
| addContextMenuEventListener = initResponse[2];
|
|
|
| (function(){
|
|
|
| let generateOnRepeat = function(genbuttonid,interruptbuttonid){
|
| let genbutton = gradioApp().querySelector(genbuttonid);
|
| let interruptbutton = gradioApp().querySelector(interruptbuttonid);
|
| if(!interruptbutton.offsetParent){
|
| genbutton.click();
|
| }
|
| clearInterval(window.generateOnRepeatInterval)
|
| window.generateOnRepeatInterval = setInterval(function(){
|
| if(!interruptbutton.offsetParent){
|
| genbutton.click();
|
| }
|
| },
|
| 500)
|
| }
|
|
|
| appendContextMenuOption('#txt2img_generate','Generate forever',function(){
|
| generateOnRepeat('#txt2img_generate','#txt2img_interrupt');
|
| })
|
| appendContextMenuOption('#img2img_generate','Generate forever',function(){
|
| generateOnRepeat('#img2img_generate','#img2img_interrupt');
|
| })
|
|
|
| let cancelGenerateForever = function(){
|
| clearInterval(window.generateOnRepeatInterval)
|
| }
|
|
|
| appendContextMenuOption('#txt2img_interrupt','Cancel generate forever',cancelGenerateForever)
|
| appendContextMenuOption('#txt2img_generate', 'Cancel generate forever',cancelGenerateForever)
|
| appendContextMenuOption('#img2img_interrupt','Cancel generate forever',cancelGenerateForever)
|
| appendContextMenuOption('#img2img_generate', 'Cancel generate forever',cancelGenerateForever)
|
|
|
| })();
|
|
|
|
|
| onUiUpdate(function(){
|
| addContextMenuEventListener()
|
| });
|
|
|