create-vite-app-cli
Version:
a fast create webapp template cli, perfect engineering development experience, currently supported template presets include: - `react-ts` (React + TypeScript + Vite + Pnpm + Zustand + Openapi + Docker) - `vue-ts` (Vue 3 + TypeScript + Vite + Pnpm + Pinia
59 lines (50 loc) • 1.66 kB
text/typescript
import axios, { AxiosRequestConfig } from "axios";
// import { ILoginInfoStorageState, defaultLoginInfoStorage, loginInfoStorageKey } from "../store";
import { getConfig } from "./config";
import { IUserInfo, defaultUserInfo, userInfoStorageKey } from "../store/user";
const BASE_URL = getConfig().baseURL;
const instance = axios.create({
baseURL: BASE_URL,
headers: {
"Content-Type": "application/json",
},
timeout: 60000, // 超时时间60秒
});
instance.interceptors.response.use((response) => {
// 统一错误处理
// data解构
if (response.data) {
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
return response.data;
}
return response;
});
instance.interceptors.request.use((config) => {
const userInfoStorageStr = globalThis.localStorage.getItem(userInfoStorageKey);
const userInfo = userInfoStorageStr ? (JSON.parse(userInfoStorageStr).userInfo as IUserInfo) : defaultUserInfo;
if (userInfo.accessToken) {
config.headers.Authorization = userInfo.accessToken;
}
return config;
});
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const request = async <T = any>(url: string, options: AxiosRequestConfig & { requestType?: "json" | "form" } = {}) => {
// 兼容from data文件上传的情况
const { requestType, ...rest } = options;
if (requestType === "form") {
return await instance.request<T, T>({
url,
...rest,
headers: {
...(rest.headers || {}),
"Content-Type": "multipart/form-data",
},
});
} else {
return await instance.request<T, T>({
url,
...rest,
});
}
};
export default request;