Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
W
wangxiaolu-sfa-ui
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
sfa
wangxiaolu-sfa-ui
Commits
188f2da5
提交
188f2da5
authored
8月 22, 2025
作者:
lidongxu
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'release' into dev
上级
041dc901
86816a7f
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
12 个修改的文件
包含
89 行增加
和
43 行删除
+89
-43
.env.development
.env.development
+3
-3
.env.production
.env.production
+3
-3
.env.staging
.env.staging
+3
-3
App.vue
src/App.vue
+16
-7
login.js
src/api/common/login.js
+8
-3
permission.js
src/permission.js
+2
-2
user.js
src/store/modules/user.js
+14
-4
version.js
src/store/modules/version.js
+2
-2
auth.js
src/utils/auth.js
+15
-0
request.js
src/utils/request.js
+22
-15
index.vue
src/views/scm/logistics_receipt/index.vue
+0
-0
vite.config.js
vite.config.js
+1
-1
没有找到文件。
.env.development
浏览文件 @
188f2da5
...
@@ -16,11 +16,11 @@ VITE_APP_REDIRECT_URL = 'http://localhost:8085'
...
@@ -16,11 +16,11 @@ VITE_APP_REDIRECT_URL = 'http://localhost:8085'
# 积木报表服务地址
# 积木报表服务地址
VITE_APP_REPORT_URL = 'https://sfa-qa.wxl66.cn'
VITE_APP_REPORT_URL = 'https://sfa-qa.wxl66.cn'
# 积木报表预览地址
# 积木报表预览地址
VITE_APP_REPORT_PREVIEW_URL = '/report/jmreport/view'
VITE_APP_REPORT_PREVIEW_URL = '
#
/report/jmreport/view'
# 积木报表分享预览地址
# 积木报表分享预览地址
VITE_APP_REPORT_SHARE_PREVIEW_URL = '/report'
VITE_APP_REPORT_SHARE_PREVIEW_URL = '
#
/report'
# 积木报表编辑地址
# 积木报表编辑地址
VITE_APP_REPORT_EDIT_URL = '/report/jmreport/index'
VITE_APP_REPORT_EDIT_URL = '
#
/report/jmreport/index'
# 模板表格
# 模板表格
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
.env.production
浏览文件 @
188f2da5
...
@@ -15,11 +15,11 @@ VITE_APP_REDIRECT_URL = 'https://sfa.wxl66.cn/link/'
...
@@ -15,11 +15,11 @@ VITE_APP_REDIRECT_URL = 'https://sfa.wxl66.cn/link/'
# 积木报表服务地址
# 积木报表服务地址
VITE_APP_REPORT_URL = 'https://sfa.wxl66.cn'
VITE_APP_REPORT_URL = 'https://sfa.wxl66.cn'
# 积木报表预览地址
# 积木报表预览地址
VITE_APP_REPORT_PREVIEW_URL = '/report/jmreport/view'
VITE_APP_REPORT_PREVIEW_URL = '
#
/report/jmreport/view'
# 积木报表分享预览地址
# 积木报表分享预览地址
VITE_APP_REPORT_SHARE_PREVIEW_URL = '/report'
VITE_APP_REPORT_SHARE_PREVIEW_URL = '
#
/report'
# 积木报表编辑地址
# 积木报表编辑地址
VITE_APP_REPORT_EDIT_URL = '/report/jmreport/index'
VITE_APP_REPORT_EDIT_URL = '
#
/report/jmreport/index'
# 模板表格
# 模板表格
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
.env.staging
浏览文件 @
188f2da5
...
@@ -14,11 +14,11 @@ VITE_APP_REDIRECT_URL = 'https://sfa-qa.wxl66.cn/'
...
@@ -14,11 +14,11 @@ VITE_APP_REDIRECT_URL = 'https://sfa-qa.wxl66.cn/'
# 积木报表服务地址
# 积木报表服务地址
VITE_APP_REPORT_URL = 'https://sfa-qa.wxl66.cn'
VITE_APP_REPORT_URL = 'https://sfa-qa.wxl66.cn'
# 积木报表预览地址
# 积木报表预览地址
VITE_APP_REPORT_PREVIEW_URL = '/report/jmreport/view'
VITE_APP_REPORT_PREVIEW_URL = '
#
/report/jmreport/view'
# 积木报表分享预览地址
# 积木报表分享预览地址
VITE_APP_REPORT_SHARE_PREVIEW_URL = '/report'
VITE_APP_REPORT_SHARE_PREVIEW_URL = '
#
/report'
# 积木报表编辑地址
# 积木报表编辑地址
VITE_APP_REPORT_EDIT_URL = '/report/jmreport/index'
VITE_APP_REPORT_EDIT_URL = '
#
/report/jmreport/index'
# 模板表格
# 模板表格
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
VITE_APP_PLAN_TEMPLATE_EXCEL = 'https://link-promotion.oss-cn-shanghai.aliyuncs.com/file/%E6%96%B0%E5%A2%9E%E6%88%96%E4%BF%AE%E6%94%B9%E8%AE%A1%E5%88%92-%E6%A8%A1%E6%9D%BF4.0.xlsx'
src/App.vue
浏览文件 @
188f2da5
<
template
>
<
template
>
<el-watermark
:font=
"font"
<template
v-if=
"!isInWhiteList"
>
:content=
"content"
<el-watermark
:font=
"font"
class=
"wm-class"
>
:content=
"content"
class=
"wm-class"
>
<router-view
/>
</el-watermark>
</
template
>
<
template
v-else
>
<router-view
/>
<router-view
/>
</
el-watermark
>
</
template
>
<back-to-up
/>
<back-to-up
/>
</template>
</template>
...
@@ -11,6 +16,10 @@
...
@@ -11,6 +16,10 @@
import
useSettingsStore
from
'@/store/modules/settings'
import
useSettingsStore
from
'@/store/modules/settings'
import
{
handleThemeStyle
}
from
'@/utils/theme'
import
{
handleThemeStyle
}
from
'@/utils/theme'
import
useUserStore
from
'@/store/modules/user'
import
useUserStore
from
'@/store/modules/user'
import
{
isWhiteList
}
from
'@/permission'
const
route
=
useRoute
()
const
isInWhiteList
=
computed
(()
=>
isWhiteList
(
route
.
path
))
const
content
=
computed
(()
=>
{
const
content
=
computed
(()
=>
{
return
useUserStore
().
userInfo
.
nickName
+
' '
+
useUserStore
().
userInfo
.
phone
return
useUserStore
().
userInfo
.
nickName
+
' '
+
useUserStore
().
userInfo
.
phone
...
@@ -19,14 +28,14 @@ const isDark = computed(() => {
...
@@ -19,14 +28,14 @@ const isDark = computed(() => {
return
useSettingsStore
().
isDark
return
useSettingsStore
().
isDark
})
})
const
font
=
reactive
({
const
font
=
reactive
({
color
:
'rgba(0, 0, 0, .
1
5)'
,
color
:
'rgba(0, 0, 0, .
0
5)'
,
})
})
watch
(
watch
(
isDark
,
isDark
,
()
=>
{
()
=>
{
font
.
color
=
isDark
.
value
font
.
color
=
isDark
.
value
?
'rgba(255, 255, 255, 0.
1
5)'
?
'rgba(255, 255, 255, 0.
0
5)'
:
'rgba(0, 0, 0, .
1
5)'
:
'rgba(0, 0, 0, .
0
5)'
},
},
{
{
immediate
:
true
,
immediate
:
true
,
...
...
src/api/common/login.js
浏览文件 @
188f2da5
...
@@ -73,9 +73,14 @@ export function logout() {
...
@@ -73,9 +73,14 @@ export function logout() {
// 刷新 token 有效期
// 刷新 token 有效期
export
function
refreshToken
(
)
{
export
function
refreshToken
API
(
refreshToken
)
{
return
request
({
return
request
({
url
:
'/auth/refresh'
,
url
:
'/auth/refreshToken'
,
method
:
'post'
method
:
'post'
,
headers
:
{
isToken
:
false
,
// 本次请求无需设置在请求拦截器设置请求头上的 token(容易把过期的 token 覆盖到 Authorization 了,而这次 Authorization 我带的是刷新的 refreshToken 给后端)
'Authorization'
:
`Bearer `
+
refreshToken
},
})
})
}
}
src/permission.js
浏览文件 @
188f2da5
...
@@ -14,9 +14,9 @@ import useVersionStore from '@/store/modules/version'
...
@@ -14,9 +14,9 @@ import useVersionStore from '@/store/modules/version'
NProgress
.
configure
({
showSpinner
:
false
})
NProgress
.
configure
({
showSpinner
:
false
})
// 登录页,物流查询页
// 登录页,物流查询页
export
const
whiteList
=
[
'/login'
,
'/logistics'
]
const
whiteList
=
[
'/login'
,
'/logistics'
]
const
isWhiteList
=
(
path
)
=>
{
export
const
isWhiteList
=
(
path
)
=>
{
return
whiteList
.
some
(
pattern
=>
isPathMatch
(
pattern
,
path
))
return
whiteList
.
some
(
pattern
=>
isPathMatch
(
pattern
,
path
))
}
}
...
...
src/store/modules/user.js
浏览文件 @
188f2da5
import
{
login
,
fsLogin
,
getInfo
,
qcLogin
}
from
'@/api'
import
{
login
,
fsLogin
,
getInfo
,
qcLogin
,
refreshTokenAPI
}
from
'@/api'
import
{
getToken
,
setToken
,
removeToken
}
from
'@/utils/auth'
import
{
getToken
,
setToken
,
removeToken
,
getRefreshToken
,
setRefreshToken
,
removeRefreshToken
}
from
'@/utils/auth'
import
{
isHttp
,
isEmpty
}
from
"@/utils/validate"
import
{
isHttp
,
isEmpty
}
from
"@/utils/validate"
import
defAva
from
'@/assets/images/profile.jpg'
import
defAva
from
'@/assets/images/profile.jpg'
...
@@ -8,6 +9,7 @@ export default defineStore(
...
@@ -8,6 +9,7 @@ export default defineStore(
{
{
state
:
()
=>
({
state
:
()
=>
({
token
:
getToken
(),
token
:
getToken
(),
refreshToken
:
getRefreshToken
(),
id
:
''
,
id
:
''
,
name
:
''
,
name
:
''
,
avatar
:
''
,
avatar
:
''
,
...
@@ -27,7 +29,9 @@ export default defineStore(
...
@@ -27,7 +29,9 @@ export default defineStore(
const
{
username
,
password
}
=
data
const
{
username
,
password
}
=
data
login
({
username
,
password
}).
then
(
res
=>
{
login
({
username
,
password
}).
then
(
res
=>
{
this
.
token
=
res
.
data
.
access_token
this
.
token
=
res
.
data
.
access_token
this
.
refreshToken
=
res
.
data
.
refresh_token
setToken
(
res
.
data
.
access_token
)
setToken
(
res
.
data
.
access_token
)
setRefreshToken
(
res
.
data
.
refresh_token
)
resolve
()
resolve
()
}).
catch
(
error
=>
{
}).
catch
(
error
=>
{
reject
(
error
)
reject
(
error
)
...
@@ -92,7 +96,13 @@ export default defineStore(
...
@@ -92,7 +96,13 @@ export default defineStore(
// reject(error)
// reject(error)
// })
// })
})
})
}
},
// 刷新token
async
refreshTokenFn
()
{
const
res
=
await
refreshTokenAPI
(
this
.
refreshToken
)
this
.
token
=
res
.
data
.
access_token
setToken
(
res
.
data
.
access_token
)
},
},
},
getters
:
{
getters
:
{
/**
/**
...
@@ -109,7 +119,7 @@ export default defineStore(
...
@@ -109,7 +119,7 @@ export default defineStore(
empId
:
state
.
userInfo
.
userId
,
// 员工 id
empId
:
state
.
userInfo
.
userId
,
// 员工 id
empNo
:
state
.
userInfo
.
userName
,
// 员工工号
empNo
:
state
.
userInfo
.
userName
,
// 员工工号
empName
:
state
.
userInfo
.
nickName
,
// 员工昵称名字
empName
:
state
.
userInfo
.
nickName
,
// 员工昵称名字
}
}
}
}
}
}
})
})
...
...
src/store/modules/version.js
浏览文件 @
188f2da5
...
@@ -14,8 +14,8 @@ export default defineStore(
...
@@ -14,8 +14,8 @@ export default defineStore(
getVersion
()
{
getVersion
()
{
return
new
Promise
((
resolve
,
reject
)
=>
{
return
new
Promise
((
resolve
,
reject
)
=>
{
getVersionAPI
().
then
(
res
=>
{
getVersionAPI
().
then
(
res
=>
{
this
.
versionChange
=
!
(
this
.
version
===
res
.
data
[
0
].
version
)
this
.
versionChange
=
!
(
this
.
version
===
res
.
data
[
0
]
?
.
version
)
this
.
version
=
res
.
data
[
0
].
version
this
.
version
=
res
.
data
[
0
]
?
.
version
// 组织版本内容数据
// 组织版本内容数据
this
.
versionList
=
res
.
data
[
0
]?.
changes
.
map
(
o
=>
{
this
.
versionList
=
res
.
data
[
0
]?.
changes
.
map
(
o
=>
{
return
{
return
{
...
...
src/utils/auth.js
浏览文件 @
188f2da5
import
Cookies
from
'js-cookie'
import
Cookies
from
'js-cookie'
const
TokenKey
=
'Admin-Token'
const
TokenKey
=
'Admin-Token'
const
refreshToken
=
'admin-t'
export
function
getToken
()
{
export
function
getToken
()
{
return
Cookies
.
get
(
TokenKey
)
return
Cookies
.
get
(
TokenKey
)
...
@@ -13,3 +14,17 @@ export function setToken(token) {
...
@@ -13,3 +14,17 @@ export function setToken(token) {
export
function
removeToken
()
{
export
function
removeToken
()
{
return
Cookies
.
remove
(
TokenKey
)
return
Cookies
.
remove
(
TokenKey
)
}
}
export
function
getRefreshToken
()
{
return
Cookies
.
get
(
refreshToken
)
}
export
function
setRefreshToken
(
token
)
{
return
Cookies
.
set
(
refreshToken
,
token
)
}
export
function
removeRefreshToken
()
{
return
Cookies
.
remove
(
refreshToken
)
}
src/utils/request.js
浏览文件 @
188f2da5
...
@@ -6,7 +6,7 @@ import { tansParams, blobValidate } from '@/utils/ruoyi'
...
@@ -6,7 +6,7 @@ import { tansParams, blobValidate } from '@/utils/ruoyi'
import
cache
from
'@/plugins/cache'
import
cache
from
'@/plugins/cache'
import
{
saveAs
}
from
'file-saver'
import
{
saveAs
}
from
'file-saver'
import
useUserStore
from
'@/store/modules/user'
import
useUserStore
from
'@/store/modules/user'
import
{
fsClientAuth
,
refreshToken
}
from
'@/api'
import
{
fsClientAuth
}
from
'@/api'
let
downloadLoadingInstance
;
let
downloadLoadingInstance
;
// 是否显示重新登录
// 是否显示重新登录
...
@@ -81,7 +81,6 @@ service.interceptors.request.use(config => {
...
@@ -81,7 +81,6 @@ service.interceptors.request.use(config => {
// 响应拦截器
// 响应拦截器
service
.
interceptors
.
response
.
use
(
async
res
=>
{
service
.
interceptors
.
response
.
use
(
async
res
=>
{
// 未设置状态码则默认成功状态
// 未设置状态码则默认成功状态
const
code
=
res
.
data
.
code
||
200
;
const
code
=
res
.
data
.
code
||
200
;
// 获取错误信息
// 获取错误信息
...
@@ -102,21 +101,29 @@ service.interceptors.response.use(async res => {
...
@@ -102,21 +101,29 @@ service.interceptors.response.use(async res => {
return
service
(
res
.
config
)
return
service
(
res
.
config
)
}
}
// PC/移动端刷新 token 有效期
// PC/移动端刷新 token 有效期
// await
refreshToke
n()
// await
useUserStore().refreshTokenF
n()
// return service(res.config)
// return service(res.config)
ElMessageBox
.
confirm
(
'登录状态已过期,您可以继续留在该页面,或者重新登录'
,
'系统提示'
,
{
confirmButtonText
:
'重新登录'
,
cancelButtonText
:
'取消'
,
type
:
'warning'
}).
then
(()
=>
{
if
(
!
isRelogin
.
show
)
{
isRelogin
.
show
=
false
;
isRelogin
.
show
=
true
;
useUserStore
().
logOut
().
then
(()
=>
{
ElMessageBox
.
confirm
(
'登录状态已过期,您可以继续留在该页面,或者重新登录'
,
'系统提示'
,
{
confirmButtonText
:
'重新登录'
,
cancelButtonText
:
'取消'
,
type
:
'warning'
}).
then
(()
=>
{
location
.
href
=
'#/login'
;
isRelogin
.
show
=
false
;
})
useUserStore
().
logOut
().
then
(()
=>
{
}).
catch
(()
=>
{
location
.
href
=
'#/login'
;
isRelogin
.
show
=
false
;
})
});
}).
catch
(()
=>
{
isRelogin
.
show
=
false
;
});
}
return
Promise
.
reject
(
'无效的会话,或者会话已过期,请重新登录。'
)
return
Promise
.
reject
(
'无效的会话,或者会话已过期,请重新登录。'
)
}
else
if
(
code
===
403
)
{
// 如果刷新 refreshToken 接口也报错了,证明需要重新登录
// ElMessageBox.confirm('登录状态已过期,您可以继续留在该页面,或者重新登录', '系统提示', { confirmButtonText: '重新登录', cancelButtonText: '取消', type: 'warning' }).then(() => {
// isRelogin.show = false;
// useUserStore().logOut().then(() => {
// location.href = '#/login';
// })
// }).catch(() => {
// isRelogin.show = false;
// });
// return Promise.reject('无效的会话,或者会话已过期,请重新登录。')
}
else
if
(
code
===
500
)
{
}
else
if
(
code
===
500
)
{
ElMessage
({
message
:
msg
,
type
:
'error'
})
ElMessage
({
message
:
msg
,
type
:
'error'
})
return
Promise
.
reject
(
new
Error
(
msg
))
return
Promise
.
reject
(
new
Error
(
msg
))
...
...
src/views/scm/logistics_receipt/index.vue
浏览文件 @
188f2da5
差异被折叠。
点击展开。
vite.config.js
浏览文件 @
188f2da5
...
@@ -39,7 +39,7 @@ export default defineConfig(({ mode, command }) => {
...
@@ -39,7 +39,7 @@ export default defineConfig(({ mode, command }) => {
rewrite
:
(
p
)
=>
p
.
replace
(
/^
\/
ql_local/
,
''
)
rewrite
:
(
p
)
=>
p
.
replace
(
/^
\/
ql_local/
,
''
)
},
},
'/bc_local'
:
{
'/bc_local'
:
{
target
:
'http://192.168.100.1
03
:8180'
,
target
:
'http://192.168.100.1
80
:8180'
,
changeOrigin
:
true
,
changeOrigin
:
true
,
rewrite
:
(
p
)
=>
p
.
replace
(
/^
\/
bc_local/
,
''
)
rewrite
:
(
p
)
=>
p
.
replace
(
/^
\/
bc_local/
,
''
)
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论