|
|
@ -3,96 +3,104 @@ import { connect } from 'react-redux'; |
|
|
|
import moment from 'moment'; |
|
|
|
import { WorkflowModal, WorkFlowViewModal } from "$components" |
|
|
|
import { EmisRequest, EmisApiTable } from "$utils" |
|
|
|
import { Card, Notification, Space, Button } from '@douyinfe/semi-ui'; |
|
|
|
import { Card, Notification, Space, Button, Spin } from '@douyinfe/semi-ui'; |
|
|
|
import { IconArticle } from '@douyinfe/semi-icons'; |
|
|
|
import '../style.less' |
|
|
|
|
|
|
|
const { Meta } = Card; |
|
|
|
|
|
|
|
const JobOrder = (props) => { |
|
|
|
const { dispatch, actions, user, workflowProcess } = props |
|
|
|
const { dispatch, actions, user, workflowProcess, clientHeight } = props |
|
|
|
const { workOrder } = actions |
|
|
|
const [workflowModalVisible, setWorkflowModalVisible] = useState(false) |
|
|
|
const [launchProcessId, setLaunchProcessId] = useState(null) |
|
|
|
const [formStateRequestingIndex, setFormStateRequestingIndex] = useState(false) |
|
|
|
|
|
|
|
useEffect(() => { |
|
|
|
dispatch(workOrder.getEnabledWorkflowProcess()) |
|
|
|
}, []) |
|
|
|
|
|
|
|
return ( |
|
|
|
<div className='work-order-container' style={{ |
|
|
|
display: 'grid', gridTemplateColumns: `repeat(auto-fit, minmax(340px, 1fr))`, gridAutoRows: `minmax(0, auto)`, gridGap: 12, |
|
|
|
}}> |
|
|
|
{ |
|
|
|
workflowProcess.map(p => { |
|
|
|
return ( |
|
|
|
<Card |
|
|
|
key={p.id} |
|
|
|
className='work-order-card' |
|
|
|
style={{ gridColumn: `span 1`, cursor: 'pointer' }} |
|
|
|
footerLine={true} |
|
|
|
footerStyle={{ display: 'flex', justifyContent: 'flex-end' }} |
|
|
|
footer={ |
|
|
|
`创建时间:${moment(p.createTime || p.updateTime).format('YYYY-MM-DD HH:mm:ss')}` |
|
|
|
} |
|
|
|
onClick={() => { |
|
|
|
EmisRequest.get(EmisApiTable.getProcessByName, { |
|
|
|
name: decodeURIComponent(p.name), |
|
|
|
resource: p.id |
|
|
|
}).then(res => { |
|
|
|
console.log(res); |
|
|
|
if (res) { |
|
|
|
// if (res.deleted) { |
|
|
|
// Notification.error({ title: '该表单流程已删除,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else if (res.isEdited) { |
|
|
|
// Notification.error({ title: '该表单流程已修改,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else if (!res.isEnable) { |
|
|
|
// Notification.error({ title: '该表单流程已停用,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else |
|
|
|
if (res.id) { |
|
|
|
setLaunchProcessId(res.id) |
|
|
|
setWorkflowModalVisible(true) |
|
|
|
<div> |
|
|
|
<div className='work-order-container' style={{ |
|
|
|
display: 'grid', gridTemplateColumns: `repeat(auto-fit, minmax(340px, 1fr))`, gridAutoRows: `minmax(0, auto)`, gridGap: 12, |
|
|
|
}}> |
|
|
|
{ |
|
|
|
workflowProcess.map((p, index) => { |
|
|
|
return ( |
|
|
|
<Card |
|
|
|
key={p.id} |
|
|
|
className='work-order-card' |
|
|
|
style={{ gridColumn: `span 1`, cursor: 'pointer' }} |
|
|
|
footerLine={true} |
|
|
|
footerStyle={{ display: 'flex', justifyContent: 'flex-end' }} |
|
|
|
footer={ |
|
|
|
`创建时间:${moment(p.createTime || p.updateTime).format('YYYY-MM-DD HH:mm:ss')}` |
|
|
|
} |
|
|
|
onClick={() => { |
|
|
|
if (formStateRequestingIndex) return; |
|
|
|
setFormStateRequestingIndex(index + 1) |
|
|
|
EmisRequest.get(EmisApiTable.getProcessByName, { |
|
|
|
name: decodeURIComponent(p.name), |
|
|
|
resource: p.id |
|
|
|
}).then(res => { |
|
|
|
setFormStateRequestingIndex(false) |
|
|
|
if (res) { |
|
|
|
// if (res.deleted) { |
|
|
|
// Notification.error({ title: '该表单流程已删除,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else if (res.isEdited) { |
|
|
|
// Notification.error({ title: '该表单流程已修改,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else if (!res.isEnable) { |
|
|
|
// Notification.error({ title: '该表单流程已停用,请尝试退出账号重新登录或联系项企管理员' }) |
|
|
|
// } else |
|
|
|
if (res.id) { |
|
|
|
setLaunchProcessId(res.id) |
|
|
|
setWorkflowModalVisible(true) |
|
|
|
} |
|
|
|
} else { |
|
|
|
Notification.error({ title: `获取指定流程失败` }); |
|
|
|
} |
|
|
|
} else { |
|
|
|
Notification.error({ title: `获取指定流程失败` }); |
|
|
|
} |
|
|
|
}) |
|
|
|
}} |
|
|
|
> |
|
|
|
<div> |
|
|
|
<Meta |
|
|
|
title={p.name} |
|
|
|
// description="全面、易用、优质" |
|
|
|
avatar={ |
|
|
|
<IconArticle style={{ fontSize: 42 }} /> |
|
|
|
} |
|
|
|
/> |
|
|
|
</div> |
|
|
|
</Card> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
{/* <WorkflowModal |
|
|
|
}) |
|
|
|
}} |
|
|
|
> |
|
|
|
<div> |
|
|
|
<Meta |
|
|
|
title={ |
|
|
|
<span>{p.name}<Spin style={{ position: 'relative', top: 6, left: 6 }} spinning={formStateRequestingIndex == index + 1} /></span> |
|
|
|
} |
|
|
|
avatar={ |
|
|
|
<IconArticle style={{ fontSize: 42 }} /> |
|
|
|
} |
|
|
|
/> |
|
|
|
</div> |
|
|
|
</Card> |
|
|
|
) |
|
|
|
}) |
|
|
|
} |
|
|
|
</div> |
|
|
|
<WorkflowModal |
|
|
|
visible={workflowModalVisible} |
|
|
|
title={''} |
|
|
|
processId={launchProcessId} |
|
|
|
onCancel={() => { setWorkflowModalVisible(false) }} |
|
|
|
successCallBack={() => { setWorkflowModalVisible(false) }} |
|
|
|
/> */} |
|
|
|
<WorkFlowViewModal |
|
|
|
/> |
|
|
|
{/* <WorkFlowViewModal |
|
|
|
visible={workflowModalVisible} |
|
|
|
processId={launchProcessId} |
|
|
|
/> |
|
|
|
/> */} |
|
|
|
</div> |
|
|
|
) |
|
|
|
} |
|
|
|
|
|
|
|
function mapStateToProps (state) { |
|
|
|
const { auth, global, workflowProcess } = state; |
|
|
|
console.log(global); |
|
|
|
return { |
|
|
|
user: auth.user, |
|
|
|
actions: global.actions, |
|
|
|
workflowProcess: workflowProcess.data || [] |
|
|
|
workflowProcess: workflowProcess.data || [], |
|
|
|
clientHeight: global.clientHeight |
|
|
|
}; |
|
|
|
} |
|
|
|
|
|
|
|