diff options
author | Vendicated <vendicated@riseup.net> | 2022-09-03 17:49:16 +0200 |
---|---|---|
committer | Vendicated <vendicated@riseup.net> | 2022-09-03 17:49:16 +0200 |
commit | 113f47ca7fb6adf382c89541602b0680dfdc24e2 (patch) | |
tree | ad00d36e5779eec92b15c3d4c08d02f8fe727c6b /src/api/settings.ts | |
parent | 8a8c6a4b526ffcb37f42716d2896a6ff0f565d82 (diff) | |
download | Vencord-113f47ca7fb6adf382c89541602b0680dfdc24e2.tar.gz Vencord-113f47ca7fb6adf382c89541602b0680dfdc24e2.tar.bz2 Vencord-113f47ca7fb6adf382c89541602b0680dfdc24e2.zip |
Add QuickCss toggle; add settings listener api
Diffstat (limited to 'src/api/settings.ts')
-rw-r--r-- | src/api/settings.ts | 33 |
1 files changed, 26 insertions, 7 deletions
diff --git a/src/api/settings.ts b/src/api/settings.ts index a6f24a4..8646412 100644 --- a/src/api/settings.ts +++ b/src/api/settings.ts @@ -5,6 +5,7 @@ import { mergeDefaults } from '../utils/misc'; interface Settings { unsafeRequire: boolean; + useQuickCss: boolean; plugins: { [plugin: string]: { enabled: boolean; @@ -15,8 +16,9 @@ interface Settings { const DefaultSettings: Settings = { unsafeRequire: false, + useQuickCss: true, plugins: {} -}; +} as any; for (const plugin in plugins) { DefaultSettings.plugins[plugin] = { @@ -35,21 +37,26 @@ try { var settings = mergeDefaults({} as Settings, DefaultSettings); } -const subscriptions = new Set<() => void>(); +type SubscriptionCallback = ((newValue: any) => void) & { _path?: string; }; +const subscriptions = new Set<SubscriptionCallback>(); -function makeProxy(settings: Settings, root = settings): Settings { +function makeProxy(settings: Settings, root = settings, path = ""): Settings { return new Proxy(settings, { - get(target, p) { + get(target, p: string) { const v = target[p]; - if (typeof v === "object" && !Array.isArray(v)) return makeProxy(v, root); + if (typeof v === "object" && !Array.isArray(v)) + return makeProxy(v, root, `${path}${path && "."}${p}`); return v; }, - set(target, p, v) { + set(target, p: string, v) { if (target[p] === v) return true; target[p] = v; + const setPath = `${path}${path && "."}${p}`; for (const subscription of subscriptions) { - subscription(); + if (!subscription._path || subscription._path === setPath) { + subscription(v); + } } VencordNative.ipc.invoke(IpcEvents.SET_SETTINGS, JSON.stringify(root, null, 4)); return true; @@ -78,4 +85,16 @@ export function useSettings() { }, []); return Settings; +} + +// Resolves a possibly nested prop in the form of "some.nested.prop" to type of T.some.nested.prop +type ResolvePropDeep<T, P> = P extends "" ? T : + P extends `${infer Pre}.${infer Suf}` ? + Pre extends keyof T ? ResolvePropDeep<T[Pre], Suf> : never : P extends keyof T ? T[P] : never; + +export function addSettingsListener<Path extends keyof Settings>(path: Path, onUpdate: (newValue: Settings[Path]) => void): void; +export function addSettingsListener<Path extends string>(path: Path, onUpdate: (newValue: ResolvePropDeep<Settings, Path>) => void): void; +export function addSettingsListener(path: string, onUpdate: (newValue: any) => void) { + (onUpdate as SubscriptionCallback)._path = path; + subscriptions.add(onUpdate); }
\ No newline at end of file |