Some checks failed
Python Linting / Run Ruff (push) Has been cancelled
Python Linting / Run Pylint (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.10, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.11, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.12, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-unix-nightly (12.1, , linux, 3.11, [self-hosted Linux], nightly) (push) Has been cancelled
Execution Tests / test (macos-latest) (push) Has been cancelled
Execution Tests / test (ubuntu-latest) (push) Has been cancelled
Execution Tests / test (windows-latest) (push) Has been cancelled
Test server launches without errors / test (push) Has been cancelled
Unit Tests / test (macos-latest) (push) Has been cancelled
Unit Tests / test (ubuntu-latest) (push) Has been cancelled
Unit Tests / test (windows-2022) (push) Has been cancelled
Includes 30 custom nodes committed directly, 7 Civitai-exclusive loras stored via Git LFS, and a setup script that installs all dependencies and downloads HuggingFace-hosted models on vast.ai. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
41 lines
1.4 KiB
TypeScript
41 lines
1.4 KiB
TypeScript
// @ts-ignore
|
|
import {rgthreeConfig} from "rgthree/config.js";
|
|
import {getObjectValue, setObjectValue} from "rgthree/common/shared_utils.js";
|
|
import {rgthreeApi} from "rgthree/common/rgthree_api.js";
|
|
|
|
/**
|
|
* A singleton service exported as `SERVICE` to handle configuration routines.
|
|
*/
|
|
class ConfigService extends EventTarget {
|
|
getConfigValue(key: string, def?: any) {
|
|
return getObjectValue(rgthreeConfig, key, def);
|
|
}
|
|
|
|
getFeatureValue(key: string, def?: any) {
|
|
key = "features." + key.replace(/^features\./, "");
|
|
return getObjectValue(rgthreeConfig, key, def);
|
|
}
|
|
|
|
/**
|
|
* Given an object of key:value changes it will send to the server and wait for a successful
|
|
* response before setting the values on the local rgthreeConfig.
|
|
*/
|
|
async setConfigValues(changed: {[key: string]: any}) {
|
|
const body = new FormData();
|
|
body.append("json", JSON.stringify(changed));
|
|
const response = await rgthreeApi.fetchJson("/config", {method: "POST", body});
|
|
if (response.status === "ok") {
|
|
for (const [key, value] of Object.entries(changed)) {
|
|
setObjectValue(rgthreeConfig, key, value);
|
|
this.dispatchEvent(new CustomEvent("config-change", {detail: {key, value}}));
|
|
}
|
|
} else {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
|
|
/** The ConfigService singleton. */
|
|
export const SERVICE = new ConfigService();
|