mirror of
https://github.com/willmiao/ComfyUI-Lora-Manager.git
synced 2026-03-24 22:52:12 -03:00
feat(lora-pool): add external value handling and config update support
- Add `onSetValue` callback to handle external updates like workflow loading - Implement `updateConfig` method for direct widget value updates - Add value change detection in `restoreFromConfig` to prevent unnecessary updates - Remove debug console log on component mount - Extend widget value type to support legacy config format
This commit is contained in:
@@ -58,7 +58,11 @@ export function useLoraPoolState(widget: ComponentWidget) {
|
||||
}
|
||||
|
||||
// Update widget value
|
||||
widget.value = config
|
||||
if (widget.updateConfig) {
|
||||
widget.updateConfig(config)
|
||||
} else {
|
||||
widget.value = config
|
||||
}
|
||||
return config
|
||||
}
|
||||
|
||||
@@ -95,13 +99,23 @@ export function useLoraPoolState(widget: ComponentWidget) {
|
||||
if (!config?.filters) return
|
||||
|
||||
const { filters, preview } = config
|
||||
selectedBaseModels.value = filters.baseModels || []
|
||||
includeTags.value = filters.tags?.include || []
|
||||
excludeTags.value = filters.tags?.exclude || []
|
||||
includeFolders.value = filters.folders?.include || []
|
||||
excludeFolders.value = filters.folders?.exclude || []
|
||||
noCreditRequired.value = filters.license?.noCreditRequired ?? false
|
||||
allowSelling.value = filters.license?.allowSelling ?? false
|
||||
|
||||
// Helper to update ref only if value changed
|
||||
const updateIfChanged = <T>(refValue: { value: T }, newValue: T) => {
|
||||
if (JSON.stringify(refValue.value) !== JSON.stringify(newValue)) {
|
||||
refValue.value = newValue
|
||||
}
|
||||
}
|
||||
|
||||
updateIfChanged(selectedBaseModels, filters.baseModels || [])
|
||||
updateIfChanged(includeTags, filters.tags?.include || [])
|
||||
updateIfChanged(excludeTags, filters.tags?.exclude || [])
|
||||
updateIfChanged(includeFolders, filters.folders?.include || [])
|
||||
updateIfChanged(excludeFolders, filters.folders?.exclude || [])
|
||||
updateIfChanged(noCreditRequired, filters.license?.noCreditRequired ?? false)
|
||||
updateIfChanged(allowSelling, filters.license?.allowSelling ?? false)
|
||||
|
||||
// matchCount doesn't trigger watchers, so direct assignment is fine
|
||||
matchCount.value = preview?.matchCount || 0
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user