Better serialize widget values
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
import { LiteGraph, type ContextMenuItem, type LGraphNode, type Vector2, LConnectionKind, LLink, LGraphCanvas, type SlotType, TitleMode, type SlotLayout, LGraph, type INodeInputSlot, type ITextWidget, type INodeOutputSlot } from "@litegraph-ts/core";
|
||||
import { LiteGraph, type ContextMenuItem, type LGraphNode, type Vector2, LConnectionKind, LLink, LGraphCanvas, type SlotType, TitleMode, type SlotLayout, LGraph, type INodeInputSlot, type ITextWidget, type INodeOutputSlot, type SerializedLGraphNode } from "@litegraph-ts/core";
|
||||
import ComfyGraphNode from "./ComfyGraphNode";
|
||||
import ComboWidget from "$lib/widgets/ComboWidget.svelte";
|
||||
import RangeWidget from "$lib/widgets/RangeWidget.svelte";
|
||||
@@ -127,13 +127,19 @@ export abstract class ComfyWidgetNode<T = any> extends ComfyGraphNode {
|
||||
}
|
||||
}
|
||||
|
||||
if (changed) {
|
||||
// Force trigger reactivity to update component based on new props
|
||||
this.propsChanged.set(true)
|
||||
}
|
||||
// Force reactivity change so the frontend can be updated with the new props
|
||||
this.propsChanged.set(!get(this.propsChanged))
|
||||
}
|
||||
|
||||
clampOneConfig(input: IComfyInputSlot) {}
|
||||
clampOneConfig(input: IComfyInputSlot) { }
|
||||
|
||||
override onSerialize(o: SerializedLGraphNode) {
|
||||
(o as any).comfyValue = get(this.value)
|
||||
}
|
||||
|
||||
override onConfigure(o: SerializedLGraphNode) {
|
||||
this.value.set((o as any).comfyValue)
|
||||
}
|
||||
}
|
||||
|
||||
export interface ComfySliderProperties extends ComfyWidgetProperties {
|
||||
|
||||
@@ -12,7 +12,7 @@
|
||||
|
||||
$: widget && setNodeValue(widget);
|
||||
|
||||
$: if ($propsChanged && nodeValue !== null) {
|
||||
$: if (nodeValue !== null && (!$propsChanged || $propsChanged)) {
|
||||
setOption($nodeValue)
|
||||
setNodeValue(widget)
|
||||
node.properties = node.properties
|
||||
|
||||
@@ -20,7 +20,9 @@
|
||||
}
|
||||
};
|
||||
|
||||
$: if ($propsChanged && nodeValue !== null) {
|
||||
// I don't know why but this is necessary to watch for changes to node
|
||||
// properties from ComfyWidgetNode.
|
||||
$: if (nodeValue !== null && (!$propsChanged || $propsChanged)) {
|
||||
setOption($nodeValue)
|
||||
setNodeValue(widget)
|
||||
node.properties = node.properties
|
||||
|
||||
@@ -6,12 +6,25 @@
|
||||
export let widget: WidgetLayout | null = null;
|
||||
let node: ComfyComboNode | null = null;
|
||||
let nodeValue: Writable<string> | null = null;
|
||||
let propsChanged: Writable<boolean> | null = null;
|
||||
let itemValue: WidgetUIStateStore | null = null;
|
||||
|
||||
$: if(widget) {
|
||||
node = widget.node as ComfyComboNode
|
||||
nodeValue = node.value;
|
||||
$: widget && setNodeValue(widget);
|
||||
|
||||
function setNodeValue(widget: WidgetLayout) {
|
||||
if (widget) {
|
||||
node = widget.node as ComfySliderNode
|
||||
nodeValue = node.value;
|
||||
propsChanged = node.propsChanged;
|
||||
}
|
||||
};
|
||||
|
||||
// I don't know why but this is necessary to watch for changes to node
|
||||
// properties from ComfyWidgetNode.
|
||||
$: if (nodeValue !== null && (!$propsChanged || $propsChanged)) {
|
||||
setNodeValue(widget)
|
||||
node.properties = node.properties
|
||||
}
|
||||
</script>
|
||||
|
||||
<div class="wrapper gr-textbox">
|
||||
|
||||
Reference in New Issue
Block a user