diff --git a/src/Vencord.ts b/src/Vencord.ts index 578e69d06..9a0873e0c 100644 --- a/src/Vencord.ts +++ b/src/Vencord.ts @@ -5,10 +5,10 @@ export * as Updater from "./utils/updater"; export * as QuickCss from "./utils/quickCss"; import { popNotice, showNotice } from "./api/Notices"; -import { Settings } from "./api/settings"; +import { Settings, PlainSettings } from "./api/settings"; import { startAllPlugins } from "./plugins"; -export { Settings }; +export { Settings, PlainSettings }; import "./webpack/patchWebpack"; import "./utils/quickCss"; diff --git a/src/api/settings.ts b/src/api/settings.ts index 0f2356f97..a5bda8386 100644 --- a/src/api/settings.ts +++ b/src/api/settings.ts @@ -46,7 +46,7 @@ function makeProxy(settings: Settings, root = settings, path = ""): Settings { return new Proxy(settings, { get(target, p: string) { const v = target[p]; - if (typeof v === "object" && !Array.isArray(v)) + if (typeof v === "object" && !Array.isArray(v) && v !== null) return makeProxy(v, root, `${path}${path && "."}${p}`); return v; }, @@ -66,12 +66,18 @@ function makeProxy(settings: Settings, root = settings, path = ""): Settings { }); } +/** + * Same as {@link Settings} but unproxied. You should treat this as readonly, + * as modifying properties on this will not save to disk or call settings + * listeners. + */ +export const PlainSettings = settings; /** * A smart settings object. Altering props automagically saves * the updated settings to disk. + * This recursively proxies objects. If you need the object non proxied, use {@link PlainSettings} */ export const Settings = makeProxy(settings); - /** * Settings hook for React components. Returns a smart settings * object that automagically triggers a rerender if any properties