Front-end of ComfyUI modernized. This repo is fully compatible with the existing extension system.
-
Migrate all code to TypeScript with minimal change modification to the original logic.
-
Bundle all code with vite's rollup build.
-
Added a shim layer to be backward compatible with the existing extension system. https://github.com/huchenlei/ComfyUI_frontend/pull/15
-
Front-end dev server.
-
Zod schema for input validation on ComfyUI workflow.
-
Make litegraph a npm dependency. Comfy-Org#89
-
Introduce Vue to start managing part of the UI.
- Starting with node search box revamp
- Replace the existing ComfyUI front-end impl (comfyanonymous/ComfyUI#3897).
- Remove
@ts-ignore
s. - Turn on
strict
ontsconfig.json
. - Introduce a UI library to add more widget types for node developers.
- LLM streaming node.
- Linear mode (Similar to InvokeAI's linear mode).
- Better node management. Sherlock https://github.com/Nuked88/ComfyUI-N-Sidebar.
- Keybinding settings management. Register keybindings API for custom nodes.
- New extensions API for adding UI-related features.
Run npm run prepare
to install Git pre-commit hooks. Currently, the pre-commit
hook is used to auto-format code on commit.
Note: The dev server will NOT load any extension from the ComfyUI server. Only core extensions will be loaded.
- Run
npm install
to install the necessary packages - Start local ComfyUI backend at
localhost:8188
- Run
npm run dev
to start the dev server
git clone https://github.com/comfyanonymous/ComfyUI_examples.git
totests-ui/ComfyUI_examples
or the EXAMPLE_REPO_PATH location specified in .envnpm i
to install all dependenciesnpm run test:generate
to fetchtests-ui/data/object_info.json
npm run test:generate:examples
to extract the example workflowsnpm run test
to execute all unit tests.
- Option 1: Set
DEPLOY_COMFYUI_DIR
in.env
and runnpm run deploy
. - Option 2: Copy everything under
dist/
toComfyUI/web/
in your ComfyUI checkout manually.
- api.api_url now adds a prefix
api/
to every url going through the method. If the custom node registers a new api endpoint but does not offer theapi/
prefixed alt endpoint, it will have issue. Luckily there aren't many extensions that do that. We can perform an audit before launching to resolve this issue.