From c6c7364cc2ae1cdf4bd1e8f1cbc1f63b28d1a5a2 Mon Sep 17 00:00:00 2001 From: wenlele Date: Thu, 18 May 2023 09:55:30 +0800 Subject: [PATCH] =?UTF-8?q?=E4=B8=8B=E8=BD=BD=E5=AE=8C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- web/client/src/layout/actions/global.js | 1 + web/client/src/layout/reducers/global.js | 2 + .../means/containers/projectMeans.jsx | 48 +++++++++++++++---- web/routes/attachment/index.js | 3 +- 4 files changed, 45 insertions(+), 9 deletions(-) diff --git a/web/client/src/layout/actions/global.js b/web/client/src/layout/actions/global.js index cf8082d..2e51bd2 100644 --- a/web/client/src/layout/actions/global.js +++ b/web/client/src/layout/actions/global.js @@ -41,6 +41,7 @@ export function initApiRoot () { iotVcmpWeb:res.iotVcmpWeb, pomsMonitor:res.pomsMonitor, dcWeb:res.dcWeb, + qiniu:res.qiniu, } }) }); diff --git a/web/client/src/layout/reducers/global.js b/web/client/src/layout/reducers/global.js index 2b16eef..6aff8f8 100644 --- a/web/client/src/layout/reducers/global.js +++ b/web/client/src/layout/reducers/global.js @@ -14,6 +14,7 @@ function global (state = { iotVcmpWeb: '', pomsMonitor:'', dcWeb:'', + qiniu:{} }, action) { const payload = action.payload; switch (action.type) { @@ -36,6 +37,7 @@ function global (state = { iotVcmpWeb: payload.iotVcmpWeb, pomsMonitor:payload.pomsMonitor, dcWeb:payload.dcWeb, + qiniu:payload.qiniu, }).toJS(); case PEPPROJECTID: return Immutable.fromJS(state).merge({ diff --git a/web/client/src/sections/means/containers/projectMeans.jsx b/web/client/src/sections/means/containers/projectMeans.jsx index 56e8c78..fce98a9 100644 --- a/web/client/src/sections/means/containers/projectMeans.jsx +++ b/web/client/src/sections/means/containers/projectMeans.jsx @@ -10,7 +10,7 @@ import './style.less' const Rest = (props) => { - const { dispatch, actions, user, loading, clientHeight, overallProjectId } = props + const { dispatch, actions, user, qiniu, loading, clientHeight, overallProjectId } = props const { install, means } = actions const [pomsList, setPomsList] = useState([]); //项目 const [showPomsList, setShowPomsList] = useState([]); //项目 @@ -26,6 +26,8 @@ const Rest = (props) => { const [dataSource, setDataSource] = useState([]) //表格数据 const [query, setQuery] = useState({ limit: 10, page: 0 }) const [count, setCount] = useState(0) + const [videoModalV, setVideoModalV] = useState(false); + const [videoUrl, setvideoUrl] = useState(null); @@ -101,10 +103,8 @@ const Rest = (props) => { } }) } - console.log(treeData); treeDataList(treeData) let datas = params || query - console.log(fileIds); dispatch(means.folderFileList({ fileId: JSON.stringify(fileIds), ...datas })).then((res => { if (res.success) { setDataSource(res.payload.data?.rows || []) @@ -165,7 +165,7 @@ const Rest = (props) => { title: '文件名', dataIndex: 'name', key: 'name', - render: (text) => text?.length > 30 ?
{text.slice(0,30)}...
: text + render: (text) => text?.length > 30 ?
{text.slice(0, 30)}...
: text }, { title: '文件大小', @@ -197,7 +197,7 @@ const Rest = (props) => { 下载 @@ -244,6 +244,18 @@ const Rest = (props) => { }, ]; + const preview = (url) => { + let link = encodeURI(`${qiniu}/${url}`) + if (url.indexOf("pdf") !== -1) { + window.open(link) + } else if (url.indexOf("png") !== -1 || url.indexOf("jpg") !== -1) { + setVideoModalV(true) + setvideoUrl(link) + } else { + window.open(`https://view.officeapps.live.com/op/view.aspx?src=${link}`) + } + } + return ( //
@@ -464,7 +476,27 @@ const Rest = (props) => {
*/}
- + { + videoModalV ? + { + setVideoModalV(false) + setvideoUrl('') + }} width={400} + footer={null}> + +
+ +
+
+ : '' + } // ) @@ -472,14 +504,14 @@ const Rest = (props) => { function mapStateToProps (state) { const { auth, global, members, webSocket } = state; - return { // loading: members.isRequesting, user: auth.user, actions: global.actions, overallProjectId: global.pepProjectId, // socket: webSocket.socket - clientHeight: global.clientHeight + clientHeight: global.clientHeight, + qiniu: global.qiniu?.domain }; } diff --git a/web/routes/attachment/index.js b/web/routes/attachment/index.js index e45964b..53eda71 100644 --- a/web/routes/attachment/index.js +++ b/web/routes/attachment/index.js @@ -19,7 +19,7 @@ module.exports = { entry: function (app, router, opts) { const getApiRoot = async function (ctx) { - const { apiUrl, iotVcmpWeb, pomsMonitor, dcWeb } = opts; + const { apiUrl, iotVcmpWeb, pomsMonitor, dcWeb,qiniu } = opts; ctx.status = 200; ctx.body = { @@ -27,6 +27,7 @@ module.exports = { iotVcmpWeb: iotVcmpWeb, pomsMonitor: pomsMonitor, dcWeb: dcWeb, + qiniu:qiniu }; };