|
@ -2,9 +2,9 @@ |
|
|
|
|
|
|
|
|
import React from 'react'; |
|
|
import React from 'react'; |
|
|
import { connect } from 'react-redux'; |
|
|
import { connect } from 'react-redux'; |
|
|
import { Modal, Spin, Notification, Row } from '@douyinfe/semi-ui'; |
|
|
import { Modal, Spin, Notification, Row, Space, Button } from '@douyinfe/semi-ui'; |
|
|
import { RouteTable } from '../../utils/webapi'; |
|
|
import { RouteTable } from '../../utils/webapi'; |
|
|
import { RouteRequest } from '@peace/utils'; |
|
|
import { EmisRequest, EmisApiTable } from '$utils'; |
|
|
import { useState } from 'react'; |
|
|
import { useState } from 'react'; |
|
|
import { useEffect } from 'react'; |
|
|
import { useEffect } from 'react'; |
|
|
import { IconClose } from '@douyinfe/semi-icons'; |
|
|
import { IconClose } from '@douyinfe/semi-icons'; |
|
@ -14,10 +14,9 @@ import './index.less' |
|
|
const { confirm } = Modal; |
|
|
const { confirm } = Modal; |
|
|
|
|
|
|
|
|
const WorkFlowModal = (props) => { |
|
|
const WorkFlowModal = (props) => { |
|
|
const { successCallBack = () => { }, title, visible, clientHeight, postData, processId, user, dispatch, webEmis } = props; |
|
|
const { successCallBack = () => { }, title, visible, clientHeight, postData, processId, user, dispatch, webEmis, webOa, onCancel } = props; |
|
|
const [loading, setLoading] = useState(true); |
|
|
const [loading, setLoading] = useState(true); |
|
|
const [ifShowMessage, setIfShowMessage] = useState(true); |
|
|
const [ifShowMessage, setIfShowMessage] = useState(true); |
|
|
const [webUrl, setWebUrl] = useState(null); |
|
|
|
|
|
const [customVisible, setCustomVisible] = useState(false); |
|
|
const [customVisible, setCustomVisible] = useState(false); |
|
|
const [draftId, setDraftId] = useState(); |
|
|
const [draftId, setDraftId] = useState(); |
|
|
const iframeRef = React.createRef(); |
|
|
const iframeRef = React.createRef(); |
|
@ -26,7 +25,6 @@ const WorkFlowModal = (props) => { |
|
|
if (draftId) { |
|
|
if (draftId) { |
|
|
setCustomVisible(false); |
|
|
setCustomVisible(false); |
|
|
} else { |
|
|
} else { |
|
|
const { onCancel } = props; |
|
|
|
|
|
onCancel && onCancel(); |
|
|
onCancel && onCancel(); |
|
|
setLoading(false); |
|
|
setLoading(false); |
|
|
} |
|
|
} |
|
@ -47,11 +45,9 @@ const WorkFlowModal = (props) => { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const handelApprovalCenter = (activeKey) => { |
|
|
const handelApprovalCenter = (activeKey) => { |
|
|
RouteRequest.get(RouteTable.getWebUrl + `?sys=emisWebUrl`).then(res => { |
|
|
if (webOa) { |
|
|
if (res.url) { |
|
|
window.open(webOa + "/approval/center?activeKey=" + activeKey); |
|
|
window.open(res.url + "/approval/center?activeKey=" + activeKey); |
|
|
|
|
|
} |
|
|
} |
|
|
}); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const handelOk = () => { |
|
|
const handelOk = () => { |
|
@ -63,18 +59,13 @@ const WorkFlowModal = (props) => { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const handelDeny = () => { |
|
|
const handelDeny = () => { |
|
|
// dispatch(delDraft(draftId)).then(res => { |
|
|
EmisRequest.delete(EmisApiTable.delDraftUrl.replace('{draftId}', draftId)).then(res => { |
|
|
// if (res.success) { |
|
|
Notification.success({ title: '删除草稿成功' }); |
|
|
// Notification.success({title:'删除草稿成功'}); |
|
|
onCancel && onCancel(); |
|
|
// const { onCancel } = props; |
|
|
setLoading(false); |
|
|
// onCancel && onCancel(); |
|
|
setCustomVisible(false); |
|
|
// setLoading(false); |
|
|
setDraftId(null); |
|
|
// setCustomVisible(false); |
|
|
}) |
|
|
// setDraftId(null); |
|
|
|
|
|
// } else { |
|
|
|
|
|
// Notification.error({title:'删除草稿失败,请联系管理员'}); |
|
|
|
|
|
// } |
|
|
|
|
|
// }) |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const cancel = () => { |
|
|
const cancel = () => { |
|
@ -87,6 +78,7 @@ const WorkFlowModal = (props) => { |
|
|
let data = JSON.parse(event.data); |
|
|
let data = JSON.parse(event.data); |
|
|
const { type, isSaveDraft, setIntervalSave, draftId, msg } = data; |
|
|
const { type, isSaveDraft, setIntervalSave, draftId, msg } = data; |
|
|
if (msg) { |
|
|
if (msg) { |
|
|
|
|
|
console.log(msg); |
|
|
Notification.success({ title: msg }) |
|
|
Notification.success({ title: msg }) |
|
|
} |
|
|
} |
|
|
setDraftId(draftId); |
|
|
setDraftId(draftId); |
|
@ -112,31 +104,21 @@ const WorkFlowModal = (props) => { |
|
|
} |
|
|
} |
|
|
//监听message事件 |
|
|
//监听message事件 |
|
|
window.addEventListener('message', receiveMessageFromIndex, false); |
|
|
window.addEventListener('message', receiveMessageFromIndex, false); |
|
|
//获取企业统一认证管理平台web的URL |
|
|
|
|
|
if (!webUrl) { |
|
|
|
|
|
RouteRequest.get(RouteTable.getEmisWebUrl).then(res => { |
|
|
|
|
|
if (res.url) { |
|
|
|
|
|
setWebUrl(res.url); |
|
|
|
|
|
} |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
}, []) |
|
|
}, []) |
|
|
|
|
|
|
|
|
|
|
|
console.log(webEmis, processId); |
|
|
return ( |
|
|
return ( |
|
|
<div> |
|
|
<div> |
|
|
<Modal |
|
|
<Modal |
|
|
fullScreen |
|
|
fullScreen |
|
|
visible={visible} |
|
|
visible={visible} |
|
|
width={'100%'} |
|
|
width={'100%'} |
|
|
// style={{ top: 0, left: 0, padding: 0, maxWidth: '100%' }} |
|
|
|
|
|
// bodyStyle={{ paddingLeft: 32, paddingRight: 32, margin: 0, backgroundColor: '#FAFAFA', height: '100%', overflowY: 'auto' }} |
|
|
|
|
|
title={''} |
|
|
title={''} |
|
|
closable={false} |
|
|
closable={false} |
|
|
hasCancel={false} |
|
|
hasCancel={false} |
|
|
footer={null} |
|
|
footer={null} |
|
|
wrapClassName='process_modal_wrap' |
|
|
wrapClassName='process_modal_wrap' |
|
|
onCancel={showConfirm} |
|
|
// onCancel={showConfirm} |
|
|
destroyOnClose |
|
|
|
|
|
> |
|
|
> |
|
|
<Row> |
|
|
<Row> |
|
|
<div className='workflow-body'> |
|
|
<div className='workflow-body'> |
|
@ -152,7 +134,7 @@ const WorkFlowModal = (props) => { |
|
|
<Spin |
|
|
<Spin |
|
|
spinning={loading} |
|
|
spinning={loading} |
|
|
> |
|
|
> |
|
|
{webUrl && processId ? <iframe |
|
|
{webEmis && processId ? <iframe |
|
|
id='workflowFrame' |
|
|
id='workflowFrame' |
|
|
onLoad={() => { |
|
|
onLoad={() => { |
|
|
let frameWin = document.getElementById('workflowFrame'); |
|
|
let frameWin = document.getElementById('workflowFrame'); |
|
@ -161,7 +143,7 @@ const WorkFlowModal = (props) => { |
|
|
}} |
|
|
}} |
|
|
allowTransparency="true" |
|
|
allowTransparency="true" |
|
|
ref={iframeRef} |
|
|
ref={iframeRef} |
|
|
src={`${webUrl}/process/${processId}/apply?token=${user.token}`} |
|
|
src={`${webEmis}/process/${processId}/apply?token=${user.token}`} |
|
|
width={'100%'} |
|
|
width={'100%'} |
|
|
style={{ height: '100vh' }} |
|
|
style={{ height: '100vh' }} |
|
|
frameBorder="0" |
|
|
frameBorder="0" |
|
@ -170,16 +152,27 @@ const WorkFlowModal = (props) => { |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
{ |
|
|
{ |
|
|
customVisible ? <div className='modalBox'> |
|
|
customVisible ? |
|
|
<div className='modal'> |
|
|
<Modal |
|
|
<p className='content'>此表单已保存为草稿,是否需要保留</p> |
|
|
title="此表单已保存为草稿,是否需要保留" |
|
|
<ul className='btn'> |
|
|
visible={customVisible} |
|
|
<li className='confirm' onClick={() => handelOk()}>是</li> |
|
|
footer={ |
|
|
<li className='deny' onClick={() => handelDeny()}>否</li> |
|
|
<Space> |
|
|
<li className='cancel' onClick={() => cancel()}>取消</li> |
|
|
<Button type="primary" onClick={() => handelOk()}> |
|
|
</ul> |
|
|
是 |
|
|
</div> |
|
|
</Button> |
|
|
</div> : '' |
|
|
<Button type="primary" onClick={() => handelDeny()}> |
|
|
|
|
|
否 |
|
|
|
|
|
</Button> |
|
|
|
|
|
<Button type="primary" onClick={() => cancel()}> |
|
|
|
|
|
取消 |
|
|
|
|
|
</Button> |
|
|
|
|
|
</Space> |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
> |
|
|
|
|
|
</Modal> |
|
|
|
|
|
: '' |
|
|
} |
|
|
} |
|
|
</Row> |
|
|
</Row> |
|
|
</Modal > |
|
|
</Modal > |
|
@ -189,11 +182,11 @@ const WorkFlowModal = (props) => { |
|
|
|
|
|
|
|
|
function mapStateToProps (state) { |
|
|
function mapStateToProps (state) { |
|
|
const { auth, global } = state; |
|
|
const { auth, global } = state; |
|
|
console.log(global); |
|
|
|
|
|
return { |
|
|
return { |
|
|
user: auth.user, |
|
|
user: auth.user, |
|
|
clientHeight: global.clientHeight, |
|
|
clientHeight: global.clientHeight, |
|
|
webEmis: global.webEmis |
|
|
webEmis: global.webEmis, |
|
|
|
|
|
webOa: global.webOa |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|