link colors change after palette swap

didn't work previously as same function was defined repeatedly
This commit is contained in:
EllangoK 2023-04-08 11:55:27 -04:00
parent 327e49da42
commit d9220a0bd6

View File

@ -238,6 +238,7 @@ app.registerExtension({
if (colorPalette.colors) { if (colorPalette.colors) {
if (colorPalette.colors.node_slot) { if (colorPalette.colors.node_slot) {
Object.assign(app.canvas.default_connection_color_byType, colorPalette.colors.node_slot); Object.assign(app.canvas.default_connection_color_byType, colorPalette.colors.node_slot);
customizeRenderLink(colorPalette);
} }
if (colorPalette.colors.litegraph_base) { if (colorPalette.colors.litegraph_base) {
// Everything updates correctly in the loop, except the Node Title and Link Color for some reason // Everything updates correctly in the loop, except the Node Title and Link Color for some reason
@ -250,7 +251,6 @@ app.registerExtension({
} }
} }
} }
customizeRenderLink(colorPalette);
app.canvas.draw(true, true); app.canvas.draw(true, true);
} }
}; };
@ -411,7 +411,8 @@ app.registerExtension({
function customizeRenderLink(colorPalette) { function customizeRenderLink(colorPalette) {
var LGraphCanvas = LiteGraph.LGraphCanvas; var LGraphCanvas = LiteGraph.LGraphCanvas;
function getLinkColor(link, inputNode, outputNode, colorPalette) { if (!LGraphCanvas.prototype.getLinkColor) {
LGraphCanvas.prototype.getLinkColor = function(link, inputNode, outputNode, colorPalette) {
let color = null; let color = null;
if (link && link.color) { if (link && link.color) {
color = link.color; color = link.color;
@ -426,9 +427,12 @@ function customizeRenderLink(colorPalette) {
} }
} }
return color; return color;
};
} }
var originalRenderLink = LGraphCanvas.prototype.renderLink; if (!LGraphCanvas.prototype.originalRenderLink) {
LGraphCanvas.prototype.originalRenderLink = LGraphCanvas.prototype.renderLink;
}
LGraphCanvas.prototype.renderLink = function( LGraphCanvas.prototype.renderLink = function(
ctx, ctx,
@ -445,10 +449,11 @@ function customizeRenderLink(colorPalette) {
if (link) { if (link) {
const inputNode = this.graph.getNodeById(link.origin_id); const inputNode = this.graph.getNodeById(link.origin_id);
const outputNode = this.graph.getNodeById(link.target_id); const outputNode = this.graph.getNodeById(link.target_id);
color = getLinkColor(link, inputNode, outputNode, colorPalette); color = this.getLinkColor(link, inputNode, outputNode, colorPalette);
} }
originalRenderLink.call( // call the original renderLink function
this.originalRenderLink.call(
this, this,
ctx, ctx,
a, a,