77 lines
3.4 KiB
JavaScript
77 lines
3.4 KiB
JavaScript
import axios from 'axios';
|
||
|
||
const api = axios.create({
|
||
baseURL: import.meta.env.VITE_API_URL || 'http://localhost:8000/api',
|
||
timeout: 8000, // 增加超时时间到 10秒
|
||
headers: {
|
||
'Content-Type': 'application/json',
|
||
}
|
||
});
|
||
|
||
// 请求拦截器:自动附加 Token
|
||
api.interceptors.request.use((config) => {
|
||
const token = localStorage.getItem('token');
|
||
if (token) {
|
||
config.headers.Authorization = `Bearer ${token}`;
|
||
}
|
||
return config;
|
||
}, (error) => {
|
||
return Promise.reject(error);
|
||
});
|
||
|
||
export const getConfigs = () => api.get('/configs/');
|
||
export const createOrder = (data) => api.post('/orders/', data);
|
||
export const nativePay = (data) => api.post('/pay/', data);
|
||
export const getOrder = (id) => api.get(`/orders/${id}/`);
|
||
export const queryOrderStatus = (id) => api.get(`/orders/${id}/query_status/`);
|
||
export const initiatePayment = (orderId) => api.post(`/orders/${orderId}/initiate_payment/`);
|
||
export const confirmPayment = (orderId) => api.post(`/orders/${orderId}/confirm_payment/`);
|
||
|
||
export const getServices = () => api.get('/services/');
|
||
export const getServiceDetail = (id) => api.get(`/services/${id}/`);
|
||
export const createServiceOrder = (data) => api.post('/service-orders/', data);
|
||
export const getVCCourses = () => api.get('/courses/');
|
||
export const getVCCourseDetail = (id) => api.get(`/courses/${id}/`);
|
||
export const enrollCourse = (data) => api.post('/course-enrollments/', data);
|
||
|
||
export const sendSms = (data) => api.post('/auth/send-sms/', data);
|
||
export const queryMyOrders = (data) => api.post('/orders/my_orders/', data);
|
||
export const phoneLogin = (data) => api.post('/auth/phone-login/', data);
|
||
export const getUserInfo = () => {
|
||
// 如果没有获取用户信息的接口,可以暂时从本地解析或依赖 update_user_info 的返回
|
||
// 但后端有 /wechat/update/ 可以返回用户信息,或者我们可以加一个 /auth/me/
|
||
// 目前 phone_login 返回了用户信息,前端可以保存。
|
||
// 如果需要刷新,可以复用 update_user_info(虽然名字叫update,但传空通常返回当前信息,需确认后端逻辑)
|
||
// 查看后端逻辑:update_user_info 是 patch 更新,如果 data 为空,update 不会执行但会返回 serializer.data
|
||
return api.post('/wechat/update/', {});
|
||
};
|
||
|
||
export const updateUserInfo = (data) => api.post('/wechat/update/', data);
|
||
export const uploadUserAvatar = (data) => {
|
||
// 使用 axios 直接请求外部接口,避免 base URL 和拦截器干扰
|
||
return axios.post('https://data.tangledup-ai.com/upload?folder=uploads/market/avator', data, {
|
||
headers: {
|
||
'Content-Type': 'multipart/form-data',
|
||
}
|
||
});
|
||
};
|
||
|
||
// Community / Forum API
|
||
export const getTopics = (params) => api.get('/community/topics/', { params });
|
||
export const getTopicDetail = (id) => api.get(`/community/topics/${id}/`);
|
||
export const createTopic = (data) => api.post('/community/topics/', data);
|
||
export const getReplies = (params) => api.get('/community/replies/', { params });
|
||
export const createReply = (data) => api.post('/community/replies/', data);
|
||
export const uploadMedia = (data) => {
|
||
return api.post('/community/media/', data, {
|
||
headers: {
|
||
'Content-Type': 'multipart/form-data',
|
||
}
|
||
});
|
||
};
|
||
export const getStarUsers = () => api.get('/users/stars/');
|
||
export const getMyPaidItems = () => api.get('/users/paid-items/');
|
||
export const getAnnouncements = () => api.get('/community/announcements/');
|
||
|
||
export default api;
|