47 lines
1.3 KiB
TypeScript
47 lines
1.3 KiB
TypeScript
|
import axios from 'axios';
|
||
|
import _Vue from 'vue';
|
||
|
|
||
|
class AxiosPlugin {
|
||
|
public install(Vue: typeof _Vue) {
|
||
|
// Full config: https://github.com/axios/axios#request-config
|
||
|
// axios.defaults.baseURL = process.env.baseURL || process.env.apiUrl || '';
|
||
|
// axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
|
||
|
// axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
|
||
|
|
||
|
const config = {
|
||
|
// baseURL: process.env.baseURL || process.env.apiUrl || ""
|
||
|
// timeout: 60 * 1000, // Timeout
|
||
|
// withCredentials: true, // Check cross-site Access-Control
|
||
|
};
|
||
|
|
||
|
const _axios = axios.create(config);
|
||
|
|
||
|
_axios.interceptors.request.use(
|
||
|
function (config) {
|
||
|
// Do something before request is sent
|
||
|
return config;
|
||
|
},
|
||
|
function (error) {
|
||
|
// Do something with request error
|
||
|
return Promise.reject(error);
|
||
|
}
|
||
|
);
|
||
|
|
||
|
// Add a response interceptor
|
||
|
_axios.interceptors.response.use(
|
||
|
function (response) {
|
||
|
// Do something with response data
|
||
|
return response;
|
||
|
},
|
||
|
function (error) {
|
||
|
// Do something with response error
|
||
|
return Promise.reject(error);
|
||
|
}
|
||
|
);
|
||
|
|
||
|
Vue.prototype.$axios = _axios;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export default new AxiosPlugin();
|