- DeepAnalysis: 4 个 fetch → axios - DynamicTracking: 3 个 fetch → axios (NewsPanel, ForecastPanel) - MarketDataView/services: 4 个 fetch → axios - CompanyOverview/hooks: 9 个 fetch → axios (6 个文件) - StockQuoteCard/hooks: 1 个 fetch → axios - ValueChainNodeCard: 1 个 fetch → axios 清理: - 删除未使用的 useCompanyOverviewData.ts - 移除所有 getApiBase/API_BASE_URL 引用 总计: 22 个 fetch 调用迁移, 复用项目已有的 axios 拦截器配置 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
59 lines
1.5 KiB
TypeScript
59 lines
1.5 KiB
TypeScript
// src/views/Company/components/CompanyOverview/hooks/useDisclosureData.ts
|
|
// 披露日程数据 Hook - 用于工商信息 Tab
|
|
|
|
import { useState, useEffect, useCallback } from "react";
|
|
import { logger } from "@utils/logger";
|
|
import axios from "@utils/axiosConfig";
|
|
import type { DisclosureSchedule } from "../types";
|
|
|
|
interface ApiResponse<T> {
|
|
success: boolean;
|
|
data: T;
|
|
}
|
|
|
|
interface UseDisclosureDataResult {
|
|
disclosureSchedule: DisclosureSchedule[];
|
|
loading: boolean;
|
|
error: string | null;
|
|
}
|
|
|
|
/**
|
|
* 披露日程数据 Hook
|
|
* @param stockCode - 股票代码
|
|
*/
|
|
export const useDisclosureData = (stockCode?: string): UseDisclosureDataResult => {
|
|
const [disclosureSchedule, setDisclosureSchedule] = useState<DisclosureSchedule[]>([]);
|
|
const [loading, setLoading] = useState(false);
|
|
const [error, setError] = useState<string | null>(null);
|
|
|
|
const loadData = useCallback(async () => {
|
|
if (!stockCode) return;
|
|
|
|
setLoading(true);
|
|
setError(null);
|
|
|
|
try {
|
|
const { data: result } = await axios.get<ApiResponse<DisclosureSchedule[]>>(
|
|
`/api/stock/${stockCode}/disclosure-schedule`
|
|
);
|
|
|
|
if (result.success) {
|
|
setDisclosureSchedule(result.data);
|
|
} else {
|
|
setError("加载披露日程数据失败");
|
|
}
|
|
} catch (err) {
|
|
logger.error("useDisclosureData", "loadData", err, { stockCode });
|
|
setError("网络请求失败");
|
|
} finally {
|
|
setLoading(false);
|
|
}
|
|
}, [stockCode]);
|
|
|
|
useEffect(() => {
|
|
loadData();
|
|
}, [loadData]);
|
|
|
|
return { disclosureSchedule, loading, error };
|
|
};
|