| | |
| | | import { useGlobSetting } from '/@/hooks/setting'; |
| | | import { useMessage } from '/@/hooks/web/useMessage'; |
| | | import { RequestEnum, ResultEnum, ContentTypeEnum } from '/@/enums/httpEnum'; |
| | | import { isString } from '/@/utils/is'; |
| | | import { isString, isUnDef, isNull, isEmpty } from '/@/utils/is'; |
| | | import { getToken } from '/@/utils/auth'; |
| | | import { setObjToUrlParams, deepMerge } from '/@/utils'; |
| | | import { useErrorLogStoreWithOut } from '/@/store/modules/errorLog'; |
| | |
| | | import { joinTimestamp, formatRequestDate } from './helper'; |
| | | import { useUserStoreWithOut } from '/@/store/modules/user'; |
| | | import { AxiosRetry } from '/@/utils/http/axios/axiosRetry'; |
| | | import axios from 'axios'; |
| | | |
| | | const globSetting = useGlobSetting(); |
| | | const urlPrefix = globSetting.urlPrefix; |
| | | const { createMessage, createErrorModal } = useMessage(); |
| | | const { createMessage, createErrorModal, createSuccessModal } = useMessage(); |
| | | |
| | | /** |
| | | * @description: 数据处理,方便区分多种处理方式 |
| | | */ |
| | | const transform: AxiosTransform = { |
| | | /** |
| | | * @description: 处理请求数据。如果数据不是预期格式,可直接抛出错误 |
| | | * @description: 处理响应数据。如果数据不是预期格式,可直接抛出错误 |
| | | */ |
| | | transformRequestHook: (res: AxiosResponse<Result>, options: RequestOptions) => { |
| | | transformResponseHook: (res: AxiosResponse<Result>, options: RequestOptions) => { |
| | | const { t } = useI18n(); |
| | | const { isTransformResponse, isReturnNativeResponse } = options; |
| | | // 是否返回原生响应头 比如:需要获取响应头时使用该属性 |
| | |
| | | // 这里逻辑可以根据项目进行修改 |
| | | const hasSuccess = data && Reflect.has(data, 'code') && code === ResultEnum.SUCCESS; |
| | | if (hasSuccess) { |
| | | let successMsg = message; |
| | | |
| | | if (isNull(successMsg) || isUnDef(successMsg) || isEmpty(successMsg)) { |
| | | successMsg = t(`sys.api.operationSuccess`); |
| | | } |
| | | |
| | | if (options.successMessageMode === 'modal') { |
| | | createSuccessModal({ title: t('sys.api.successTip'), content: successMsg }); |
| | | } else if (options.successMessageMode === 'message') { |
| | | createMessage.success(successMsg); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | |
| | | } |
| | | } |
| | | |
| | | // errorMessageMode=‘modal’的时候会显示modal错误弹窗,而不是消息提示,用于一些比较重要的错误 |
| | | // errorMessageMode='modal'的时候会显示modal错误弹窗,而不是消息提示,用于一些比较重要的错误 |
| | | // errorMessageMode='none' 一般是调用时明确表示不希望自动弹出错误提示 |
| | | if (options.errorMessageMode === 'modal') { |
| | | createErrorModal({ title: t('sys.api.errorTip'), content: timeoutMsg }); |
| | |
| | | } else { |
| | | if (!isString(params)) { |
| | | formatDate && formatRequestDate(params); |
| | | if (Reflect.has(config, 'data') && config.data && Object.keys(config.data).length > 0) { |
| | | if ( |
| | | Reflect.has(config, 'data') && |
| | | config.data && |
| | | (Object.keys(config.data).length > 0 || config.data instanceof FormData) |
| | | ) { |
| | | config.data = data; |
| | | config.params = params; |
| | | } else { |
| | |
| | | const err: string = error?.toString?.() ?? ''; |
| | | let errMessage = ''; |
| | | |
| | | if (axios.isCancel(error)) { |
| | | return Promise.reject(error); |
| | | } |
| | | |
| | | try { |
| | | if (code === 'ECONNABORTED' && message.indexOf('timeout') !== -1) { |
| | | errMessage = t('sys.api.apiTimeoutMessage'); |
| | |
| | | |
| | | function createAxios(opt?: Partial<CreateAxiosOptions>) { |
| | | return new VAxios( |
| | | // 深度合并 |
| | | deepMerge( |
| | | { |
| | | // See https://developer.mozilla.org/en-US/docs/Web/HTTP/Authentication#authentication_schemes |