mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-25 16:56:22 +02:00
feat: migrate document upload to use jotai + tanstack query mutation atom
- Replace imperative fetch API with uploadDocumentMutationAtom in DocumentUploadTab - Maintain backward compatibility with existing UI behavior - Remove unused document query atoms from document-query.atoms.ts - Use mutation state (isPending) for loading state management - Preserve progress animation and error handling
This commit is contained in:
parent
ecb48ddb03
commit
7f80c9c408
2 changed files with 36 additions and 94 deletions
|
|
@ -20,21 +20,6 @@ export const documentsAtom = atomWithQuery((get) => {
|
|||
};
|
||||
});
|
||||
|
||||
export const getDocumentAtom = (documentId: number) =>
|
||||
atomWithQuery(() => {
|
||||
return {
|
||||
queryKey: cacheKeys.documents.document(String(documentId)),
|
||||
enabled: !!documentId,
|
||||
queryFn: async () => {
|
||||
if (!documentId) {
|
||||
throw new Error("No active document id found");
|
||||
}
|
||||
|
||||
return documentsApiService.getDocument({ id: documentId });
|
||||
},
|
||||
};
|
||||
});
|
||||
|
||||
export const documentTypeCountsAtom = atomWithQuery((get) => {
|
||||
const searchSpaceId = get(activeSearchSpaceIdAtom);
|
||||
|
||||
|
|
@ -50,37 +35,3 @@ export const documentTypeCountsAtom = atomWithQuery((get) => {
|
|||
},
|
||||
};
|
||||
});
|
||||
|
||||
export const getDocumentByChunkAtom = (chunkId: number) =>
|
||||
atomWithQuery(() => {
|
||||
return {
|
||||
queryKey: cacheKeys.documents.byChunk(String(chunkId)),
|
||||
enabled: !!chunkId,
|
||||
queryFn: async () => {
|
||||
if (!chunkId) {
|
||||
throw new Error("No active chunk id found");
|
||||
}
|
||||
|
||||
return documentsApiService.getDocumentByChunk({ chunk_id: chunkId });
|
||||
},
|
||||
};
|
||||
});
|
||||
|
||||
export const searchDocumentsAtom = (request: SearchDocumentsRequest) =>
|
||||
atomWithQuery((get) => {
|
||||
const searchSpaceId = get(activeSearchSpaceIdAtom);
|
||||
|
||||
return {
|
||||
queryKey: cacheKeys.documents.globalQueryParams(request.queryParams),
|
||||
enabled: !!searchSpaceId,
|
||||
queryFn: async () => {
|
||||
return documentsApiService.searchDocuments({
|
||||
...request,
|
||||
queryParams: {
|
||||
...request.queryParams,
|
||||
search_space_id: searchSpaceId ?? undefined,
|
||||
},
|
||||
});
|
||||
},
|
||||
};
|
||||
});
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue