Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
chenpangpang
ComfyUI
Commits
84f13f82
Commit
84f13f82
authored
Jun 14, 2023
by
comfyanonymous
Browse files
Merge branch 'issue-752' of
https://github.com/reaper47/ComfyUI
parents
388567f2
aba886e9
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
68 additions
and
24 deletions
+68
-24
web/extensions/core/colorPalette.js
web/extensions/core/colorPalette.js
+46
-24
web/index.html
web/index.html
+1
-0
web/lib/litegraph.extensions.js
web/lib/litegraph.extensions.js
+21
-0
No files found.
web/extensions/core/colorPalette.js
View file @
84f13f82
import
{
app
}
from
"
/scripts/app.js
"
;
import
{
$el
}
from
"
/scripts/ui.js
"
;
import
{
api
}
from
"
/scripts/api.js
"
;
import
{
app
}
from
"
/scripts/app.js
"
;
import
{
$el
}
from
"
/scripts/ui.js
"
;
// Manage color palettes
...
...
@@ -24,6 +23,8 @@ const colorPalettes = {
"
TAESD
"
:
"
#DCC274
"
,
// cheesecake
},
"
litegraph_base
"
:
{
"
BACKGROUND_IMAGE
"
:
"

"
,
"
CLEAR_BACKGROUND_COLOR
"
:
"
#222
"
,
"
NODE_TITLE_COLOR
"
:
"
#999
"
,
"
NODE_SELECTED_TITLE_COLOR
"
:
"
#FFF
"
,
"
NODE_TEXT_SIZE
"
:
14
,
...
...
@@ -77,6 +78,8 @@ const colorPalettes = {
"
VAE
"
:
"
#FF7043
"
,
// deep orange
},
"
litegraph_base
"
:
{
"
BACKGROUND_IMAGE
"
:
"

"
,
"
CLEAR_BACKGROUND_COLOR
"
:
"
lightgray
"
,
"
NODE_TITLE_COLOR
"
:
"
#222
"
,
"
NODE_SELECTED_TITLE_COLOR
"
:
"
#000
"
,
"
NODE_TEXT_SIZE
"
:
14
,
...
...
@@ -191,7 +194,7 @@ app.registerExtension({
const
nodeData
=
defs
[
nodeId
];
var
inputs
=
nodeData
[
"
input
"
][
"
required
"
];
if
(
nodeData
[
"
input
"
][
"
optional
"
]
!=
undefined
){
if
(
nodeData
[
"
input
"
][
"
optional
"
]
!=
undefined
)
{
inputs
=
Object
.
assign
({},
nodeData
[
"
input
"
][
"
required
"
],
nodeData
[
"
input
"
][
"
optional
"
])
}
...
...
@@ -232,12 +235,9 @@ app.registerExtension({
"
id
"
:
"
my_color_palette_unique_id
"
,
"
name
"
:
"
My Color Palette
"
,
"
colors
"
:
{
"
node_slot
"
:
{
},
"
litegraph_base
"
:
{
},
"
comfy_base
"
:
{
}
"
node_slot
"
:
{},
"
litegraph_base
"
:
{},
"
comfy_base
"
:
{}
}
};
...
...
@@ -266,7 +266,7 @@ app.registerExtension({
};
const
addCustomColorPalette
=
async
(
colorPalette
)
=>
{
if
(
typeof
(
colorPalette
)
!==
"
object
"
)
{
if
(
typeof
(
colorPalette
)
!==
"
object
"
)
{
app
.
ui
.
dialog
.
show
(
"
Invalid color palette
"
);
return
;
}
...
...
@@ -286,7 +286,7 @@ app.registerExtension({
return
;
}
if
(
colorPalette
.
colors
.
node_slot
&&
typeof
(
colorPalette
.
colors
.
node_slot
)
!==
"
object
"
)
{
if
(
colorPalette
.
colors
.
node_slot
&&
typeof
(
colorPalette
.
colors
.
node_slot
)
!==
"
object
"
)
{
app
.
ui
.
dialog
.
show
(
"
Invalid color palette colors.node_slot
"
);
return
;
}
...
...
@@ -301,7 +301,11 @@ app.registerExtension({
}
}
els
.
select
.
append
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
+
"
(custom)
"
,
value
:
"
custom_
"
+
colorPalette
.
id
,
selected
:
true
}));
els
.
select
.
append
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
+
"
(custom)
"
,
value
:
"
custom_
"
+
colorPalette
.
id
,
selected
:
true
}));
setColorPalette
(
"
custom_
"
+
colorPalette
.
id
);
await
loadColorPalette
(
colorPalette
);
...
...
@@ -380,7 +384,7 @@ app.registerExtension({
const
fileInput
=
$el
(
"
input
"
,
{
type
:
"
file
"
,
accept
:
"
.json
"
,
style
:
{
display
:
"
none
"
},
style
:
{
display
:
"
none
"
},
parent
:
document
.
body
,
onchange
:
()
=>
{
let
file
=
fileInput
.
files
[
0
];
...
...
@@ -403,17 +407,25 @@ app.registerExtension({
for
(
const
c
in
colorPalettes
)
{
const
colorPalette
=
colorPalettes
[
c
];
options
.
push
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
,
value
:
colorPalette
.
id
,
selected
:
colorPalette
.
id
===
value
}));
options
.
push
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
,
value
:
colorPalette
.
id
,
selected
:
colorPalette
.
id
===
value
}));
}
let
customColorPalettes
=
getCustomColorPalettes
();
for
(
const
c
in
customColorPalettes
)
{
const
colorPalette
=
customColorPalettes
[
c
];
options
.
push
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
+
"
(custom)
"
,
value
:
"
custom_
"
+
colorPalette
.
id
,
selected
:
"
custom_
"
+
colorPalette
.
id
===
value
}));
options
.
push
(
$el
(
"
option
"
,
{
textContent
:
colorPalette
.
name
+
"
(custom)
"
,
value
:
"
custom_
"
+
colorPalette
.
id
,
selected
:
"
custom_
"
+
colorPalette
.
id
===
value
}));
}
return
$el
(
"
div
"
,
[
$el
(
"
label
"
,
{
textContent
:
name
||
id
},
[
$el
(
"
label
"
,
{
textContent
:
name
||
id
},
[
els
.
select
=
$el
(
"
select
"
,
{
onchange
:
(
e
)
=>
{
setter
(
e
.
target
.
value
);
...
...
@@ -427,12 +439,12 @@ app.registerExtension({
const
colorPaletteId
=
app
.
ui
.
settings
.
getSettingValue
(
id
,
defaultColorPaletteId
);
const
colorPalette
=
await
completeColorPalette
(
getColorPalette
(
colorPaletteId
));
const
json
=
JSON
.
stringify
(
colorPalette
,
null
,
2
);
// convert the data to a JSON string
const
blob
=
new
Blob
([
json
],
{
type
:
"
application/json
"
});
const
blob
=
new
Blob
([
json
],
{
type
:
"
application/json
"
});
const
url
=
URL
.
createObjectURL
(
blob
);
const
a
=
$el
(
"
a
"
,
{
href
:
url
,
download
:
colorPaletteId
+
"
.json
"
,
style
:
{
display
:
"
none
"
},
style
:
{
display
:
"
none
"
},
parent
:
document
.
body
,
});
a
.
click
();
...
...
@@ -455,12 +467,12 @@ app.registerExtension({
onclick
:
async
()
=>
{
const
colorPalette
=
await
getColorPaletteTemplate
();
const
json
=
JSON
.
stringify
(
colorPalette
,
null
,
2
);
// convert the data to a JSON string
const
blob
=
new
Blob
([
json
],
{
type
:
"
application/json
"
});
const
blob
=
new
Blob
([
json
],
{
type
:
"
application/json
"
});
const
url
=
URL
.
createObjectURL
(
blob
);
const
a
=
$el
(
"
a
"
,
{
href
:
url
,
download
:
"
color_palette.json
"
,
style
:
{
display
:
"
none
"
},
style
:
{
display
:
"
none
"
},
parent
:
document
.
body
,
});
a
.
click
();
...
...
@@ -496,15 +508,25 @@ app.registerExtension({
return
;
}
if
(
colorPalettes
[
value
])
{
await
loadColorPalette
(
colorPalettes
[
value
]);
let
palette
=
colorPalettes
[
value
];
if
(
palette
)
{
await
loadColorPalette
(
palette
);
}
else
if
(
value
.
startsWith
(
"
custom_
"
))
{
value
=
value
.
substr
(
7
);
let
customColorPalettes
=
getCustomColorPalettes
();
if
(
customColorPalettes
[
value
])
{
palette
=
customColorPalettes
[
value
];
await
loadColorPalette
(
customColorPalettes
[
value
]);
}
}
let
{
BACKGROUND_IMAGE
,
CLEAR_BACKGROUND_COLOR
}
=
palette
.
colors
.
litegraph_base
;
if
(
BACKGROUND_IMAGE
===
undefined
||
CLEAR_BACKGROUND_COLOR
===
undefined
)
{
const
base
=
colorPalettes
[
"
dark
"
].
colors
.
litegraph_base
;
BACKGROUND_IMAGE
=
base
.
BACKGROUND_IMAGE
;
CLEAR_BACKGROUND_COLOR
=
base
.
CLEAR_BACKGROUND_COLOR
;
}
app
.
canvas
.
updateBackground
(
BACKGROUND_IMAGE
,
CLEAR_BACKGROUND_COLOR
);
},
});
},
...
...
web/index.html
View file @
84f13f82
...
...
@@ -7,6 +7,7 @@
<link
rel=
"stylesheet"
type=
"text/css"
href=
"lib/litegraph.css"
/>
<link
rel=
"stylesheet"
type=
"text/css"
href=
"style.css"
/>
<script
type=
"text/javascript"
src=
"lib/litegraph.core.js"
></script>
<script
type=
"text/javascript"
src=
"lib/litegraph.extensions.js"
defer
></script>
<script
type=
"module"
>
import
{
app
}
from
"
/scripts/app.js
"
;
await
app
.
setup
();
...
...
web/lib/litegraph.extensions.js
0 → 100644
View file @
84f13f82
/**
* Changes the background color of the canvas.
*
* @method updateBackground
* @param {image} String
* @param {clearBackgroundColor} String
* @
*/
LGraphCanvas
.
prototype
.
updateBackground
=
function
(
image
,
clearBackgroundColor
)
{
this
.
_bg_img
=
new
Image
();
this
.
_bg_img
.
name
=
image
;
this
.
_bg_img
.
src
=
image
;
this
.
_bg_img
.
onload
=
()
=>
{
this
.
draw
(
true
,
true
);
};
this
.
background_image
=
image
;
this
.
clear_background
=
true
;
this
.
clear_background_color
=
clearBackgroundColor
;
this
.
_pattern
=
null
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment