Compare commits

..

14 Commits

Author SHA1 Message Date
Dr.Lt.Data
5393653ddc improved: restore_snapshot - better log message
fixed: restore_snapshot - failing channel validation

https://github.com/ltdrdata/ComfyUI-Manager/issues/1659

https://github.com/ltdrdata/ComfyUI-Manager/issues/1664
2025-03-15 20:36:50 +09:00
Dr.Lt.Data
1f3274d3f5 fixed: Removed -> str | None typing.
- Python versions below 3.10 do not support it.

https://github.com/ltdrdata/ComfyUI-Manager/issues/1663
2025-03-15 20:14:08 +09:00
Dr.Lt.Data
39eaa76b8a fixed: remove migration code completely
https://github.com/ltdrdata/ComfyUI-Manager/issues/1659
2025-03-14 18:24:30 +09:00
Dr.Lt.Data
e5396713ce fixed: gitclone_install - add mode 2025-03-14 12:59:06 +09:00
Dr.Lt.Data
79943de808 fixed: install via git url - failed to install if the git url is exists in the default channel
https://github.com/ltdrdata/ComfyUI-Manager/issues/1651#issuecomment-2720408569
2025-03-14 12:53:59 +09:00
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
23 changed files with 4294 additions and 2110 deletions

View File

@@ -314,9 +314,6 @@ The following settings are applied based on the section marked as `is_default`.
* Use `aria2` as downloader
* [howto](docs/en/use_aria2.md)
* If you add the item `skip_migration_check = True` to `config.ini`, it will not check whether there are nodes that can be migrated at startup.
* This option can be used if performance issues occur in a Colab+GDrive environment.
## Environment Variables

View File

