Nested sidebar ordering almost working

This commit is contained in:
Gregory Schier
2023-11-03 14:08:46 -07:00
parent 30e1ecac39
commit 867f3908ed
5 changed files with 220 additions and 110 deletions

View File

@@ -0,0 +1,28 @@
import { useMutation, useQueryClient } from '@tanstack/react-query';
import { invoke } from '@tauri-apps/api';
import type { Folder, HttpRequest } from '../lib/models';
import { getFolder, getRequest } from '../lib/store';
import { requestsQueryKey } from './useRequests';
import { foldersQueryKey } from './useFolders';
export function useUpdateAnyFolder() {
const queryClient = useQueryClient();
return useMutation<void, unknown, { id: string; update: (r: Folder) => Folder }>({
mutationFn: async ({ id, update }) => {
const folder = await getFolder(id);
if (folder === null) {
throw new Error("Can't update a null folder");
}
await invoke('update_folder', { request: update(folder) });
},
onMutate: async ({ id, update }) => {
const folder = await getFolder(id);
if (folder === null) return;
queryClient.setQueryData<Folder[]>(foldersQueryKey(folder), (folders) =>
(folders ?? []).map((f) => (f.id === folder.id ? update(f) : f)),
);
},
});
}