Dedicated event for model creation

This commit is contained in:
Gregory Schier
2023-03-30 16:49:49 -07:00
parent e458675627
commit 643356bad3
5 changed files with 67 additions and 34 deletions

View File

@@ -2,18 +2,21 @@ import { useMutation } from '@tanstack/react-query';
import { invoke } from '@tauri-apps/api';
import type { HttpRequest } from '../lib/models';
import { useActiveWorkspace } from './useActiveWorkspace';
import { useRequests } from './useRequests';
import { useRoutes } from './useRoutes';
export function useCreateRequest({ navigateAfter }: { navigateAfter: boolean }) {
const workspace = useActiveWorkspace();
const routes = useRoutes();
const requests = useRequests();
return useMutation<string, unknown, Pick<HttpRequest, 'name' | 'sortPriority'>>({
return useMutation<string, unknown, Partial<Pick<HttpRequest, 'name' | 'sortPriority'>>>({
mutationFn: (patch) => {
if (workspace === null) {
throw new Error("Cannot create request when there's no active workspace");
}
return invoke('create_request', { ...patch, workspaceId: workspace.id });
const sortPriority = maxSortPriority(requests) + 1000;
return invoke('create_request', { sortPriority, workspaceId: workspace.id, ...patch });
},
onSuccess: async (requestId) => {
if (navigateAfter && workspace !== null) {
@@ -22,3 +25,8 @@ export function useCreateRequest({ navigateAfter }: { navigateAfter: boolean })
},
});
}
function maxSortPriority(requests: HttpRequest[]) {
if (requests.length === 0) return 1000;
return Math.max(...requests.map((r) => r.sortPriority));
}