@@ -1271,20 +1271,6 @@ def export_custom_node_ids(
print(f"{x['id']}@unknown", file=output_file)
@app.command(
"migrate",
help="Migrate legacy node system to new node system",
)
def migrate(
user_directory: str = typer.Option(
None,
help="user directory"
)
):
cmd_ctx.set_user_directory(user_directory)
asyncio.run(unified_manager.migrate_unmanaged_nodes())
if __name__ == '__main__':
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
sys.exit(app())

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",
@@ -19750,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 ",
@@ -21319,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",
@@ -21667,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",
@@ -21932,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",
@@ -21994,6 +22064,198 @@
"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

@@ -43,7 +43,7 @@ import manager_downloader
from node_package import InstalledNodePackage
version_code = [3, 30, 7]
version_code = [3, 31, 4]
version_str = f"V{version_code[0]}.{version_code[1]}" + (f'.{version_code[2]}' if len(version_code) > 2 else '')
@@ -768,6 +768,9 @@ class UnifiedManager:
@staticmethod
async def load_nightly(channel, mode):
if channel is None:
return {}
res = {}
channel_url = normalize_channel(channel)
@@ -798,9 +801,6 @@ class UnifiedManager:
return res
async def get_custom_nodes(self, channel, mode):
# default_channel = normalize_channel('default')
# cache = self.custom_node_map_cache.get((default_channel, mode)) # CNR/nightly should always be based on the default channel.
channel = normalize_channel(channel)
cache = self.custom_node_map_cache.get((channel, mode)) # CNR/nightly should always be based on the default channel.
@@ -808,7 +808,6 @@ class UnifiedManager:
return cache
channel = normalize_channel(channel)
print(f"nightly_channel: {channel}/{mode}")
nodes = await self.load_nightly(channel, mode)
res = {}
@@ -889,14 +888,6 @@ class UnifiedManager:
return True
def reserve_migration(self, moves):
script_path = os.path.join(manager_startup_script_path, "install-scripts.txt")
with open(script_path, "a") as file:
obj = ["", "#LAZY-MIGRATION", moves]
file.write(f"{obj}\n")
return True
def unified_fix(self, node_id, version_spec, instant_execution=False, no_deps=False):
"""
fix dependencies
@@ -1630,7 +1621,6 @@ def write_config():
'model_download_by_agent': get_config()['model_download_by_agent'],
'downgrade_blacklist': get_config()['downgrade_blacklist'],
'security_level': get_config()['security_level'],
'skip_migration_check': get_config()['skip_migration_check'],
'always_lazy_install': get_config()['always_lazy_install'],
'network_mode': get_config()['network_mode'],
'db_mode': get_config()['db_mode'],
@@ -1669,7 +1659,6 @@ def read_config():
'windows_selector_event_loop_policy': get_bool('windows_selector_event_loop_policy', False),
'model_download_by_agent': get_bool('model_download_by_agent', False),
'downgrade_blacklist': default_conf.get('downgrade_blacklist', '').lower(),
'skip_migration_check': get_bool('skip_migration_check', False),
'always_lazy_install': get_bool('always_lazy_install', False),
'network_mode': default_conf.get('network_mode', 'public').lower(),
'security_level': default_conf.get('security_level', 'normal').lower(),
@@ -1693,7 +1682,6 @@ def read_config():
'windows_selector_event_loop_policy': False,
'model_download_by_agent': False,
'downgrade_blacklist': '',
'skip_migration_check': False,
'always_lazy_install': False,
'network_mode': 'public', # public | private | offline
'security_level': 'normal', # strong | normal | normal- | weak
@@ -2098,7 +2086,7 @@ async def gitclone_install(url, instant_execution=False, msg_prefix='', no_deps=
cnr = unified_manager.get_cnr_by_repo(url)
if cnr:
cnr_id = cnr['id']
return await unified_manager.install_by_id(cnr_id, version_spec='nightly')
return await unified_manager.install_by_id(cnr_id, version_spec='nightly', channel='default', mode='cache')
else:
repo_name = os.path.splitext(os.path.basename(url))[0]
@@ -3138,22 +3126,22 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
disabled_repos.append(x)
for x in todo_enable:
res = unified_manager.unified_enable(x, 'nightly')
res = unified_manager.unified_enable(x[0], 'nightly')
is_switched = False
if res and res.target:
is_switched = repo_switch_commit(res.target, x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
enabled_repos.append(x)
enabled_repos.append(x[0])
for x in todo_checkout:
is_switched = repo_switch_commit(x[0], x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
skip_node_packs.append(x[0])
@@ -3170,8 +3158,6 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
if x in git_info:
del git_info[x]
# remained nightly will be installed and migrated
# for unknown restore
todo_disable = []
todo_enable = []
@@ -3218,15 +3204,15 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
is_switched = repo_switch_commit(res.target, x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
enabled_repos.append(x)
enabled_repos.append(x[0])
for x in todo_checkout:
is_switched = repo_switch_commit(x[0], x[1])
if is_switched:
checkout_repos.append(x)
checkout_repos.append(f"{x[0]}@{x[1]}")
else:
skip_node_packs.append(x[0])
@@ -3243,9 +3229,6 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
unified_manager.repo_install(repo_url, to_path, instant_execution=True, no_deps=False, return_postinstall=False)
cloned_repos.append(repo_name)
# reload
await unified_manager.migrate_unmanaged_nodes()
# print summary
for x in cloned_repos:
print(f"[ INSTALLED ] {x}")
@@ -3262,34 +3245,6 @@ async def restore_snapshot(snapshot_path, git_helper_extras=None):
# print("[bold red]ERROR: Failed to restore snapshot.[/bold red]")
# check need to migrate
need_to_migrate = False
async def check_need_to_migrate():
global need_to_migrate
await unified_manager.reload('cache')
await unified_manager.load_nightly(channel='default', mode='cache')
legacy_custom_nodes = []
for x in unified_manager.active_nodes.values():
if x[0] == 'nightly' and not x[1].endswith('@nightly'):
legacy_custom_nodes.append(x[1])
for x in unified_manager.nightly_inactive_nodes.values():
if not x.endswith('@nightly'):
legacy_custom_nodes.append(x)
if len(legacy_custom_nodes) > 0:
print("\n--------------------- ComfyUI-Manager migration notice --------------------")
print("The following custom nodes were installed using the old management method and require migration:\n")
print("\n".join(legacy_custom_nodes))
print("---------------------------------------------------------------------------\n")
need_to_migrate = True
def get_comfyui_versions(repo=None):
if repo is None:
repo = git.Repo(comfy_path)

View File

@@ -279,8 +279,17 @@ def get_model_dir(data, show_log=False):
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.
@@ -1739,11 +1748,6 @@ async def default_cache_update():
logging.info("[ComfyUI-Manager] All startup tasks have been completed.")
# NOTE: hide migration button temporarily.
# if not core.get_config()['skip_migration_check']:
# await core.check_need_to_migrate()
# else:
# logging.info("[ComfyUI-Manager] Migration check is skipped...")
threading.Thread(target=lambda: asyncio.run(default_cache_update())).start()

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

@@ -13,7 +13,7 @@ import {
import { OpenArtShareDialog } from "./comfyui-share-openart.js";
import {
free_models, install_pip, install_via_git_url, manager_instance,
rebootAPI, migrateAPI, setManagerInstance, show_message, customAlert, customPrompt,
rebootAPI, setManagerInstance, show_message, customAlert, customPrompt,
infoToast, showTerminal, setNeedRestart
} from "./common.js";
import { ComponentBuilderDialog, getPureName, load_components, set_component_policy } from "./components-manager.js";
@@ -946,28 +946,6 @@ class ManagerMenuDialog extends ComfyDialog {
restart_stop_button,
];
let migration_btn =
$el("button.cm-button-orange", {
type: "button",
textContent: "Migrate to New Node System",
onclick: () => migrateAPI()
});
migration_btn.style.display = 'none';
res.push(migration_btn);
api.fetchApi('/manager/need_to_migrate')
.then(response => response.text())
.then(text => {
if (text === 'True') {
migration_btn.style.display = 'block';
}
})
.catch(error => {
console.error('Error checking migration status:', error);
});
return res;
}

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) {
@@ -181,23 +182,6 @@ export function rebootAPI() {
}
export async function migrateAPI() {
let confirmed = await customConfirm("When performing a migration, existing installed custom nodes will be renamed and the server will be restarted. Are you sure you want to apply this?\n\n(If you don't perform the migration, ComfyUI-Manager's start-up time will be longer each time due to re-checking during startup.)")
if (confirmed) {
try {
await api.fetchApi("/manager/migrate_unmanaged_nodes");
api.fetchApi("/manager/reboot");
}
catch(exception) {
}
return true;
}
return false;
}
export var manager_instance = null;
export function setManagerInstance(obj) {
@@ -404,12 +388,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 +489,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,289 @@
},
{
"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",
@@ -72,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",
@@ -421,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']
@@ -689,14 +689,6 @@ def execute_lazy_cnr_switch(target, zip_url, from_path, to_path, no_deps, custom
file.write('\n'.join(list(extracted)))
def execute_migration(moves):
import shutil
for x in moves:
if os.path.exists(x[0]) and not os.path.exists(x[1]):
shutil.move(x[0], x[1])
print(f"[ComfyUI-Manager] MIGRATION: '{x[0]}' -> '{x[1]}'")
script_executed = False
def execute_startup_script():
@@ -754,9 +746,6 @@ def execute_startup_script():
execute_lazy_cnr_switch(script[0], script[2], script[3], script[4], script[5], script[6])
execute_lazy_install_script(script[3], script[7])
elif script[1] == "#LAZY-MIGRATION":
execute_migration(script[2])
elif script[1] == "#LAZY-DELETE-NODEPACK":
execute_lazy_delete(script[2])

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.7"
version = "3.31.4"
license = { file = "LICENSE.txt" }
dependencies = ["GitPython", "PyGithub", "matrix-client==0.4.0", "transformers", "huggingface-hub>0.20", "typer", "rich", "typing-extensions", "toml", "uv", "chardet"]