Spaces:
Sleeping
Sleeping
File size: 2,371 Bytes
5f2aab6 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 | import { createQueryOptions } from '@/api-client/query-config';
import { rpcClient } from '@/api-client/utils/rpc-client';
import type { ExcelRequest, ExcelResponse } from '@/schema/gradio-proxy/excel';
import type { FetchQueryOptions } from '@tanstack/react-query';
import { useQueryClient } from '@tanstack/react-query';
import { useCallback } from 'react';
/**
* excel APIを呼び出すカスタムフック
* @returns キャッシュ対応のAPI呼び出し関数(タイムアウト20分、キャッシュ24時間)
*/
export function useExcel() {
const queryClient = useQueryClient();
return useCallback(
async (request: ExcelRequest): Promise<ExcelResponse> => {
console.log('[useExcel] API呼び出し開始:', {
ownUrl: request.ownUrl,
urlCount: request.urlText.length,
hasCommonDict: !!request.commonDict,
hasScoreDict: !!request.scoreDict,
hasSummary: !!request.summary,
hasSwot: !!request.swot,
hasProposalFV: !!request.proposal_fv,
hasProposalCN: !!request.proposal_cn,
hasProposalPrediction: !!request.proposal_prediction,
hasProposalIntent: !!request.proposal_intent,
dummyMode: request.dummyMode,
});
return queryClient.fetchQuery(
createQueryOptions<ExcelResponse>({
queryKey: ['excel', request],
queryFn: async (): Promise<ExcelResponse> => {
try {
const response = await rpcClient['gradio-proxy']['excel'].$post({
json: request,
});
if (!response.ok) {
console.error('[useExcel] Response status:', response.status);
const errorData = (await response.json()) as { message?: string; status?: string };
console.error('[useExcel] API エラー:', errorData);
throw new Error(errorData.message || 'excel APIの呼び出しに失敗しました');
}
const data = await response.json();
console.log('[useExcel] API呼び出し成功');
return data as ExcelResponse;
} catch (error) {
console.error('[useExcel] API呼び出しエラー:', error);
throw error;
}
},
}) as FetchQueryOptions<ExcelResponse>,
);
},
[queryClient],
);
}
|