mirror of
https://github.com/willmiao/ComfyUI-Lora-Manager.git
synced 2026-03-22 05:32:12 -03:00
- Add disabled and loading states for control group buttons with appropriate cursor and opacity styling - Enhance dropdown toggle active state styling for update filter group - Improve dropdown toggle layout with flex centering - Add disabled state styling for dropdown items - Refactor model update check to use shared helper function, removing redundant success handling and simplifying error flow - Maintain existing functionality while improving user experience and code maintainability
137 lines
4.7 KiB
JavaScript
137 lines
4.7 KiB
JavaScript
import { BaseContextMenu } from './BaseContextMenu.js';
|
|
import { showToast } from '../../utils/uiHelpers.js';
|
|
import { state } from '../../state/index.js';
|
|
import { performModelUpdateCheck } from '../../utils/updateCheckHelpers.js';
|
|
|
|
export class GlobalContextMenu extends BaseContextMenu {
|
|
constructor() {
|
|
super('globalContextMenu');
|
|
this._cleanupInProgress = false;
|
|
this._updateCheckInProgress = false;
|
|
}
|
|
|
|
showMenu(x, y, origin = null) {
|
|
const contextOrigin = origin || { type: 'global' };
|
|
super.showMenu(x, y, contextOrigin);
|
|
}
|
|
|
|
handleMenuAction(action, menuItem) {
|
|
switch (action) {
|
|
case 'cleanup-example-images-folders':
|
|
this.cleanupExampleImagesFolders(menuItem).catch((error) => {
|
|
console.error('Failed to trigger example images cleanup:', error);
|
|
});
|
|
break;
|
|
case 'download-example-images':
|
|
this.downloadExampleImages(menuItem).catch((error) => {
|
|
console.error('Failed to trigger example images download:', error);
|
|
});
|
|
break;
|
|
case 'check-model-updates':
|
|
this.checkModelUpdates(menuItem).catch((error) => {
|
|
console.error('Failed to check model updates:', error);
|
|
});
|
|
break;
|
|
default:
|
|
console.warn(`Unhandled global context menu action: ${action}`);
|
|
break;
|
|
}
|
|
}
|
|
|
|
async downloadExampleImages(menuItem) {
|
|
const exampleImagesManager = window.exampleImagesManager;
|
|
|
|
if (!exampleImagesManager) {
|
|
showToast('globalContextMenu.downloadExampleImages.unavailable', {}, 'error');
|
|
return;
|
|
}
|
|
|
|
const downloadPath = state?.global?.settings?.example_images_path;
|
|
if (!downloadPath) {
|
|
showToast('globalContextMenu.downloadExampleImages.missingPath', {}, 'warning');
|
|
return;
|
|
}
|
|
|
|
menuItem?.classList.add('disabled');
|
|
|
|
try {
|
|
await exampleImagesManager.handleDownloadButton();
|
|
} finally {
|
|
menuItem?.classList.remove('disabled');
|
|
}
|
|
}
|
|
|
|
async cleanupExampleImagesFolders(menuItem) {
|
|
if (this._cleanupInProgress) {
|
|
return;
|
|
}
|
|
|
|
this._cleanupInProgress = true;
|
|
menuItem?.classList.add('disabled');
|
|
|
|
try {
|
|
const response = await fetch('/api/lm/cleanup-example-image-folders', {
|
|
method: 'POST',
|
|
});
|
|
|
|
let payload;
|
|
try {
|
|
payload = await response.json();
|
|
} catch (parseError) {
|
|
payload = { error: 'Unexpected response format.' };
|
|
}
|
|
|
|
if (response.ok && (payload.success || payload.partial_success)) {
|
|
const movedTotal = payload.moved_total || 0;
|
|
|
|
if (movedTotal > 0) {
|
|
showToast('globalContextMenu.cleanupExampleImages.success', { count: movedTotal }, 'success');
|
|
} else {
|
|
showToast('globalContextMenu.cleanupExampleImages.none', {}, 'info');
|
|
}
|
|
|
|
if (payload.partial_success) {
|
|
showToast(
|
|
'globalContextMenu.cleanupExampleImages.partial',
|
|
{ failures: payload.move_failures ?? 0 },
|
|
'warning',
|
|
);
|
|
}
|
|
} else {
|
|
const message = payload?.error || 'Unknown error';
|
|
showToast('globalContextMenu.cleanupExampleImages.error', { message }, 'error');
|
|
}
|
|
} catch (error) {
|
|
showToast('globalContextMenu.cleanupExampleImages.error', { message: error.message || 'Unknown error' }, 'error');
|
|
} finally {
|
|
this._cleanupInProgress = false;
|
|
menuItem?.classList.remove('disabled');
|
|
}
|
|
}
|
|
|
|
async checkModelUpdates(menuItem) {
|
|
if (this._updateCheckInProgress) {
|
|
return;
|
|
}
|
|
|
|
this._updateCheckInProgress = true;
|
|
menuItem?.classList.add('disabled');
|
|
|
|
try {
|
|
await performModelUpdateCheck({
|
|
onComplete: () => {
|
|
menuItem?.classList.remove('disabled');
|
|
this._updateCheckInProgress = false;
|
|
}
|
|
});
|
|
} catch (error) {
|
|
console.error('Failed to check model updates:', error);
|
|
} finally {
|
|
if (this._updateCheckInProgress) {
|
|
this._updateCheckInProgress = false;
|
|
menuItem?.classList.remove('disabled');
|
|
}
|
|
}
|
|
}
|
|
}
|