diff --git a/web/comfyui/menu_auto_nest.js b/web/comfyui/menu_auto_nest.js index daba30b..adbd996 100644 --- a/web/comfyui/menu_auto_nest.js +++ b/web/comfyui/menu_auto_nest.js @@ -9,105 +9,108 @@ app.registerExtension({ name: "rgthree.ContextMenuAutoNest", async setup() { const logger = rgthree.newLogSession("[ContextMenuAutoNest]"); - const existingContextMenu = LiteGraph.ContextMenu; - LiteGraph.ContextMenu = function (values, options) { - var _a, _b, _c, _d, _e; - const threshold = CONFIG_SERVICE.getConfigValue("features.menu_auto_nest.threshold", 20); - const enabled = CONFIG_SERVICE.getConfigValue("features.menu_auto_nest.subdirs", false); - let incompatible = !enabled; - if (!incompatible) { - if (values.length <= threshold) { - incompatible = `Skipping context menu auto nesting b/c threshold is not met (${threshold})`; - } - if (!((_a = options.parentMenu) === null || _a === void 0 ? void 0 : _a.options.rgthree_originalCallback)) { - if (!(options === null || options === void 0 ? void 0 : options.callback)) { - incompatible = `Skipping context menu auto nesting b/c a callback was expected.`; + + class ContextMenuAutoNest extends LiteGraph.ContextMenu { + constructor(values, options) { + var _a, _b, _c, _d, _e; + const threshold = CONFIG_SERVICE.getConfigValue("features.menu_auto_nest.threshold", 20); + const enabled = CONFIG_SERVICE.getConfigValue("features.menu_auto_nest.subdirs", false); + let incompatible = !enabled; + if (!incompatible) { + if (values.length <= threshold) { + incompatible = `Skipping context menu auto nesting b/c threshold is not met (${threshold})`; } - else if (values.some((i) => typeof i !== "string")) { - incompatible = `Skipping context menu auto nesting b/c not all values were strings.`; + if (!((_a = options.parentMenu) === null || _a === void 0 ? void 0 : _a.options.rgthree_originalCallback)) { + if (!(options === null || options === void 0 ? void 0 : options.callback)) { + incompatible = `Skipping context menu auto nesting b/c a callback was expected.`; + } + else if (values.some((i) => typeof i !== "string")) { + incompatible = `Skipping context menu auto nesting b/c not all values were strings.`; + } } } - } - if (incompatible) { - if (enabled) { - const [n, v] = logger.infoParts("Skipping context menu auto nesting for incompatible menu."); - (_b = console[n]) === null || _b === void 0 ? void 0 : _b.call(console, ...v); - } - return existingContextMenu.apply(this, [...arguments]); - } - const folders = {}; - const specialOps = []; - const folderless = []; - for (const value of values) { - if (!value) { - folderless.push(value); - continue; - } - const newValue = typeof value === "string" ? { content: value } : Object.assign({}, value); - newValue.rgthree_originalValue = value.rgthree_originalValue || value; - const valueContent = newValue.content; - const splitBy = valueContent.indexOf("/") > -1 ? "/" : "\\"; - const valueSplit = valueContent.split(splitBy); - if (valueSplit.length > 1) { - const key = valueSplit.shift(); - newValue.content = valueSplit.join(splitBy); - folders[key] = folders[key] || []; - folders[key].push(newValue); + if (incompatible) { + if (enabled) { + const [n, v] = logger.infoParts("Skipping context menu auto nesting for incompatible menu."); + (_b = console[n]) === null || _b === void 0 ? void 0 : _b.call(console, ...v); + } + return super(values, options); } - else if (SPECIAL_ENTRIES.some(r => r.test(valueContent))) { - specialOps.push(newValue); + const folders = {}; + const specialOps = []; + const folderless = []; + for (const value of values) { + if (!value) { + folderless.push(value); + continue; + } + const newValue = typeof value === "string" ? { content: value } : Object.assign({}, value); + newValue.rgthree_originalValue = value.rgthree_originalValue || value; + const valueContent = newValue.content; + const splitBy = valueContent.indexOf("/") > -1 ? "/" : "\\"; + const valueSplit = valueContent.split(splitBy); + if (valueSplit.length > 1) { + const key = valueSplit.shift(); + newValue.content = valueSplit.join(splitBy); + folders[key] = folders[key] || []; + folders[key].push(newValue); + } + else if (SPECIAL_ENTRIES.some(r => r.test(valueContent))) { + specialOps.push(newValue); + } + else { + folderless.push(newValue); + } } - else { - folderless.push(newValue); + const foldersCount = Object.values(folders).length; + if (foldersCount > 0) { + options.rgthree_originalCallback = + options.rgthree_originalCallback || + ((_c = options.parentMenu) === null || _c === void 0 ? void 0 : _c.options.rgthree_originalCallback) || + options.callback; + const oldCallback = options.rgthree_originalCallback; + options.callback = undefined; + const newCallback = (item, options, event, parentMenu, node) => { + oldCallback === null || oldCallback === void 0 ? void 0 : oldCallback(item === null || item === void 0 ? void 0 : item.rgthree_originalValue, options, event, undefined, node); + }; + const [n, v] = logger.infoParts(`Nested folders found (${foldersCount}).`); + (_d = console[n]) === null || _d === void 0 ? void 0 : _d.call(console, ...v); + const newValues = []; + for (const [folderName, folderValues] of Object.entries(folders)) { + newValues.push({ + content: `📁 ${folderName}`, + has_submenu: true, + callback: () => { + }, + submenu: { + options: folderValues.map((value) => { + value.callback = newCallback; + return value; + }), + }, + }); + } + values = [].concat(specialOps.map((f) => { + if (typeof f === "string") { + f = { content: f }; + } + f.callback = newCallback; + return f; + }), newValues, folderless.map((f) => { + if (typeof f === "string") { + f = { content: f }; + } + f.callback = newCallback; + return f; + })); } - } - const foldersCount = Object.values(folders).length; - if (foldersCount > 0) { - options.rgthree_originalCallback = - options.rgthree_originalCallback || - ((_c = options.parentMenu) === null || _c === void 0 ? void 0 : _c.options.rgthree_originalCallback) || - options.callback; - const oldCallback = options.rgthree_originalCallback; - options.callback = undefined; - const newCallback = (item, options, event, parentMenu, node) => { - oldCallback === null || oldCallback === void 0 ? void 0 : oldCallback(item === null || item === void 0 ? void 0 : item.rgthree_originalValue, options, event, undefined, node); - }; - const [n, v] = logger.infoParts(`Nested folders found (${foldersCount}).`); - (_d = console[n]) === null || _d === void 0 ? void 0 : _d.call(console, ...v); - const newValues = []; - for (const [folderName, folderValues] of Object.entries(folders)) { - newValues.push({ - content: `📁 ${folderName}`, - has_submenu: true, - callback: () => { - }, - submenu: { - options: folderValues.map((value) => { - value.callback = newCallback; - return value; - }), - }, - }); + if (options.scale == null) { + options.scale = Math.max(((_e = app.canvas.ds) === null || _e === void 0 ? void 0 : _e.scale) || 1, 1); } - values = [].concat(specialOps.map((f) => { - if (typeof f === "string") { - f = { content: f }; - } - f.callback = newCallback; - return f; - }), newValues, folderless.map((f) => { - if (typeof f === "string") { - f = { content: f }; - } - f.callback = newCallback; - return f; - })); - } - if (options.scale == null) { - options.scale = Math.max(((_e = app.canvas.ds) === null || _e === void 0 ? void 0 : _e.scale) || 1, 1); + return super(values, options); } - return existingContextMenu.call(this, values, options); - }; - LiteGraph.ContextMenu.prototype = existingContextMenu.prototype; + } + LiteGraph.ContextMenu = ContextMenuAutoNest; + window.ContextMenu = ContextMenuAutoNest; }, });