Compare commits

...

16 Commits
3.30.4 ... 3.31

Author SHA1 Message Date
Dr.Lt.Data
e05f329602 bump version to 3.31 2025-03-14 00:59:11 +09:00
Dr.Lt.Data
eed0e8ebea update DB 2025-03-14 00:58:55 +09:00
SirWillance
731eb4fcbe Please verify my changes (#1643)
* Update custom-node-list.json

* Update custom-node-list.json

* Update custom-node-list.json

* Update custom-node-list.json

I felt the need to change the Title and the Description

---------

Co-authored-by: Dr.Lt.Data <128333288+ltdrdata@users.noreply.github.com>
2025-03-14 00:53:36 +09:00
Dr.Lt.Data
44a63e4b6d update DB 2025-03-14 00:52:06 +09:00
CenFun
7651e5e48b UI improvement (#1625) 2025-03-14 00:51:37 +09:00
Dr.Lt.Data
2449636d32 update DB 2025-03-14 00:45:47 +09:00
Dr.Lt.Data
f9990ca8eb fixed: make_pip_cmd - add '-s' option 2025-03-13 22:48:13 +09:00
Dr.Lt.Data
c3eed981c0 fixed: robust validation when model downloading #2 2025-03-12 21:24:31 +09:00
Dr.Lt.Data
bbb54d4a08 fixed: robust validation when model downloading 2025-03-12 21:10:02 +09:00
Dr.Lt.Data
4566c585db fixed: a condition code wasn’t saved after editing... lol 2025-03-12 21:00:05 +09:00
Dr.Lt.Data
a946338a18 fixed: invalid channel exception when startup 2025-03-12 17:28:17 +09:00
Dr.Lt.Data
0a60a44478 fixed: several security bugs
refactor: remove serveal unused code
2025-03-12 11:32:16 +09:00
Dr.Lt.Data
cef0ad6707 update DB 2025-03-12 07:21:38 +09:00
Robin Huang
7176f0837a Add linux form factor. (#1648) 2025-03-12 07:20:06 +09:00
Yuan-Man
6b1f2b2d9d Add ComfyUI-StyleStudio node (#1639) 2025-03-12 07:15:58 +09:00
Laureηt
38a1a9b320 add comfyui-finegrain to custom-node-list.json (#1587) 2025-03-12 07:04:18 +09:00
21 changed files with 4369 additions and 2020 deletions

View File

@@ -8825,27 +8825,7 @@
"https://github.com/if-ai/ComfyUI-IF_DatasetMkr"
],
"install_type": "git-clone",
"description": "Create Video datasets staright from YT or a video file path"
},
{
"author": "impactframes",
"title": "IF_VideoPrompts",
"reference": "https://github.com/if-ai/ComfyUI-IF_VideoPrompts",
"files": [
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts"
],
"install_type": "git-clone",
"description": "ComfyUI extension for video-based prompting and processing with support for various models and video processing capabilities"
},
{
"author": "impactframes",
"title": "IF_LLM",
"reference": "https://github.com/if-ai/ComfyUI-IF_LLM",
"files": [
"https://github.com/if-ai/ComfyUI-IF_LLM"
],
"install_type": "git-clone",
"description": "Run Local and API LLMs, Features Conditioning manipulation via Omost, supports Ollama, LlamaCPP LMstudio, Koboldcpp, TextGen, Transformers or via APIs Anthropic, Groq, OpenAI, Google Gemini, Mistral, xAI and create your own charcters assistants (SystemPrompts) with custom presets and muchmore\n[w/It Might comflict with IF_AI_tools so if you have it installed please remove it before installing IF_LLM I am working on adding this tools to IF_AI_tools so you only need one or the other]"
"description": "Create Video datasets straight from YT or a video file path"
},
{
"author": "dmMaze",
@@ -9342,6 +9322,16 @@
"install_type": "git-clone",
"description": "A ComfyUI node that utilizes Moviepy to convert and send your images or videos to a webhook endpoint directly from ComfyUI."
},
{
"author": "KytraScript",
"title": "ComfyUI_MatAnyone_Kytra",
"reference": "https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra",
"files": [
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra"
],
"install_type": "git-clone",
"description": "This is a ComfyUI node for [a/MatAnyone](https://github.com/pq-yang/MatAnyone), a state-of-the-art video matting model that can remove backgrounds from videos using just a single mask for the first frame for enhanced/guided video matting."
},
{
"author": "1mckw",
"title": "Comfyui-Gelbooru",
@@ -10504,7 +10494,7 @@
"https://github.com/smthemex/ComfyUI_Sapiens"
],
"install_type": "git-clone",
"description": "You can call Using Sapiens to get seg,normal,pose,depth,mask maps. Sapiens From: [a/facebookresearch/sapiens](https://github.com/facebookresearch/sapiens)"
"description": "You can call Using Sapiens to get segnormalposedepthmask."
},
{
"author": "smthemex",
@@ -10656,6 +10646,16 @@
"install_type": "git-clone",
"description": "PhotoDoodle: Learning Artistic Image Editing from Few-Shot Pairwise Datayou can use it in comfyUI"
},
{
"author": "smthemex",
"title": "ComfyUI_KV_Edit",
"reference": "https://github.com/smthemex/ComfyUI_KV_Edit",
"files": [
"https://github.com/smthemex/ComfyUI_KV_Edit"
],
"install_type": "git-clone",
"description": "KV-Edit: Training-Free Image Editing for Precise Background Preservation,you can use it in comfyUI"
},
{
"author": "choey",
"title": "Comfy-Topaz",
@@ -14214,6 +14214,16 @@
"install_type": "git-clone",
"description": "The ComfyUI-Visionatrix nodes are designed for convenient ComfyUI to [a/Visionatrix](https://github.com/Visionatrix/Visionatrix) workflow support migration, in particular to extract prompt input params (input, textarea, checkbox, select, range, file) to be used in simplified Visionatrix UI."
},
{
"author": "Visionatrix",
"title": "ComfyUI-RemoteVAE",
"reference": "https://github.com/Visionatrix/ComfyUI-RemoteVAE",
"files": [
"https://github.com/Visionatrix/ComfyUI-RemoteVAE"
],
"install_type": "git-clone",
"description": "ComfyUI Nodes for Remote VAE Decoding."
},
{
"author": "liangt",
"title": "comfyui-loadimagewithsubfolder",
@@ -14495,7 +14505,7 @@
"https://github.com/GeekyGhost/ComfyUI-GeekyRemB"
],
"install_type": "git-clone",
"description": "GeekyRemB is a powerful and versatile image processing node for ComfyUI, designed to remove backgrounds from images with advanced customization options. This node leverages the rembg library and offers a wide range of features for fine-tuning the background removal process and enhancing the resulting images."
"description": "GeekyRemB is a powerful suite of image processing nodes for ComfyUI, offering advanced background removal, animation, lighting effects, and keyframe-based positioning. Built on the rembg library with additional capabilities for chroma keying, mask refinement, realistic lighting, shadow generation, and dynamic animations."
},
{
"author": "GeekyGhost",
@@ -14659,6 +14669,26 @@
"install_type": "git-clone",
"description": "The latest DIT architecture-based image generation model from Zhipu that supports Chinese text generation."
},
{
"author": "leeguandong",
"title": "ComfyUI_1Prompt1Story",
"reference": "https://github.com/leeguandong/ComfyUI_1Prompt1Story",
"files": [
"https://github.com/leeguandong/ComfyUI_1Prompt1Story"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/1Prompt1Story](https://github.com/byliutao/1Prompt1Story)"
},
{
"author": "leeguandong",
"title": "ComfyUI_ChatGen",
"reference": "https://github.com/leeguandong/ComfyUI_ChatGen",
"files": [
"https://github.com/leeguandong/ComfyUI_ChatGen"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/ChatGen](https://github.com/chengyou-jia/ChatGen)"
},
{
"author": "lenskikh",
"title": "Propmt Worker",
@@ -15115,6 +15145,16 @@
"install_type": "git-clone",
"description": "Metadata for loaded models"
},
{
"author": "markuryy",
"title": "Video XY Plot",
"reference": "https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot",
"files": [
"https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot"
],
"install_type": "git-clone",
"description": "A collection of custom nodes for ComfyUI"
},
{
"author": "eesahe",
"title": "ComfyUI-eesahesNodes",
@@ -16064,7 +16104,7 @@
},
{
"author": "Cyber-BCat",
"title": "ComfyUI_Auto_Caption",
"title": "Cyber-BlackCat",
"reference": "https://github.com/Cyber-BCat/ComfyUI_Auto_Caption",
"files": [
"https://github.com/Cyber-BCat/ComfyUI_Auto_Caption"
@@ -16759,6 +16799,16 @@
"install_type": "git-clone",
"description": "Through this node, you can more easily test the impact of different blocks in flux_lora on the final result."
},
{
"author": "SSsnap",
"title": "ComfyUI-Ad_scheduler",
"reference": "https://github.com/SS-snap/ComfyUI-Ad_scheduler",
"files": [
"https://github.com/SS-snap/ComfyUI-Ad_scheduler"
],
"install_type": "git-clone",
"description": "This node is used to enhance image details. We can add a latent space image and introduce any amount of noise. Then, we can start denoising at any timestep. This allows us to add more details to the image while maintaining overall consistency as much as possible."
},
{
"author": "RiceRound",
"title": "ComfyUI Compression and Encryption Node",
@@ -16875,16 +16925,6 @@
"install_type": "git-clone",
"description": "This is a node to convert workflows to cyuai api available nodes."
},
{
"author": "l1yongch1",
"title": "ComfyUI_PhiCaption",
"reference": "https://github.com/l1yongch1/ComfyUI_PhiCaption",
"files": [
"https://github.com/l1yongch1/ComfyUI_PhiCaption"
],
"install_type": "git-clone",
"description": "In addition to achieving conventional single-image, single-round reverse engineering, it can also achieve single-image multi-round and multi-image single-round reverse engineering. Moreover, the Phi model has a better understanding of prompts."
},
{
"author": "tkreuziger",
"title": "ComfyUI and Claude",
@@ -18410,13 +18450,13 @@
{
"author": "lightricks",
"title": "ComfyUI-LTXVideo",
"id": "ltxv",
"id": "comfyui-ltxvideo",
"reference": "https://github.com/Lightricks/ComfyUI-LTXVideo",
"files": [
"https://github.com/Lightricks/ComfyUI-LTXVideo"
],
"install_type": "git-clone",
"description": "ComfyUI nodes for LTXVideo model."
"description": "Custom nodes for LTX-Video support in ComfyUI"
},
{
"author": "Kai Duehrkop",
@@ -18573,6 +18613,16 @@
"install_type": "git-clone",
"description": "ComfyUI nodes for PhotoDoodle model."
},
{
"author": "Yuan-ManX",
"title": "ComfyUI-StyleStudio",
"reference": "https://github.com/Yuan-ManX/ComfyUI-StyleStudio",
"files": [
"https://github.com/Yuan-ManX/ComfyUI-StyleStudio"
],
"install_type": "git-clone",
"description": "ComfyUI nodes for StyleStudio model."
},
{
"author": "Starnodes2024",
"title": "ComfyUI_StarNodes",
@@ -19740,6 +19790,16 @@
"install_type": "git-clone",
"description": "ComfyUI_NTCosyVoice is a plugin of ComfyUI for Cosysvoice2"
},
{
"author": "muxueChen",
"title": "ComfyUI-NTQwen25-VL",
"reference": "https://github.com/muxueChen/ComfyUI-NTQwen25-VL",
"files": [
"https://github.com/muxueChen/ComfyUI-NTQwen25-VL"
],
"install_type": "git-clone",
"description": "Qwen25-VL is a plugin for ComfyU"
},
{
"author": "inventorado",
"title": "ComfyUI Neural Network Toolkit NNT ",
@@ -21309,6 +21369,16 @@
"install_type": "git-clone",
"description": "Data analysis custom modules for ComfyUI - Use Pandas & Matplotlib from within ComfyUI"
},
{
"author": "HowToSD",
"title": "ComfyUI-Pt-Wrapper",
"reference": "https://github.com/HowToSD/ComfyUI-Pt-Wrapper",
"files": [
"https://github.com/HowToSD/ComfyUI-Pt-Wrapper"
],
"install_type": "git-clone",
"description": "PyTorch extension for ComfyUI featuring extensive PyTorch wrapper nodes for seamless tensor operations and PyTorch model training."
},
{
"author": "dasilva333",
"title": "ComfyUI_ContrastingColor",
@@ -21657,14 +21727,14 @@
},
{
"author": "SirWillance",
"title": "Force of Will Suite Light",
"title": "FoW - Light",
"id": "fow-suite-light",
"reference": "https://github.com/SirWillance/FoW_Suite_LIGHT",
"files": [
"https://github.com/SirWillance/FoW_Suite_LIGHT"
],
"install_type": "git-clone",
"description": "Beginner-friendly nodes for prompt refinement in ComfyUI, including custom nodes for weighting, splitting, combining, catalogues, and the PromptRefiner for a simple prompt interface. For more info, join me on https://www.twitch.tv/sirwillance. Be one of the first 50 followers to get a FREE upgrade to the Standard Tier!"
"description": "A Beginner-friendly Node Suite for prompt refinement in ComfyUI, including custom nodes for weighting, splitting, combining, catalogues, and the PromptRefiner for a simple prompt interface. For more info, join me on https://www.twitch.tv/sirwillance. Be one of the first 50 followers to get a FREE upgrade to the Standard Tier!"
},
{
"author": "KAVVATARE",
@@ -21922,6 +21992,16 @@
"install_type": "git-clone",
"description": "Quickly select preset prompts and merge them"
},
{
"author": "S4MUEL-404",
"title": "ComfyUI-S4Tool-Image-Overlay",
"reference": "https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay",
"files": [
"https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay"
],
"install_type": "git-clone",
"description": "Quickly set up image overlay effects"
},
{
"author": "ZYK-AI",
"title": "ComfyUI-YK Line loading",
@@ -21974,6 +22054,208 @@
"install_type": "git-clone",
"description": "A ComfyUI custom node that provides dynamic text substitution using wildcards and CSV files. Perfect for creating varied prompts with consistent relationships between terms."
},
{
"author": "finegrain",
"title": "comfyui-finegrain",
"reference": "https://github.com/finegrain-ai/comfyui-finegrain",
"files": [
"https://github.com/finegrain-ai/comfyui-finegrain"
],
"install_type": "git-clone",
"description": "ComfyUI custom nodes to interact with the Finegrain API."
},
{
"author": "Diohim",
"title": "ComfyUI Unusual Tools",
"reference": "https://github.com/Diohim/ComfyUI-Unusual-Tools",
"files": [
"https://github.com/Diohim/ComfyUI-Unusual-Tools"
],
"install_type": "git-clone",
"description": "A collection of unusual but useful image processing nodes for ComfyUI."
},
{
"author": "penposs",
"title": "ComfyUI Gemini Pro Node",
"reference": "https://github.com/penposs/ComfyUI_Gemini_Pro",
"files": [
"https://github.com/penposs/ComfyUI_Gemini_Pro"
],
"install_type": "git-clone",
"description": "This is a Google Gemini Pro API integration node for ComfyUI, supporting text, image, video, and audio inputs."
},
{
"author": "cardenluo",
"title": "ComfyUI-Apt_Preset",
"reference": "https://github.com/cardenluo/ComfyUI-Apt_Preset",
"files": [
"https://github.com/cardenluo/ComfyUI-Apt_Preset"
],
"install_type": "git-clone",
"description": "ComfyUI-Apt_Preset is a node package designed to simplify workflows"
},
{
"author": "Holasyb918",
"title": "Ghost2_Comfyui",
"reference": "https://github.com/Holasyb918/Ghost2_Comfyui",
"files": [
"https://github.com/Holasyb918/Ghost2_Comfyui"
],
"install_type": "git-clone",
"description": "ComfyUI adaptation of [a/GHOST 2.0](https://github.com/ai-forever/ghost-2.0)."
},
{
"author": "mit-han-lab",
"title": "ComfyUI-nunchaku",
"reference": "https://github.com/mit-han-lab/ComfyUI-nunchaku",
"files": [
"https://github.com/mit-han-lab/ComfyUI-nunchaku"
],
"install_type": "git-clone",
"description": "Nunchaku ComfyUI Node. Nunchaku is the inference that supports SVDQuant. SVDQuant is a new post-training training quantization paradigm for diffusion models, which quantize both the weights and activations of FLUX.1 to 4 bits, achieving 3.5× memory and 8.7× latency reduction on a 16GB laptop 4090 GPU. See more details: https://github.com/mit-han-lab/nunchaku"
},
{
"author": "billwuhao",
"title": "ComfyUI_DiffRhythm",
"reference": "https://github.com/billwuhao/ComfyUI_DiffRhythm",
"files": [
"https://github.com/billwuhao/ComfyUI_DiffRhythm"
],
"install_type": "git-clone",
"description": "Blazingly Fast and Embarrassingly Simple End-to-End Full-Length Song Generation. A node for ComfyUI."
},
{
"author": "Nikosis",
"title": "ComfyUI-Nikosis-Nodes",
"reference": "https://github.com/Nikosis/ComfyUI-Nikosis-Nodes",
"files": [
"https://github.com/Nikosis/ComfyUI-Nikosis-Nodes"
],
"install_type": "git-clone",
"description": "Nodes: Aspect Ratio, Prompt Multiple Styles Selector, Text Concatenate"
},
{
"author": "vadimcro",
"title": "VKriez Edge Preprocessors for ComfyUI",
"reference": "https://github.com/vadimcro/VKRiez-Edge",
"files": [
"https://github.com/vadimcro/VKRiez-Edge"
],
"install_type": "git-clone",
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps for ControlNet guidance. Currently based on CPU computation, so might be a tid-bit on a slow side. If anyone is willing to refactor the code to GPU computation - Kudos!"
},
{
"author": "Duanyll",
"title": "Duanyll Nodepack",
"reference": "https://github.com/Duanyll/duanyll_nodepack",
"files": [
"https://github.com/Duanyll/duanyll_nodepack"
],
"install_type": "git-clone",
"description": "A collection of custom nodes for ComfyUI"
},
{
"author": "irreveloper",
"title": "ComfyUI-DSD",
"reference": "https://github.com/irreveloper/ComfyUI-DSD",
"files": [
"https://github.com/irreveloper/ComfyUI-DSD"
],
"install_type": "git-clone",
"description": "An Unofficial ComfyUI custom node package that integrates [a/Diffusion Self-Distillation (DSD)](https://github.com/primecai/diffusion-self-distillation) for zero-shot customized image generation.\nDSD is a model for subject-preserving image generation that allows you to create images of a specific subject in novel contexts without per-instance tuning."
},
{
"author": "HannibalP",
"title": "comfyui-HannibalPack",
"reference": "https://github.com/HannibalP/comfyui-HannibalPack",
"files": [
"https://github.com/HannibalP/comfyui-HannibalPack"
],
"install_type": "git-clone",
"description": "This node improves the merging of LoRA for movements and physical resemblance when adding multiple LoRA to a model."
},
{
"author": "xingBaGan",
"title": "ComfyUI-connect-ui",
"reference": "https://github.com/xingBaGan/ComfyUI-connect-ui",
"files": [
"https://github.com/xingBaGan/ComfyUI-connect-ui"
],
"install_type": "git-clone",
"description": "Real-time image transfer between client and server Base64 image encoding/decoding support Supports PNG image format Includes a floating preview window for received images Preview window has minimize/maximize functionality"
},
{
"author": "iDAPPA",
"title": "AMD GPU Monitor for ComfyUI",
"reference": "https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor",
"files": [
"https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor"
],
"install_type": "git-clone",
"description": "A simple, lightweight AMD GPU monitoring tool for ComfyUI that displays real-time information about your AMD GPU directly in the UI."
},
{
"author": "roundyyy",
"title": "Mesh Simplifier for ComfyUI",
"reference": "https://github.com/roundyyy/ComfyUI-mesh-simplifier",
"files": [
"https://github.com/roundyyy/ComfyUI-mesh-simplifier"
],
"install_type": "git-clone",
"description": "A custom node for ComfyUI that implements mesh simplification with texture preservation using PyMeshLab. This node allows you to reduce the complexity of 3D meshes while preserving visual quality, and is compatible with ComfyUI-3D-Pack's mesh format."
},
{
"author": "notagen-mw",
"title": "ComfyUI_NotaGen",
"reference": "https://github.com/billwuhao/ComfyUI_NotaGen",
"files": [
"https://github.com/billwuhao/ComfyUI_NotaGen"
],
"install_type": "git-clone",
"description": "Symbolic Music Generation, NotaGen node for ComfyUI."
},
{
"author": "orssorbit",
"title": "ComfyUI-wanBlockswap",
"reference": "https://github.com/orssorbit/ComfyUI-wanBlockswap",
"files": [
"https://github.com/orssorbit/ComfyUI-wanBlockswap"
],
"install_type": "git-clone",
"description": "This is a simple Wan block swap node for ComfyUI native nodes, works by swapping upto 40 blocks to the CPU to reduce VRAM."
},
{
"author": "joreyaesh",
"title": "ComfyUI Scroll Over Textarea",
"reference": "https://github.com/joreyaesh/comfyui_scroll_over_textarea",
"files": [
"https://github.com/joreyaesh/comfyui_scroll_over_textarea"
],
"install_type": "git-clone",
"description": "A ComfyUI extension to allow textarea elements to be scrolled over. Useful when using a trackpad in order to prevent accidental forward/back navigation (two fingers horizontally on a Mac) when scrolling around the UI."
},
{
"author": "ali-vilab",
"title": "ComfyUI-ACE_Plus",
"id": "ace_plus",
"reference": "https://github.com/ali-vilab/ACE_plus",
"files": [
"https://github.com/ali-vilab/ACE_plus"
],
"install_type": "git-clone",
"description": "Custom nodes for various visual generation and editing tasks using ACE_Plus FFT Model."
},

View File

@@ -77,7 +77,12 @@
],
"https://github.com/1038lab/ComfyUI-RMBG": [
[
"BiRefNet",
"AiLab_ImagePreview",
"AiLab_LoadImage",
"AiLab_MaskPreview",
"AiLab_Preview",
"BiRefNetRMBG",
"BodySegment",
"ClothesSegment",
"FaceSegment",
"FashionSegmentAccessories",
@@ -222,6 +227,7 @@
[
"Character2Video",
"Image2Video",
"StartEnd2Video",
"Text2Video",
"UpscaleVideo",
"VideoDownloader"
@@ -451,7 +457,6 @@
"PrimitiveNode",
"Random_Select_Prompt",
"Run_BEN_v2",
"Run_Similarity",
"Run_torchvision_model",
"Sam2AutoSegmentation_data",
"Save_Image_Out",
@@ -466,23 +471,20 @@
"Video_OverlappingSeparation_test",
"WAS_Mask_Fill_Region_batch",
"adv_crop",
"any_data",
"any_math",
"any_math_v2",
"array_count",
"bbox_restore_mask",
"color_segmentation",
"color_segmentation_v2",
"coords_select_mask",
"filter_DensePose_color",
"get_image_data",
"image_ValueMath",
"image_math",
"image_math_value",
"invert_channel_adv",
"load_BEN_model",
"load_ColorName_config",
"load_EasyOCR_model",
"load_Similarity",
"load_color_config",
"load_model_value",
"load_torchvision_model",
@@ -1413,8 +1415,11 @@
"Faishme Mannequin to Model Loader",
"Faishme Memory Debug",
"Faishme Moondream",
"Faishme Repeat BBOX",
"Faishme Repeat Image Batch",
"Faishme Repeat Latent Batch",
"Faishme Repeat Tensor Batch",
"Faishme Save Image",
"Faishme Stack Images",
"Faishme Stack Latents",
"Faishme Unstack Images",
@@ -1704,6 +1709,7 @@
"HTBaseShiftNode",
"HTConsoleLoggerNode",
"HTConversionNode",
"HTDetectionBatchProcessor",
"HTDiffusionLoaderMulti",
"HTDimensionAnalyzerNode",
"HTDimensionFormatterNode",
@@ -1718,7 +1724,6 @@
"HTNodeStateController",
"HTNodeUnmuteAll",
"HTNullNode",
"HTOIDNNode",
"HTParameterExtractorNode",
"HTPhotoshopBlurNode",
"HTRegexNode",
@@ -2311,6 +2316,7 @@
"ShotByImageNode",
"ShotByTextNode",
"TailoredModelInfoNode",
"TailoredPortraitNode",
"Text2ImageBaseNode",
"Text2ImageFastNode",
"Text2ImageHDNode"
@@ -2536,7 +2542,8 @@
[
"Directory File Counter",
"Simple Number Counter",
"Text File Line Counter"
"Text File Line Counter",
"Text File Line Reader"
],
{
"title_aux": "ComfyUI-Line-counter"
@@ -2554,6 +2561,8 @@
"Conditioning Recast FP64",
"ConditioningAdd",
"ConditioningAverageScheduler",
"ConditioningBatch4",
"ConditioningBatch8",
"ConditioningMultiply",
"ConditioningOrthoCollin",
"ConditioningToBase64",
@@ -2857,11 +2866,14 @@
"https://github.com/Cyber-BCat/ComfyUI_Auto_Caption": [
[
"Auto Caption",
"Auto_Caption2",
"ExtraOptionsSet",
"Joy Model load",
"Joy_Model2_load",
"LoadManyImages"
],
{
"title_aux": "ComfyUI_Auto_Caption"
"title_aux": "Cyber-BlackCat"
}
],
"https://github.com/Cyber-Blacat/ComfyUI-Yuan": [
@@ -3127,6 +3139,17 @@
"title_aux": "Comfyui SDAPI Request / NovelAI"
}
],
"https://github.com/Diohim/ComfyUI-Unusual-Tools": [
[
"AdjustCrop",
"AutoImageResize",
"BatchLoadLatentImage",
"BatchSaveLatentImage"
],
{
"title_aux": "ComfyUI Unusual Tools"
}
],
"https://github.com/Dobidop/ComfyStereo": [
[
"DeoVRViewNode",
@@ -3225,6 +3248,14 @@
"title_aux": "Boyonodes"
}
],
"https://github.com/Duanyll/duanyll_nodepack": [
[
"PhotoDoddleConditioning"
],
{
"title_aux": "Duanyll Nodepack"
}
],
"https://github.com/Eagle-CN/ComfyUI-Addoor": [
[
"AD_AnyFileList",
@@ -4177,7 +4208,10 @@
],
"https://github.com/GeekyGhost/ComfyUI-GeekyRemB": [
[
"GeekyRemB"
"GeekyRemB",
"GeekyRemB_Animator",
"GeekyRemB_KeyframePosition",
"GeekyRemB_LightShadow"
],
{
"title_aux": "ComfyUI-GeekyRemB"
@@ -4261,6 +4295,7 @@
"GR Image Resize Methods",
"GR Image Size",
"GR Image/Depth Mask",
"GR Lora Randomizer",
"GR Mask",
"GR Mask Create",
"GR Mask Create Random",
@@ -4430,6 +4465,14 @@
"title_aux": "Recognize Anything Model (RAM) for ComfyUI"
}
],
"https://github.com/HannibalP/comfyui-HannibalPack": [
[
"HannibalLoraLoader"
],
{
"title_aux": "comfyui-HannibalPack"
}
],
"https://github.com/Haoming02/comfyui-diffusion-cg": [
[
"Normalization",
@@ -4546,6 +4589,23 @@
"title_aux": "Hiero-Nodes"
}
],
"https://github.com/Holasyb918/Ghost2_Comfyui": [
[
"AlignPipeline",
"BlenderPipeline",
"FaceAnalysisePipeline",
"FaceParsingPipeline",
"LoadAlignerModel",
"LoadBlenderModel",
"LoadFaceAnalysisModel",
"LoadFaceParsingModel",
"LoadInpainterModel",
"LoadStyleMatteModel"
],
{
"title_aux": "Ghost2_Comfyui"
}
],
"https://github.com/Hopping-Mad-Games/ComfyUI_LiteLLM": [
[
"AgentMemoryProvider",
@@ -5159,6 +5219,7 @@
"ImagetoTD",
"LoadTDImage",
"Tripo3DtoTD",
"TripoSRtoTD",
"VideotoTD"
],
{
@@ -5689,6 +5750,15 @@
"title_aux": "ComfyUI_KytraWebhookHTTP"
}
],
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra": [
[
"Kytra_Images_To_RGB",
"MatAnyoneVideoMatting"
],
{
"title_aux": "ComfyUI_MatAnyone_Kytra"
}
],
"https://github.com/LAOGOU-666/ComfyUI_LG_FFT": [
[
"LG_FFTNode",
@@ -6858,6 +6928,7 @@
"WinampViz",
"WinampVizV2",
"ZenkaiImagePromptV1",
"ZenkaiImagePromptV2",
"ZenkaiPoseMap",
"ZenkaiPrompt",
"ZenkaiPromptV2",
@@ -7063,6 +7134,16 @@
"title_aux": "ComfyUI_TravelSuite"
}
],
"https://github.com/Nikosis/ComfyUI-Nikosis-Nodes": [
[
"AspectRatioNikosis",
"PromptMultipleStylesSelectorNikosis",
"TextConcatenateNikosis"
],
{
"title_aux": "ComfyUI-Nikosis-Nodes"
}
],
"https://github.com/NimaNzrii/comfyui-photoshop": [
[
"\ud83d\udd39 Photoshop RemoteConnection",
@@ -7376,14 +7457,6 @@
"title_aux": "ComfyUI-Fooocus-V2-Expansion"
}
],
"https://github.com/PanicTitan/ComfyUI-Gallery": [
[
"GalleryNode"
],
{
"title_aux": "ComfyUI-Gallery"
}
],
"https://github.com/Parameshvadivel/ComfyUI-SVGview": [
[
"SVGPreview"
@@ -7918,6 +7991,17 @@
"title_aux": "ComfyUI-Prompts-Selector"
}
],
"https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay": [
[
"ImageBlendWithAlpha",
"ImageColor",
"ImageOverlay",
"ImageSelector"
],
{
"title_aux": "ComfyUI-S4Tool-Image-Overlay"
}
],
"https://github.com/S4MUEL-404/ComfyUI-Text-On-Image": [
[
"TextOnImage"
@@ -8000,6 +8084,14 @@
"title_aux": "ComfyUI-LexTools"
}
],
"https://github.com/SS-snap/ComfyUI-Ad_scheduler": [
[
"AD_Scheduler"
],
{
"title_aux": "ComfyUI-Ad_scheduler"
}
],
"https://github.com/SS-snap/ComfyUI-LBW_flux": [
[
"LoraBlockWeight_Flux"
@@ -8562,6 +8654,14 @@
"title_aux": "ComfyUI-FreeMemory"
}
],
"https://github.com/ShmuelRonen/ComfyUI-FreeVC_wrapper": [
[
"FreeVC Voice Conversion"
],
{
"title_aux": "ComfyUI-FreeVC_wrapper"
}
],
"https://github.com/ShmuelRonen/ComfyUI-Gemini_Flash_2.0_Exp": [
[
"AudioRecorder",
@@ -9110,6 +9210,7 @@
"Star Face Loader",
"Star3LoRAs",
"StarDivisibleDimension",
"StarEasyTextStorage",
"StarFiveWildcards",
"StarImageSwitch",
"StarLatentSwitch",
@@ -10188,6 +10289,14 @@
"title_aux": "VEnhancer ComfyUI Extension"
}
],
"https://github.com/Visionatrix/ComfyUI-RemoteVAE": [
[
"RemoteVAEDecode"
],
{
"title_aux": "ComfyUI-RemoteVAE"
}
],
"https://github.com/Visionatrix/ComfyUI-Visionatrix": [
[
"StyleAlignedBatchAlign",
@@ -10905,6 +11014,14 @@
"title_aux": "ComfyUI-SoundHub"
}
],
"https://github.com/Yuan-ManX/ComfyUI-StyleStudio": [
[
"StyleStudio Image Stylization"
],
{
"title_aux": "ComfyUI-StyleStudio"
}
],
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-APISR": [
[
"APISR_Lterative_Zho",
@@ -12076,6 +12193,8 @@
"Sage_GetFileHash",
"Sage_JoinText",
"Sage_KSampler",
"Sage_KSamplerDecoder",
"Sage_KSamplerTiledDecoder",
"Sage_LastLoraInfo",
"Sage_LoadImage",
"Sage_LogicalSwitch",
@@ -12091,6 +12210,7 @@
"Sage_SetFloat",
"Sage_SetInteger",
"Sage_SetText",
"Sage_TilingInfo",
"Sage_TripleJoinText",
"Sage_TripleLoraStack",
"Sage_UNETLoader",
@@ -12153,6 +12273,7 @@
"PCLazyTextEncode",
"PCLazyTextEncodeAdvanced",
"PCLoraHooksFromText",
"PCSaveExpandedWorkflow",
"PCSetLogLevel",
"PCSetPCTextEncodeSettings",
"PCTextEncode",
@@ -12677,6 +12798,16 @@
"title_aux": "ComfyUI_TextAssets"
}
],
"https://github.com/billwuhao/ComfyUI_DiffRhythm": [
[
"AudioRecorderDR",
"DiffRhythmRun",
"MultiLinePrompt"
],
{
"title_aux": "ComfyUI_DiffRhythm"
}
],
"https://github.com/billwuhao/ComfyUI_KokoroTTS_MW": [
[
"Kokoro Run",
@@ -12686,6 +12817,14 @@
"title_aux": "ComfyUI_KokoroTTS_MW"
}
],
"https://github.com/billwuhao/ComfyUI_NotaGen": [
[
"NotaGenRun"
],
{
"title_aux": "ComfyUI_NotaGen"
}
],
"https://github.com/billwuhao/ComfyUI_OneButtonPrompt_Flux": [
[
"DeepseekRun",
@@ -13325,6 +13464,60 @@
"title_aux": "ComfyUI-TostAI"
}
],
"https://github.com/cardenluo/ComfyUI-Apt_Preset": [
[
"CN_preset1",
"Data_chx_Merge",
"Data_chx_MergeBig",
"Data_fullData",
"Data_presetData",
"Data_preset_save",
"Data_sample",
"Data_select",
"Date_basic",
"Date_basic_easy",
"Model_Preset",
"Unpack_CN",
"Unpack_Model",
"Unpack_param",
"Unpack_photoshop",
"basic_Ksampler_custom",
"basic_Ksampler_full",
"basic_Ksampler_mid",
"basic_Ksampler_simple",
"chx_Ksampler_adv",
"chx_Ksampler_inpaint",
"chx_Ksampler_mix",
"chx_Ksampler_refine",
"chx_Ksampler_texture",
"chx_StyleModelApply",
"chx_Style_Redux",
"chx_Upscale_simple",
"chx_YC_LG_Redux",
"chx_controlnet",
"chx_controlnet_union",
"chx_easy_text",
"chx_ksampler_Deforum",
"chx_ksampler_tile",
"chx_mask_Mulcondi",
"chx_re_fluxguide",
"load_FLUX",
"load_SD35",
"load_basic",
"param_preset",
"photoshop_preset",
"pre_make_context",
"pre_sample_data",
"sum_controlnet",
"sum_editor",
"sum_latent",
"sum_load",
"sum_lora"
],
{
"title_aux": "ComfyUI-Apt_Preset"
}
],
"https://github.com/catboxanon/comfyui_stealth_pnginfo": [
[
"CatboxAnonSaveImageStealth"
@@ -13956,7 +14149,11 @@
"https://github.com/chenpipi0807/PIP_ArtisticWords": [
[
"PIP Artistic Text Generator",
"PIP Text Preview"
"PIP ArtisticWords Fusion",
"PIP ColorPicker",
"PIP SVG Recorder",
"PIP Text Preview",
"PIPColorPicker"
],
{
"title_aux": "PIP Artistic Words for ComfyUI"
@@ -16308,14 +16505,17 @@
"Eden_Bool",
"Eden_BoolBinaryOperation",
"Eden_Compare",
"Eden_DebugPrint",
"Eden_Debug_Anything",
"Eden_DepthSlice_MaskVideo",
"Eden_DetermineFrameCount",
"Eden_FaceToMask",
"Eden_Face_Crop",
"Eden_Float",
"Eden_FloatToInt",
"Eden_GPTPromptEnhancer",
"Eden_IMG_padder",
"Eden_IMG_unpadder",
"Eden_ImageMaskComposite",
"Eden_Image_Math",
"Eden_Int",
"Eden_IntToFloat",
@@ -16323,12 +16523,14 @@
"Eden_MaskCombiner",
"Eden_Math",
"Eden_RandomPromptFromFile",
"Eden_Regex_Replace",
"Eden_RepeatLatentBatch",
"Eden_Seed",
"Eden_String",
"Eden_StringHash",
"Eden_StringReplace",
"Eden_gpt4_node",
"Eden_randbool",
"Extend_Sequence",
"FolderScanner",
"GetRandomFile",
@@ -16800,6 +17002,7 @@
"FL_Dither",
"FL_FractalKSampler",
"FL_GPT_Vision",
"FL_GeminiVideoCaptioner",
"FL_Glitch",
"FL_GoogleDriveDownloader",
"FL_GoogleDriveImageDownloader",
@@ -16862,6 +17065,7 @@
"FL_SaveCSV",
"FL_SaveImages",
"FL_SaveWebPImage(SaveImage)",
"FL_SceneCut",
"FL_SchedulerStrings",
"FL_SendToDiscordWebhook",
"FL_SeparateMaskComponents",
@@ -16871,6 +17075,7 @@
"FL_TetrisGame",
"FL_TimeLine",
"FL_UpscaleModel",
"FL_VideoCaptionSaver",
"FL_VideoCropMask",
"FL_VideoRecompose",
"FL_ZipDirectory",
@@ -18518,6 +18723,14 @@
"title_aux": "Comfy-UI on-complete-email-me"
}
],
"https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor": [
[
"AMDGPUMonitor"
],
{
"title_aux": "AMD GPU Monitor for ComfyUI"
}
],
"https://github.com/iFREEGROUP/comfyui-undistort": [
[
"IG_LoadCheckerboardImageForCalibrateCamera",
@@ -18630,28 +18843,6 @@
"title_aux": "IF_DatasetMkr"
}
],
"https://github.com/if-ai/ComfyUI-IF_LLM": [
[
"IF_DisplayText",
"IF_JoinText",
"IF_LLM",
"IF_LLM_DisplayOmni",
"IF_LLM_DisplayText",
"IF_LLM_DisplayTextWildcard",
"IF_LLM_JoinText",
"IF_LLM_ListModels",
"IF_LLM_LoadImagesS",
"IF_LLM_SaveText",
"IF_LLM_TextTyper",
"IF_LoadImagesS",
"IF_TextTyper",
"IF_saveText",
"ListModelsNode"
],
{
"title_aux": "IF_LLM"
}
],
"https://github.com/if-ai/ComfyUI-IF_MemoAvatar": [
[
"IF_MemoAvatar",
@@ -18670,14 +18861,6 @@
"title_aux": "ComfyUI-IF_Trellis"
}
],
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts": [
[
"VideoPromptNode"
],
{
"title_aux": "IF_VideoPrompts"
}
],
"https://github.com/ifmylove2011/comfyui-missing-tool": [
[
"ImageQueueLoader",
@@ -18834,6 +19017,18 @@
"title_aux": "ComfyUI Neural Network Toolkit NNT "
}
],
"https://github.com/irreveloper/ComfyUI-DSD": [
[
"DSDGeminiPromptEnhancer",
"DSDImageGenerator",
"DSDModelDownloader",
"DSDModelLoader",
"DSDModelSelector"
],
{
"title_aux": "ComfyUI-DSD"
}
],
"https://github.com/iwanders/ComfyUI_nodes": [
[
"IW_JsonPickItem",
@@ -19098,6 +19293,7 @@
"Evaluate Floats JK",
"Evaluate Ints JK",
"Evaluate Strings JK",
"Get OrbitPoses From List JK",
"Get Size JK",
"Guidance Default JK",
"HintImageEnchance JK",
@@ -19375,6 +19571,7 @@
"LoadLoraFromHF",
"LoadLoraFromHFWithToken",
"LoadWanVideoLoraFromCivitAI",
"LoadWanVideoLoraFromComfyOnline",
"SaveAudioAsWav",
"SaveText"
],
@@ -19698,6 +19895,14 @@
"title_aux": "ComfyUI Deepface"
}
],
"https://github.com/joreyaesh/comfyui_scroll_over_textarea": [
[
"ScrollOverTextareaDummyNode"
],
{
"title_aux": "ComfyUI Scroll Over Textarea"
}
],
"https://github.com/jroc22/ComfyUI-CSV-prompt-builder": [
[
"BuildPromptFromCSV"
@@ -20502,6 +20707,7 @@
"HyVideoSTG",
"HyVideoSampler",
"HyVideoTeaCache",
"HyVideoTextEmbedBridge",
"HyVideoTextEmbedsLoad",
"HyVideoTextEmbedsSave",
"HyVideoTextEncode",
@@ -20599,6 +20805,7 @@
"GradientToFloat",
"GrowMaskWithBlur",
"HunyuanVideoBlockLoraSelect",
"HunyuanVideoEncodeKeyframesToCond",
"INTConstant",
"ImageAddMulti",
"ImageAndMaskPreview",
@@ -20680,6 +20887,7 @@
"StableZero123_BatchSchedule",
"StringConstant",
"StringConstantMultiline",
"StringToFloatList",
"StyleModelApplyAdvanced",
"Superprompt",
"TimerNodeKJ",
@@ -20694,6 +20902,7 @@
"TransitionImagesMulti",
"VAELoaderKJ",
"VRAM_Debug",
"WanVideoEnhanceAVideoKJ",
"WanVideoTeaCacheKJ",
"WebcamCaptureCV2",
"WeightScheduleConvert",
@@ -20975,6 +21184,7 @@
"Custom_Save_Image",
"Display_Any",
"Image_Size_Extractor",
"Load_Image_Folder",
"Mask_Blur_Plus",
"Preview_Mask",
"Preview_Mask_Plus",
@@ -21155,15 +21365,6 @@
"title_aux": "WatermarkRemoval"
}
],
"https://github.com/l1yongch1/ComfyUI_PhiCaption": [
[
"PhiInfer",
"PhiModelLoder"
],
{
"title_aux": "ComfyUI_PhiCaption"
}
],
"https://github.com/l20richo/ComfyUI-Azure-Blob-Storage": [
[
"DownloadFileBLOB",
@@ -21291,6 +21492,25 @@
"title_aux": "Google Photos Loader - by PabloGFX"
}
],
"https://github.com/leeguandong/ComfyUI_1Prompt1Story": [
[
"GenerateStoryImage",
"PromptStoryModelLoader"
],
{
"title_aux": "ComfyUI_1Prompt1Story"
}
],
"https://github.com/leeguandong/ComfyUI_ChatGen": [
[
"ChatGenGenerate",
"ChatGenImageProcessor",
"ChatGenModelLoader"
],
{
"title_aux": "ComfyUI_ChatGen"
}
],
"https://github.com/leeguandong/ComfyUI_Cogview4": [
[
"CogView4ImageGenerator",
@@ -21439,6 +21659,7 @@
[
"AddPaddingToImage",
"ForLoopNode",
"ImageAndTextDescriptionBySeed",
"ImageMetadataExtractor",
"InputNode",
"MetadataExtractBySeed",
@@ -22811,6 +23032,9 @@
],
"https://github.com/mang01010/MangoNodePack": [
[
"CompositeMangoLoader",
"FluxGuidanceMango",
"FluxSamplerMango",
"ImageSaverMango",
"KSamplerMango",
"LatentImageMango",
@@ -22925,6 +23149,14 @@
"title_aux": "ComfyUI Flux Prompt Saver"
}
],
"https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot": [
[
"VideoXYPlotSampler"
],
{
"title_aux": "Video XY Plot"
}
],
"https://github.com/markuryy/ComfyUI-SuperLoader": [
[
"Display String",
@@ -23268,7 +23500,8 @@
],
"https://github.com/metal3d/ComfyUI_M3D_photo_effects": [
[
"Bleach Bypass"
"Bleach Bypass",
"RGB Curve"
],
{
"title_aux": "M3D photo effects"
@@ -23493,6 +23726,17 @@
"title_aux": "MLTask_ComfyUI"
}
],
"https://github.com/mit-han-lab/ComfyUI-nunchaku": [
[
"SVDQuantDepthPreprocessor",
"SVDQuantFluxDiTLoader",
"SVDQuantFluxLoraLoader",
"SVDQuantTextEncoderLoader"
],
{
"title_aux": "ComfyUI-nunchaku"
}
],
"https://github.com/mittimi/ComfyUI_mittimiLoadPreset2": [
[
"CombineParamDataMittimi",
@@ -24461,6 +24705,14 @@
"title_aux": " ComfyUI-Regex-Runner"
}
],
"https://github.com/orssorbit/ComfyUI-wanBlockswap": [
[
"wanBlockSwap"
],
{
"title_aux": "ComfyUI-wanBlockswap"
}
],
"https://github.com/osi1880vr/prompt_quill_comfyui": [
[
"PromptQuillGenerate",
@@ -24651,6 +24903,14 @@
"title_aux": "ComfyUI-LyraVSIH"
}
],
"https://github.com/penposs/ComfyUI_Gemini_Pro": [
[
"Gemini Pro"
],
{
"title_aux": "ComfyUI Gemini Pro Node"
}
],
"https://github.com/pharmapsychotic/comfy-cliption": [
[
"CLIPtionBeamSearch",
@@ -25490,6 +25750,14 @@
"title_aux": "ComfyUIFlexiLoRALoader"
}
],
"https://github.com/roundyyy/ComfyUI-mesh-simplifier": [
[
"MeshSimplifierNode"
],
{
"title_aux": "Mesh Simplifier for ComfyUI"
}
],
"https://github.com/royceschultz/ComfyUI-Notifications": [
[
"Notif-PlaySound",
@@ -26211,14 +26479,17 @@
"ApplyMBCacheAndSkipBlocks",
"ApplyMBCacheAndSkipBlocksForSana",
"ApplySageAttention",
"ApplySpargeAttn",
"ApplyTeaCacheAndSkipBlocks",
"ApplyToCa",
"ApplyTokenMerging",
"CompileAndQuantizeModel",
"SanaCLIPLoader",
"SanaDiffusionLoader",
"SanaEmptyLatentImage",
"SanaTextEncode",
"SanaVAELoader"
"SanaVAELoader",
"SaveSpargeAttnHyperparams"
],
{
"title_aux": "ComfyUI-Lightning"
@@ -26723,6 +26994,16 @@
"title_aux": "ComfyUI_InstantIR_Wrapper"
}
],
"https://github.com/smthemex/ComfyUI_KV_Edit": [
[
"KV_Edit_Load",
"KV_Edit_PreData",
"KV_Edit_Sampler"
],
{
"title_aux": "ComfyUI_KV_Edit"
}
],
"https://github.com/smthemex/ComfyUI_Light_A_Video": [
[
"Light_A_Video_Loader",
@@ -27369,7 +27650,8 @@
"TagRemover",
"TagReplace",
"TagSelector",
"TagSwitcher"
"TagSwitcher",
"TagWildcardFilter"
],
{
"title_aux": "comfyui_tag_filter"
@@ -27847,7 +28129,8 @@
"Load Random Text From File",
"LoadWebcamImage",
"Remove noise",
"SaveImagetoPath"
"SaveImagetoPath",
"VisualAreaMask"
],
{
"title_aux": "ComfyUI_toyxyz_test_nodes"
@@ -28142,6 +28425,15 @@
"title_aux": "unwdef-nodes"
}
],
"https://github.com/vadimcro/VKRiez-Edge": [
[
"VKriezEnhancedEdgePreprocessor",
"VKriezHybridEdgePreprocessor"
],
{
"title_aux": "VKriez Edge Preprocessors for ComfyUI"
}
],
"https://github.com/vahlok-alunmid/ComfyUI-ExtendIPAdapterClipVision": [
[
"EXTEND_CLIP_VISION_INPUT_SIZE",
@@ -28465,9 +28757,8 @@
"https://github.com/welltop-cn/ComfyUI-TeaCache": [
[
"CompileModel",
"TeaCacheForCogVideoX",
"TeaCacheForImgGen",
"TeaCacheForVidGen"
"TeaCache",
"TeaCacheForCogVideoX"
],
{
"title_aux": "ComfyUI-TeaCache"
@@ -28858,6 +29149,15 @@
"title_aux": "hd-nodes-comfyui"
}
],
"https://github.com/xingBaGan/ComfyUI-connect-ui": [
[
"SaveImageByWebsocket",
"reciveImageByWebsocket"
],
{
"title_aux": "ComfyUI-connect-ui"
}
],
"https://github.com/xlinx/ComfyUI-decadetw-auto-messaging-realtime": [
[
"Auto-MSG-ALL",
@@ -29981,13 +30281,13 @@
],
"https://github.com/zmwv823/ComfyUI_Anytext": [
[
"UL_AnyText2Fonts",
"UL_AnyTextComposer",
"UL_AnyTextEncoder",
"UL_AnyTextFontImg",
"UL_AnyTextFormatter",
"UL_AnyTextLoaderTest",
"UL_AnyText_Composer",
"UL_AnyText_FontImg",
"UL_AnyText_Loader",
"UL_AnyText_Sampler",
"UL_AnyTextLoader",
"UL_AnyTextSampler",
"UL_DiffusersCheckpointLoader",
"UL_DiffusersControlNetApplyAdvanced",
"UL_DiffusersControlNetLoader",
@@ -29999,7 +30299,8 @@
"UL_Image_Generation_JoyType_Render_List",
"UL_Image_Process_Common_Cv2_Canny",
"UL_Translator",
"UL_TranslatorLoader"
"UL_TranslatorLoader",
"U_LoRAS"
],
{
"title_aux": "ComfyUI_Anytext"

View File

@@ -1494,11 +1494,6 @@
"last_update": "2024-12-01 00:43:54",
"author_account_age_days": 923
},
"https://github.com/GoingAI1998/Comfyui_imgcanvas": {
"stars": 5,
"last_update": "2025-01-21 05:32:24",
"author_account_age_days": 440
},
"https://github.com/Goktug/comfyui-saveimage-plus": {
"stars": 11,
"last_update": "2024-11-13 06:03:10",
@@ -2919,11 +2914,6 @@
"last_update": "2024-11-22 19:28:20",
"author_account_age_days": 1701
},
"https://github.com/Samulebotin/ComfyUI-FreeVC_wrapper": {
"stars": 0,
"last_update": "2025-03-06 11:44:50",
"author_account_age_days": 894
},
"https://github.com/SayanoAI/Comfy-RVC": {
"stars": 18,
"last_update": "2024-10-09 04:08:31",
@@ -7034,11 +7024,6 @@
"last_update": "2025-01-13 05:33:32",
"author_account_age_days": 68
},
"https://github.com/l1yongch1/ComfyUI_PhiCaption": {
"stars": 0,
"last_update": "2024-10-10 07:28:29",
"author_account_age_days": 1033
},
"https://github.com/l20richo/ComfyUI-Azure-Blob-Storage": {
"stars": 2,
"last_update": "2024-06-22 16:53:47",

View File

@@ -42,6 +42,7 @@ async def _get_cnr_data(cache_mode=True, dont_wait=True):
system = platform.system().lower()
is_windows = system == 'windows'
is_mac = system == 'darwin'
is_linux = system == 'linux'
# Get ComfyUI version tag
if is_desktop:
@@ -62,6 +63,8 @@ async def _get_cnr_data(cache_mode=True, dont_wait=True):
form_factor = 'git-windows'
elif is_mac:
form_factor = 'git-mac'
elif is_linux:
form_factor = 'git-linux'
else:
form_factor = 'other'

View File

@@ -43,7 +43,7 @@ import manager_downloader
from node_package import InstalledNodePackage
version_code = [3, 30, 4]
version_code = [3, 31]
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
@@ -53,6 +53,11 @@ DEFAULT_CHANNEL = "https://raw.githubusercontent.com/ltdrdata/ComfyUI-Manager/ma
default_custom_nodes_path = None
class InvalidChannel(Exception):
def __init__(self, channel):
self.channel = channel
super().__init__(channel)
def get_default_custom_nodes_path():
global default_custom_nodes_path
if default_custom_nodes_path is None:
@@ -251,6 +256,7 @@ comfy_ui_revision = "Unknown"
comfy_ui_commit_datetime = datetime(1900, 1, 1, 0, 0, 0)
channel_dict = None
valid_channels = set()
channel_list = None
@@ -355,7 +361,7 @@ def normalize_channel(channel):
if channel_url:
return channel_url
raise Exception(f"Invalid channel name '{channel}'")
raise InvalidChannel(channel)
class ManagedResult:
@@ -770,6 +776,11 @@ class UnifiedManager:
print(f"[bold red]ERROR: Invalid mode is specified `--mode {mode}`[/bold red]", file=sys.stderr)
return {}
# validate channel - only the channel set by the user is allowed.
if channel_url not in valid_channels:
logging.error(f'[ComfyUI-Manager] An invalid channel was used: {channel_url}')
raise InvalidChannel(channel_url)
json_obj = await get_data_by_mode(mode, 'custom-node-list.json', channel_url=channel_url)
for x in json_obj['custom_nodes']:
try:
@@ -1414,7 +1425,11 @@ class UnifiedManager:
version_spec = self.resolve_unspecified_version(node_id)
if version_spec == 'unknown' or version_spec == 'nightly':
custom_nodes = await self.get_custom_nodes(channel, mode)
try:
custom_nodes = await self.get_custom_nodes(channel, mode)
except InvalidChannel as e:
return ManagedResult('fail').fail(f'Invalid channel is used: {e.channel}')
the_node = custom_nodes.get(node_id)
if the_node is not None:
if version_spec == 'unknown':
@@ -1472,28 +1487,6 @@ class UnifiedManager:
return res
async def migrate_unmanaged_nodes(self):
"""
fix path for nightly and unknown nodes of unmanaged nodes
"""
await self.reload('cache')
await self.get_custom_nodes('default', 'cache')
print("Migration: STAGE 1")
moves = []
# migrate nightly inactive
for x, v in self.nightly_inactive_nodes.items():
if v.endswith('@nightly'):
continue
new_path = os.path.join(get_default_custom_nodes_path(), '.disabled', f"{x}@nightly")
moves.append((v, new_path))
self.reserve_migration(moves)
print("DONE (Migration reserved)")
unified_manager = UnifiedManager()
@@ -1563,8 +1556,14 @@ def get_installed_node_packs():
return res
def refresh_channel_dict():
if channel_dict is None:
get_channel_dict()
def get_channel_dict():
global channel_dict
global valid_channels
if channel_dict is None:
channel_dict = {}
@@ -1578,6 +1577,7 @@ def get_channel_dict():
channel_info = x.split("::")
if len(channel_info) == 2:
channel_dict[channel_info[0]] = channel_info[1]
valid_channels.add(channel_info[1])
return channel_dict

View File

@@ -273,14 +273,23 @@ import zipfile
import urllib.request
def get_model_dir(data, show_log=False):
def get_model_dir(data, show_log=False) -> str | None:
if 'download_model_base' in folder_paths.folder_names_and_paths:
models_base = folder_paths.folder_names_and_paths['download_model_base'][0][0]
else:
models_base = folder_paths.models_dir
# NOTE: Validate to prevent path traversal.
if any(char in data['filename'] for char in {'/', '\\', ':'}):
return None
def resolve_custom_node(save_path):
save_path = save_path[13:] # remove 'custom_nodes/'
# NOTE: Validate to prevent path traversal.
if save_path.startswith(os.path.sep) or ':' in save_path:
return None
repo_name = save_path.replace('\\','/').split('/')[0] # get custom node repo name
# NOTE: The creation of files within the custom node path should be removed in the future.
@@ -399,7 +408,6 @@ async def task_worker():
try:
node_spec = core.unified_manager.resolve_node_spec(node_spec_str)
if node_spec is None:
logging.error(f"Cannot resolve install target: '{node_spec_str}'")
return f"Cannot resolve install target: '{node_spec_str}'"
@@ -929,6 +937,7 @@ def check_model_installed(json_obj):
@routes.get("/externalmodel/getlist")
async def fetch_externalmodel_list(request):
# The model list is only allowed in the default channel, yet.
json_obj = await core.get_data_by_mode(request.rel_url.query["mode"], 'model-list.json')
check_model_installed(json_obj)
@@ -1197,9 +1206,8 @@ async def install_custom_node(request):
git_url = None
if json_data['version'] != 'unknown':
selected_version = json_data.get('selected_version')
selected_version = json_data.get('selected_version')
if json_data['version'] != 'unknown' and selected_version != 'unknown':
if skip_post_install:
if cnr_id in core.unified_manager.nightly_inactive_nodes or cnr_id in core.unified_manager.cnr_inactive_nodes:
core.unified_manager.unified_enable(cnr_id)
@@ -1216,6 +1224,9 @@ async def install_custom_node(request):
if git_url is None:
logging.error(f"[ComfyUI-Manager] Following node pack doesn't provide `nightly` version: ${git_url}")
return web.Response(status=404, text=f"Following node pack doesn't provide `nightly` version: ${git_url}")
elif json_data['version'] != 'unknown' and selected_version == 'unknown':
logging.error(f"[ComfyUI-Manager] Invalid installation request: {json_data}")
return web.Response(status=400, text="Invalid installation request")
else:
# unknown
unknown_name = os.path.basename(json_data['files'][0])
@@ -1407,17 +1418,14 @@ async def disable_node(request):
return web.Response(status=200)
@routes.get("/manager/migrate_unmanaged_nodes")
async def migrate_unmanaged_nodes(request):
logging.info("[ComfyUI-Manager] Migrating unmanaged nodes...")
await core.unified_manager.migrate_unmanaged_nodes()
logging.info("Done.")
return web.Response(status=200)
async def check_whitelist_for_model(item):
json_obj = await core.get_data_by_mode('cache', 'model-list.json')
@routes.get("/manager/need_to_migrate")
async def need_to_migrate(request):
return web.Response(text=str(core.need_to_migrate), status=200)
for x in json_obj.get('models', []):
if x['save_path'] == item['save_path'] and x['base'] == item['base'] and x['filename'] == item['filename']:
return True
return False
@routes.post("/manager/queue/install_model")
@@ -1428,6 +1436,11 @@ async def install_model(request):
logging.error(SECURITY_MESSAGE_MIDDLE_OR_BELOW)
return web.Response(status=403, text="A security error has occurred. Please check the terminal logs")
# validate request
if not await check_whitelist_for_model(json_data):
logging.error(f"[ComfyUI-Manager] Invalid model install request is detected: {json_data}")
return web.Response(status=400, text="Invalid model install request is detected")
if not json_data['filename'].endswith('.safetensors') and not is_allowed_security_level('high'):
models_json = await core.get_data_by_mode('cache', 'model-list.json', 'default')
@@ -1695,6 +1708,7 @@ cm_global.register_api('cm.try-install-custom-node', confirm_try_install)
async def default_cache_update():
core.refresh_channel_dict()
channel_url = core.get_config()['channel_url']
async def get_cache(filename):
try:

View File

@@ -36,9 +36,9 @@ def add_python_path_to_env():
def make_pip_cmd(cmd):
if use_uv:
return [sys.executable, '-m', 'uv', 'pip'] + cmd
return [sys.executable, '-s', '-m', 'uv', 'pip'] + cmd
else:
return [sys.executable, '-m', 'pip'] + cmd
return [sys.executable, '-s', '-m', 'pip'] + cmd
# DON'T USE StrictVersion - cannot handle pre_release version

View File

@@ -1,6 +1,7 @@
import { app } from "../../scripts/app.js";
import { api } from "../../scripts/api.js";
import { $el, ComfyDialog } from "../../scripts/ui.js";
import { getBestPosition, getPositionStyle, getRect } from './popover-helper.js';
function internalCustomConfirm(message, confirmMessage, cancelMessage) {
@@ -404,12 +405,14 @@ export async function fetchData(route, options) {
}
}
// https://cenfun.github.io/open-icons/
export const icons = {
search: '<svg viewBox="0 0 24 24" width="100%" height="100%" pointer-events="none" xmlns="http://www.w3.org/2000/svg"><path fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="m21 21-4.486-4.494M19 10.5a8.5 8.5 0 1 1-17 0 8.5 8.5 0 0 1 17 0"/></svg>',
extensions: '<svg viewBox="64 64 896 896" width="100%" height="100%" pointer-events="none" xmlns="http://www.w3.org/2000/svg"><path fill="currentColor" d="M843.5 737.4c-12.4-75.2-79.2-129.1-155.3-125.4S550.9 676 546 752c-153.5-4.8-208-40.7-199.1-113.7 3.3-27.3 19.8-41.9 50.1-49 18.4-4.3 38.8-4.9 57.3-3.2 1.7.2 3.5.3 5.2.5 11.3 2.7 22.8 5 34.3 6.8 34.1 5.6 68.8 8.4 101.8 6.6 92.8-5 156-45.9 159.2-132.7 3.1-84.1-54.7-143.7-147.9-183.6-29.9-12.8-61.6-22.7-93.3-30.2-14.3-3.4-26.3-5.7-35.2-7.2-7.9-75.9-71.5-133.8-147.8-134.4S189.7 168 180.5 243.8s40 146.3 114.2 163.9 149.9-23.3 175.7-95.1c9.4 1.7 18.7 3.6 28 5.8 28.2 6.6 56.4 15.4 82.4 26.6 70.7 30.2 109.3 70.1 107.5 119.9-1.6 44.6-33.6 65.2-96.2 68.6-27.5 1.5-57.6-.9-87.3-5.8-8.3-1.4-15.9-2.8-22.6-4.3-3.9-.8-6.6-1.5-7.8-1.8l-3.1-.6c-2.2-.3-5.9-.8-10.7-1.3-25-2.3-52.1-1.5-78.5 4.6-55.2 12.9-93.9 47.2-101.1 105.8-15.7 126.2 78.6 184.7 276 188.9 29.1 70.4 106.4 107.9 179.6 87 73.3-20.9 119.3-93.4 106.9-168.6M329.1 345.2a83.3 83.3 0 1 1 .01-166.61 83.3 83.3 0 0 1-.01 166.61M695.6 845a83.3 83.3 0 1 1 .01-166.61A83.3 83.3 0 0 1 695.6 845"/></svg>',
conflicts: '<svg viewBox="0 0 400 400" width="100%" height="100%" pointer-events="none" xmlns="http://www.w3.org/2000/svg"><path fill="currentColor" d="m397.2 350.4.2-.2-180-320-.2.2C213.8 24.2 207.4 20 200 20s-13.8 4.2-17.2 10.4l-.2-.2-180 320 .2.2c-1.6 2.8-2.8 6-2.8 9.6 0 11 9 20 20 20h360c11 0 20-9 20-20 0-3.6-1.2-6.8-2.8-9.6M220 340h-40v-40h40zm0-60h-40V120h40z"/></svg>',
passed: '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 426.667 426.667"><path fill="#6AC259" d="M213.333,0C95.518,0,0,95.514,0,213.333s95.518,213.333,213.333,213.333c117.828,0,213.333-95.514,213.333-213.333S331.157,0,213.333,0z M174.199,322.918l-93.935-93.931l31.309-31.309l62.626,62.622l140.894-140.898l31.309,31.309L174.199,322.918z"/></svg>',
download: '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" width="100%" height="100%" viewBox="0 0 32 32"><path fill="currentColor" d="M26 24v4H6v-4H4v4a2 2 0 0 0 2 2h20a2 2 0 0 0 2-2v-4zm0-10l-1.41-1.41L17 20.17V2h-2v18.17l-7.59-7.58L6 14l10 10l10-10z"></path></svg>'
download: '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" width="100%" height="100%" viewBox="0 0 32 32"><path fill="currentColor" d="M26 24v4H6v-4H4v4a2 2 0 0 0 2 2h20a2 2 0 0 0 2-2v-4zm0-10l-1.41-1.41L17 20.17V2h-2v18.17l-7.59-7.58L6 14l10 10l10-10z"></path></svg>',
close: '<svg xmlns="http://www.w3.org/2000/svg" pointer-events="none" width="100%" height="100%" viewBox="0 0 16 16"><g fill="currentColor"><path fill-rule="evenodd" clip-rule="evenodd" d="m7.116 8-4.558 4.558.884.884L8 8.884l4.558 4.558.884-.884L8.884 8l4.558-4.558-.884-.884L8 7.116 3.442 2.558l-.884.884L7.116 8z"/></g></svg>',
arrowRight: '<svg xmlns="http://www.w3.org/2000/svg" pointer-events="none" width="100%" height="100%" viewBox="0 0 20 20"><path fill="currentColor" fill-rule="evenodd" d="m2.542 2.154 7.254 7.26c.136.14.204.302.204.483a.73.73 0 0 1-.204.5l-7.575 7.398c-.383.317-.724.317-1.022 0-.299-.317-.299-.643 0-.98l7.08-6.918-6.754-6.763c-.237-.343-.215-.654.066-.935.281-.28.598-.295.951-.045Zm9 0 7.254 7.26c.136.14.204.302.204.483a.73.73 0 0 1-.204.5l-7.575 7.398c-.383.317-.724.317-1.022 0-.299-.317-.299-.643 0-.98l7.08-6.918-6.754-6.763c-.237-.343-.215-.654.066-.935.281-.28.598-.295.951-.045Z"/></svg>'
}
export function sanitizeHTML(str) {
@@ -503,3 +506,166 @@ export function restoreColumnWidth(gridId, columns) {
});
}
export function getTimeAgo(dateStr) {
const date = new Date(dateStr);
if (!date || !(date instanceof Date) || isNaN(date.getTime())) {
return "";
}
const units = [
{ max: 2760000, value: 60000, name: 'minute', past: 'a minute ago', future: 'in a minute' },
{ max: 72000000, value: 3600000, name: 'hour', past: 'an hour ago', future: 'in an hour' },
{ max: 518400000, value: 86400000, name: 'day', past: 'yesterday', future: 'tomorrow' },
{ max: 2419200000, value: 604800000, name: 'week', past: 'last week', future: 'in a week' },
{ max: 28512000000, value: 2592000000, name: 'month', past: 'last month', future: 'in a month' }
];
const diff = Date.now() - date.getTime();
// less than a minute
if (Math.abs(diff) < 60000)
return 'just now';
for (let i = 0; i < units.length; i++) {
if (Math.abs(diff) < units[i].max) {
return format(diff, units[i].value, units[i].name, units[i].past, units[i].future, diff < 0);
}
}
function format(diff, divisor, unit, past, future, isInTheFuture) {
const val = Math.round(Math.abs(diff) / divisor);
if (isInTheFuture)
return val <= 1 ? future : 'in ' + val + ' ' + unit + 's';
return val <= 1 ? past : val + ' ' + unit + 's ago';
}
return format(diff, 31536000000, 'year', 'last year', 'in a year', diff < 0);
};
export const loadCss = (cssFile) => {
const cssPath = import.meta.resolve(cssFile);
//console.log(cssPath);
const $link = document.createElement("link");
$link.setAttribute("rel", 'stylesheet');
$link.setAttribute("href", cssPath);
document.head.appendChild($link);
};
export const copyText = (text) => {
return new Promise((resolve) => {
let err;
try {
navigator.clipboard.writeText(text);
} catch (e) {
err = e;
}
if (err) {
resolve(false);
} else {
resolve(true);
}
});
};
function renderPopover($elem, target, options = {}) {
// async microtask
queueMicrotask(() => {
const containerRect = getRect(window);
const targetRect = getRect(target);
const elemRect = getRect($elem);
const positionInfo = getBestPosition(
containerRect,
targetRect,
elemRect,
options.positions
);
const style = getPositionStyle(positionInfo, {
bgColor: options.bgColor,
borderColor: options.borderColor,
borderRadius: options.borderRadius
});
$elem.style.top = positionInfo.top + "px";
$elem.style.left = positionInfo.left + "px";
$elem.style.background = style.background;
});
}
let $popover;
export function hidePopover() {
if ($popover) {
$popover.remove();
$popover = null;
}
}
export function showPopover(target, text, className, options) {
hidePopover();
$popover = document.createElement("div");
$popover.className = ['cn-popover', className].filter(it => it).join(" ");
document.body.appendChild($popover);
$popover.innerHTML = text;
$popover.style.display = "block";
renderPopover($popover, target, {
borderRadius: 10,
... options
});
}
let $tooltip;
export function hideTooltip(target) {
if ($tooltip) {
$tooltip.style.display = "none";
$tooltip.innerHTML = "";
$tooltip.style.top = "0px";
$tooltip.style.left = "0px";
}
}
export function showTooltip(target, text, className = 'cn-tooltip', styleMap = {}) {
if (!$tooltip) {
$tooltip = document.createElement("div");
$tooltip.className = className;
$tooltip.style.cssText = `
pointer-events: none;
position: fixed;
z-index: 10001;
padding: 20px;
color: #1e1e1e;
max-width: 350px;
filter: drop-shadow(1px 5px 5px rgb(0 0 0 / 30%));
${Object.keys(styleMap).map(k=>k+":"+styleMap[k]+";").join("")}
`;
document.body.appendChild($tooltip);
}
$tooltip.innerHTML = text;
$tooltip.style.display = "block";
renderPopover($tooltip, target, {
positions: ['top', 'bottom', 'right', 'center'],
bgColor: "#ffffff",
borderColor: "#cccccc",
borderRadius: 5
});
}
function initTooltip () {
const mouseenterHandler = (e) => {
const target = e.target;
const text = target.getAttribute('tooltip');
if (text) {
showTooltip(target, text);
}
};
const mouseleaveHandler = (e) => {
const target = e.target;
const text = target.getAttribute('tooltip');
if (text) {
hideTooltip(target);
}
};
document.body.removeEventListener('mouseenter', mouseenterHandler, true);
document.body.removeEventListener('mouseleave', mouseleaveHandler, true);
document.body.addEventListener('mouseenter', mouseenterHandler, true);
document.body.addEventListener('mouseleave', mouseleaveHandler, true);
}
initTooltip();

699
js/custom-nodes-manager.css Normal file
View File

@@ -0,0 +1,699 @@
.cn-manager {
--grid-font: -apple-system, BlinkMacSystemFont, "Segue UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
z-index: 1099;
width: 80%;
height: 80%;
display: flex;
flex-direction: column;
gap: 10px;
color: var(--fg-color);
font-family: arial, sans-serif;
text-underline-offset: 3px;
outline: none;
}
.cn-manager .cn-flex-auto {
flex: auto;
}
.cn-manager button {
font-size: 16px;
color: var(--input-text);
background-color: var(--comfy-input-bg);
border-radius: 8px;
border-color: var(--border-color);
border-style: solid;
margin: 0;
padding: 4px 8px;
min-width: 100px;
}
.cn-manager button:disabled,
.cn-manager input:disabled,
.cn-manager select:disabled {
color: gray;
}
.cn-manager button:disabled {
background-color: var(--comfy-input-bg);
}
.cn-manager .cn-manager-restart {
display: none;
background-color: #500000;
color: white;
}
.cn-manager .cn-manager-stop {
display: none;
background-color: #500000;
color: white;
}
.cn-manager .cn-manager-back {
align-items: center;
justify-content: center;
}
.arrow-icon {
height: 1em;
width: 1em;
margin-right: 5px;
transform: translateY(2px);
}
.cn-icon {
display: block;
width: 16px;
height: 16px;
}
.cn-icon svg {
display: block;
margin: 0;
pointer-events: none;
}
.cn-manager-header {
display: flex;
flex-wrap: wrap;
gap: 5px;
align-items: center;
padding: 0 5px;
}
.cn-manager-header label {
display: flex;
gap: 5px;
align-items: center;
}
.cn-manager-filter {
height: 28px;
line-height: 28px;
}
.cn-manager-keywords {
height: 28px;
line-height: 28px;
padding: 0 5px 0 26px;
background-size: 16px;
background-position: 5px center;
background-repeat: no-repeat;
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2024%2024%22%20width%3D%22100%25%22%20height%3D%22100%25%22%20pointer-events%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill%3D%22none%22%20stroke%3D%22%23888%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%20d%3D%22m21%2021-4.486-4.494M19%2010.5a8.5%208.5%200%201%201-17%200%208.5%208.5%200%200%201%2017%200%22%2F%3E%3C%2Fsvg%3E");
}
.cn-manager-status {
padding-left: 10px;
}
.cn-manager-grid {
flex: auto;
border: 1px solid var(--border-color);
overflow: hidden;
position: relative;
}
.cn-manager-selection {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cn-manager-message {
position: relative;
}
.cn-manager-footer {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cn-manager-grid .tg-turbogrid {
font-family: var(--grid-font);
font-size: 15px;
background: var(--bg-color);
}
.cn-manager-grid .tg-turbogrid .tg-highlight::after {
position: absolute;
top: 0;
left: 0;
content: "";
display: block;
width: 100%;
height: 100%;
box-sizing: border-box;
background-color: #80bdff11;
pointer-events: none;
}
.cn-manager-grid .cn-pack-name a {
color: skyblue;
text-decoration: none;
word-break: break-word;
}
.cn-manager-grid .cn-pack-desc a {
color: #5555FF;
font-weight: bold;
text-decoration: none;
}
.cn-manager-grid .tg-cell a:hover {
text-decoration: underline;
}
.cn-manager-grid .cn-pack-version {
line-height: 100%;
display: flex;
flex-direction: column;
justify-content: center;
height: 100%;
gap: 5px;
}
.cn-manager-grid .cn-pack-nodes {
line-height: 100%;
display: flex;
flex-direction: column;
justify-content: center;
gap: 5px;
cursor: pointer;
height: 100%;
}
.cn-manager-grid .cn-pack-nodes:hover {
text-decoration: underline;
}
.cn-manager-grid .cn-pack-conflicts {
color: orange;
}
.cn-popover {
position: fixed;
z-index: 10000;
padding: 20px;
color: #1e1e1e;
filter: drop-shadow(1px 5px 5px rgb(0 0 0 / 30%));
overflow: hidden;
}
.cn-flyover {
position: absolute;
top: 0;
right: 0;
z-index: 1000;
display: none;
width: 50%;
height: 100%;
background-color: var(--comfy-menu-bg);
animation-duration: 0.2s;
animation-fill-mode: both;
flex-direction: column;
}
.cn-flyover::before {
position: absolute;
top: 0;
content: "";
z-index: 10;
display: block;
width: 10px;
height: 100%;
pointer-events: none;
left: -10px;
background-image: linear-gradient(to left, rgb(0 0 0 / 20%), rgb(0 0 0 / 0%));
}
.cn-flyover-header {
height: 45px;
display: flex;
align-items: center;
gap: 5px;
border-bottom: 1px solid var(--border-color);
}
.cn-flyover-close {
display: flex;
align-items: center;
padding: 0 10px;
justify-content: center;
cursor: pointer;
opacity: 0.8;
height: 100%;
}
.cn-flyover-close:hover {
opacity: 1;
}
.cn-flyover-close svg {
display: block;
margin: 0;
pointer-events: none;
width: 20px;
height: 20px;
}
.cn-flyover-title {
display: flex;
align-items: center;
font-weight: bold;
gap: 10px;
flex: auto;
}
.cn-flyover-body {
height: calc(100% - 45px);
overflow-y: auto;
position: relative;
background-color: var(--comfy-menu-secondary-bg);
}
@keyframes cn-slide-in-right {
from {
visibility: visible;
transform: translate3d(100%, 0, 0);
}
to {
transform: translate3d(0, 0, 0);
}
}
.cn-slide-in-right {
animation-name: cn-slide-in-right;
}
@keyframes cn-slide-out-right {
from {
transform: translate3d(0, 0, 0);
}
to {
visibility: hidden;
transform: translate3d(100%, 0, 0);
}
}
.cn-slide-out-right {
animation-name: cn-slide-out-right;
}
.cn-nodes-list {
width: 100%;
}
.cn-nodes-row {
display: flex;
align-items: center;
gap: 10px;
}
.cn-nodes-row:nth-child(odd) {
background-color: rgb(0 0 0 / 5%);
}
.cn-nodes-row:hover {
background-color: rgb(0 0 0 / 10%);
}
.cn-nodes-sn {
text-align: right;
min-width: 35px;
color: var(--drag-text);
flex-shrink: 0;
font-size: 12px;
padding: 8px 5px;
}
.cn-nodes-name {
cursor: pointer;
white-space: nowrap;
flex-shrink: 0;
position: relative;
padding: 8px 5px;
}
.cn-nodes-name::after {
content: attr(action);
position: absolute;
pointer-events: none;
top: 50%;
left: 100%;
transform: translate(5px, -50%);
font-size: 12px;
color: var(--drag-text);
background-color: var(--comfy-input-bg);
border-radius: 10px;
border: 1px solid var(--border-color);
padding: 3px 8px;
display: none;
}
.cn-nodes-name.action::after {
display: block;
}
.cn-nodes-name:hover {
text-decoration: underline;
}
.cn-nodes-conflict .cn-nodes-name,
.cn-nodes-conflict .cn-icon {
color: orange;
}
.cn-conflicts-list {
display: flex;
flex-wrap: wrap;
gap: 5px;
align-items: center;
padding: 5px 0;
}
.cn-conflicts-list b {
font-weight: normal;
color: var(--descrip-text);
}
.cn-nodes-pack {
cursor: pointer;
color: skyblue;
}
.cn-nodes-pack:hover {
text-decoration: underline;
}
.cn-pack-badge {
font-size: 12px;
font-weight: normal;
background-color: var(--comfy-input-bg);
border-radius: 10px;
border: 1px solid var(--border-color);
padding: 3px 8px;
color: var(--error-text);
}
.cn-preview {
min-width: 300px;
max-width: 500px;
min-height: 120px;
overflow: hidden;
font-size: 12px;
pointer-events: none;
padding: 12px;
color: var(--fg-color);
}
.cn-preview-header {
display: flex;
gap: 8px;
align-items: center;
border-bottom: 1px solid var(--comfy-input-bg);
padding: 5px 10px;
}
.cn-preview-dot {
width: 8px;
height: 8px;
border-radius: 50%;
background-color: grey;
position: relative;
filter: drop-shadow(1px 2px 3px rgb(0 0 0 / 30%));
}
.cn-preview-dot.cn-preview-optional::after {
content: "";
position: absolute;
pointer-events: none;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
background-color: var(--comfy-input-bg);
border-radius: 50%;
width: 3px;
height: 3px;
}
.cn-preview-dot.cn-preview-grid {
border-radius: 0;
}
.cn-preview-dot.cn-preview-grid::before {
content: '';
position: absolute;
border-left: 1px solid var(--comfy-input-bg);
border-right: 1px solid var(--comfy-input-bg);
width: 4px;
height: 100%;
left: 2px;
top: 0;
z-index: 1;
}
.cn-preview-dot.cn-preview-grid::after {
content: '';
position: absolute;
border-top: 1px solid var(--comfy-input-bg);
border-bottom: 1px solid var(--comfy-input-bg);
width: 100%;
height: 4px;
left: 0;
top: 2px;
z-index: 1;
}
.cn-preview-name {
flex: auto;
font-size: 14px;
}
.cn-preview-io {
display: flex;
justify-content: space-between;
padding: 10px 10px;
}
.cn-preview-column > div {
display: flex;
gap: 10px;
align-items: center;
height: 18px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
.cn-preview-input {
justify-content: flex-start;
}
.cn-preview-output {
justify-content: flex-end;
}
.cn-preview-list {
display: flex;
flex-direction: column;
gap: 3px;
padding: 0 10px 10px 10px;
}
.cn-preview-switch {
position: relative;
display: flex;
justify-content: space-between;
align-items: center;
background: var(--bg-color);
border: 2px solid var(--border-color);
border-radius: 10px;
text-wrap: nowrap;
padding: 2px 20px;
gap: 10px;
}
.cn-preview-switch::before,
.cn-preview-switch::after {
position: absolute;
pointer-events: none;
top: 50%;
transform: translate(0, -50%);
color: var(--fg-color);
opacity: 0.8;
}
.cn-preview-switch::before {
content: "◀";
left: 5px;
}
.cn-preview-switch::after {
content: "▶";
right: 5px;
}
.cn-preview-value {
color: var(--descrip-text);
}
.cn-preview-string {
min-height: 30px;
max-height: 300px;
background: var(--bg-color);
color: var(--descrip-text);
border-radius: 3px;
padding: 3px 5px;
overflow-y: auto;
overflow-x: hidden;
}
.cn-preview-description {
margin: 0px 10px 10px 10px;
padding: 6px;
background: var(--border-color);
color: var(--descrip-text);
border-radius: 5px;
font-style: italic;
word-break: break-word;
}
.cn-tag-list {
display: flex;
flex-wrap: wrap;
gap: 5px;
align-items: center;
margin-bottom: 5px;
}
.cn-tag-list > div {
background-color: var(--border-color);
border-radius: 5px;
padding: 0 5px;
}
.cn-install-buttons {
display: flex;
flex-direction: column;
gap: 3px;
padding: 3px;
align-items: center;
justify-content: center;
height: 100%;
}
.cn-selected-buttons {
display: flex;
gap: 5px;
align-items: center;
padding-right: 20px;
}
.cn-manager .cn-btn-enable {
background-color: #333399;
color: white;
}
.cn-manager .cn-btn-disable {
background-color: #442277;
color: white;
}
.cn-manager .cn-btn-update {
background-color: #1155AA;
color: white;
}
.cn-manager .cn-btn-try-update {
background-color: Gray;
color: white;
}
.cn-manager .cn-btn-try-fix {
background-color: #6495ED;
color: white;
}
.cn-manager .cn-btn-import-failed {
background-color: #AA1111;
font-size: 10px;
font-weight: bold;
color: white;
}
.cn-manager .cn-btn-install {
background-color: black;
color: white;
}
.cn-manager .cn-btn-try-install {
background-color: Gray;
color: white;
}
.cn-manager .cn-btn-uninstall {
background-color: #993333;
color: white;
}
.cn-manager .cn-btn-reinstall {
background-color: #993333;
color: white;
}
.cn-manager .cn-btn-switch {
background-color: #448833;
color: white;
}
@keyframes cn-btn-loading-bg {
0% {
left: 0;
}
100% {
left: -105px;
}
}
.cn-manager button.cn-btn-loading {
position: relative;
overflow: hidden;
border-color: rgb(0 119 207 / 80%);
background-color: var(--comfy-input-bg);
}
.cn-manager button.cn-btn-loading::after {
position: absolute;
top: 0;
left: 0;
content: "";
width: 500px;
height: 100%;
background-image: repeating-linear-gradient(
-45deg,
rgb(0 119 207 / 30%),
rgb(0 119 207 / 30%) 10px,
transparent 10px,
transparent 15px
);
animation: cn-btn-loading-bg 2s linear infinite;
}
.cn-manager-light .cn-pack-name a {
color: blue;
}
.cn-manager-light .cm-warn-note {
background-color: #ccc !important;
}
.cn-manager-light .cn-btn-install {
background-color: #333;
}

View File

File diff suppressed because it is too large Load Diff

213
js/model-manager.css Normal file
View File

@@ -0,0 +1,213 @@
.cmm-manager {
--grid-font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
z-index: 1099;
width: 80%;
height: 80%;
display: flex;
flex-direction: column;
gap: 10px;
color: var(--fg-color);
font-family: arial, sans-serif;
}
.cmm-manager .cmm-flex-auto {
flex: auto;
}
.cmm-manager button {
font-size: 16px;
color: var(--input-text);
background-color: var(--comfy-input-bg);
border-radius: 8px;
border-color: var(--border-color);
border-style: solid;
margin: 0;
padding: 4px 8px;
min-width: 100px;
}
.cmm-manager button:disabled,
.cmm-manager input:disabled,
.cmm-manager select:disabled {
color: gray;
}
.cmm-manager button:disabled {
background-color: var(--comfy-input-bg);
}
.cmm-manager .cmm-manager-refresh {
display: none;
background-color: #000080;
color: white;
}
.cmm-manager .cmm-manager-stop {
display: none;
background-color: #500000;
color: white;
}
.cmm-manager-header {
display: flex;
flex-wrap: wrap;
gap: 5px;
align-items: center;
padding: 0 5px;
}
.cmm-manager-header label {
display: flex;
gap: 5px;
align-items: center;
}
.cmm-manager-type,
.cmm-manager-base,
.cmm-manager-filter {
height: 28px;
line-height: 28px;
}
.cmm-manager-keywords {
height: 28px;
line-height: 28px;
padding: 0 5px 0 26px;
background-size: 16px;
background-position: 5px center;
background-repeat: no-repeat;
background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2024%2024%22%20width%3D%22100%25%22%20height%3D%22100%25%22%20pointer-events%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill%3D%22none%22%20stroke%3D%22%23888%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%20d%3D%22m21%2021-4.486-4.494M19%2010.5a8.5%208.5%200%201%201-17%200%208.5%208.5%200%200%201%2017%200%22%2F%3E%3C%2Fsvg%3E");
}
.cmm-manager-status {
padding-left: 10px;
}
.cmm-manager-grid {
flex: auto;
border: 1px solid var(--border-color);
overflow: hidden;
}
.cmm-manager-selection {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cmm-manager-footer {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cmm-manager-grid .tg-turbogrid {
font-family: var(--grid-font);
font-size: 15px;
background: var(--bg-color);
}
.cmm-manager-grid .cmm-node-name a {
color: skyblue;
text-decoration: none;
word-break: break-word;
}
.cmm-manager-grid .cmm-node-desc a {
color: #5555FF;
font-weight: bold;
text-decoration: none;
}
.cmm-manager-grid .tg-cell a:hover {
text-decoration: underline;
}
.cmm-icon-passed {
width: 20px;
height: 20px;
position: absolute;
left: calc(50% - 10px);
top: calc(50% - 10px);
}
.cmm-manager .cmm-btn-enable {
background-color: blue;
color: white;
}
.cmm-manager .cmm-btn-disable {
background-color: MediumSlateBlue;
color: white;
}
.cmm-manager .cmm-btn-install {
background-color: black;
color: white;
}
.cmm-btn-download {
width: 18px;
height: 18px;
position: absolute;
left: calc(50% - 10px);
top: calc(50% - 10px);
cursor: pointer;
opacity: 0.8;
color: #fff;
}
.cmm-btn-download:hover {
opacity: 1;
}
.cmm-manager-light .cmm-btn-download {
color: #000;
}
@keyframes cmm-btn-loading-bg {
0% {
left: 0;
}
100% {
left: -105px;
}
}
.cmm-manager button.cmm-btn-loading {
position: relative;
overflow: hidden;
border-color: rgb(0 119 207 / 80%);
background-color: var(--comfy-input-bg);
}
.cmm-manager button.cmm-btn-loading::after {
position: absolute;
top: 0;
left: 0;
content: "";
width: 500px;
height: 100%;
background-image: repeating-linear-gradient(
-45deg,
rgb(0 119 207 / 30%),
rgb(0 119 207 / 30%) 10px,
transparent 10px,
transparent 15px
);
animation: cmm-btn-loading-bg 2s linear infinite;
}
.cmm-manager-light .cmm-node-name a {
color: blue;
}
.cmm-manager-light .cm-warn-note {
background-color: #ccc !important;
}
.cmm-manager-light .cmm-btn-install {
background-color: #333;
}

View File

@@ -3,236 +3,17 @@ import { $el } from "../../scripts/ui.js";
import {
manager_instance, rebootAPI,
fetchData, md5, icons, show_message, customAlert, infoToast, showTerminal,
storeColumnWidth, restoreColumnWidth
storeColumnWidth, restoreColumnWidth, loadCss
} from "./common.js";
import { api } from "../../scripts/api.js";
// https://cenfun.github.io/turbogrid/api.html
import TG from "./turbogrid.esm.js";
loadCss("./model-manager.css");
const gridId = "model";
const pageCss = `
.cmm-manager {
--grid-font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
z-index: 1099;
width: 80%;
height: 80%;
display: flex;
flex-direction: column;
gap: 10px;
color: var(--fg-color);
font-family: arial, sans-serif;
}
.cmm-manager .cmm-flex-auto {
flex: auto;
}
.cmm-manager button {
font-size: 16px;
color: var(--input-text);
background-color: var(--comfy-input-bg);
border-radius: 8px;
border-color: var(--border-color);
border-style: solid;
margin: 0;
padding: 4px 8px;
min-width: 100px;
}
.cmm-manager button:disabled,
.cmm-manager input:disabled,
.cmm-manager select:disabled {
color: gray;
}
.cmm-manager button:disabled {
background-color: var(--comfy-input-bg);
}
.cmm-manager .cmm-manager-refresh {
display: none;
background-color: #000080;
color: white;
}
.cmm-manager .cmm-manager-stop {
display: none;
background-color: #500000;
color: white;
}
.cmm-manager-header {
display: flex;
flex-wrap: wrap;
gap: 5px;
align-items: center;
padding: 0 5px;
}
.cmm-manager-header label {
display: flex;
gap: 5px;
align-items: center;
}
.cmm-manager-type,
.cmm-manager-base,
.cmm-manager-filter {
height: 28px;
line-height: 28px;
}
.cmm-manager-keywords {
height: 28px;
line-height: 28px;
padding: 0 5px 0 26px;
background-size: 16px;
background-position: 5px center;
background-repeat: no-repeat;
background-image: url("data:image/svg+xml;charset=utf8,${encodeURIComponent(icons.search.replace("currentColor", "#888"))}");
}
.cmm-manager-status {
padding-left: 10px;
}
.cmm-manager-grid {
flex: auto;
border: 1px solid var(--border-color);
overflow: hidden;
}
.cmm-manager-selection {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cmm-manager-message {
}
.cmm-manager-footer {
display: flex;
flex-wrap: wrap;
gap: 10px;
align-items: center;
}
.cmm-manager-grid .tg-turbogrid {
font-family: var(--grid-font);
font-size: 15px;
background: var(--bg-color);
}
.cmm-manager-grid .cmm-node-name a {
color: skyblue;
text-decoration: none;
word-break: break-word;
}
.cmm-manager-grid .cmm-node-desc a {
color: #5555FF;
font-weight: bold;
text-decoration: none;
}
.cmm-manager-grid .tg-cell a:hover {
text-decoration: underline;
}
.cmm-icon-passed {
width: 20px;
height: 20px;
position: absolute;
left: calc(50% - 10px);
top: calc(50% - 10px);
}
.cmm-manager .cmm-btn-enable {
background-color: blue;
color: white;
}
.cmm-manager .cmm-btn-disable {
background-color: MediumSlateBlue;
color: white;
}
.cmm-manager .cmm-btn-install {
background-color: black;
color: white;
}
.cmm-btn-download {
width: 18px;
height: 18px;
position: absolute;
left: calc(50% - 10px);
top: calc(50% - 10px);
cursor: pointer;
opacity: 0.8;
color: #fff;
}
.cmm-btn-download:hover {
opacity: 1;
}
.cmm-manager-light .cmm-btn-download {
color: #000;
}
@keyframes cmm-btn-loading-bg {
0% {
left: 0;
}
100% {
left: -105px;
}
}
.cmm-manager button.cmm-btn-loading {
position: relative;
overflow: hidden;
border-color: rgb(0 119 207 / 80%);
background-color: var(--comfy-input-bg);
}
.cmm-manager button.cmm-btn-loading::after {
position: absolute;
top: 0;
left: 0;
content: "";
width: 500px;
height: 100%;
background-image: repeating-linear-gradient(
-45deg,
rgb(0 119 207 / 30%),
rgb(0 119 207 / 30%) 10px,
transparent 10px,
transparent 15px
);
animation: cmm-btn-loading-bg 2s linear infinite;
}
.cmm-manager-light .cmm-node-name a {
color: blue;
}
.cmm-manager-light .cm-warn-note {
background-color: #ccc !important;
}
.cmm-manager-light .cmm-btn-install {
background-color: #333;
}
`;
const pageHtml = `
<div class="cmm-manager-header">
<label>Filter
@@ -283,14 +64,6 @@ export class ModelManager {
}
init() {
if (!document.querySelector(`style[context="${this.id}"]`)) {
const $style = document.createElement("style");
$style.setAttribute("context", this.id);
$style.innerHTML = pageCss;
document.head.appendChild($style);
}
this.element = $el("div", {
parent: document.body,
className: "comfy-modal cmm-manager"
@@ -561,7 +334,7 @@ export class ModelManager {
sortable: false,
align: 'center',
formatter: (url, rowItem, columnItem) => {
return `<a class="cmm-btn-download" title="Download file" href="${url}" target="_blank">${icons.download}</a>`;
return `<a class="cmm-btn-download" tooltip="Download file" href="${url}" target="_blank">${icons.download}</a>`;
}
}, {
id: 'size',

619
js/popover-helper.js Normal file
View File

@@ -0,0 +1,619 @@
const hasOwn = function(obj, key) {
return Object.prototype.hasOwnProperty.call(obj, key);
};
const isNum = function(num) {
if (typeof num !== 'number' || isNaN(num)) {
return false;
}
const isInvalid = function(n) {
if (n === Number.MAX_VALUE || n === Number.MIN_VALUE || n === Number.NEGATIVE_INFINITY || n === Number.POSITIVE_INFINITY) {
return true;
}
return false;
};
if (isInvalid(num)) {
return false;
}
return true;
};
const toNum = (num) => {
if (typeof (num) !== 'number') {
num = parseFloat(num);
}
if (isNaN(num)) {
num = 0;
}
num = Math.round(num);
return num;
};
const clamp = function(value, min, max) {
return Math.max(min, Math.min(max, value));
};
const isWindow = (obj) => {
return Boolean(obj && obj === obj.window);
};
const isDocument = (obj) => {
return Boolean(obj && obj.nodeType === 9);
};
const isElement = (obj) => {
return Boolean(obj && obj.nodeType === 1);
};
// ===========================================================================================
export const toRect = (obj) => {
if (obj) {
return {
left: toNum(obj.left || obj.x),
top: toNum(obj.top || obj.y),
width: toNum(obj.width),
height: toNum(obj.height)
};
}
return {
left: 0,
top: 0,
width: 0,
height: 0
};
};
export const getElement = (selector) => {
if (typeof selector === 'string' && selector) {
if (selector.startsWith('#')) {
return document.getElementById(selector.slice(1));
}
return document.querySelector(selector);
}
if (isDocument(selector)) {
return selector.body;
}
if (isElement(selector)) {
return selector;
}
};
export const getRect = (target, fixed) => {
if (!target) {
return toRect();
}
if (isWindow(target)) {
return {
left: 0,
top: 0,
width: window.innerWidth,
height: window.innerHeight
};
}
const elem = getElement(target);
if (!elem) {
return toRect(target);
}
const br = elem.getBoundingClientRect();
const rect = toRect(br);
// fix offset
if (!fixed) {
rect.left += window.scrollX;
rect.top += window.scrollY;
}
rect.width = elem.offsetWidth;
rect.height = elem.offsetHeight;
return rect;
};
// ===========================================================================================
const calculators = {
bottom: (info, containerRect, targetRect) => {
info.space = containerRect.top + containerRect.height - targetRect.top - targetRect.height - info.height;
info.top = targetRect.top + targetRect.height;
info.left = Math.round(targetRect.left + targetRect.width * 0.5 - info.width * 0.5);
},
top: (info, containerRect, targetRect) => {
info.space = targetRect.top - info.height - containerRect.top;
info.top = targetRect.top - info.height;
info.left = Math.round(targetRect.left + targetRect.width * 0.5 - info.width * 0.5);
},
right: (info, containerRect, targetRect) => {
info.space = containerRect.left + containerRect.width - targetRect.left - targetRect.width - info.width;
info.top = Math.round(targetRect.top + targetRect.height * 0.5 - info.height * 0.5);
info.left = targetRect.left + targetRect.width;
},
left: (info, containerRect, targetRect) => {
info.space = targetRect.left - info.width - containerRect.left;
info.top = Math.round(targetRect.top + targetRect.height * 0.5 - info.height * 0.5);
info.left = targetRect.left - info.width;
}
};
// with order
export const getDefaultPositions = () => {
return Object.keys(calculators);
};
const calculateSpace = (info, containerRect, targetRect) => {
const calculator = calculators[info.position];
calculator(info, containerRect, targetRect);
if (info.space >= 0) {
info.passed += 1;
}
};
// ===========================================================================================
const calculateAlignOffset = (info, containerRect, targetRect, alignType, sizeType) => {
const popoverStart = info[alignType];
const popoverSize = info[sizeType];
const containerStart = containerRect[alignType];
const containerSize = containerRect[sizeType];
const targetStart = targetRect[alignType];
const targetSize = targetRect[sizeType];
const targetCenter = targetStart + targetSize * 0.5;
// size overflow
if (popoverSize > containerSize) {
const overflow = (popoverSize - containerSize) * 0.5;
info[alignType] = containerStart - overflow;
info.offset = targetCenter - containerStart + overflow;
return;
}
const space1 = popoverStart - containerStart;
const space2 = (containerStart + containerSize) - (popoverStart + popoverSize);
// both side passed, default to center
if (space1 >= 0 && space2 >= 0) {
if (info.passed) {
info.passed += 2;
}
info.offset = popoverSize * 0.5;
return;
}
// one side passed
if (info.passed) {
info.passed += 1;
}
if (space1 < 0) {
const min = containerStart;
info[alignType] = min;
info.offset = targetCenter - min;
return;
}
// space2 < 0
const max = containerStart + containerSize - popoverSize;
info[alignType] = max;
info.offset = targetCenter - max;
};
const calculateHV = (info, containerRect) => {
if (['top', 'bottom'].includes(info.position)) {
info.top = clamp(info.top, containerRect.top, containerRect.top + containerRect.height - info.height);
return ['left', 'width'];
}
info.left = clamp(info.left, containerRect.left, containerRect.left + containerRect.width - info.width);
return ['top', 'height'];
};
const calculateOffset = (info, containerRect, targetRect) => {
const [alignType, sizeType] = calculateHV(info, containerRect);
calculateAlignOffset(info, containerRect, targetRect, alignType, sizeType);
info.offset = clamp(info.offset, 0, info[sizeType]);
};
// ===========================================================================================
const calculateDistance = (info, previousPositionInfo) => {
if (!previousPositionInfo) {
return;
}
// no change if position no change with previous
if (info.position === previousPositionInfo.position) {
return;
}
const ax = info.left + info.width * 0.5;
const ay = info.top + info.height * 0.5;
const bx = previousPositionInfo.left + previousPositionInfo.width * 0.5;
const by = previousPositionInfo.top + previousPositionInfo.height * 0.5;
const dx = Math.abs(ax - bx);
const dy = Math.abs(ay - by);
info.distance = Math.round(Math.sqrt(dx * dx + dy * dy));
};
// ===========================================================================================
const calculatePositionInfo = (info, containerRect, targetRect, previousPositionInfo) => {
calculateSpace(info, containerRect, targetRect);
calculateOffset(info, containerRect, targetRect);
calculateDistance(info, previousPositionInfo);
};
// ===========================================================================================
const calculateBestPosition = (containerRect, targetRect, infoMap, withOrder, previousPositionInfo) => {
// position space: +1
// align space:
// two side passed: +2
// one side passed: +1
const safePassed = 3;
if (previousPositionInfo) {
const prevInfo = infoMap[previousPositionInfo.position];
if (prevInfo) {
calculatePositionInfo(prevInfo, containerRect, targetRect);
if (prevInfo.passed >= safePassed) {
return prevInfo;
}
prevInfo.calculated = true;
}
}
const positionList = [];
Object.values(infoMap).forEach((info) => {
if (!info.calculated) {
calculatePositionInfo(info, containerRect, targetRect, previousPositionInfo);
}
positionList.push(info);
});
positionList.sort((a, b) => {
if (a.passed !== b.passed) {
return b.passed - a.passed;
}
if (withOrder && a.passed >= safePassed && b.passed >= safePassed) {
return a.index - b.index;
}
if (a.space !== b.space) {
return b.space - a.space;
}
return a.index - b.index;
});
// logTable(positionList);
return positionList[0];
};
// const logTable = (() => {
// let time_id;
// return (info) => {
// clearTimeout(time_id);
// time_id = setTimeout(() => {
// console.table(info);
// }, 10);
// };
// })();
// ===========================================================================================
const getAllowPositions = (positions, defaultAllowPositions) => {
if (!positions) {
return;
}
if (Array.isArray(positions)) {
positions = positions.join(',');
}
positions = String(positions).split(',').map((it) => it.trim().toLowerCase()).filter((it) => it);
positions = positions.filter((it) => defaultAllowPositions.includes(it));
if (!positions.length) {
return;
}
return positions;
};
const isPositionChanged = (info, previousPositionInfo) => {
if (!previousPositionInfo) {
return true;
}
if (info.left !== previousPositionInfo.left) {
return true;
}
if (info.top !== previousPositionInfo.top) {
return true;
}
return false;
};
// ===========================================================================================
// const log = (name, time) => {
// if (time > 0.1) {
// console.log(name, time);
// }
// };
export const getBestPosition = (containerRect, targetRect, popoverRect, positions, previousPositionInfo) => {
const defaultAllowPositions = getDefaultPositions();
let withOrder = true;
let allowPositions = getAllowPositions(positions, defaultAllowPositions);
if (!allowPositions) {
allowPositions = defaultAllowPositions;
withOrder = false;
}
// console.log('withOrder', withOrder);
// const start_time = performance.now();
const infoMap = {};
allowPositions.forEach((k, i) => {
infoMap[k] = {
position: k,
index: i,
top: 0,
left: 0,
width: popoverRect.width,
height: popoverRect.height,
space: 0,
offset: 0,
passed: 0,
distance: 0
};
});
// log('infoMap', performance.now() - start_time);
const bestPosition = calculateBestPosition(containerRect, targetRect, infoMap, withOrder, previousPositionInfo);
// check left/top
bestPosition.changed = isPositionChanged(bestPosition, previousPositionInfo);
return bestPosition;
};
// ===========================================================================================
const getTemplatePath = (width, height, arrowOffset, arrowSize, borderRadius) => {
const p = (px, py) => {
return [px, py].join(',');
};
const px = function(num, alignEnd) {
const floor = Math.floor(num);
let n = num < floor + 0.5 ? floor + 0.5 : floor + 1.5;
if (alignEnd) {
n -= 1;
}
return n;
};
const pxe = function(num) {
return px(num, true);
};
const ls = [];
const innerLeft = px(arrowSize);
const innerRight = pxe(width - arrowSize);
arrowOffset = clamp(arrowOffset, innerLeft, innerRight);
const innerTop = px(arrowSize);
const innerBottom = pxe(height - arrowSize);
const startPoint = p(innerLeft, innerTop + borderRadius);
const arrowPoint = p(arrowOffset, 1);
const LT = p(innerLeft, innerTop);
const RT = p(innerRight, innerTop);
const AOT = p(arrowOffset - arrowSize, innerTop);
const RRT = p(innerRight - borderRadius, innerTop);
ls.push(`M${startPoint}`);
ls.push(`V${innerBottom - borderRadius}`);
ls.push(`Q${p(innerLeft, innerBottom)} ${p(innerLeft + borderRadius, innerBottom)}`);
ls.push(`H${innerRight - borderRadius}`);
ls.push(`Q${p(innerRight, innerBottom)} ${p(innerRight, innerBottom - borderRadius)}`);
ls.push(`V${innerTop + borderRadius}`);
if (arrowOffset < innerLeft + arrowSize + borderRadius) {
ls.push(`Q${RT} ${RRT}`);
ls.push(`H${arrowOffset + arrowSize}`);
ls.push(`L${arrowPoint}`);
if (arrowOffset < innerLeft + arrowSize) {
ls.push(`L${LT}`);
ls.push(`L${startPoint}`);
} else {
ls.push(`L${AOT}`);
ls.push(`Q${LT} ${startPoint}`);
}
} else if (arrowOffset > innerRight - arrowSize - borderRadius) {
if (arrowOffset > innerRight - arrowSize) {
ls.push(`L${RT}`);
} else {
ls.push(`Q${RT} ${p(arrowOffset + arrowSize, innerTop)}`);
}
ls.push(`L${arrowPoint}`);
ls.push(`L${AOT}`);
ls.push(`H${innerLeft + borderRadius}`);
ls.push(`Q${LT} ${startPoint}`);
} else {
ls.push(`Q${RT} ${RRT}`);
ls.push(`H${arrowOffset + arrowSize}`);
ls.push(`L${arrowPoint}`);
ls.push(`L${AOT}`);
ls.push(`H${innerLeft + borderRadius}`);
ls.push(`Q${LT} ${startPoint}`);
}
return ls.join('');
};
const getPathData = function(position, width, height, arrowOffset, arrowSize, borderRadius) {
const handlers = {
bottom: () => {
const d = getTemplatePath(width, height, arrowOffset, arrowSize, borderRadius);
return {
d,
transform: ''
};
},
top: () => {
const d = getTemplatePath(width, height, width - arrowOffset, arrowSize, borderRadius);
return {
d,
transform: `rotate(180,${width * 0.5},${height * 0.5})`
};
},
left: () => {
const d = getTemplatePath(height, width, arrowOffset, arrowSize, borderRadius);
const x = (width - height) * 0.5;
const y = (height - width) * 0.5;
return {
d,
transform: `translate(${x} ${y}) rotate(90,${height * 0.5},${width * 0.5})`
};
},
right: () => {
const d = getTemplatePath(height, width, height - arrowOffset, arrowSize, borderRadius);
const x = (width - height) * 0.5;
const y = (height - width) * 0.5;
return {
d,
transform: `translate(${x} ${y}) rotate(-90,${height * 0.5},${width * 0.5})`
};
}
};
return handlers[position]();
};
// ===========================================================================================
// position style cache
const styleCache = {
// position: '',
// top: {},
// bottom: {},
// left: {},
// right: {}
};
export const getPositionStyle = (info, options = {}) => {
const o = {
bgColor: '#fff',
borderColor: '#ccc',
borderRadius: 5,
arrowSize: 10
};
Object.keys(o).forEach((k) => {
if (hasOwn(options, k)) {
const d = o[k];
const v = options[k];
if (typeof d === 'string') {
// string
if (typeof v === 'string' && v) {
o[k] = v;
}
} else {
// number
if (isNum(v) && v >= 0) {
o[k] = v;
}
}
}
});
const key = [
info.width,
info.height,
info.offset,
o.arrowSize,
o.borderRadius,
o.bgColor,
o.borderColor
].join('-');
const positionCache = styleCache[info.position];
if (positionCache && key === positionCache.key) {
const st = positionCache.style;
st.changed = styleCache.position !== info.position;
styleCache.position = info.position;
return st;
}
// console.log(options);
const data = getPathData(info.position, info.width, info.height, info.offset, o.arrowSize, o.borderRadius);
// console.log(data);
const viewBox = [0, 0, info.width, info.height].join(' ');
const svg = [
`<svg viewBox="${viewBox}" xmlns="http://www.w3.org/2000/svg">`,
`<path d="${data.d}" fill="${o.bgColor}" stroke="${o.borderColor}" transform="${data.transform}" />`,
'</svg>'
].join('');
// console.log(svg);
const backgroundImage = `url("data:image/svg+xml;charset=utf8,${encodeURIComponent(svg)}")`;
const background = `${backgroundImage} center no-repeat`;
const padding = `${o.arrowSize + o.borderRadius}px`;
const style = {
background,
backgroundImage,
padding,
changed: true
};
styleCache.position = info.position;
styleCache[info.position] = {
key,
style
};
return style;
};

View File

@@ -11,7 +11,26 @@
{
"author": "silveroxides",
"title": "ComfyUI-ModelUtils [WIP]",
"reference": "https://github.com/silveroxides/ComfyUI-ModelUtils",
"files": [
"https://github.com/silveroxides/ComfyUI-ModelUtils"
],
"install_type": "git-clone",
"description": "[WIP]Custom nodes for handling, inspecting, modifying and creating various model files."
},
{
"author": "thisiseddy-ab",
"title": "ComfyUI-Edins-Ultimate-Pack",
"reference": "https://github.com/thisiseddy-ab/ComfyUI-Edins-Ultimate-Pack",
"files": [
"https://github.com/thisiseddy-ab/ComfyUI-Edins-Ultimate-Pack"
],
"install_type": "git-clone",
"description": "Well i needet a Tiled Ksampler that still works for Comfy UI there were none so i made one, in this Package i will put all Nodes i will develop for Comfy Ui still in beta alot will change.."
},
{
"author": "longzoho",
"title": "ComfyUI-Qdrant-Saver",
@@ -22,16 +41,6 @@
"install_type": "git-clone",
"description": "NODES: QDrant Saver Node"
},
{
"author": "nova-florealis",
"title": "comfyui-alien",
"reference": "https://github.com/nova-florealis/comfyui-alien",
"files": [
"https://github.com/nova-florealis/comfyui-alien"
],
"install_type": "git-clone",
"description": "NODES: Text to Text (LLM), Text Output, Convert to Markdown, List Display (Debug)"
},
{
"author": "RUFFY-369",
"title": "ComfyUI-FeatureBank",
@@ -44,7 +53,7 @@
},
{
"author": "Pablerdo",
"title": "ComfyUI-Sa2VAWrapper",
"title": "ComfyUI-Sa2VAWrapper [WIP]",
"reference": "https://github.com/Pablerdo/ComfyUI-Sa2VAWrapper",
"files": [
"https://github.com/Pablerdo/ComfyUI-Sa2VAWrapper"
@@ -1808,16 +1817,6 @@
"install_type": "git-clone",
"description": "a custom node for [a/Ultralight-Digital-Human](https://github.com/anliyuan/Ultralight-Digital-Human)\nNOTE: The files in the repo are not organized."
},
{
"author": "vahidzxc",
"title": "ComfyUI-My-Handy-Nodes",
"reference": "https://github.com/vahidzxc/ComfyUI-My-Handy-Nodes",
"files": [
"https://github.com/vahidzxc/ComfyUI-My-Handy-Nodes"
],
"install_type": "git-clone",
"description": "NODES:VahCropImage"
},
{
"author": "StartHua",
"title": "Comfyui_Flux_Style_Ctr [WIP]",
@@ -4560,16 +4559,6 @@
"install_type": "git-clone",
"description": "Image manipulation nodes, Temperature control nodes, Tiling nodes, Primitive and operation nodes, ..."
},
{
"author": "PluMaZero",
"title": "ComfyUI-SpaceFlower",
"reference": "https://github.com/PluMaZero/ComfyUI-SpaceFlower",
"files": [
"https://github.com/PluMaZero/ComfyUI-SpaceFlower"
],
"install_type": "git-clone",
"description": "Nodes: SpaceFlower_Prompt, SpaceFlower_HangulPrompt, ..."
},
{
"author": "laksjdjf",
"title": "ssd-1b-comfyui",

View File

@@ -630,6 +630,7 @@
"DevToolsErrorRaiseNodeWithMessage",
"DevToolsExperimentalNode",
"DevToolsLongComboDropdown",
"DevToolsMultiSelectNode",
"DevToolsNodeWithBooleanInput",
"DevToolsNodeWithForceInput",
"DevToolsNodeWithOnlyOptionalInput",
@@ -1128,29 +1129,42 @@
],
"https://github.com/KurtHokke/ComfyUI_KurtHokke-Nodes": [
[
"AIO_Tuner",
"AIO_Tuner_Pipe",
"BasicAdvScheduler",
"Beta_Config",
"BooleanFromPipe",
"BooleanToPipe",
"COND_ExtraOpts",
"ChainTextEncode",
"CkptPipe",
"DynamicThresholding",
"DynamicThresholdingBasic",
"EmptyLatentSize",
"EmptyLatentSize64",
"ExpMath",
"ExpMathDual",
"ExpMathQuad",
"LMS_Config",
"LoadUnetAndClip",
"LoraFluxParams",
"MergeExtraOpts",
"ModelPipe1",
"ModelPipe2",
"NoModel_CkptLoader",
"Node_BOOL",
"Node_Float",
"Node_INT",
"Node_String",
"Node_StringMultiline",
"SamplerCustomAdvanced_Pipe",
"SamplerSel",
"SchedulerSel",
"SedOnString",
"UnetClipLoraLoader",
"UnetClipLoraLoaderBasic",
"stopipe"
"VAE_ExtraOpts",
"debug_object",
"get_lora_metadata",
"re_sub_str",
"str_str",
"str_str_str_str"
],
{
"title_aux": "ComfyUI_KurtHokke-Nodes"
@@ -1387,6 +1401,7 @@
"Data_handle_Node",
"DeepSeek_Node",
"Delay_node",
"Delete_folder_Node",
"DongShowTextNode",
"Dong_Pixelate_Node",
"Dong_Text_Node",
@@ -1405,6 +1420,7 @@
"LibLib_upload_Node",
"LogicToolsNode",
"LoraIterator",
"Notice_Node",
"PromptConcatNode",
"RandomNumbersNode",
"RenameNode",
@@ -1414,11 +1430,13 @@
"TextToJsonNode",
"TranslateAPINode",
"ZIPwith7zNode",
"find_files_by_extension_Node",
"img_understanding_Node",
"klingai_video_Node",
"path_join_Node",
"save_img_NODE",
"set_api_Node"
"set_api_Node",
"text_replace_node"
],
{
"title_aux": "ComfyUI-tools-by-dong [UNSAFE]"
@@ -1459,16 +1477,7 @@
"GetCaptionFromImages"
],
{
"title_aux": "ComfyUI-Sa2VAWrapper"
}
],
"https://github.com/PluMaZero/ComfyUI-SpaceFlower": [
[
"SpaceFlower_HangulPrompt",
"SpaceFlower_Prompt"
],
{
"title_aux": "ComfyUI-SpaceFlower"
"title_aux": "ComfyUI-Sa2VAWrapper [WIP]"
}
],
"https://github.com/Poseidon-fan/ComfyUI-fileCleaner": [
@@ -1815,7 +1824,8 @@
[
"Example",
"FluxImageUpscaler",
"FluxLoader"
"FluxLoader",
"FluxTextPrompt"
],
{
"title_aux": "comfyui_flux_collection_advanced [WIP]"
@@ -2184,6 +2194,7 @@
"ImageToPrompt",
"MiniMaxAIAPIClient",
"MiniMaxImage2Video",
"MiniMaxImageGenerator",
"MiniMaxPreviewVideo"
],
{
@@ -3968,6 +3979,7 @@
"HyVideoSTG",
"HyVideoSampler",
"HyVideoTeaCache",
"HyVideoTextEmbedBridge",
"HyVideoTextEmbedsLoad",
"HyVideoTextEmbedsSave",
"HyVideoTextEncode",
@@ -4037,6 +4049,7 @@
"LoadWanVideoT5TextEncoder",
"WanVideoBlockSwap",
"WanVideoContextOptions",
"WanVideoControlEmbeds",
"WanVideoDecode",
"WanVideoEmptyEmbeds",
"WanVideoEncode",
@@ -4047,6 +4060,7 @@
"WanVideoLoraBlockEdit",
"WanVideoLoraSelect",
"WanVideoModelLoader",
"WanVideoSLG",
"WanVideoSampler",
"WanVideoTeaCache",
"WanVideoTextEmbedBridge",
@@ -4087,6 +4101,7 @@
"Custom_Save_Image",
"Display_Any",
"Image_Size_Extractor",
"Load_Image_Folder",
"Mask_Blur_Plus",
"Preview_Mask",
"Preview_Mask_Plus",
@@ -4830,29 +4845,20 @@
"ClusterFanOutImage",
"ClusterFanOutLatent",
"ClusterFanOutMask",
"ClusterFlattenBatchedImageList",
"ClusterGatherImages",
"ClusterGatherLatents",
"ClusterGatherMasks",
"ClusterGetInstanceWorkItemFromBatch",
"ClusterInfo",
"ClusterListenTensorBroadcast"
"ClusterListenTensorBroadcast",
"ClusterSplitBatchToList",
"ClusterStridedReorder"
],
{
"title_aux": "ComfyUI_Cluster [WIP]"
}
],
"https://github.com/nova-florealis/comfyui-alien": [
[
"ConvertMarkdown",
"ListDisplayNode",
"MarkdownConverterModule",
"TextOutput",
"TextToText"
],
{
"title_aux": "comfyui-alien"
}
],
"https://github.com/oshtz/ComfyUI-oshtz-nodes": [
[
"EasyAspectRatioNode",
@@ -5241,6 +5247,17 @@
"title_aux": "ComfyUI_CheckPointLoader_Ext [WIP]"
}
],
"https://github.com/silveroxides/ComfyUI-ModelUtils": [
[
"CLIPMetaKeys",
"CheckpointMetaKeys",
"LoRAMetaKeys",
"UNetMetaKeys"
],
{
"title_aux": "ComfyUI-ModelUtils [WIP]"
}
],
"https://github.com/sizzlebop/comfyui-llm-prompt-enhancer": [
[
"PromptEnhancer"
@@ -5439,6 +5456,20 @@
"title_aux": "Divergent Nodes [WIP]"
}
],
"https://github.com/thisiseddy-ab/ComfyUI-Edins-Ultimate-Pack": [
[
"EUP - Iterative Latent Upscaler",
"EUP - Latent Merger",
"EUP - Latent Tiler",
"EUP - Pixel TiledKSample Upscaler Provider",
"EUP - Pixel TiledKSample Upscaler Provider Pipe",
"EUP - Tiled KSampler",
"EUP - Tiled KSampler Advanced"
],
{
"title_aux": "ComfyUI-Edins-Ultimate-Pack"
}
],
"https://github.com/threadedblue/MLXnodes": [
[
"MLXImg2Img",
@@ -5544,14 +5575,6 @@
"title_aux": "ComfyUI-Dist [WIP]"
}
],
"https://github.com/vahidzxc/ComfyUI-My-Handy-Nodes": [
[
"VahCropImage"
],
{
"title_aux": "ComfyUI-My-Handy-Nodes"
}
],
"https://github.com/var1ableX/ComfyUI_Accessories": [
[
"ACC_AnyCast",
@@ -5681,6 +5704,8 @@
"AceIntegerX",
"CheckpointLoaderBNB_X",
"CheckpointLoaderNF4_X",
"ColorTransferNodeX",
"DeepSeekX",
"DepthDisplaceX",
"EmptyLatentX",
"IfConditionX",
@@ -5690,8 +5715,12 @@
"LoopCloseX",
"LoopOpenX",
"LoraBatchSamplerX",
"PixtralVisionX",
"PixtralX",
"RegionTesterNodeX",
"RelightX",
"RemoveBackgroundX",
"SaveImageX",
"SelectiveDepthLoraBlocksX",
"UnetLoaderBNB_X",
"WhiteBalanceX"
@@ -5702,21 +5731,26 @@
],
"https://github.com/yanhuifair/ComfyUI-FairLab": [
[
"AppendTagsNode",
"BlacklistTagsNode",
"CLIPTranslatedNode",
"DownloadImageNode",
"FillAlphaNode",
"FixUTF8StringNode",
"FloatNode",
"ImageResizeNode",
"ImageToVideoNode",
"IntNode",
"LoadImageFromDirectoryNode",
"LoadImageFromURLNode",
"PrependTagsNode",
"PrintAnyNode",
"PrintImageNode",
"SaveImageToDirectoryNode",
"SaveStringToDirectoryNode",
"SequenceStringListNode",
"StringCombineNode",
"StringFieldNode",
"StringNode",
"TranslateStringNode",
"VideoToImageNode"
],

View File

File diff suppressed because it is too large Load Diff

View File

@@ -11,6 +11,46 @@
{
"author": "l1yongch1",
"title": "ComfyUI_PhiCaption [REMOVED]",
"reference": "https://github.com/l1yongch1/ComfyUI_PhiCaption",
"files": [
"https://github.com/l1yongch1/ComfyUI_PhiCaption"
],
"install_type": "git-clone",
"description": "In addition to achieving conventional single-image, single-round reverse engineering, it can also achieve single-image multi-round and multi-image single-round reverse engineering. Moreover, the Phi model has a better understanding of prompts."
},
{
"author": "nova-florealis",
"title": "comfyui-alien [REMOVED]",
"reference": "https://github.com/nova-florealis/comfyui-alien",
"files": [
"https://github.com/nova-florealis/comfyui-alien"
],
"install_type": "git-clone",
"description": "NODES: Text to Text (LLM), Text Output, Convert to Markdown, List Display (Debug)"
},
{
"author": "PluMaZero",
"title": "ComfyUI-SpaceFlower [REMOVED]",
"reference": "https://github.com/PluMaZero/ComfyUI-SpaceFlower",
"files": [
"https://github.com/PluMaZero/ComfyUI-SpaceFlower"
],
"install_type": "git-clone",
"description": "Nodes: SpaceFlower_Prompt, SpaceFlower_HangulPrompt, ..."
},
{
"author": "vahidzxc",
"title": "ComfyUI-My-Handy-Nodes [REMOVED]",
"reference": "https://github.com/vahidzxc/ComfyUI-My-Handy-Nodes",
"files": [
"https://github.com/vahidzxc/ComfyUI-My-Handy-Nodes"
],
"install_type": "git-clone",
"description": "NODES:VahCropImage"
},
{
"author": "Samulebotin",
"title": "ComfyUI-FreeVC_wrapper [REMOVED]",

View File

@@ -9,6 +9,309 @@
},
{
"author": "ali-vilab",
"title": "ComfyUI-ACE_Plus",
"id": "ace_plus",
"reference": "https://github.com/ali-vilab/ACE_plus",
"files": [
"https://github.com/ali-vilab/ACE_plus"
],
"install_type": "git-clone",
"description": "Custom nodes for various visual generation and editing tasks using ACE_Plus FFT Model."
},
{
"author": "notagen-mw",
"title": "ComfyUI_NotaGen",
"reference": "https://github.com/billwuhao/ComfyUI_NotaGen",
"files": [
"https://github.com/billwuhao/ComfyUI_NotaGen"
],
"install_type": "git-clone",
"description": "Symbolic Music Generation, NotaGen node for ComfyUI."
},
{
"author": "smthemex",
"title": "ComfyUI_KV_Edit",
"reference": "https://github.com/smthemex/ComfyUI_KV_Edit",
"files": [
"https://github.com/smthemex/ComfyUI_KV_Edit"
],
"install_type": "git-clone",
"description": "KV-Edit: Training-Free Image Editing for Precise Background Preservation,you can use it in comfyUI"
},
{
"author": "mit-han-lab",
"title": "ComfyUI-nunchaku",
"reference": "https://github.com/mit-han-lab/ComfyUI-nunchaku",
"files": [
"https://github.com/mit-han-lab/ComfyUI-nunchaku"
],
"install_type": "git-clone",
"description": "Nunchaku ComfyUI Node. Nunchaku is the inference that supports SVDQuant. SVDQuant is a new post-training training quantization paradigm for diffusion models, which quantize both the weights and activations of FLUX.1 to 4 bits, achieving 3.5× memory and 8.7× latency reduction on a 16GB laptop 4090 GPU. See more details: https://github.com/mit-han-lab/nunchaku"
},
{
"author": "billwuhao",
"title": "ComfyUI_DiffRhythm",
"reference": "https://github.com/billwuhao/ComfyUI_DiffRhythm",
"files": [
"https://github.com/billwuhao/ComfyUI_DiffRhythm"
],
"install_type": "git-clone",
"description": "Blazingly Fast and Embarrassingly Simple End-to-End Full-Length Song Generation. A node for ComfyUI."
},
{
"author": "Visionatrix",
"title": "ComfyUI-RemoteVAE",
"reference": "https://github.com/Visionatrix/ComfyUI-RemoteVAE",
"files": [
"https://github.com/Visionatrix/ComfyUI-RemoteVAE"
],
"install_type": "git-clone",
"description": "ComfyUI Nodes for Remote VAE Decoding."
},
{
"author": "markuryy",
"title": "Video XY Plot",
"reference": "https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot",
"files": [
"https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot"
],
"install_type": "git-clone",
"description": "A collection of custom nodes for ComfyUI"
},
{
"author": "joreyaesh",
"title": "ComfyUI Scroll Over Textarea",
"reference": "https://github.com/joreyaesh/comfyui_scroll_over_textarea",
"files": [
"https://github.com/joreyaesh/comfyui_scroll_over_textarea"
],
"install_type": "git-clone",
"description": "A ComfyUI extension to allow textarea elements to be scrolled over. Useful when using a trackpad in order to prevent accidental forward/back navigation (two fingers horizontally on a Mac) when scrolling around the UI."
},
{
"author": "SSsnap",
"title": "ComfyUI-Ad_scheduler",
"reference": "https://github.com/SS-snap/ComfyUI-Ad_scheduler",
"files": [
"https://github.com/SS-snap/ComfyUI-Ad_scheduler"
],
"install_type": "git-clone",
"description": "This node is used to enhance image details. We can add a latent space image and introduce any amount of noise. Then, we can start denoising at any timestep. This allows us to add more details to the image while maintaining overall consistency as much as possible."
},
{
"author": "iDAPPA",
"title": "AMD GPU Monitor for ComfyUI",
"reference": "https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor",
"files": [
"https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor"
],
"install_type": "git-clone",
"description": "A simple, lightweight AMD GPU monitoring tool for ComfyUI that displays real-time information about your AMD GPU directly in the UI."
},
{
"author": "orssorbit",
"title": "ComfyUI-wanBlockswap",
"reference": "https://github.com/orssorbit/ComfyUI-wanBlockswap",
"files": [
"https://github.com/orssorbit/ComfyUI-wanBlockswap"
],
"install_type": "git-clone",
"description": "This is a simple Wan block swap node for ComfyUI native nodes, works by swapping upto 40 blocks to the CPU to reduce VRAM."
},
{
"author": "KytraScript",
"title": "ComfyUI_MatAnyone_Kytra",
"reference": "https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra",
"files": [
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra"
],
"install_type": "git-clone",
"description": "This is a ComfyUI node for [a/MatAnyone](https://github.com/pq-yang/MatAnyone), a state-of-the-art video matting model that can remove backgrounds from videos using just a single mask for the first frame for enhanced/guided video matting."
},
{
"author": "irreveloper",
"title": "ComfyUI-DSD",
"reference": "https://github.com/irreveloper/ComfyUI-DSD",
"files": [
"https://github.com/irreveloper/ComfyUI-DSD"
],
"install_type": "git-clone",
"description": "An Unofficial ComfyUI custom node package that integrates [a/Diffusion Self-Distillation (DSD)](https://github.com/primecai/diffusion-self-distillation) for zero-shot customized image generation.\nDSD is a model for subject-preserving image generation that allows you to create images of a specific subject in novel contexts without per-instance tuning."
},
{
"author": "Nikosis",
"title": "ComfyUI-Nikosis-Nodes",
"reference": "https://github.com/Nikosis/ComfyUI-Nikosis-Nodes",
"files": [
"https://github.com/Nikosis/ComfyUI-Nikosis-Nodes"
],
"install_type": "git-clone",
"description": "Nodes: Aspect Ratio, Prompt Multiple Styles Selector, Text Concatenate"
},
{
"author": "roundyyy",
"title": "Mesh Simplifier for ComfyUI",
"reference": "https://github.com/roundyyy/ComfyUI-mesh-simplifier",
"files": [
"https://github.com/roundyyy/ComfyUI-mesh-simplifier"
],
"install_type": "git-clone",
"description": "A custom node for ComfyUI that implements mesh simplification with texture preservation using PyMeshLab. This node allows you to reduce the complexity of 3D meshes while preserving visual quality, and is compatible with ComfyUI-3D-Pack's mesh format."
},
{
"author": "leeguandong",
"title": "ComfyUI_1Prompt1Story",
"reference": "https://github.com/leeguandong/ComfyUI_1Prompt1Story",
"files": [
"https://github.com/leeguandong/ComfyUI_1Prompt1Story"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/1Prompt1Story](https://github.com/byliutao/1Prompt1Story)"
},
{
"author": "leeguandong",
"title": "ComfyUI_ChatGen",
"reference": "https://github.com/leeguandong/ComfyUI_ChatGen",
"files": [
"https://github.com/leeguandong/ComfyUI_ChatGen"
],
"install_type": "git-clone",
"description": "ComfyUI nodes to use [a/ChatGen](https://github.com/chengyou-jia/ChatGen)"
},
{
"author": "S4MUEL-404",
"title": "ComfyUI-S4Tool-Image-Overlay",
"reference": "https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay",
"files": [
"https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay"
],
"install_type": "git-clone",
"description": "Quickly set up image overlay effects"
},
{
"author": "xingBaGan",
"title": "ComfyUI-connect-ui",
"reference": "https://github.com/xingBaGan/ComfyUI-connect-ui",
"files": [
"https://github.com/xingBaGan/ComfyUI-connect-ui"
],
"install_type": "git-clone",
"description": "Real-time image transfer between client and server Base64 image encoding/decoding support Supports PNG image format Includes a floating preview window for received images Preview window has minimize/maximize functionality"
},
{
"author": "Duanyll",
"title": "Duanyll Nodepack",
"reference": "https://github.com/Duanyll/duanyll_nodepack",
"files": [
"https://github.com/Duanyll/duanyll_nodepack"
],
"install_type": "git-clone",
"description": "A collection of custom nodes for ComfyUI"
},
{
"author": "HannibalP",
"title": "comfyui-HannibalPack",
"reference": "https://github.com/HannibalP/comfyui-HannibalPack",
"files": [
"https://github.com/HannibalP/comfyui-HannibalPack"
],
"install_type": "git-clone",
"description": "This node improves the merging of LoRA for movements and physical resemblance when adding multiple LoRA to a model."
},
{
"author": "HowToSD",
"title": "ComfyUI-Pt-Wrapper",
"reference": "https://github.com/HowToSD/ComfyUI-Pt-Wrapper",
"files": [
"https://github.com/HowToSD/ComfyUI-Pt-Wrapper"
],
"install_type": "git-clone",
"description": "PyTorch extension for ComfyUI featuring extensive PyTorch wrapper nodes for seamless tensor operations and PyTorch model training."
},
{
"author": "vadimcro",
"title": "VKriez Edge Preprocessors for ComfyUI",
"reference": "https://github.com/vadimcro/VKRiez-Edge",
"files": [
"https://github.com/vadimcro/VKRiez-Edge"
],
"install_type": "git-clone",
"description": "A collection of advanced edge detection nodes for ComfyUI that generate high-quality edge maps for ControlNet guidance. Currently based on CPU computation, so might be a tid-bit on a slow side. If anyone is willing to refactor the code to GPU computation - Kudos!"
},
{
"author": "muxueChen",
"title": "ComfyUI-NTQwen25-VL",
"reference": "https://github.com/muxueChen/ComfyUI-NTQwen25-VL",
"files": [
"https://github.com/muxueChen/ComfyUI-NTQwen25-VL"
],
"install_type": "git-clone",
"description": "Qwen25-VL is a plugin for ComfyU"
},
{
"author": "Holasyb918",
"title": "Ghost2_Comfyui",
"reference": "https://github.com/Holasyb918/Ghost2_Comfyui",
"files": [
"https://github.com/Holasyb918/Ghost2_Comfyui"
],
"install_type": "git-clone",
"description": "ComfyUI adaptation of [a/GHOST 2.0](https://github.com/ai-forever/ghost-2.0)."
},
{
"author": "Diohim",
"title": "ComfyUI Unusual Tools",
"reference": "https://github.com/Diohim/ComfyUI-Unusual-Tools",
"files": [
"https://github.com/Diohim/ComfyUI-Unusual-Tools"
],
"install_type": "git-clone",
"description": "A collection of unusual but useful image processing nodes for ComfyUI."
},
{
"author": "penposs",
"title": "ComfyUI Gemini Pro Node",
"reference": "https://github.com/penposs/ComfyUI_Gemini_Pro",
"files": [
"https://github.com/penposs/ComfyUI_Gemini_Pro"
],
"install_type": "git-clone",
"description": "This is a Google Gemini Pro API integration node for ComfyUI, supporting text, image, video, and audio inputs."
},
{
"author": "cardenluo",
"title": "ComfyUI-Apt_Preset",
"reference": "https://github.com/cardenluo/ComfyUI-Apt_Preset",
"files": [
"https://github.com/cardenluo/ComfyUI-Apt_Preset"
],
"install_type": "git-clone",
"description": "ComfyUI-Apt_Preset is a node package designed to simplify workflows"
},
{
"author": "finegrain",
"title": "comfyui-finegrain",
"reference": "https://github.com/finegrain-ai/comfyui-finegrain",
"files": [
"https://github.com/finegrain-ai/comfyui-finegrain"
],
"install_type": "git-clone",
"description": "ComfyUI custom nodes to interact with the Finegrain API."
},
{
"author": "Yuan-ManX",
"title": "ComfyUI-StyleStudio",
"reference": "https://github.com/Yuan-ManX/ComfyUI-StyleStudio",
"files": [
"https://github.com/Yuan-ManX/ComfyUI-StyleStudio"
],
"install_type": "git-clone",
"description": "ComfyUI nodes for StyleStudio model."
},
{
"author": "Jerome Bacquet",
"title": "ComfyUI XenoFlow",
@@ -52,26 +355,6 @@
"install_type": "git-clone",
"description": "Create Video datasets staright from YT or a video file path"
},
{
"author": "impactframes",
"title": "IF_VideoPrompts",
"reference": "https://github.com/if-ai/ComfyUI-IF_VideoPrompts",
"files": [
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts"
],
"install_type": "git-clone",
"description": "ComfyUI extension for video-based prompting and processing with support for various models and video processing capabilities"
},
{
"author": "impactframes",
"title": "IF_LLM",
"reference": "https://github.com/if-ai/ComfyUI-IF_LLM",
"files": [
"https://github.com/if-ai/ComfyUI-IF_LLM"
],
"install_type": "git-clone",
"description": "Run Local and API LLMs, Features Conditioning manipulation via Omost, supports Ollama, LlamaCPP LMstudio, Koboldcpp, TextGen, Transformers or via APIs Anthropic, Groq, OpenAI, Google Gemini, Mistral, xAI and create your own charcters assistants (SystemPrompts) with custom presets and muchmore\n[w/It Might comflict with IF_AI_tools so if you have it installed please remove it before installing IF_LLM I am working on adding this tools to IF_AI_tools so you only need one or the other]"
},
{
"author": "markuryy",
"title": "Super Loader",
@@ -401,433 +684,6 @@
],
"install_type": "git-clone",
"description": "This package provides a custom node to ComfyUI to send a message and image by means of a webhook"
},
{
"author": "huimengshiguang",
"title": "AspectAwareTiling",
"reference": "https://github.com/huimengshiguang/AspectAwareTiling",
"files": [
"https://raw.githubusercontent.com/huimengshiguang/AspectAwareTiling/refs/heads/main/hmsg-quanjing.py"
],
"install_type": "copy",
"description": "This is an extension script for Stable Diffusion WebUI, modified based on the original functionality. It now supports fixing FLUX panorama seams. It allows users to independently configure seamless image tiling for both the X and Y axes while also being capable of handling FLUX panorama seam issues."
},
{
"author": "Yuan-ManX",
"title": "ComfyUI-PhotoDoodle",
"reference": "https://github.com/Yuan-ManX/ComfyUI-PhotoDoodle",
"files": [
"https://github.com/Yuan-ManX/ComfyUI-PhotoDoodle"
],
"install_type": "git-clone",
"description": "ComfyUI nodes for PhotoDoodle model."
},
{
"author": "JiSenHua",
"title": "ComfyUI-TD",
"id": "touchdesigner",
"reference": "https://github.com/JiSenHua/ComfyUI-TD",
"files": [
"https://github.com/JiSenHua/ComfyUI-TD"
],
"install_type": "git-clone",
"description": "A custom node for ComfyUI designed to facilitate the real-time transmission of rendered images, videos, or 3D models to TouchDesigner."
},
{
"author": "Slickytail",
"title": "ComfyUI-RegionalAdaptiveSampling",
"reference": "https://github.com/Slickytail/ComfyUI-RegionalAdaptiveSampling",
"files": [
"https://github.com/Slickytail/ComfyUI-RegionalAdaptiveSampling"
],
"description": "ComfyUI implementation of Regional Adaptive Sampling, (original implementation at https://github.com/microsoft/RAS).",
"install_type": "git-clone"
},
{
"author": "ShmuelRonen",
"title": "ComfyUI-WanVideoKsampler",
"reference": "https://github.com/ShmuelRonen/ComfyUI-WanVideoKsampler",
"files": [
"https://github.com/ShmuelRonen/ComfyUI-WanVideoKsampler"
],
"install_type": "git-clone",
"description": "An advanced custom node for ComfyUI that provides optimized access to Wan2.1, a state-of-the-art video foundation model suite. The WanVideoKsampler node features intelligent memory management to enable higher resolution outputs and longer video sequences, even on consumer-grade hardware."
},
{
"author": "fluffydiveX",
"title": "ComfyUI-hvBlockswap",
"reference": "https://github.com/fluffydiveX/ComfyUI-hvBlockswap",
"files": [
"https://github.com/fluffydiveX/ComfyUI-hvBlockswap"
],
"install_type": "git-clone",
"description": "It is a simple HunyuanVideo block swap node for ComfyUI native nodes."
},
{
"author": "blepping",
"title": "ComfyUI-ApplyResAdapterUnet",
"reference": "https://github.com/blepping/ComfyUI-ApplyResAdapterUnet",
"files": [
"https://github.com/blepping/ComfyUI-ApplyResAdapterUnet"
],
"install_type": "git-clone",
"description": "ComfyUI node to apply the ResAdapter Unet patch for SD1.5 models"
},
{
"author": "RiceRound",
"title": "RiceRound Cloud Node",
"id": "riceround",
"reference": "https://github.com/RiceRound/ComfyUI_RiceRound",
"files": [
"https://github.com/RiceRound/ComfyUI_RiceRound"
],
"install_type": "git-clone",
"description": "This is an imaginative project that allows for one-click deployment, providing both an online page and a ComfyUI cloud node.[w/This custom node is vulnerable because it can dynamically download and execute nodes.]"
},
{
"author": "Taremin",
"title": "comfyui-prompt-config",
"reference": "https://github.com/Taremin/comfyui-prompt-config",
"files": [
"https://github.com/Taremin/comfyui-prompt-config"
],
"install_type": "git-clone",
"description": "This is a custom node for ComfyUI.\nThe PromptGenerationConfig node allows users to configure settings such as image dimensions, step count, and CFGScale through prompts during image generation.\nThe PromptEdit node enables users to add text from the prompt to the negative prompt (or vice versa) and replace parts of the prompt using regular expressions."
},
{
"author": "InceptionsAI",
"title": "ComfyUI-RunComfy-Helper",
"reference": "https://github.com/InceptionsAI/ComfyUI-RunComfy-Helper",
"files": [
"https://github.com/InceptionsAI/ComfyUI-RunComfy-Helper"
],
"install_type": "git-clone",
"description": "Helper nodes for [a/RunComfy](https://www.runcomfy.com)"
},
{
"author": "zichongc",
"title": "ComfyUI-Attention-Distillation",
"reference": "https://github.com/zichongc/ComfyUI-Attention-Distillation",
"files": [
"https://github.com/zichongc/ComfyUI-Attention-Distillation"
],
"install_type": "git-clone",
"description": "Non-native [a/AttentionDistillation](https://github.com/xugao97/AttentionDistillation) for ComfyUI.\nOfficial ComfyUI demo for the paper AttentionDistillation, implemented as an extension of ComfyUI. Note that this extension incorporates AttentionDistillation using diffusers."
},
{
"author": "maximclouser",
"title": "ComfyUI-InferenceTimeScaling",
"reference": "https://github.com/YRIKKA/ComfyUI-InferenceTimeScaling",
"files": [
"https://github.com/YRIKKA/ComfyUI-InferenceTimeScaling"
],
"install_type": "git-clone",
"description": "Inference-time techniques to enhance diffusion-based image generation quality through random search and zero-order optimization algorithms"
},
{
"author": "smthemex",
"title": "ComfyUI_PhotoDoodle",
"reference": "https://github.com/smthemex/ComfyUI_PhotoDoodle",
"files": [
"https://github.com/smthemex/ComfyUI_PhotoDoodle"
],
"install_type": "git-clone",
"description": "PhotoDoodle: Learning Artistic Image Editing from Few-Shot Pairwise Datayou can use it in comfyUI"
},
{
"author": "duhaifeng",
"title": "ComfyUI-MaskEditor-Extension",
"reference": "https://github.com/rubi-du/ComfyUI-MaskEditor-Extension",
"files": [
"https://github.com/rubi-du/ComfyUI-MaskEditor-Extension"
],
"install_type": "git-clone",
"description": "This repository packages the latest BiRefNet model as a ComfyUI node for use, supporting chunked loading on both CPU and GPU, as well as model caching features."
},
{
"author": "PanicTitan",
"title": "ComfyUI-Fooocus-V2-Expansion",
"reference": "https://github.com/PanicTitan/ComfyUI-Fooocus-V2-Expansion",
"files": [
"https://github.com/PanicTitan/ComfyUI-Fooocus-V2-Expansion"
],
"install_type": "git-clone",
"description": "Adaptation of Fooocus Prompt Expansion for ComfyUI\nForked from [a/ComfyUI-Prompt-Expansion](https://github.com/meap158/ComfyUI-Prompt-Expansion) with some updates and changes based on original Fooocus, to be more specific [a/expansion.py](https://github.com/lllyasviel/Fooocus/blob/main/extras/expansion.py) and [a/LykosAI - GPT-Prompt-Expansion-Fooocus-v2](https://huggingface.co/LykosAI/GPT-Prompt-Expansion-Fooocus-v2)"
},
{
"author": "moose-lab",
"title": "ComfyUI-GPT",
"reference": "https://github.com/moose-lab/ComfyUI-GPT",
"files": [
"https://github.com/moose-lab/ComfyUI-GPT"
],
"install_type": "git-clone",
"description": "Help comfy deisgner develope custom nodes by foreground GUI without any coding knowledge, complementing the workflow what you design with LLM automatically"
},
{
"author": "shinich39",
"title": "comfyui-model-metadata",
"reference": "https://github.com/shinich39/comfyui-model-metadata",
"files": [
"https://github.com/shinich39/comfyui-model-metadata"
],
"install_type": "git-clone",
"description": "Print model metadata on note node"
},
{
"author": "leeguandong",
"title": "ComfyUI nodes to use AttentionMask",
"reference": "https://github.com/leeguandong/ComfyUI_FluxAttentionMask",
"files": [
"https://github.com/leeguandong/ComfyUI_FluxAttentionMask"
],
"install_type": "git-clone",
"description": "The attention mask in the T5 part of flux and SD3 utilizes the text-side attention mask to make the model focus more on text embeddings during image generation, thereby enhancing semantic alignment with the text."
},
{
"author": "marawan206",
"title": "Face Cropper Node (2:3 Ratio)",
"reference": "https://github.com/marawan206/ComfyUI-FaceCropper",
"files": [
"https://github.com/marawan206/ComfyUI-FaceCropper"
],
"install_type": "git-clone",
"description": "The Face Cropper Node (MarwanFaceCropping) is a custom image processing node designed for ComfyUI. It takes an input image and crops it to a 2:3 aspect ratio, ensuring that most of the subject remains in the frame while maintaining the correct proportions."
},
{
"author": "Easymode-ai",
"title": "ComfyUI-BPT",
"reference": "https://github.com/Easymode-ai/ComfyUI-BPT",
"files": [
"https://github.com/Easymode-ai/ComfyUI-BPT"
],
"install_type": "git-clone",
"description": "Comfyui [a/BPT](https://github.com/whaohan/bpt) Wrapper (Trimesh in/out connections)"
},
{
"author": "ShmuelRonen",
"title": "ComfyUI-FreeVC_wrapper",
"reference": "https://github.com/ShmuelRonen/ComfyUI-FreeVC_wrapper",
"files": [
"https://github.com/ShmuelRonen/ComfyUI-FreeVC_wrapper"
],
"install_type": "git-clone",
"description": "A voice conversion extension node for ComfyUI based on [a/FreeVC](https://github.com/OlaWod/FreeVC), enabling high-quality voice conversion capabilities within the ComfyUI framework."
},
{
"author": "fat-tire",
"title": "ComfyUI Unified Media Suite",
"reference": "https://github.com/fat-tire/comfyui-unified-media-suite",
"files": [
"https://github.com/fat-tire/comfyui-unified-media-suite"
],
"install_type": "git-clone",
"description": "Lightweight [a/PyAV](https://pypi.org/project/av/)-powered ComfyUI nodes to load/save multimedia."
},
{
"author": "leeguandong",
"title": "ComfyUI nodes to use FluxClipWeight",
"reference": "https://github.com/leeguandong/ComfyUI_FluxClipWeight",
"files": [
"https://github.com/leeguandong/ComfyUI_FluxClipWeight"
],
"install_type": "git-clone",
"description": "In Flux, the T5 and CLIP in the text branch are weighted separately to regulate the strength of text-side embeddings."
},
{
"author": "SirWillance",
"title": "Force of Will Suite Light",
"id": "fow-suite-light",
"reference": "https://github.com/SirWillance/FoW_Suite_LIGHT",
"files": [
"https://github.com/SirWillance/FoW_Suite_LIGHT"
],
"install_type": "git-clone",
"description": "Beginner-friendly nodes for prompt refinement in ComfyUI, including custom nodes for weighting, splitting, combining, catalogues, and the PromptRefiner for a simple prompt interface. For more info, join me on https://www.twitch.tv/sirwillance. Be one of the first 50 followers to get a FREE upgrade to the Standard Tier!"
},
{
"author": "KAVVATARE",
"title": " ComfyUI-Light-N-Color",
"reference": "https://github.com/KAVVATARE/ComfyUI-Light-N-Color",
"files": [
"https://github.com/KAVVATARE/ComfyUI-Light-N-Color"
],
"install_type": "git-clone",
"description": "ComfyUI node that adds Brightness, RGB channels, and Depth of Field to AI-generated image"
},
{
"author": "ajbergh",
"title": "comfyui-ethnicity_hairstyle_clip_encoder",
"reference": "https://github.com/ajbergh/comfyui-ethnicity_hairstyle_clip_encoder",
"files": [
"https://github.com/ajbergh/comfyui-ethnicity_hairstyle_clip_encoder"
],
"install_type": "git-clone",
"description": "This ComfyUI custom node enhances the standard CLIP text encoding functionality by integrating ethnicity and hairstyle selection into the positive prompt. Designed to work seamlessly with ComfyUI, this node allows you to influence the conditioning process by dynamically appending descriptive modifiers. Users can choose a specific ethnicity or hairstyle, or opt for a 'random' selection that picks an option from a predefined CSV list."
},
{
"author": "RodrigoSKohl",
"title": "Interior Design for Comfyui",
"reference": "https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI",
"files": [
"https://github.com/RodrigoSKohl/InteriorDesign-for-ComfyUI"
],
"install_type": "git-clone",
"description": "This node is based on MykolaL/StableDesign"
},
{
"author": "orange90",
"title": " ComfyUI-Regex-Runner ",
"id": "comfyui-regex-runner",
"reference": "https://github.com/orange90/ComfyUI-Regex-Runner",
"files": [
"https://github.com/orange90/ComfyUI-Regex-Runner"
],
"install_type": "git-clone",
"description": "This is a node to run regex for strings."
},
{
"author": "smthemex",
"title": "ComfyUI_YuE",
"reference": "https://github.com/smthemex/ComfyUI_YuE",
"files": [
"https://github.com/smthemex/ComfyUI_YuE"
],
"install_type": "git-clone",
"description": "[a/YuE](https://github.com/multimodal-art-projection/YuE) is a groundbreaking series of open-source foundation models designed for music generation, specifically for transforming lyrics into full songs (lyrics2song). you can use it in comfyUI"
},
{
"author": "benda1989",
"title": "GKK·Sonic",
"reference": "https://github.com/benda1989/Sonic_ComfyUI",
"files": [
"https://github.com/benda1989/Sonic_ComfyUI"
],
"install_type": "git-clone",
"description": "a plugin of ComfyUI for Long Sonic"
},
{
"author": "ainewsto",
"title": "Comfyui_Comfly",
"reference": "https://github.com/ainewsto/Comfyui_Comfly",
"files": [
"https://github.com/ainewsto/Comfyui_Comfly"
],
"install_type": "git-clone",
"description": "NODES: Comfly_Mj, Comfly_mjstyle, Comfly_upload, Comfly_Mju, Comfly_Mjv, Comfly_kling_videoPreview"
},
{
"author": "svetozarov",
"title": "AS_GeminiCaptioning Node",
"reference": "https://github.com/svetozarov/AS_GeminiCaptioning",
"files": [
"https://github.com/svetozarov/AS_GeminiCaptioning"
],
"install_type": "git-clone",
"description": "A ComfyUI node that combines an image with simple text parameters to create a prompt, sends it to the Google Gemini API via the google-generativeai SDK, and returns the generated text response along with the original prompt and an execution log"
},
{
"author": "Pablerdo",
"title": "ComfyUI-MultiCutAndDrag",
"reference": "https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag",
"files": [
"https://github.com/Pablerdo/ComfyUI-MultiCutAndDrag"
],
"install_type": "git-clone",
"description": "Cut and and drag that allows you to cut and drag multiple images on a path"
},
{
"author": "LAOGOU-666",
"title": "ComfyUI-LG_HotReload",
"id": "ComfyUI-LG_HotReload",
"reference": "https://github.com/LAOGOU-666/ComfyUI-LG_HotReload",
"files": [
"https://github.com/LAOGOU-666/ComfyUI-LG_HotReload"
],
"install_type": "git-clone",
"description": "An extension for ComfyUI that allows hot reloading. Once installed, you can preview changes in real-time while developing custom nodes or installing plugins without restarting ComfyUI."
},
{
"author": "fairy-root",
"title": "ComfyUI-Show-Text",
"reference": "https://github.com/fairy-root/ComfyUI-Show-Text",
"files": [
"https://github.com/fairy-root/ComfyUI-Show-Text"
],
"install_type": "git-clone",
"description": "A simple but powerful node for ComfyUI that displays text input in a readable format. Perfect for viewing outputs from text generation nodes, prompt builders, interrogators, and more."
},
{
"author": "Taremin",
"title": "comfyui-keep-multiple-tabs",
"reference": "https://github.com/Taremin/comfyui-keep-multiple-tabs",
"files": [
"https://github.com/Taremin/comfyui-keep-multiple-tabs"
],
"install_type": "git-clone",
"description": "This is an extension for ComfyUI. It retains multiple workflow tabs so that they are not lost when reloading or restarting."
},
{
"author": "Shiba-2-shiba",
"title": "ComfyUI_FreeU_V2_timestepadd",
"id": "ComfyUI_FreeU_V2_timestepadd",
"reference": "https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd",
"files": [
"https://github.com/Shiba-2-shiba/ComfyUI_FreeU_V2_timestepadd"
],
"install_type": "git-clone",
"description": "This is a custom node to add timestep for FreeU V2."
},
{
"author": "MeeeyoAI",
"title": "ComfyUI_StringOps",
"reference": "https://github.com/MeeeyoAI/ComfyUI_StringOps",
"files": [
"https://github.com/MeeeyoAI/ComfyUI_StringOps"
],
"install_type": "git-clone",
"description": "StringOps is a versatile text processing toolkit built for ComfyUI's node-based workflows"
},
{
"author": "crave33",
"title": "RenesStuffDanboruTagGet",
"reference": "https://github.com/crave33/RenesStuffDanboruTagGet",
"files": [
"https://github.com/crave33/RenesStuffDanboruTagGet"
],
"install_type": "git-clone",
"description": "generate tags / prompt from danboru image_id input"
},
{
"author": "smthemex",
"title": "ComfyUI_Light_A_Video",
"reference": "https://github.com/smthemex/ComfyUI_Light_A_Video",
"files": [
"https://github.com/smthemex/ComfyUI_Light_A_Video"
],
"install_type": "git-clone",
"description": "Light-A-Video: Training-free Video Relighting via Progressive Light Fusion,you can use it in comfyUI"
},
{
"author": "Easymode-ai",
"title": "ComfyUI-ShadowR",
"reference": "https://github.com/Easymode-ai/ComfyUI-ShadowR",
"files": [
"https://github.com/Easymode-ai/ComfyUI-ShadowR"
],
"install_type": "git-clone",
"description": "ComfyUI [a/movingforward100/Shadow_R](https://github.com/movingforward100/Shadow_R) Wrapper"
},
{
"author": "chenlongming",
"title": "ComfyUI_Spectral",
"reference": "https://github.com/chenlongming/ComfyUI_Spectral",
"files": [
"https://github.com/chenlongming/ComfyUI_Spectral"
],
"install_type": "git-clone",
"description": "ComfyUI Spectral is a ComfyUI custom nodes library based on the spectral, mainly used for visual processing of spectral files"
}
]
}

View File

@@ -77,7 +77,12 @@
],
"https://github.com/1038lab/ComfyUI-RMBG": [
[
"BiRefNet",
"AiLab_ImagePreview",
"AiLab_LoadImage",
"AiLab_MaskPreview",
"AiLab_Preview",
"BiRefNetRMBG",
"BodySegment",
"ClothesSegment",
"FaceSegment",
"FashionSegmentAccessories",
@@ -222,6 +227,7 @@
[
"Character2Video",
"Image2Video",
"StartEnd2Video",
"Text2Video",
"UpscaleVideo",
"VideoDownloader"
@@ -451,7 +457,6 @@
"PrimitiveNode",
"Random_Select_Prompt",
"Run_BEN_v2",
"Run_Similarity",
"Run_torchvision_model",
"Sam2AutoSegmentation_data",
"Save_Image_Out",
@@ -466,23 +471,20 @@
"Video_OverlappingSeparation_test",
"WAS_Mask_Fill_Region_batch",
"adv_crop",
"any_data",
"any_math",
"any_math_v2",
"array_count",
"bbox_restore_mask",
"color_segmentation",
"color_segmentation_v2",
"coords_select_mask",
"filter_DensePose_color",
"get_image_data",
"image_ValueMath",
"image_math",
"image_math_value",
"invert_channel_adv",
"load_BEN_model",
"load_ColorName_config",
"load_EasyOCR_model",
"load_Similarity",
"load_color_config",
"load_model_value",
"load_torchvision_model",
@@ -1413,8 +1415,11 @@
"Faishme Mannequin to Model Loader",
"Faishme Memory Debug",
"Faishme Moondream",
"Faishme Repeat BBOX",
"Faishme Repeat Image Batch",
"Faishme Repeat Latent Batch",
"Faishme Repeat Tensor Batch",
"Faishme Save Image",
"Faishme Stack Images",
"Faishme Stack Latents",
"Faishme Unstack Images",
@@ -1704,6 +1709,7 @@
"HTBaseShiftNode",
"HTConsoleLoggerNode",
"HTConversionNode",
"HTDetectionBatchProcessor",
"HTDiffusionLoaderMulti",
"HTDimensionAnalyzerNode",
"HTDimensionFormatterNode",
@@ -1718,7 +1724,6 @@
"HTNodeStateController",
"HTNodeUnmuteAll",
"HTNullNode",
"HTOIDNNode",
"HTParameterExtractorNode",
"HTPhotoshopBlurNode",
"HTRegexNode",
@@ -2311,6 +2316,7 @@
"ShotByImageNode",
"ShotByTextNode",
"TailoredModelInfoNode",
"TailoredPortraitNode",
"Text2ImageBaseNode",
"Text2ImageFastNode",
"Text2ImageHDNode"
@@ -2536,7 +2542,8 @@
[
"Directory File Counter",
"Simple Number Counter",
"Text File Line Counter"
"Text File Line Counter",
"Text File Line Reader"
],
{
"title_aux": "ComfyUI-Line-counter"
@@ -2554,6 +2561,8 @@
"Conditioning Recast FP64",
"ConditioningAdd",
"ConditioningAverageScheduler",
"ConditioningBatch4",
"ConditioningBatch8",
"ConditioningMultiply",
"ConditioningOrthoCollin",
"ConditioningToBase64",
@@ -2857,11 +2866,14 @@
"https://github.com/Cyber-BCat/ComfyUI_Auto_Caption": [
[
"Auto Caption",
"Auto_Caption2",
"ExtraOptionsSet",
"Joy Model load",
"Joy_Model2_load",
"LoadManyImages"
],
{
"title_aux": "ComfyUI_Auto_Caption"
"title_aux": "Cyber-BlackCat"
}
],
"https://github.com/Cyber-Blacat/ComfyUI-Yuan": [
@@ -3127,6 +3139,17 @@
"title_aux": "Comfyui SDAPI Request / NovelAI"
}
],
"https://github.com/Diohim/ComfyUI-Unusual-Tools": [
[
"AdjustCrop",
"AutoImageResize",
"BatchLoadLatentImage",
"BatchSaveLatentImage"
],
{
"title_aux": "ComfyUI Unusual Tools"
}
],
"https://github.com/Dobidop/ComfyStereo": [
[
"DeoVRViewNode",
@@ -3225,6 +3248,14 @@
"title_aux": "Boyonodes"
}
],
"https://github.com/Duanyll/duanyll_nodepack": [
[
"PhotoDoddleConditioning"
],
{
"title_aux": "Duanyll Nodepack"
}
],
"https://github.com/Eagle-CN/ComfyUI-Addoor": [
[
"AD_AnyFileList",
@@ -4177,7 +4208,10 @@
],
"https://github.com/GeekyGhost/ComfyUI-GeekyRemB": [
[
"GeekyRemB"
"GeekyRemB",
"GeekyRemB_Animator",
"GeekyRemB_KeyframePosition",
"GeekyRemB_LightShadow"
],
{
"title_aux": "ComfyUI-GeekyRemB"
@@ -4261,6 +4295,7 @@
"GR Image Resize Methods",
"GR Image Size",
"GR Image/Depth Mask",
"GR Lora Randomizer",
"GR Mask",
"GR Mask Create",
"GR Mask Create Random",
@@ -4430,6 +4465,14 @@
"title_aux": "Recognize Anything Model (RAM) for ComfyUI"
}
],
"https://github.com/HannibalP/comfyui-HannibalPack": [
[
"HannibalLoraLoader"
],
{
"title_aux": "comfyui-HannibalPack"
}
],
"https://github.com/Haoming02/comfyui-diffusion-cg": [
[
"Normalization",
@@ -4546,6 +4589,23 @@
"title_aux": "Hiero-Nodes"
}
],
"https://github.com/Holasyb918/Ghost2_Comfyui": [
[
"AlignPipeline",
"BlenderPipeline",
"FaceAnalysisePipeline",
"FaceParsingPipeline",
"LoadAlignerModel",
"LoadBlenderModel",
"LoadFaceAnalysisModel",
"LoadFaceParsingModel",
"LoadInpainterModel",
"LoadStyleMatteModel"
],
{
"title_aux": "Ghost2_Comfyui"
}
],
"https://github.com/Hopping-Mad-Games/ComfyUI_LiteLLM": [
[
"AgentMemoryProvider",
@@ -5159,6 +5219,7 @@
"ImagetoTD",
"LoadTDImage",
"Tripo3DtoTD",
"TripoSRtoTD",
"VideotoTD"
],
{
@@ -5689,6 +5750,15 @@
"title_aux": "ComfyUI_KytraWebhookHTTP"
}
],
"https://github.com/KytraScript/ComfyUI_MatAnyone_Kytra": [
[
"Kytra_Images_To_RGB",
"MatAnyoneVideoMatting"
],
{
"title_aux": "ComfyUI_MatAnyone_Kytra"
}
],
"https://github.com/LAOGOU-666/ComfyUI_LG_FFT": [
[
"LG_FFTNode",
@@ -6858,6 +6928,7 @@
"WinampViz",
"WinampVizV2",
"ZenkaiImagePromptV1",
"ZenkaiImagePromptV2",
"ZenkaiPoseMap",
"ZenkaiPrompt",
"ZenkaiPromptV2",
@@ -7063,6 +7134,16 @@
"title_aux": "ComfyUI_TravelSuite"
}
],
"https://github.com/Nikosis/ComfyUI-Nikosis-Nodes": [
[
"AspectRatioNikosis",
"PromptMultipleStylesSelectorNikosis",
"TextConcatenateNikosis"
],
{
"title_aux": "ComfyUI-Nikosis-Nodes"
}
],
"https://github.com/NimaNzrii/comfyui-photoshop": [
[
"\ud83d\udd39 Photoshop RemoteConnection",
@@ -7376,14 +7457,6 @@
"title_aux": "ComfyUI-Fooocus-V2-Expansion"
}
],
"https://github.com/PanicTitan/ComfyUI-Gallery": [
[
"GalleryNode"
],
{
"title_aux": "ComfyUI-Gallery"
}
],
"https://github.com/Parameshvadivel/ComfyUI-SVGview": [
[
"SVGPreview"
@@ -7918,6 +7991,17 @@
"title_aux": "ComfyUI-Prompts-Selector"
}
],
"https://github.com/S4MUEL-404/ComfyUI-S4Tool-Image-Overlay": [
[
"ImageBlendWithAlpha",
"ImageColor",
"ImageOverlay",
"ImageSelector"
],
{
"title_aux": "ComfyUI-S4Tool-Image-Overlay"
}
],
"https://github.com/S4MUEL-404/ComfyUI-Text-On-Image": [
[
"TextOnImage"
@@ -8000,6 +8084,14 @@
"title_aux": "ComfyUI-LexTools"
}
],
"https://github.com/SS-snap/ComfyUI-Ad_scheduler": [
[
"AD_Scheduler"
],
{
"title_aux": "ComfyUI-Ad_scheduler"
}
],
"https://github.com/SS-snap/ComfyUI-LBW_flux": [
[
"LoraBlockWeight_Flux"
@@ -8562,6 +8654,14 @@
"title_aux": "ComfyUI-FreeMemory"
}
],
"https://github.com/ShmuelRonen/ComfyUI-FreeVC_wrapper": [
[
"FreeVC Voice Conversion"
],
{
"title_aux": "ComfyUI-FreeVC_wrapper"
}
],
"https://github.com/ShmuelRonen/ComfyUI-Gemini_Flash_2.0_Exp": [
[
"AudioRecorder",
@@ -9110,6 +9210,7 @@
"Star Face Loader",
"Star3LoRAs",
"StarDivisibleDimension",
"StarEasyTextStorage",
"StarFiveWildcards",
"StarImageSwitch",
"StarLatentSwitch",
@@ -10188,6 +10289,14 @@
"title_aux": "VEnhancer ComfyUI Extension"
}
],
"https://github.com/Visionatrix/ComfyUI-RemoteVAE": [
[
"RemoteVAEDecode"
],
{
"title_aux": "ComfyUI-RemoteVAE"
}
],
"https://github.com/Visionatrix/ComfyUI-Visionatrix": [
[
"StyleAlignedBatchAlign",
@@ -10905,6 +11014,14 @@
"title_aux": "ComfyUI-SoundHub"
}
],
"https://github.com/Yuan-ManX/ComfyUI-StyleStudio": [
[
"StyleStudio Image Stylization"
],
{
"title_aux": "ComfyUI-StyleStudio"
}
],
"https://github.com/ZHO-ZHO-ZHO/ComfyUI-APISR": [
[
"APISR_Lterative_Zho",
@@ -12076,6 +12193,8 @@
"Sage_GetFileHash",
"Sage_JoinText",
"Sage_KSampler",
"Sage_KSamplerDecoder",
"Sage_KSamplerTiledDecoder",
"Sage_LastLoraInfo",
"Sage_LoadImage",
"Sage_LogicalSwitch",
@@ -12091,6 +12210,7 @@
"Sage_SetFloat",
"Sage_SetInteger",
"Sage_SetText",
"Sage_TilingInfo",
"Sage_TripleJoinText",
"Sage_TripleLoraStack",
"Sage_UNETLoader",
@@ -12153,6 +12273,7 @@
"PCLazyTextEncode",
"PCLazyTextEncodeAdvanced",
"PCLoraHooksFromText",
"PCSaveExpandedWorkflow",
"PCSetLogLevel",
"PCSetPCTextEncodeSettings",
"PCTextEncode",
@@ -12677,6 +12798,16 @@
"title_aux": "ComfyUI_TextAssets"
}
],
"https://github.com/billwuhao/ComfyUI_DiffRhythm": [
[
"AudioRecorderDR",
"DiffRhythmRun",
"MultiLinePrompt"
],
{
"title_aux": "ComfyUI_DiffRhythm"
}
],
"https://github.com/billwuhao/ComfyUI_KokoroTTS_MW": [
[
"Kokoro Run",
@@ -12686,6 +12817,14 @@
"title_aux": "ComfyUI_KokoroTTS_MW"
}
],
"https://github.com/billwuhao/ComfyUI_NotaGen": [
[
"NotaGenRun"
],
{
"title_aux": "ComfyUI_NotaGen"
}
],
"https://github.com/billwuhao/ComfyUI_OneButtonPrompt_Flux": [
[
"DeepseekRun",
@@ -13325,6 +13464,60 @@
"title_aux": "ComfyUI-TostAI"
}
],
"https://github.com/cardenluo/ComfyUI-Apt_Preset": [
[
"CN_preset1",
"Data_chx_Merge",
"Data_chx_MergeBig",
"Data_fullData",
"Data_presetData",
"Data_preset_save",
"Data_sample",
"Data_select",
"Date_basic",
"Date_basic_easy",
"Model_Preset",
"Unpack_CN",
"Unpack_Model",
"Unpack_param",
"Unpack_photoshop",
"basic_Ksampler_custom",
"basic_Ksampler_full",
"basic_Ksampler_mid",
"basic_Ksampler_simple",
"chx_Ksampler_adv",
"chx_Ksampler_inpaint",
"chx_Ksampler_mix",
"chx_Ksampler_refine",
"chx_Ksampler_texture",
"chx_StyleModelApply",
"chx_Style_Redux",
"chx_Upscale_simple",
"chx_YC_LG_Redux",
"chx_controlnet",
"chx_controlnet_union",
"chx_easy_text",
"chx_ksampler_Deforum",
"chx_ksampler_tile",
"chx_mask_Mulcondi",
"chx_re_fluxguide",
"load_FLUX",
"load_SD35",
"load_basic",
"param_preset",
"photoshop_preset",
"pre_make_context",
"pre_sample_data",
"sum_controlnet",
"sum_editor",
"sum_latent",
"sum_load",
"sum_lora"
],
{
"title_aux": "ComfyUI-Apt_Preset"
}
],
"https://github.com/catboxanon/comfyui_stealth_pnginfo": [
[
"CatboxAnonSaveImageStealth"
@@ -13956,7 +14149,11 @@
"https://github.com/chenpipi0807/PIP_ArtisticWords": [
[
"PIP Artistic Text Generator",
"PIP Text Preview"
"PIP ArtisticWords Fusion",
"PIP ColorPicker",
"PIP SVG Recorder",
"PIP Text Preview",
"PIPColorPicker"
],
{
"title_aux": "PIP Artistic Words for ComfyUI"
@@ -16308,14 +16505,17 @@
"Eden_Bool",
"Eden_BoolBinaryOperation",
"Eden_Compare",
"Eden_DebugPrint",
"Eden_Debug_Anything",
"Eden_DepthSlice_MaskVideo",
"Eden_DetermineFrameCount",
"Eden_FaceToMask",
"Eden_Face_Crop",
"Eden_Float",
"Eden_FloatToInt",
"Eden_GPTPromptEnhancer",
"Eden_IMG_padder",
"Eden_IMG_unpadder",
"Eden_ImageMaskComposite",
"Eden_Image_Math",
"Eden_Int",
"Eden_IntToFloat",
@@ -16323,12 +16523,14 @@
"Eden_MaskCombiner",
"Eden_Math",
"Eden_RandomPromptFromFile",
"Eden_Regex_Replace",
"Eden_RepeatLatentBatch",
"Eden_Seed",
"Eden_String",
"Eden_StringHash",
"Eden_StringReplace",
"Eden_gpt4_node",
"Eden_randbool",
"Extend_Sequence",
"FolderScanner",
"GetRandomFile",
@@ -16800,6 +17002,7 @@
"FL_Dither",
"FL_FractalKSampler",
"FL_GPT_Vision",
"FL_GeminiVideoCaptioner",
"FL_Glitch",
"FL_GoogleDriveDownloader",
"FL_GoogleDriveImageDownloader",
@@ -16862,6 +17065,7 @@
"FL_SaveCSV",
"FL_SaveImages",
"FL_SaveWebPImage(SaveImage)",
"FL_SceneCut",
"FL_SchedulerStrings",
"FL_SendToDiscordWebhook",
"FL_SeparateMaskComponents",
@@ -16871,6 +17075,7 @@
"FL_TetrisGame",
"FL_TimeLine",
"FL_UpscaleModel",
"FL_VideoCaptionSaver",
"FL_VideoCropMask",
"FL_VideoRecompose",
"FL_ZipDirectory",
@@ -18518,6 +18723,14 @@
"title_aux": "Comfy-UI on-complete-email-me"
}
],
"https://github.com/iDAPPA/ComfyUI-AMDGPUMonitor": [
[
"AMDGPUMonitor"
],
{
"title_aux": "AMD GPU Monitor for ComfyUI"
}
],
"https://github.com/iFREEGROUP/comfyui-undistort": [
[
"IG_LoadCheckerboardImageForCalibrateCamera",
@@ -18630,28 +18843,6 @@
"title_aux": "IF_DatasetMkr"
}
],
"https://github.com/if-ai/ComfyUI-IF_LLM": [
[
"IF_DisplayText",
"IF_JoinText",
"IF_LLM",
"IF_LLM_DisplayOmni",
"IF_LLM_DisplayText",
"IF_LLM_DisplayTextWildcard",
"IF_LLM_JoinText",
"IF_LLM_ListModels",
"IF_LLM_LoadImagesS",
"IF_LLM_SaveText",
"IF_LLM_TextTyper",
"IF_LoadImagesS",
"IF_TextTyper",
"IF_saveText",
"ListModelsNode"
],
{
"title_aux": "IF_LLM"
}
],
"https://github.com/if-ai/ComfyUI-IF_MemoAvatar": [
[
"IF_MemoAvatar",
@@ -18670,14 +18861,6 @@
"title_aux": "ComfyUI-IF_Trellis"
}
],
"https://github.com/if-ai/ComfyUI-IF_VideoPrompts": [
[
"VideoPromptNode"
],
{
"title_aux": "IF_VideoPrompts"
}
],
"https://github.com/ifmylove2011/comfyui-missing-tool": [
[
"ImageQueueLoader",
@@ -18834,6 +19017,18 @@
"title_aux": "ComfyUI Neural Network Toolkit NNT "
}
],
"https://github.com/irreveloper/ComfyUI-DSD": [
[
"DSDGeminiPromptEnhancer",
"DSDImageGenerator",
"DSDModelDownloader",
"DSDModelLoader",
"DSDModelSelector"
],
{
"title_aux": "ComfyUI-DSD"
}
],
"https://github.com/iwanders/ComfyUI_nodes": [
[
"IW_JsonPickItem",
@@ -19098,6 +19293,7 @@
"Evaluate Floats JK",
"Evaluate Ints JK",
"Evaluate Strings JK",
"Get OrbitPoses From List JK",
"Get Size JK",
"Guidance Default JK",
"HintImageEnchance JK",
@@ -19375,6 +19571,7 @@
"LoadLoraFromHF",
"LoadLoraFromHFWithToken",
"LoadWanVideoLoraFromCivitAI",
"LoadWanVideoLoraFromComfyOnline",
"SaveAudioAsWav",
"SaveText"
],
@@ -19698,6 +19895,14 @@
"title_aux": "ComfyUI Deepface"
}
],
"https://github.com/joreyaesh/comfyui_scroll_over_textarea": [
[
"ScrollOverTextareaDummyNode"
],
{
"title_aux": "ComfyUI Scroll Over Textarea"
}
],
"https://github.com/jroc22/ComfyUI-CSV-prompt-builder": [
[
"BuildPromptFromCSV"
@@ -20502,6 +20707,7 @@
"HyVideoSTG",
"HyVideoSampler",
"HyVideoTeaCache",
"HyVideoTextEmbedBridge",
"HyVideoTextEmbedsLoad",
"HyVideoTextEmbedsSave",
"HyVideoTextEncode",
@@ -20599,6 +20805,7 @@
"GradientToFloat",
"GrowMaskWithBlur",
"HunyuanVideoBlockLoraSelect",
"HunyuanVideoEncodeKeyframesToCond",
"INTConstant",
"ImageAddMulti",
"ImageAndMaskPreview",
@@ -20680,6 +20887,7 @@
"StableZero123_BatchSchedule",
"StringConstant",
"StringConstantMultiline",
"StringToFloatList",
"StyleModelApplyAdvanced",
"Superprompt",
"TimerNodeKJ",
@@ -20694,6 +20902,7 @@
"TransitionImagesMulti",
"VAELoaderKJ",
"VRAM_Debug",
"WanVideoEnhanceAVideoKJ",
"WanVideoTeaCacheKJ",
"WebcamCaptureCV2",
"WeightScheduleConvert",
@@ -20975,6 +21184,7 @@
"Custom_Save_Image",
"Display_Any",
"Image_Size_Extractor",
"Load_Image_Folder",
"Mask_Blur_Plus",
"Preview_Mask",
"Preview_Mask_Plus",
@@ -21155,15 +21365,6 @@
"title_aux": "WatermarkRemoval"
}
],
"https://github.com/l1yongch1/ComfyUI_PhiCaption": [
[
"PhiInfer",
"PhiModelLoder"
],
{
"title_aux": "ComfyUI_PhiCaption"
}
],
"https://github.com/l20richo/ComfyUI-Azure-Blob-Storage": [
[
"DownloadFileBLOB",
@@ -21291,6 +21492,25 @@
"title_aux": "Google Photos Loader - by PabloGFX"
}
],
"https://github.com/leeguandong/ComfyUI_1Prompt1Story": [
[
"GenerateStoryImage",
"PromptStoryModelLoader"
],
{
"title_aux": "ComfyUI_1Prompt1Story"
}
],
"https://github.com/leeguandong/ComfyUI_ChatGen": [
[
"ChatGenGenerate",
"ChatGenImageProcessor",
"ChatGenModelLoader"
],
{
"title_aux": "ComfyUI_ChatGen"
}
],
"https://github.com/leeguandong/ComfyUI_Cogview4": [
[
"CogView4ImageGenerator",
@@ -21439,6 +21659,7 @@
[
"AddPaddingToImage",
"ForLoopNode",
"ImageAndTextDescriptionBySeed",
"ImageMetadataExtractor",
"InputNode",
"MetadataExtractBySeed",
@@ -22811,6 +23032,9 @@
],
"https://github.com/mang01010/MangoNodePack": [
[
"CompositeMangoLoader",
"FluxGuidanceMango",
"FluxSamplerMango",
"ImageSaverMango",
"KSamplerMango",
"LatentImageMango",
@@ -22925,6 +23149,14 @@
"title_aux": "ComfyUI Flux Prompt Saver"
}
],
"https://github.com/markuryy/ComfyUI-Simple-Video-XY-Plot": [
[
"VideoXYPlotSampler"
],
{
"title_aux": "Video XY Plot"
}
],
"https://github.com/markuryy/ComfyUI-SuperLoader": [
[
"Display String",
@@ -23268,7 +23500,8 @@
],
"https://github.com/metal3d/ComfyUI_M3D_photo_effects": [
[
"Bleach Bypass"
"Bleach Bypass",
"RGB Curve"
],
{
"title_aux": "M3D photo effects"
@@ -23493,6 +23726,17 @@
"title_aux": "MLTask_ComfyUI"
}
],
"https://github.com/mit-han-lab/ComfyUI-nunchaku": [
[
"SVDQuantDepthPreprocessor",
"SVDQuantFluxDiTLoader",
"SVDQuantFluxLoraLoader",
"SVDQuantTextEncoderLoader"
],
{
"title_aux": "ComfyUI-nunchaku"
}
],
"https://github.com/mittimi/ComfyUI_mittimiLoadPreset2": [
[
"CombineParamDataMittimi",
@@ -24461,6 +24705,14 @@
"title_aux": " ComfyUI-Regex-Runner"
}
],
"https://github.com/orssorbit/ComfyUI-wanBlockswap": [
[
"wanBlockSwap"
],
{
"title_aux": "ComfyUI-wanBlockswap"
}
],
"https://github.com/osi1880vr/prompt_quill_comfyui": [
[
"PromptQuillGenerate",
@@ -24651,6 +24903,14 @@
"title_aux": "ComfyUI-LyraVSIH"
}
],
"https://github.com/penposs/ComfyUI_Gemini_Pro": [
[
"Gemini Pro"
],
{
"title_aux": "ComfyUI Gemini Pro Node"
}
],
"https://github.com/pharmapsychotic/comfy-cliption": [
[
"CLIPtionBeamSearch",
@@ -25490,6 +25750,14 @@
"title_aux": "ComfyUIFlexiLoRALoader"
}
],
"https://github.com/roundyyy/ComfyUI-mesh-simplifier": [
[
"MeshSimplifierNode"
],
{
"title_aux": "Mesh Simplifier for ComfyUI"
}
],
"https://github.com/royceschultz/ComfyUI-Notifications": [
[
"Notif-PlaySound",
@@ -26211,14 +26479,17 @@
"ApplyMBCacheAndSkipBlocks",
"ApplyMBCacheAndSkipBlocksForSana",
"ApplySageAttention",
"ApplySpargeAttn",
"ApplyTeaCacheAndSkipBlocks",
"ApplyToCa",
"ApplyTokenMerging",
"CompileAndQuantizeModel",
"SanaCLIPLoader",
"SanaDiffusionLoader",
"SanaEmptyLatentImage",
"SanaTextEncode",
"SanaVAELoader"
"SanaVAELoader",
"SaveSpargeAttnHyperparams"
],
{
"title_aux": "ComfyUI-Lightning"
@@ -26723,6 +26994,16 @@
"title_aux": "ComfyUI_InstantIR_Wrapper"
}
],
"https://github.com/smthemex/ComfyUI_KV_Edit": [
[
"KV_Edit_Load",
"KV_Edit_PreData",
"KV_Edit_Sampler"
],
{
"title_aux": "ComfyUI_KV_Edit"
}
],
"https://github.com/smthemex/ComfyUI_Light_A_Video": [
[
"Light_A_Video_Loader",
@@ -27369,7 +27650,8 @@
"TagRemover",
"TagReplace",
"TagSelector",
"TagSwitcher"
"TagSwitcher",
"TagWildcardFilter"
],
{
"title_aux": "comfyui_tag_filter"
@@ -27847,7 +28129,8 @@
"Load Random Text From File",
"LoadWebcamImage",
"Remove noise",
"SaveImagetoPath"
"SaveImagetoPath",
"VisualAreaMask"
],
{
"title_aux": "ComfyUI_toyxyz_test_nodes"
@@ -28142,6 +28425,15 @@
"title_aux": "unwdef-nodes"
}
],
"https://github.com/vadimcro/VKRiez-Edge": [
[
"VKriezEnhancedEdgePreprocessor",
"VKriezHybridEdgePreprocessor"
],
{
"title_aux": "VKriez Edge Preprocessors for ComfyUI"
}
],
"https://github.com/vahlok-alunmid/ComfyUI-ExtendIPAdapterClipVision": [
[
"EXTEND_CLIP_VISION_INPUT_SIZE",
@@ -28465,9 +28757,8 @@
"https://github.com/welltop-cn/ComfyUI-TeaCache": [
[
"CompileModel",
"TeaCacheForCogVideoX",
"TeaCacheForImgGen",
"TeaCacheForVidGen"
"TeaCache",
"TeaCacheForCogVideoX"
],
{
"title_aux": "ComfyUI-TeaCache"
@@ -28858,6 +29149,15 @@
"title_aux": "hd-nodes-comfyui"
}
],
"https://github.com/xingBaGan/ComfyUI-connect-ui": [
[
"SaveImageByWebsocket",
"reciveImageByWebsocket"
],
{
"title_aux": "ComfyUI-connect-ui"
}
],
"https://github.com/xlinx/ComfyUI-decadetw-auto-messaging-realtime": [
[
"Auto-MSG-ALL",
@@ -29981,13 +30281,13 @@
],
"https://github.com/zmwv823/ComfyUI_Anytext": [
[
"UL_AnyText2Fonts",
"UL_AnyTextComposer",
"UL_AnyTextEncoder",
"UL_AnyTextFontImg",
"UL_AnyTextFormatter",
"UL_AnyTextLoaderTest",
"UL_AnyText_Composer",
"UL_AnyText_FontImg",
"UL_AnyText_Loader",
"UL_AnyText_Sampler",
"UL_AnyTextLoader",
"UL_AnyTextSampler",
"UL_DiffusersCheckpointLoader",
"UL_DiffusersControlNetApplyAdvanced",
"UL_DiffusersControlNetLoader",
@@ -29999,7 +30299,8 @@
"UL_Image_Generation_JoyType_Render_List",
"UL_Image_Process_Common_Cv2_Canny",
"UL_Translator",
"UL_TranslatorLoader"
"UL_TranslatorLoader",
"U_LoRAS"
],
{
"title_aux": "ComfyUI_Anytext"

View File

@@ -21,6 +21,8 @@ import cm_global
import manager_downloader
import folder_paths
manager_util.add_python_path_to_env()
import datetime
if hasattr(datetime, 'datetime'):
from datetime import datetime
@@ -35,8 +37,6 @@ else:
security_check.security_check()
manager_util.add_python_path_to_env()
cm_global.pip_blacklist = {'torch', 'torchsde', 'torchvision'}
cm_global.pip_downgrade_blacklist = ['torch', 'torchsde', 'torchvision', 'transformers', 'safetensors', 'kornia']

View File

@@ -1,7 +1,7 @@
[project]
name = "comfyui-manager"
description = "ComfyUI-Manager provides features to install and manage custom nodes for ComfyUI, as well as various functionalities to assist with ComfyUI."
version = "3.30.4"
version = "3.31"
license = { file = "LICENSE.txt" }
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]