Compare commits

..

1 Commits

Author SHA1 Message Date
xu
63229eea7d SZX-1324视频播放卡顿。 2025-12-10 13:55:34 +08:00
17 changed files with 3282 additions and 4167 deletions

View File

@@ -87,16 +87,4 @@
border: 1px solid #e7e7e7 !important;
box-shadow: 0px 1px 5px 1px rgba(92,98,111,.3);
}
#app {
pointer-events: none;
}
#app > *:not(.case-expert-dialog) {
pointer-events: auto;
}
.case-expert-dialog {
pointer-events: auto;
}
</style>

View File

@@ -19,57 +19,52 @@ import errorCode from '@/utils/errorCode'
// const ReLoginUrl=process.env.VUE_APP_LOGIN_URL;
const TokenName = 'XBOE-Access-Token';
const TokenName='XBOE-Access-Token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
//用于普通的发送请求
const formRequest = axios.create({
const formRequest=axios.create({
// headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
// baseURL: process.env.VUE_APP_CESOURCE_BASE_API,
//超时
timeout: 60000,
})
//发送json对象的拦截器
formRequest.interceptors.request.use(config => {
})
//发送json对象的拦截器
formRequest.interceptors.request.use(config => {
//是否需要设置 token
const isToken = (config.headers || {}).isToken === false
if (getToken() && !isToken) {
config.headers[TokenName] = getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
}
return config
}, error => {
}, error => {
console.log(error)
Promise.reject(error)
});
formRequest.interceptors.response.use(res => {
});
formRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
//Message({message: msg, type: 'error'});
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
return res.data
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -89,22 +84,22 @@ formRequest.interceptors.response.use(res => {
})
return Promise.reject(error)
}
)
)
/**
* request请求,可以自定义参数
*/
const request = formRequest.request;
const request=formRequest.request;
/**
* get请求 ,只有url
*/
const get = function (baseURL, url) {
const get = function(baseURL,url){
return request({
baseURL,
url: url,
method: 'get',
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
@@ -113,60 +108,60 @@ const get = function (baseURL, url) {
* @param {Object} url
* @param {Object} postData
*/
const post = function (baseURL, url, postData) {
if (postData) {
postData = qs.stringify(postData);
const post=function(baseURL,url,postData){
if(postData){
postData=qs.stringify(postData);
}
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
data:postData,
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
//post请求
const postForm = function (baseURL, url, data) {
const postForm=function(baseURL,url,data){
return request({
baseURL,
url,
data,
method: 'post',
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
headers:{'Content-Type':'application/x-www-form-urlencoded'}
});
}
}
// const postJson=jsonRequest.post;
const postJson = function (baseURL, url, postData) {
const postJson=function(baseURL,url,postData){
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
data:postData,
headers:{'Content-Type':'application/json;charset=utf-8'},
})
}
const postPdf = function (baseURL, url, postData) {
const postPdf=function(baseURL,url,postData){
return request({
baseURL,
url: url,
responseType: 'blob',
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/pdf' },
data:postData,
headers:{'Content-Type':'application/pdf'},
})
}
// 导出文件请求定义
const postJsonToFile = function (baseURL, url, postData) {
const postJsonToFile=function(baseURL,url,postData){
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
data:postData,
headers:{'Content-Type':'application/json;charset=utf-8'},
responseType: 'blob'
})
}
@@ -175,33 +170,33 @@ const postJsonToFile = function (baseURL, url, postData) {
/**
* put请求
*/
const put = function (baseURL, url, data) {
if (data) {
data = qs.stringify(data);
const put=function(baseURL,url,data){
if(data){
data=qs.stringify(data);
}
return request({
baseURL,
url: url,
method: 'put',
data: data,
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
data:data,
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
const putJson = function (baseURL, url, data) {
const putJson=function(baseURL,url,data){
return request({
baseURL,
url: url,
method: 'put',
data: data,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
data:data,
headers:{'Content-Type':'application/json;charset=utf-8'},
})
}
export default {
tokenName: TokenName,
tokenName:TokenName,
request,
get,
post,

View File

@@ -19,61 +19,56 @@ import errorCode from '@/utils/errorCode'
// const ReLoginUrl=process.env.VUE_APP_LOGIN_URL;
const TokenName = 'token';
const TokenName='token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
//用于普通的发送请求
const formRequest = axios.create({
const formRequest=axios.create({
// headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
// baseURL: process.env.VUE_APP_CESOURCE_BASE_API,
//超时
timeout: 10000,
})
//发送json对象的拦截器
formRequest.interceptors.request.use(config => {
})
//发送json对象的拦截器
formRequest.interceptors.request.use(config => {
//是否需要设置 token
const isToken = (config.headers || {}).isToken === false
let curToken = getToken();
let curToken=getToken();
//curToken='eyJ0eXBlIjoidG9rZW4iLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC91LmJvZS5jb20iLCJpYXQiOjE2NzIzMTE2MTIsImV4cCI6MTY3MjMxODgxMiwiR2l2ZW5OYW1lIjoiYm9ldSIsInVzZXJJZCI6IjZCMDQ5RkFGLUMzMTQtN0NDRi0wRDI4LTBEMjNGNEM0MjUzMSIsInVJZCI6Ijk2NTM0MjAyNzQ5NzYwNzE2OCIsInBlcm1pc3Npb24iOiIifQ==.a4f41376e994c5fcd3ab537ce17572ef4c633863f87785cf7b6ffa353e2ed51c';
if (curToken && !isToken) {
config.headers[TokenName] = curToken // 让每个请求携带自定义token 请根据实际情况自行修改
}
return config
}, error => {
}, error => {
console.log(error)
Promise.reject(error)
});
formRequest.interceptors.response.use(res => {
});
formRequest.interceptors.response.use(res => {
//console.log(res);
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
return res.data
}
}
},
},
error => {
console.log('err', error)
console.log('err',error)
let { message } = error;
if (message == "Network Error") {
message = "网络异常,请稍后重试";
@@ -91,22 +86,22 @@ formRequest.interceptors.response.use(res => {
})
return Promise.reject(error)
}
)
)
/**
* request请求,可以自定义参数
*/
const request = formRequest.request;
const request=formRequest.request;
/**
* get请求 ,只有url
*/
const get = function (baseURL, url) {
const get = function(baseURL,url){
return request({
baseURL,
url: url,
method: 'get',
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
@@ -115,48 +110,48 @@ const get = function (baseURL, url) {
* @param {Object} url
* @param {Object} postData
*/
const post = function (baseURL, url, postData) {
if (postData) {
postData = qs.stringify(postData);
const post=function(baseURL,url,postData){
if(postData){
postData=qs.stringify(postData);
}
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
data:postData,
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
//post请求
const postForm = function (baseURL, url, data) {
const postForm=function(baseURL,url,data){
return request({
baseURL,
url,
data,
method: 'post',
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
headers:{'Content-Type':'application/x-www-form-urlencoded'}
});
}
}
// const postJson=jsonRequest.post;
const postJson = function (baseURL, url, postData) {
const postJson=function(baseURL,url,postData){
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/json' },
data:postData,
headers:{'Content-Type':'application/json'},
})
}
// 导出文件请求定义
const postJsonToFile = function (baseURL, url, postData) {
const postJsonToFile=function(baseURL,url,postData){
return request({
baseURL,
url: url,
method: 'post',
data: postData,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
data:postData,
headers:{'Content-Type':'application/json;charset=utf-8'},
responseType: 'blob'
})
}
@@ -165,33 +160,33 @@ const postJsonToFile = function (baseURL, url, postData) {
/**
* put请求
*/
const put = function (baseURL, url, data) {
if (data) {
data = qs.stringify(data);
const put=function(baseURL,url,data){
if(data){
data=qs.stringify(data);
}
return request({
baseURL,
url: url,
method: 'put',
data: data,
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
data:data,
headers:{'Content-Type':'application/x-www-form-urlencoded'}
})
}
const putJson = function (baseURL, url, data) {
const putJson=function(baseURL,url,data){
return request({
baseURL,
url: url,
method: 'put',
data: data,
headers: { 'Content-Type': 'application/json;charset=utf-8' },
data:data,
headers:{'Content-Type':'application/json;charset=utf-8'},
})
}
export default {
tokenName: TokenName,
tokenName:TokenName,
request,
get,
post,

View File

@@ -18,13 +18,13 @@ import errorCode from '@/utils/errorCode'
*delete请求 axios.delete(url[, config])
*/
const ReLoginUrl = process.env.VUE_APP_LOGIN_URL;
const TokenName = 'token';
const ReLoginUrl=process.env.VUE_APP_LOGIN_URL;
const TokenName='token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
const jsonRequest = axios.create({
headers: { 'Content-Type': 'application/json;charset=utf-8' },
const jsonRequest=axios.create({
headers:{'Content-Type':'application/json;charset=utf-8'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_BOE_BASE_API,
//超时
@@ -47,32 +47,27 @@ jsonRequest.interceptors.request.use(config => {
jsonRequest.interceptors.response.use(res => {
const code1 = res.data.status || 200;
const code = parseInt(code1);
if (code === 200) {
const code=parseInt(code1);
if(code===200){
return res.data
} else {
if (code == 6001) { //对方是字符串,所以这里不要使用三个等号
}else{
if(code == 6001){ //对方是字符串,所以这里不要使用三个等号
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
//return res.data;
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err:' + res.data.error);
//return Promise.reject(new Error(res.data.message))
return res.data;
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -96,8 +91,8 @@ jsonRequest.interceptors.response.use(res => {
)
//用于普通的发送请求
const formRequest = axios.create({
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
const formRequest=axios.create({
headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_BOE_BASE_API,
//超时
@@ -117,30 +112,25 @@ formRequest.interceptors.request.use(config => {
});
formRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code == 6001) { //对方是字符串,所以这里不要使用三个等号
}else{
if(code == 6001){ //对方是字符串,所以这里不要使用三个等号
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
//return Promise.reject(new Error(res.data.message))
return res.data;//返回给用户做业务处理
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -164,44 +154,44 @@ formRequest.interceptors.response.use(res => {
)
//request请求
const request = function (cfg) {
if (cfg.data) {
cfg.data = qs.stringify(cfg.data);
const request=function(cfg){
if(cfg.data){
cfg.data=qs.stringify(cfg.data);
}
};
//requestJson请求
const requestJson = jsonRequest.request;
const requestJson=jsonRequest.request;
//get请求
const get = formRequest.request;
const get=formRequest.request;
//post请求
const post = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const post=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.post(url, data, config);
return formRequest.post(url,data,config);
}
//postJson请求
const postJson = jsonRequest.post;
const postJson=jsonRequest.post;
//put请求
const put = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const put=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.put(url, data, config);
return formRequest.put(url,data,config);
}
//putJson请求
const putJson = jsonRequest.put;
const putJson=jsonRequest.put;
//patch请求
const patch = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const patch=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.patch(url, data, config);
return formRequest.patch(url,data,config);
}
//patchJson请求
const patchJson = jsonRequest.patch;
const patchJson=jsonRequest.patch;
//delete请求
const del = formRequest.delete;
const del=formRequest.delete;
export default {

View File

@@ -17,12 +17,12 @@ import errorCode from '@/utils/errorCode'
*delete请求 axios.delete(url[, config])
*/
const ReLoginUrl = "/login";
const TokenName = 'XBOE-Access-Token';
const ReLoginUrl="/login";
const TokenName='XBOE-Access-Token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
const jsonRequest = axios.create({
headers: { 'Content-Type': 'application/json;charset=utf-8' },
const jsonRequest=axios.create({
headers:{'Content-Type':'application/json;charset=utf-8'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_CESOURCE_BASE_API,
//超时
@@ -45,30 +45,25 @@ jsonRequest.interceptors.request.use(config => {
jsonRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err:' + res.data.error);
return res.data;
//return Promise.reject(new Error(res.data.message))
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -91,8 +86,8 @@ jsonRequest.interceptors.response.use(res => {
)
//用于普通的发送请求
const formRequest = axios.create({
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
const formRequest=axios.create({
headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_CESOURCE_BASE_API,
//超时
@@ -112,29 +107,24 @@ formRequest.interceptors.request.use(config => {
});
formRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
return res.data
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -157,44 +147,44 @@ formRequest.interceptors.response.use(res => {
)
//request请求
const request = function (cfg) {
if (cfg.data) {
cfg.data = qs.stringify(cfg.data);
const request=function(cfg){
if(cfg.data){
cfg.data=qs.stringify(cfg.data);
}
};
//requestJson请求
const requestJson = jsonRequest.request;
const requestJson=jsonRequest.request;
//get请求
const get = formRequest.request;
const get=formRequest.request;
//post请求
const post = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const post=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.post(url, data, config);
return formRequest.post(url,data,config);
}
//postJson请求
const postJson = jsonRequest.post;
const postJson=jsonRequest.post;
//put请求
const put = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const put=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.put(url, data, config);
return formRequest.put(url,data,config);
}
//putJson请求
const putJson = jsonRequest.put;
const putJson=jsonRequest.put;
//patch请求
const patch = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const patch=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.patch(url, data, config);
return formRequest.patch(url,data,config);
}
//patchJson请求
const patchJson = jsonRequest.patch;
const patchJson=jsonRequest.patch;
//delete请求
const del = formRequest.delete;
const del=formRequest.delete;
export default {

View File

@@ -17,12 +17,12 @@ import errorCode from '@/utils/errorCode'
*delete请求 axios.delete(url[, config])
*/
const ReLoginUrl = "/login";
const TokenName = 'XBOE-Access-Token';
const ReLoginUrl="/login";
const TokenName='XBOE-Access-Token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
const jsonRequest = axios.create({
headers: { 'Content-Type': 'application/json;charset=utf-8' },
const jsonRequest=axios.create({
headers:{'Content-Type':'application/json;charset=utf-8'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_STAT_BASE_API,
//超时
@@ -45,30 +45,25 @@ jsonRequest.interceptors.request.use(config => {
jsonRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err:' + res.data.error);
return res.data;
//return Promise.reject(new Error(res.data.message))
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -91,8 +86,8 @@ jsonRequest.interceptors.response.use(res => {
)
//用于普通的发送请求
const formRequest = axios.create({
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
const formRequest=axios.create({
headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_STAT_BASE_API,
//超时
@@ -112,29 +107,24 @@ formRequest.interceptors.request.use(config => {
});
formRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code === 401) {
}else{
if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = this.webBaseUrl + ReLoginUrl;
} else {
window.location.href = this.webBaseUrl + ReLoginUrl;
}
// location.href = this.webBaseUrl + ReLoginUrl;
location.href = this.webBaseUrl + ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else {
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
return res.data
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -157,44 +147,44 @@ formRequest.interceptors.response.use(res => {
)
//request请求
const request = function (cfg) {
if (cfg.data) {
cfg.data = qs.stringify(cfg.data);
const request=function(cfg){
if(cfg.data){
cfg.data=qs.stringify(cfg.data);
}
};
//requestJson请求
const requestJson = jsonRequest.request;
const requestJson=jsonRequest.request;
//get请求
const get = formRequest.request;
const get=formRequest.request;
//post请求
const post = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const post=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.post(url, data, config);
return formRequest.post(url,data,config);
}
//postJson请求
const postJson = jsonRequest.post;
const postJson=jsonRequest.post;
//put请求
const put = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const put=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.put(url, data, config);
return formRequest.put(url,data,config);
}
//putJson请求
const putJson = jsonRequest.put;
const putJson=jsonRequest.put;
//patch请求
const patch = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const patch=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.patch(url, data, config);
return formRequest.patch(url,data,config);
}
//patchJson请求
const patchJson = jsonRequest.patch;
const patchJson=jsonRequest.patch;
//delete请求
const del = formRequest.delete;
const del=formRequest.delete;
export default {

View File

@@ -11,16 +11,16 @@ import xpage from '@/utils/xpage'
NProgress.configure({ showSpinner: false })
const whiteList = ['/login', '/logout', '/loading', '/pc/loading', '/500', '/auth-redirect', '/forget', '/reset/password']
const whiteList = ['/login','/logout','/loading','/pc/loading','/500','/auth-redirect','/forget','/reset/password']
router.beforeEach((to, from, next) => {
watermark.set("");
//动态计算文件的路径
let configPath = process.env.VUE_APP_FILE_RELATIVE_PATH;
if (configPath.startsWith('http')) {
xpage.constants.fileBaseUrl = configPath;
} else {
xpage.constants.fileBaseUrl = window.location.protocol + '//' + window.location.host + configPath;
let configPath=process.env.VUE_APP_FILE_RELATIVE_PATH;
if(configPath.startsWith('http')){
xpage.constants.fileBaseUrl=configPath;
}else{
xpage.constants.fileBaseUrl=window.location.protocol+'//'+window.location.host+configPath;
}
NProgress.start();
@@ -28,21 +28,21 @@ router.beforeEach((to, from, next) => {
if (whiteList.indexOf(to.path) !== -1) {
// 在免登录白名单,直接进入
next()
} else {
if (getToken()) {
if (to.path === '/login') {
}else{
if(getToken()){
if(to.path === '/login'){
// 如果是外部用户,把配置的路由跳转到个人中心
if (store.getters.userInfo.role === 2) {
next({ path: process.env.VUE_APP_PUBLIC_PATH + '/uc/study/courses' })
} else {
next({ path: process.env.VUE_APP_PUBLIC_PATH + '/index' })
if(store.getters.userInfo.role === 2){
next({ path: process.env.VUE_APP_PUBLIC_PATH+'/uc/study/courses' })
}else{
next({ path: process.env.VUE_APP_PUBLIC_PATH+'/index' })
}
NProgress.done();
} else {
//console.log('store.getters.userInfo:',store.getters.userInfo.role)
// 如果是外部用户,把配置的路由跳转到个人中心
if (store.getters.userInfo.role === 2) {
if (to.path === '/index' || to.path === '/course' || to.path === '/case' || to.path === '/article') location.href = '/pc/uc/study/task'
if(store.getters.userInfo.role === 2){
if(to.path === '/index' || to.path === '/course' || to.path === '/case' || to.path === '/article' ) location.href = '/pc/uc/study/task'
}
//后续这里需要增加一定的控制
if (!store.getters.init) {
@@ -56,17 +56,17 @@ router.beforeEach((to, from, next) => {
store.dispatch('resOwner/loadResOwners');
store.dispatch('sysType/loadSysTypes');
store.commit('app/SET_INITDATA', true);
store.commit('app/SET_INITDATA',true);
//routers数据先使用固定的以后在初始化接口中返回
let myRouters = routers();
store.dispatch('GenerateRoutes', { routers: myRouters }).then(accessRoutes => {
let myRouters=routers();
store.dispatch('GenerateRoutes',{routers:myRouters}).then(accessRoutes=>{
router.addRoutes(accessRoutes) // 动态添加可访问路由表
next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
});
}).catch(err => {
console.log(err);
store.commit('app/SET_INITDATA', false);
store.commit('app/SET_INITDATA',false);
//如果初始化错误,就不再执行了,不然会一直循环下去
next({ path: '/500' })
//NProgress.done();
@@ -78,7 +78,7 @@ router.beforeEach((to, from, next) => {
}
//next();
} else {
}else{
//next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
//设置之前的路径
@@ -86,12 +86,7 @@ router.beforeEach((to, from, next) => {
//console.log(location.href,'location.href');
//let urlPre=window.location.protocol+'//'+window.location.host;
//let backUrl=location.href.substring(urlPre.length); encodeURIComponent()
if (top !== window) { // 判断当前是否在iframe内
top.location.href = process.env.VUE_APP_LOGIN_URL + "?returnUrl=" + encodeURIComponent(location.href);
} else {
window.location.href = process.env.VUE_APP_LOGIN_URL + "?returnUrl=" + encodeURIComponent(location.href);
}
// location.href=process.env.VUE_APP_LOGIN_URL+"?returnUrl="+encodeURIComponent(location.href);
location.href=process.env.VUE_APP_LOGIN_URL+"?returnUrl="+encodeURIComponent(location.href);
NProgress.done()
}

View File

@@ -19,13 +19,13 @@ import errorCode from '@/utils/errorCode'
//const ReLoginUrl="/login";
const ReLoginUrl = process.env.VUE_APP_LOGIN_URL;
const ReLoginUrl=process.env.VUE_APP_LOGIN_URL;
const TokenName = 'XBOE-Access-Token';
const TokenName='XBOE-Access-Token';
/**axios.defaults.headers['Content-Type'] = 'application/x-www-form-urlencoded'**/
//只是用于发送json对象数据时使用post,put,patch
const jsonRequest = axios.create({
headers: { 'Content-Type': 'application/json;charset=utf-8' },
const jsonRequest=axios.create({
headers:{'Content-Type':'application/json;charset=utf-8'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_BASE_API,
//超时
@@ -48,56 +48,36 @@ jsonRequest.interceptors.request.use(config => {
jsonRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code == 6001) { //针对于老系统的处理
}else{
if(code == 6001){ //针对于老系统的处理
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 401) {
}else if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 402) {
}else if(code === 402){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
//return res.data;
} else if (code === 302) {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
} else {
}else if(code===302){
location.href = ReLoginUrl;
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err:' + res.data.error);
//return Promise.reject(new Error(res.data.message))
return res.data;
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -121,8 +101,8 @@ jsonRequest.interceptors.response.use(res => {
)
//用于普通的发送请求
const formRequest = axios.create({
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
const formRequest=axios.create({
headers:{'Content-Type':'application/x-www-form-urlencoded'},
// axios中请求配置有baseURL选项表示请求URL公共部分
baseURL: process.env.VUE_APP_BASE_API,
//超时
@@ -142,55 +122,35 @@ formRequest.interceptors.request.use(config => {
});
formRequest.interceptors.response.use(res => {
const code = res.data.status || 200;
if (code === 200) {
if(code===200){
return res.data
} else {
if (code == 6001) { //针对于老系统的处理,因为老系统是字符串,所以这里不使用三等于号
}else{
if(code == 6001){ //针对于老系统的处理,因为老系统是字符串,所以这里不使用三等于号
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 401) {
}else if(code === 401){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 402) {
}else if(code === 402){
store.dispatch('LogOut').then(() => {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
location.href = ReLoginUrl;
})
} else if (code === 403) {
var msg = '当前操作没有权限';
Message({ message: msg, type: 'error' });
}else if(code===403){
var msg='当前操作没有权限';
Message({message: msg, type: 'error'});
return Promise.reject(new Error(msg))
} else if (code === 302) {
if (top !== window) { // 判断当前是否在iframe内
top.location.href = ReLoginUrl;
} else {
window.location.href = ReLoginUrl;
}
// location.href = ReLoginUrl;
} else {
}else if(code===302){
location.href = ReLoginUrl;
}else{
//Message({message: res.data.message, type: 'error'});
//console.log('err' + res.data.error);
//return Promise.reject(new Error(res.data.message))
return res.data;//返回给用户做业务处理
}
}
},
},
error => {
console.log('err' + error)
let { message } = error;
@@ -214,48 +174,48 @@ formRequest.interceptors.response.use(res => {
)
//request请求
const request = function (cfg) {
if (cfg.data) {
cfg.data = qs.stringify(cfg.data);
const request=function(cfg){
if(cfg.data){
cfg.data=qs.stringify(cfg.data);
}
};
//requestJson请求
const requestJson = jsonRequest.request;
const requestJson=jsonRequest.request;
//get请求
const get = formRequest.request;
const get=formRequest.request;
//post请求
const post = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const post=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.post(url, data, config);
return formRequest.post(url,data,config);
}
//post请求
const postForm = function (url, data, config) {
return formRequest.post(url, data, config);
const postForm=function(url,data,config){
return formRequest.post(url,data,config);
}
//postJson请求
const postJson = jsonRequest.post;
const postJson=jsonRequest.post;
//put请求
const put = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const put=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.put(url, data, config);
return formRequest.put(url,data,config);
}
//putJson请求
const putJson = jsonRequest.put;
const putJson=jsonRequest.put;
//patch请求
const patch = function (url, data, config) {
if (data) {
data = qs.stringify(data);
const patch=function(url,data,config){
if(data){
data=qs.stringify(data);
}
return formRequest.patch(url, data, config);
return formRequest.patch(url,data,config);
}
//patchJson请求
const patchJson = jsonRequest.patch;
const patchJson=jsonRequest.patch;
//delete请求
const del = formRequest.delete;
const del=formRequest.delete;
export default {

View File

@@ -163,12 +163,11 @@
<!-- 精品课模块 -->
<div class="xcontent2-main">
<div class="modules-title xindex-main" v-if="this.qusisityList.list.length > 0">
<!-- <span class="jin-text">精品课</span> -->
<div class="jin-zhe"></div>
<!-- <span class="modules-text" style="color: #3D86F4;">精品课</span> -->
<span class="quyer-tag" style="margin-left: 0px;">
<!-- <img src="../assets/images/tutoring1.pn" alt=""> -->
<img class="modules-text" style="height: 28px;" src="../assets/images/course/courseTitle.png" alt="">
</span>
<span class="more">
<router-link to="/qualityCourse">查看更多>></router-link>
</span>
@@ -2827,15 +2826,6 @@ export default {
display: flex;
.modules-title {
position: relative;
.jin-zhe{
width: 410px;
height: 30px;
background: #f7f7f9;
position: absolute;
left: 86px;
}
.modules-text {
height: 28px;
font-size: 20px;
@@ -3146,13 +3136,4 @@ export default {
border: 1px solid #d9edf7;
//overflow: hidden;
}
.jin-text{
font-family: "Source Han Sans CN", "SourceHanSansCN", sans-serif !important;
font-weight: bold;
font-size: 20px;
color: #3E87F5;
// line-height: 29px;/
text-align: justify;
font-style: normal;
}
</style>

View File

@@ -5,61 +5,56 @@
</template>
<script>
import Cookies from "vue-cookies";
import apiLogin from "@/api/login.js";
import { getToken, setToken } from "@/utils/token";
export default {
mounted() {
this.toUrl = this.$route.query.returnUrl;
let token = getToken();
let $this = this;
if (!token) {
import Cookies from 'vue-cookies'
import apiLogin from '@/api/login.js'
import { getToken,setToken } from '@/utils/token'
export default{
mounted(){
this.toUrl=this.$route.query.returnUrl;
let token=getToken();
let $this=this;
if(!token){
//console.log(token,'未获取token');
setTimeout(function () {
$this.curToken = getToken();
if (!$this.curToken) {
setTimeout(function(){
$this.curToken=getToken();
if(!$this.curToken){
//console.log(token,'第二次未获取token');
if (top !== window) {
// 判断当前是否在iframe内
top.location.href = process.env.VUE_APP_LOGIN_URL;
} else {
window.location.href = process.env.VUE_APP_LOGIN_URL;
}
// location.href = process.env.VUE_APP_LOGIN_URL;
} else {
location.href = process.env.VUE_APP_LOGIN_URL;
}else{
$this.boeLogin();
}
}, 500);
} else {
this.curToken = token;
},500);
}else{
this.curToken=token;
this.boeLogin();
}
},
data() {
data(){
return {
curToken: "",
toUrl: "",
};
curToken:'',
toUrl:''
}
},
methods: {
boeLogin() {
apiLogin.boeLogin(this.curToken).then((rs) => {
if (rs.status == 200) {
methods:{
boeLogin(){
apiLogin.boeLogin(this.curToken).then(rs=>{
if(rs.status==200){
//setToken(rs.result.access_token);
localStorage.setItem(this.$xpage.constants.newLoginKey, 1);
if (this.toUrl) {
location.href = this.toUrl;
} else {
this.$router.push({ path: "/index" });
localStorage.setItem(this.$xpage.constants.newLoginKey,1);
if(this.toUrl){
location.href=this.toUrl;
}else{
this.$router.push({ path: "/index" })
}
//this.$router.push({ path: "/index" })
} else {
this.$message.error("登录失败:" + rs.message);
}else{
this.$message.error("登录失败:"+rs.message);
}
})
}
}
}
});
},
},
};
</script>
<style>

View File

@@ -134,10 +134,7 @@
<div>
<div style="line-height: 30px;">
<div>请在当前面板选择需要上传的课件</div>
<div style="">提示<br>
1课件大小超过1G时无法上传请先压缩视频或剪切成多个再上传<br>
2视频码率需在1.5Mb/s及以下帧数需在30帧及以下<br>
3如果上传zip文件必须是scorm标准打包文件</div>
<div style="">提示课件大小超过1G时无法上传请先压缩视频或剪切成多个再上传视频码率需在1.5Mb/s及以下帧数需在30帧及以下如果上传zip文件必须是scorm标准打包文件</div>
</div>
<div>
<div style="display: flex;line-height: 30px;padding: 5px 0px;">

View File

@@ -2,15 +2,17 @@
<div>
<!-- 最大化状态的弹窗 -->
<el-dialog
v-if="dialogVisible && windowState === 'maximized'"
v-show=" windowState === 'maximized'"
v-if="dialogVisible"
:visible="true"
:close-on-click-modal="false"
:show-close="true"
@close="onClose"
class="case-expert-dialog"
:modal="false"
:append-to-body="true"
:fullscreen="false"
top="0"
top="10vh"
v-resizeable
v-draggable
>
@@ -33,7 +35,6 @@
class="welcome-message"
ref="messageContainer"
@scroll="handleScroll"
@wheel="handleWheel"
>
<div class="message-text" v-for="(item, index) in messageList" :key="index">
<messages :messageData="item" :suggestions="suggestions" @getMinWindow="minimizeWindow"></messages>
@@ -192,7 +193,7 @@ export default {
left: parseInt(dialogEl.style.left),
top: parseInt(dialogEl.style.top)
};
// sessionStorage.setItem('aiCallDialogPosition', JSON.stringify(currentPosition));
sessionStorage.setItem('aiCallDialogPosition', JSON.stringify(currentPosition));
// 移除全局事件监听
document.removeEventListener('mousemove', handleMouseMove);
@@ -497,9 +498,6 @@ export default {
watch: {
dialogVisible: {
handler(newVal) {
console.log('dialogVisible发生变化');
console.log(newVal);
console.log(this.windowState);
if (newVal) {
this.$nextTick(() => {
// 获取对话框元素
@@ -516,12 +514,12 @@ export default {
}
// 检查是否有保存的位置状态
// const savedPosition = sessionStorage.getItem('aiCallDialogPosition');
// if (savedPosition) {
// const { left, top } = JSON.parse(savedPosition);
// dialogEl.style.left = left + 'px';
// dialogEl.style.top = top + 'px';
// }
const savedPosition = sessionStorage.getItem('aiCallDialogPosition');
if (savedPosition) {
const { left, top } = JSON.parse(savedPosition);
dialogEl.style.left = left + 'px';
dialogEl.style.top = top + 'px';
}
}
let doc = document.querySelector('.welcome-message')
@@ -568,7 +566,7 @@ closeMinimizedWindow() {
console.log('关闭弹窗')
// 清除保存的状态
sessionStorage.removeItem('aiCallDialogSize');
// sessionStorage.removeItem('aiCallDialogPosition');
sessionStorage.removeItem('aiCallDialogPosition');
this.$emit('close')
// 可以在这里执行其他逻辑
},
@@ -597,7 +595,6 @@ closeMinimizedWindow() {
// 处理加载状态
handleLoading(status) {
console.log('handleLoading---'+status);
this.isLoading = status;
},
@@ -658,31 +655,6 @@ closeMinimizedWindow() {
}
},
// 处理鼠标滚轮事件
handleWheel(event) {
const element = this.$refs.messageContainer;
if (!element) return;
// 阻止事件冒泡,防止滚动底层页面
event.stopPropagation();
// 计算滚动方向和距离
const delta = event.deltaY || event.detail || event.wheelDelta;
// 检查是否可以继续滚动
if (delta < 0 && element.scrollTop === 0) {
// 向上滚动且已在顶部,阻止默认行为
event.preventDefault();
} else if (delta > 0 && element.scrollHeight - element.scrollTop <= element.clientHeight) {
// 向下滚动且已在底部,阻止默认行为
event.preventDefault();
} else {
// 允许在容器内滚动
element.scrollTop += delta;
event.preventDefault();
}
},
// 最小化窗口的点击事件处理方法
onMinimizedWindowClick() {
// 当点击最小化窗口时如果dialogVisible为false则通过事件通知父组件显示对话框
@@ -697,9 +669,6 @@ closeMinimizedWindow() {
</script>
<style scoped lang="scss">
::v-deep .el-dialog__wrapper{
position: unset!important;
}
.case-expert-dialog {
::v-deep .el-dialog{
background: url("./components/u762.svg") no-repeat ;
@@ -708,8 +677,6 @@ closeMinimizedWindow() {
overflow: hidden;
display: flex;
flex-direction: column;
pointer-events: auto;
z-index: 2000;
//background-color: rgba(255, 255, 255, 0.8);
}

File diff suppressed because it is too large Load Diff

View File

@@ -5,7 +5,7 @@
type="textarea"
class="input-placeholder"
placeholder="有问题,尽管问"
@keyup.enter.native.prevent="handleSend"
@keyup.enter.native="handleSend"
:disabled="disabled"
:autosize="{ minRows: 2, maxRows: 4}"
resize="none"
@@ -56,14 +56,7 @@ export default {
}
},
methods: {
handleSend(event) {
// 阻止事件的默认行为和冒泡
if (event) {
event.preventDefault();
event.stopPropagation();
console.log('preventDefault');
}
console.log('handleSend');
handleSend() {
if (!this.inputContent.trim() || this.disabled) return
// 添加用户消息到列表
const userMessage = {

View File

@@ -2590,7 +2590,7 @@ a.custom2 {
}
.course-tags {
margin: 10px 0 0;
margin: 5px 0;
min-height: 20px;
}

View File

@@ -2477,10 +2477,6 @@ export default {
background-color: #f4f4f5;
border-color: #e9e9eb;
}
.course-tags {
margin: 10px 0 0;
min-height: 20px;
}
.course-tags ::v-deep .el-tag .keyword-highlight,
.course-tags ::v-deep .el-tag .exact-match-highlight {
color: #387DF7 !important;

File diff suppressed because it is too large Load Diff