统一使用index.ts中的全局axios配置 移除了所有重复的API_BASE_URL定义 简化了所有API调用路径格式 提高了代码一致性和可维护性 确保所有API功能保持正常
72 lines
1.5 KiB
TypeScript
72 lines
1.5 KiB
TypeScript
import axios from 'axios';
|
|
|
|
// 图表数据API接口类型
|
|
interface ChartDataResponse<T> {
|
|
message: string;
|
|
data: T;
|
|
}
|
|
|
|
interface UserActivityData {
|
|
date: string;
|
|
count: number;
|
|
}
|
|
|
|
interface FileUploadsData {
|
|
month: string;
|
|
count: number;
|
|
}
|
|
|
|
interface FileTypesData {
|
|
type: string;
|
|
value: number;
|
|
}
|
|
|
|
interface DashboardOverviewData {
|
|
userCount: number;
|
|
fileCount: number;
|
|
articleCount: number;
|
|
todayLoginCount: number;
|
|
}
|
|
|
|
// 图表数据API
|
|
export const ChartAPI = {
|
|
// 获取用户活跃度数据
|
|
getUserActivity: async (): Promise<ChartDataResponse<UserActivityData[]>> => {
|
|
try {
|
|
const response = await axios.get('/charts/user-activity');
|
|
return response.data;
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
},
|
|
|
|
// 获取文件上传统计数据
|
|
getFileUploads: async (): Promise<ChartDataResponse<FileUploadsData[]>> => {
|
|
try {
|
|
const response = await axios.get('/charts/file-uploads');
|
|
return response.data;
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
},
|
|
|
|
// 获取文件类型分布数据
|
|
getFileTypes: async (): Promise<ChartDataResponse<FileTypesData[]>> => {
|
|
try {
|
|
const response = await axios.get('/charts/file-types');
|
|
return response.data;
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
},
|
|
|
|
// 获取仪表盘概览数据
|
|
getDashboardOverview: async (): Promise<ChartDataResponse<DashboardOverviewData>> => {
|
|
try {
|
|
const response = await axios.get('/charts/dashboard-overview');
|
|
return response.data;
|
|
} catch (error) {
|
|
throw error;
|
|
}
|
|
}
|
|
}; |