/ViewComfy

ViewComfy is a open source tool to help you create beautiful web apps from ComfyUI

Primary LanguageTypeScriptGNU General Public License v3.0GPL-3.0

ViewComfy

ViewComfy is an open source tool to help you create beautiful web apps from ComfyUI workflows.

Discord Website

Group 9

Demo

view-comfy-demo.mp4

Form Editor

You can drag and drop your ComfyUI workflow_api.json file into the form editor. It will then generate a new form that you can use to configure the inputs that will be displayed on the playground.

Playground

The Playground is a simplified UI where you can run your workflows. It can easily be turned into a sharable web app using a service like ngrok.

How to use it

You need to have comfy-cli installed

pip install comfy-cli
comfy install

Install Node.js 18.18 or later (recommended v20.17)

Clone the repo

git cone https://github.com/ViewComfy/ViewComfy.git

If you're using a virtual environment, activate it.

If you're using a virtual environment with PowerShell you need to put the full path of the Activate.ps1 file in the .env file e.g:

.env file ->
VENV_ACTIVATION_PATH="C:\Users\YourUsername\comfyui\venv\Scripts\Activate.ps1"

Install dependencies and start the dev server
(Don't forget to activate the virtual environment if you're using one)

npm install
npm run dev

ViewMode

ViewMode only loads the playground page and can easily be turned into a web app. This is convenient if you want to share your workflow with someone without sharing the workflow_api.json, and without them having to install ComfyUI.

To use ViewMode you need to download the view_comfy.json that is generated when you use the form editor and place it in the root of the project along with the workflow_api.json.

To enable ViewMode, edit the .env file in the root of the project:

.env file ->
NEXT_PUBLIC_VIEW_MODE="true"

npm run dev

ViewComfy by default will look for a file called view_comfy.json in the project's root folder to render the web app. You can use the VIEW_COMFY_FILE_NAME environment variable to point to a different file. You can also use the WORKFLOW_API_FILE_NAME environment variable to point to a different workflow than the default workflow_api.json.

.env file ->
VIEW_COMFY_FILE_NAME="view_comfy.json"
WORKFLOW_API_FILE_NAME="workflow_api.json"
NEXT_PUBLIC_VIEW_MODE="true"

npm run dev

e.g with the command line:

VIEW_COMFY_FILE_NAME="view_comfy.json" NEXT_PUBLIC_VIEW_MODE="true" npm run dev

For a more detailed guide on how to set up ViewMode and share your app with ngrok you can refer to our blog: https://www.viewcomfy.com/blog/blog-post-title-one-d2cy8

Form Editor Advanced

You can also drop a view_comfy.json directly in the form editor to edit it without the need for the workflow_api.json. But be aware that if you're using the view_comfy.json directly, you will still need to have the original workflow_api.json in the project's root.

Feel free to contribute with feedback, suggestions, issues or pull requests.

Roadmap

  • Build a solution to deploy ViewComfy apps on the cloud
  • Enable video inputs and outputs
  • Randomize the seed by default at every generation
  • Enable adding parameters back to the form editor after deletion

Tech

ViewComfy is a Next.js app - Next.js Documentation