Generalized frontend model store (#193)

This commit is contained in:
Gregory Schier
2025-03-31 11:56:17 -07:00
committed by GitHub
parent ce885c3551
commit f1757ae427
201 changed files with 2185 additions and 2865 deletions

View File

@@ -1,28 +1,27 @@
import { patchModel, settingsAtom } from '@yaakapp-internal/models';
import { useAtomValue } from 'jotai';
import { useCallback } from 'react';
import { useSettings } from './useSettings';
import { useUpdateSettings } from './useUpdateSettings';
export function useZoom() {
const settings = useSettings();
const updateSettings = useUpdateSettings();
const settings = useAtomValue(settingsAtom);
const zoomIn = useCallback(() => {
const zoomIn = useCallback(async () => {
if (!settings) return;
updateSettings.mutate({
await patchModel(settings, {
interfaceScale: Math.min(1.8, settings.interfaceScale * 1.1),
});
}, [settings, updateSettings]);
}, [settings]);
const zoomOut = useCallback(() => {
const zoomOut = useCallback(async () => {
if (!settings) return;
updateSettings.mutate({
await patchModel(settings, {
interfaceScale: Math.max(0.4, settings.interfaceScale * 0.9),
});
}, [settings, updateSettings]);
}, [settings]);
const zoomReset = useCallback(() => {
updateSettings.mutate({ ...settings, interfaceScale: 1 });
}, [settings, updateSettings]);
const zoomReset = useCallback(async () => {
await patchModel(settings, { interfaceScale: 1 });
}, [settings]);
return { zoomIn, zoomOut, zoomReset };
}