mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-02-26 09:44:06 +00:00
Adds a system for selecting the inputs and outputs which should be displayed when inside linear mode. Functions only in litegraph currently. Vue support will require a separate, larger PR. Inputs and outputs can be re-ordered by dragging and dropping on the side panel.  ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-8965-Add-App-I-O-selection-system-30b6d73d365081569b36c1682a1fdbc5) by [Unito](https://www.unito.io)
124 lines
3.1 KiB
TypeScript
124 lines
3.1 KiB
TypeScript
import { watch } from 'vue'
|
|
|
|
import { useWorkflowService } from '@/platform/workflow/core/services/workflowService'
|
|
import { useWorkflowStore } from '@/platform/workflow/management/stores/workflowStore'
|
|
import { useDialogService } from '@/services/dialogService'
|
|
import { useAppModeStore } from '@/stores/appModeStore'
|
|
import { useDialogStore } from '@/stores/dialogStore'
|
|
|
|
import BuilderSaveDialogContent from './BuilderSaveDialogContent.vue'
|
|
import BuilderSaveSuccessDialogContent from './BuilderSaveSuccessDialogContent.vue'
|
|
|
|
const SAVE_DIALOG_KEY = 'builder-save'
|
|
const SUCCESS_DIALOG_KEY = 'builder-save-success'
|
|
|
|
export function useBuilderSave() {
|
|
const appModeStore = useAppModeStore()
|
|
const workflowStore = useWorkflowStore()
|
|
const workflowService = useWorkflowService()
|
|
const dialogService = useDialogService()
|
|
const dialogStore = useDialogStore()
|
|
|
|
watch(
|
|
() => appModeStore.isBuilderSaving,
|
|
(saving) => {
|
|
if (saving) void onBuilderSave()
|
|
}
|
|
)
|
|
|
|
async function onBuilderSave() {
|
|
const workflow = workflowStore.activeWorkflow
|
|
if (!workflow) {
|
|
resetSaving()
|
|
return
|
|
}
|
|
|
|
if (!workflow.isTemporary && workflow.activeState.extra?.linearMode) {
|
|
try {
|
|
workflow.changeTracker?.checkState()
|
|
appModeStore.saveSelectedToWorkflow()
|
|
await workflowService.saveWorkflow(workflow)
|
|
showSuccessDialog(workflow.filename, appModeStore.isAppMode)
|
|
} catch {
|
|
resetSaving()
|
|
}
|
|
return
|
|
}
|
|
|
|
showSaveDialog(workflow.filename)
|
|
}
|
|
|
|
function showSaveDialog(defaultFilename: string) {
|
|
dialogService.showLayoutDialog({
|
|
key: SAVE_DIALOG_KEY,
|
|
component: BuilderSaveDialogContent,
|
|
props: {
|
|
defaultFilename,
|
|
onSave: handleSave,
|
|
onClose: handleCancelSave
|
|
},
|
|
dialogComponentProps: {
|
|
onClose: resetSaving
|
|
}
|
|
})
|
|
}
|
|
|
|
function handleCancelSave() {
|
|
closeSaveDialog()
|
|
resetSaving()
|
|
}
|
|
|
|
async function handleSave(filename: string, openAsApp: boolean) {
|
|
try {
|
|
const workflow = workflowStore.activeWorkflow
|
|
if (!workflow) return
|
|
|
|
appModeStore.saveSelectedToWorkflow()
|
|
const saved = await workflowService.saveWorkflowAs(workflow, {
|
|
filename,
|
|
openAsApp
|
|
})
|
|
|
|
if (!saved) return
|
|
|
|
closeSaveDialog()
|
|
showSuccessDialog(filename, openAsApp)
|
|
} catch {
|
|
closeSaveDialog()
|
|
resetSaving()
|
|
}
|
|
}
|
|
|
|
function showSuccessDialog(workflowName: string, savedAsApp: boolean) {
|
|
dialogService.showLayoutDialog({
|
|
key: SUCCESS_DIALOG_KEY,
|
|
component: BuilderSaveSuccessDialogContent,
|
|
props: {
|
|
workflowName,
|
|
savedAsApp,
|
|
onViewApp: () => {
|
|
appModeStore.setMode('app')
|
|
closeSuccessDialog()
|
|
},
|
|
onClose: closeSuccessDialog
|
|
},
|
|
dialogComponentProps: {
|
|
onClose: resetSaving
|
|
}
|
|
})
|
|
}
|
|
|
|
function closeSaveDialog() {
|
|
dialogStore.closeDialog({ key: SAVE_DIALOG_KEY })
|
|
}
|
|
|
|
function closeSuccessDialog() {
|
|
dialogStore.closeDialog({ key: SUCCESS_DIALOG_KEY })
|
|
resetSaving()
|
|
}
|
|
|
|
function resetSaving() {
|
|
appModeStore.setBuilderSaving(false)
|
|
}
|
|
}
|