aboutsummaryrefslogtreecommitdiff
path: root/src/api/settings.ts
diff options
context:
space:
mode:
authorVendicated <vendicated@riseup.net>2022-09-03 17:49:16 +0200
committerVendicated <vendicated@riseup.net>2022-09-03 17:49:16 +0200
commit113f47ca7fb6adf382c89541602b0680dfdc24e2 (patch)
treead00d36e5779eec92b15c3d4c08d02f8fe727c6b /src/api/settings.ts
parent8a8c6a4b526ffcb37f42716d2896a6ff0f565d82 (diff)
downloadVencord-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.ts33
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