mirror of
https://github.com/WeBankFinTech/fes.js.git
synced 2025-04-05 19:41:57 +08:00
29 lines
1.4 KiB
TypeScript
29 lines
1.4 KiB
TypeScript
import { AxiosRequestConfig, AxiosResponse, AxiosError } from 'axios';
|
|
import {Ref} from 'vue';
|
|
|
|
|
|
type RequestInterceptor = (value: AxiosRequestConfig) => AxiosRequestConfig | [(value: AxiosRequestConfig) => AxiosRequestConfig, (error: any) => any];
|
|
type ResponseInterceptor = (value: AxiosResponse) => AxiosResponse | [(value: AxiosResponse) => AxiosResponse, (error: any) => any];
|
|
|
|
interface RequestPluginOption {
|
|
mergeRequest?: boolean;
|
|
dataHandler?(data: any, response: AxiosResponse): any;
|
|
errorHandler?(error: AxiosError | {type: string, msg: string, [key: string]: string}): void;
|
|
cache?: boolean | {
|
|
type: 'ram' | 'sessionStorage' | 'localStorage',
|
|
cacheTime: number;
|
|
}
|
|
}
|
|
|
|
export function request(url: string, data?: null | Record<string, any>, options?: AxiosRequestConfig & RequestPluginOption ): Promise<any>
|
|
export function useRequest(url: string, data?: null | Record<string, any>, options?: AxiosRequestConfig & RequestPluginOption ): {loadingRef: Ref<boolean>; errorRef: Ref<Error>; dataRef: Ref<any>}
|
|
declare module "@fesjs/fes" {
|
|
interface PluginRuntimeConfig {
|
|
request?: {
|
|
dataHandler?(data: any, response: AxiosResponse): any;
|
|
errorHandler?(error: AxiosError | {type: string, msg: string, [key: string]: string}): void;
|
|
requestInterceptors?: RequestInterceptor[];
|
|
responseInterceptors?: ResponseInterceptor[];
|
|
} & AxiosRequestConfig;
|
|
}
|
|
} |