2021-01-23 11:40:43 +01:00
|
|
|
import pb from "anki/backend_proto";
|
2021-01-21 16:16:58 +01:00
|
|
|
import { getGraphPreferences, setGraphPreferences } from "./graph-helpers";
|
2021-01-22 19:02:05 +01:00
|
|
|
import { Writable, writable, get } from "svelte/store";
|
2021-01-21 16:16:58 +01:00
|
|
|
|
2021-01-22 19:02:05 +01:00
|
|
|
export interface CustomStore<T> extends Writable<T> {
|
2021-01-21 13:45:49 +01:00
|
|
|
subscribe: (getter: (value: T) => void) => () => void;
|
|
|
|
set: (value: T) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type PreferenceStore = {
|
2021-01-23 11:47:45 +01:00
|
|
|
[K in keyof Omit<pb.BackendProto.GraphPreferences, "toJSON">]: CustomStore<
|
|
|
|
pb.BackendProto.GraphPreferences[K]
|
2021-01-21 13:45:49 +01:00
|
|
|
>;
|
|
|
|
};
|
|
|
|
|
2021-01-22 19:02:05 +01:00
|
|
|
export type PreferencePayload = {
|
|
|
|
[K in keyof Omit<
|
2021-01-23 11:47:45 +01:00
|
|
|
pb.BackendProto.GraphPreferences,
|
2021-01-22 19:02:05 +01:00
|
|
|
"toJSON"
|
2021-01-23 11:47:45 +01:00
|
|
|
>]: pb.BackendProto.GraphPreferences[K];
|
2021-01-22 19:02:05 +01:00
|
|
|
};
|
|
|
|
|
2021-01-21 13:45:49 +01:00
|
|
|
function createPreference<T>(
|
|
|
|
initialValue: T,
|
|
|
|
savePreferences: () => void
|
|
|
|
): CustomStore<T> {
|
2021-01-22 19:02:05 +01:00
|
|
|
const { subscribe, set, update } = writable(initialValue);
|
2021-01-21 01:51:00 +01:00
|
|
|
|
|
|
|
return {
|
|
|
|
subscribe,
|
2021-01-22 19:02:05 +01:00
|
|
|
set: (value: T): void => {
|
|
|
|
set(value);
|
|
|
|
savePreferences();
|
|
|
|
},
|
|
|
|
update: (updater: (value: T) => T): void => {
|
|
|
|
update(updater);
|
2021-01-21 13:45:49 +01:00
|
|
|
savePreferences();
|
|
|
|
},
|
2021-01-21 01:51:00 +01:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-01-22 14:56:41 +01:00
|
|
|
function preparePreferences(
|
2021-01-23 11:47:45 +01:00
|
|
|
GraphPreferences: pb.BackendProto.GraphPreferences
|
2021-01-22 14:56:41 +01:00
|
|
|
): PreferenceStore {
|
2021-01-21 13:45:49 +01:00
|
|
|
const preferences: Partial<PreferenceStore> = {};
|
|
|
|
|
2021-01-22 19:02:05 +01:00
|
|
|
function constructPreferences(): PreferencePayload {
|
|
|
|
const payload: Partial<PreferencePayload> = {};
|
|
|
|
|
|
|
|
for (const key in preferences as PreferenceStore) {
|
|
|
|
payload[key] = get(preferences[key]);
|
2021-01-21 13:45:49 +01:00
|
|
|
}
|
2021-01-22 19:02:05 +01:00
|
|
|
|
|
|
|
return payload as PreferencePayload;
|
2021-01-21 13:45:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function savePreferences(): void {
|
2021-01-21 16:16:58 +01:00
|
|
|
setGraphPreferences(constructPreferences());
|
2021-01-21 13:45:49 +01:00
|
|
|
}
|
|
|
|
|
2021-01-23 11:40:43 +01:00
|
|
|
for (const [key, value] of Object.entries(
|
2021-01-23 11:47:45 +01:00
|
|
|
pb.BackendProto.GraphPreferences.toObject(GraphPreferences, {
|
2021-01-23 11:40:43 +01:00
|
|
|
defaults: true,
|
|
|
|
})
|
|
|
|
)) {
|
2021-01-21 13:45:49 +01:00
|
|
|
preferences[key] = createPreference(value, savePreferences);
|
|
|
|
}
|
|
|
|
|
|
|
|
return preferences as PreferenceStore;
|
|
|
|
}
|
|
|
|
|
2021-01-22 19:02:05 +01:00
|
|
|
export async function getPreferences(): Promise<PreferenceStore> {
|
2021-01-21 13:45:49 +01:00
|
|
|
const initialPreferences = await getGraphPreferences();
|
2021-01-22 14:56:41 +01:00
|
|
|
return preparePreferences(initialPreferences);
|
2021-01-21 13:45:49 +01:00
|
|
|
}
|