Merge branch 'master' of http://121.41.2.71:3000/wyw/mh_jy_safe_web
This commit is contained in:
commit
e8d9b0199f
@ -720,6 +720,18 @@ class UserEditPage extends React.Component {
|
|||||||
</Select>)}
|
</Select>)}
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
|
<Col span={8}>
|
||||||
|
<Form.Item
|
||||||
|
label={'出生日期'}
|
||||||
|
{...formItemLayout}
|
||||||
|
>
|
||||||
|
<DatePicker
|
||||||
|
value={moment(this.state.data.BORN_DATE)}
|
||||||
|
placeholder={'请输入出生日期'}
|
||||||
|
onChange={(value, dateString) => { onChange('BORN_DATE', dateString, 0) }}
|
||||||
|
/>
|
||||||
|
</Form.Item>
|
||||||
|
</Col>
|
||||||
<Col span={8}>
|
<Col span={8}>
|
||||||
<Form.Item
|
<Form.Item
|
||||||
label={'入职时间'}
|
label={'入职时间'}
|
||||||
|
|||||||
@ -108,7 +108,7 @@ class FO035ShowPrint extends React.Component {
|
|||||||
<div>
|
<div>
|
||||||
<Descriptions size="middle" bordered className={stylesStep.description}>
|
<Descriptions size="middle" bordered className={stylesStep.description}>
|
||||||
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item>
|
{/* <Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item> */}
|
||||||
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
||||||
|
|||||||
@ -109,7 +109,7 @@ class FO037ShowPrint extends React.Component {
|
|||||||
<div>
|
<div>
|
||||||
<Descriptions size="middle" bordered className={stylesStep.description}>
|
<Descriptions size="middle" bordered className={stylesStep.description}>
|
||||||
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item>
|
{/* <Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item> */}
|
||||||
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import { Button,Descriptions, Popconfirm, Row, Col, Form, Input, Select, Table }
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
||||||
import ReactToPrint from "react-to-print";
|
import ReactToPrint from "react-to-print";
|
||||||
import stylesStep from '../HI/StepForm.css';
|
import styles from '../HI/StepForm.css';
|
||||||
import config from "../../../config";
|
import config from "../../../config";
|
||||||
import XLSX from 'xlsx';
|
import XLSX from 'xlsx';
|
||||||
import { connect } from 'dva';
|
import { connect } from 'dva';
|
||||||
@ -105,9 +105,9 @@ class FO041ShowPrint extends React.Component {
|
|||||||
|
|
||||||
<h1 style={{ textAlign: 'center', margin: '15px' }}>领导带班下井记录</h1>
|
<h1 style={{ textAlign: 'center', margin: '15px' }}>领导带班下井记录</h1>
|
||||||
{
|
{
|
||||||
data ?
|
data?
|
||||||
<div>
|
<div>
|
||||||
<Descriptions size="middle" bordered className={stylesStep.description}>
|
<Descriptions size="middle" bordered className={styles.description}>
|
||||||
<Descriptions.Item label="公司">{data.Nav_Company?.NAME}</Descriptions.Item>
|
<Descriptions.Item label="公司">{data.Nav_Company?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="生产单元">{data.Nav_ProductionUnit?.NAME}</Descriptions.Item>
|
<Descriptions.Item label="生产单元">{data.Nav_ProductionUnit?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="发起时间">{data.CREATE_TIME}</Descriptions.Item>
|
<Descriptions.Item label="发起时间">{data.CREATE_TIME}</Descriptions.Item>
|
||||||
@ -123,101 +123,105 @@ class FO041ShowPrint extends React.Component {
|
|||||||
<Descriptions.Item label="值班结束时间">{data.JOB_END_DATE}</Descriptions.Item>
|
<Descriptions.Item label="值班结束时间">{data.JOB_END_DATE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="班次">{data.Nav_Class?.NAME}</Descriptions.Item>
|
<Descriptions.Item label="班次">{data.Nav_Class?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="附件">{showFiles(data.Nav_Files, config.picServerHost, this)}</Descriptions.Item>
|
<Descriptions.Item label="附件">{showFiles(data.Nav_Files, config.picServerHost, this)}</Descriptions.Item>
|
||||||
{
|
|
||||||
data && data.Nav_Details?
|
|
||||||
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
|
||||||
<tbody>
|
|
||||||
|
|
||||||
<tr>
|
</Descriptions>
|
||||||
<td width="100px" className={styles.fontBold}>序号</td>
|
{
|
||||||
<td className={styles.fontBold}>开始时间</td>
|
data && data.Nav_Details?
|
||||||
<td className={styles.fontBold}>结束时间</td>
|
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
||||||
<td className={styles.fontBold}>巡视区域</td>
|
<tbody>
|
||||||
<td className={styles.fontBold}>现场情况描述</td>
|
|
||||||
<td className={styles.fontBold}>发现问题</td>
|
<tr>
|
||||||
<td className={styles.fontBold}>处置措施</td>
|
<td width="100px" className={styles.fontBold}>序号</td>
|
||||||
<td className={styles.fontBold}>附件</td>
|
<td className={styles.fontBold}>开始时间</td>
|
||||||
<td className={styles.fontBold}>现场责任人</td>
|
<td className={styles.fontBold}>结束时间</td>
|
||||||
<td className={styles.fontBold}>现场责任人签名</td>
|
<td className={styles.fontBold}>巡视区域</td>
|
||||||
<td className={styles.fontBold}>交接事项</td>
|
<td className={styles.fontBold}>现场情况描述</td>
|
||||||
</tr>
|
<td className={styles.fontBold}>发现问题</td>
|
||||||
{
|
<td className={styles.fontBold}>处置措施</td>
|
||||||
data.Nav_Details && data.Nav_Details.map((item, i) => {
|
<td className={styles.fontBold}>附件</td>
|
||||||
return <tr>
|
<td className={styles.fontBold}>现场责任人</td>
|
||||||
<td width="100px">
|
<td className={styles.fontBold}>现场责任人签名</td>
|
||||||
{i + 1}
|
<td className={styles.fontBold}>交接事项</td>
|
||||||
</td>
|
</tr>
|
||||||
<td>
|
{
|
||||||
{item.START_DATE}
|
data.Nav_Details && data.Nav_Details.map((item, i) => {
|
||||||
</td>
|
return <tr>
|
||||||
<td>
|
<td width="100px">
|
||||||
{item.END_DATE}
|
{i + 1}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{
|
{item.START_DATE}
|
||||||
item?.Nav_DetailAreas && item?.Nav_DetailAreas.map((item2, i) => {
|
</td>
|
||||||
return <tr> {item2?.Nav_Area?.NAME}</tr>
|
<td>
|
||||||
})
|
{item.END_DATE}
|
||||||
}
|
</td>
|
||||||
</td>
|
<td>
|
||||||
<td>
|
{
|
||||||
{item.DESCRIPTION}
|
item?.Nav_DetailAreas && item?.Nav_DetailAreas.map((item2, i) => {
|
||||||
</td>
|
return <tr> {item2?.Nav_Area?.NAME}</tr>
|
||||||
<td>
|
|
||||||
{item.QUESTION}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
{item.MEASURE}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
{showFiles(item.Nav_DetailFiles, config.picServerHost, this)}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
{item.Nav_User?.NAME}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
{item.USER_DEAL_STATUS == 1?showUserSign(item.Nav_User, config.picServerHost):item.Nav_User?.NAME}
|
|
||||||
</td>
|
|
||||||
<td>
|
|
||||||
{item.ITEM}
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
</tbody>
|
</td>
|
||||||
</table> : null
|
<td>
|
||||||
}
|
{item.DESCRIPTION}
|
||||||
<Descriptions.Item label="交接班地点">{data.PLACE}</Descriptions.Item>
|
</td>
|
||||||
<Descriptions.Item label="交班人">{
|
<td>
|
||||||
data.Nav_PreUsers && data.Nav_PreUsers.map((item, i) => {
|
{item.QUESTION}
|
||||||
return item.Nav_PreUser?.NAME + ' '
|
</td>
|
||||||
})
|
<td>
|
||||||
}</Descriptions.Item>
|
{item.MEASURE}
|
||||||
<Descriptions.Item label="交班人签字">{
|
</td>
|
||||||
data.Nav_PreUsers && data.Nav_PreUsers.map((item, i) => {
|
<td>
|
||||||
if (item.PRE_USER_DEAL_STATUS == 1) {
|
{showFiles(item.Nav_DetailFiles, config.picServerHost, this)}
|
||||||
showUserSign(item.Nav_PreUser, config.picServerHost)
|
</td>
|
||||||
}
|
<td>
|
||||||
})
|
{item.Nav_User?.NAME}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.USER_DEAL_STATUS == 1?showUserSign(item.Nav_User, config.picServerHost):null}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.ITEM}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table> : null
|
||||||
|
}
|
||||||
|
<br></br>
|
||||||
|
<Descriptions size="middle" bordered className={styles.description}>
|
||||||
|
<Descriptions.Item label="交接班地点">{data.PLACE}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="交班人">{
|
||||||
|
data.Nav_Users && data.Nav_Users.map((item, i) => {
|
||||||
|
return item.Nav_User?.NAME + ' '
|
||||||
|
})
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="交班人签字">{
|
||||||
|
data.Nav_Users && data.Nav_Users.map((item, i) => {
|
||||||
|
if (item.DEAL_STATUS == 1) {
|
||||||
|
showUserSign(item.Nav_User, config.picServerHost)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
<Descriptions.Item label="接班人">{
|
<Descriptions.Item label="接班人">{
|
||||||
data.Nav_AfterUsers && data.Nav_AfterUsers.map((item, i) => {
|
data.Nav_AfterUsers && data.Nav_AfterUsers.map((item, i) => {
|
||||||
return item.Nav_AfterUser?.NAME + ' '
|
return item.Nav_AfterUser?.NAME + ' '
|
||||||
})
|
})
|
||||||
|
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
<Descriptions.Item label="接班人签字">{
|
<Descriptions.Item label="接班人签字">{
|
||||||
data.Nav_AfterUsers && data.Nav_AfterUsers.map((item, i) => {
|
data.Nav_AfterUsers && data.Nav_AfterUsers.map((item, i) => {
|
||||||
if (item.AFTER_USER_DEAL_STATUS == 1) {
|
if (item.AFTER_USER_DEAL_STATUS == 1) {
|
||||||
showUserSign(item.Nav_AfterUser, config.picServerHost)
|
showUserSign(item.Nav_AfterUser, config.picServerHost)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
</Descriptions>
|
</Descriptions>
|
||||||
</div> : null
|
</div>:null
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -3,11 +3,12 @@ import { Button,Descriptions, Popconfirm, Row, Col, Form, Input, Select, Table }
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
||||||
import ReactToPrint from "react-to-print";
|
import ReactToPrint from "react-to-print";
|
||||||
import stylesStep from '../HI/StepForm.css';
|
import styles from '../HI/StepForm.css';
|
||||||
import config from "../../../config";
|
import config from "../../../config";
|
||||||
import XLSX from 'xlsx';
|
import XLSX from 'xlsx';
|
||||||
import { connect } from 'dva';
|
import { connect } from 'dva';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
|
import FormPage from '../../../components/FormPage'
|
||||||
class FO043ShowPrint extends React.Component {
|
class FO043ShowPrint extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
@ -33,14 +34,14 @@ class FO043ShowPrint extends React.Component {
|
|||||||
onTableBtnAgree() {
|
onTableBtnAgree() {
|
||||||
this.props.dispatch({
|
this.props.dispatch({
|
||||||
type: 'app/getDataByPost',
|
type: 'app/getDataByPost',
|
||||||
url: 'FO/FOLeaderWellRecord/PersonalAgree',
|
url: 'FO/FOFireJob/IdentityUpdate',
|
||||||
payload: {
|
payload: {
|
||||||
ID: this.props.data.id,
|
ID: this.props.data.id,
|
||||||
TaskID: this.props.data.TaskID,
|
TaskID: this.props.data.TaskID,
|
||||||
},
|
},
|
||||||
onComplete: (ret) => {
|
onComplete: (ret) => {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
message.success('确认成功!');
|
message.success('提交成功!');
|
||||||
this.setState({ BtnAgreeDisplay: 'none' })
|
this.setState({ BtnAgreeDisplay: 'none' })
|
||||||
this.BtnClose();
|
this.BtnClose();
|
||||||
}
|
}
|
||||||
@ -60,7 +61,7 @@ class FO043ShowPrint extends React.Component {
|
|||||||
this.props.dispatch({
|
this.props.dispatch({
|
||||||
type: 'app/getDataByPost',
|
type: 'app/getDataByPost',
|
||||||
payload: json,
|
payload: json,
|
||||||
url: 'FO/FOLeaderWellRecord/GetEdit',
|
url: 'FO/FOFireJob/GetEdit',
|
||||||
onComplete: (ret) => {
|
onComplete: (ret) => {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if(this.props.data && this.props.data.loadDataDeal)
|
if(this.props.data && this.props.data.loadDataDeal)
|
||||||
@ -73,73 +74,206 @@ class FO043ShowPrint extends React.Component {
|
|||||||
}else{
|
}else{
|
||||||
this.setState({ BtnAgreeDisplay: 'inline' })
|
this.setState({ BtnAgreeDisplay: 'inline' })
|
||||||
}
|
}
|
||||||
|
this.onClickApprove(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
onClickApprove = (appVisible) => {
|
||||||
|
const newtmpData = {
|
||||||
|
data: { id: this.props.data.id, isShow: true, key: guid(), param: this.props.data.param, appVisible: appVisible, BtnAgreeDisplay: 'inline' },
|
||||||
|
formCode: "PF123",
|
||||||
|
}
|
||||||
|
this.setState({
|
||||||
|
tmpData: newtmpData,
|
||||||
|
});
|
||||||
|
}
|
||||||
onTableBtnExport() {
|
onTableBtnExport() {
|
||||||
let TableWrap = document.getElementById('tableId' + this.props.data.id);
|
let TableWrap = document.getElementById('tableId' + this.props.data.id);
|
||||||
let Table = TableWrap.getElementsByTagName('table')[0];
|
let Table = TableWrap.getElementsByTagName('table')[0];
|
||||||
const wb = XLSX.utils.table_to_book(Table);
|
const wb = XLSX.utils.table_to_book(Table);
|
||||||
XLSX.writeFile(wb, "领导带班下井记录.xlsx")
|
XLSX.writeFile(wb, "动火作业工作票.xlsx")
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { data } = this.state;
|
const { data } = this.state;
|
||||||
|
const enums = this.props.data.enums ? this.props.data.enums : this.props.app.enums;
|
||||||
return <div>
|
return <div>
|
||||||
<div style={{ padding: '10px' }}>
|
<div style={{ padding: '10px' }}>
|
||||||
|
<Button onClick={() => this.onClickApprove(true)} style={{ marginRight: '8px' }} icon="export">审批详情</Button>
|
||||||
<ReactToPrint
|
<ReactToPrint
|
||||||
trigger={() => <Button type={'default'} icon={'printer'} style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }}>打印</Button>}
|
trigger={() => <Button type={'default'} icon={'printer'} style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }}>打印</Button>}
|
||||||
content={() => this.componentRef}
|
content={() => this.componentRef}
|
||||||
pageStyle=".printDIV { padding:0 40px;} img{width :120px}"
|
pageStyle=".printDIV { padding:0 40px;} img{width :120px}"
|
||||||
/>
|
/>
|
||||||
<Button style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }} onClick={() => this.onTableBtnExport()} icon="export" >导出</Button>
|
<Button style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }} onClick={() => this.onTableBtnExport()} icon="export" >导出</Button>
|
||||||
<Button type="primary" style={{ marginLeft: '8px', display: this.state.BtnAgreeDisplay }} onClick={() => this.onTableBtnAgree()} icon="check" >确认</Button>
|
<Button type="primary" style={{ marginLeft: '8px', display: this.state.BtnAgreeDisplay }} onClick={() => this.onTableBtnAgree()} icon="check" >审阅</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
{/* */}
|
{/* */}
|
||||||
<div ref={el => (this.componentRef = el)} style={{ padding: '20px' }} id={'tableId' + this.props.data.id} className="printDIV">
|
<div ref={el => (this.componentRef = el)} style={{ padding: '20px' }} id={'tableId' + this.props.data.id} className="printDIV">
|
||||||
|
|
||||||
<h1 style={{ textAlign: 'center', margin: '15px' }}>领导带班下井记录</h1>
|
<h1 style={{ textAlign: 'center', margin: '15px' }}>动火作业工作票</h1>
|
||||||
{
|
{
|
||||||
data ?
|
data ?
|
||||||
<div>
|
<div>
|
||||||
<Descriptions size="middle" bordered className={stylesStep.description}>
|
<Descriptions size="middle" bordered className={styles.description}>
|
||||||
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
<Descriptions.Item label="公司">{data.Nav_Company?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item>
|
<Descriptions.Item label="生产单元">{data.Nav_ProductionUnit?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
<Descriptions.Item label="发起时间">{data.CREATE_TIME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
|
||||||
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
<Descriptions.Item label="发起部门">{data.Nav_ApplyDepartment?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="被交底人">{
|
<Descriptions.Item label="发起人">{data.Nav_ApplyUser?.NAME}</Descriptions.Item>
|
||||||
data.Nav_Person && data.Nav_Person.map((item, i) => {
|
<Descriptions.Item label="工作票编号">{data.CODE}</Descriptions.Item>
|
||||||
if (i == (data.Nav_Person.length - 1)) {
|
<Descriptions.Item label="作业名称">{data.Nav_OperationStep?.NAME}</Descriptions.Item>
|
||||||
if (item.DEAL_STATUS == 0)
|
<Descriptions.Item label="审批层级">{enums.HMOperationTaskAuditEnum.enums[data.AUDIT_LEVEL]}</Descriptions.Item>
|
||||||
return <label style={{ color: 'red' }} title='未签到'> {item.Nav_User?.NAME}</label>
|
<Descriptions.Item label="作业风险等级">{enums.SKEvaluateLevelEnum.enums[data.EVALUATE_LEVEL]}</Descriptions.Item>
|
||||||
else
|
<Descriptions.Item label="动火部门">{data.Nav_FireDepartment?.NAME}</Descriptions.Item>
|
||||||
return item.Nav_User?.NAME
|
<Descriptions.Item label="动火部门负责人">{data.Nav_FireUser?.NAME}</Descriptions.Item>
|
||||||
} else {
|
<Descriptions.Item label="安全生产管理人员">{data.Nav_SafeUser?.NAME}</Descriptions.Item>
|
||||||
if (item.DEAL_STATUS == 0)
|
<Descriptions.Item label="动火区域">{data.Nav_Area?.NAME}</Descriptions.Item>
|
||||||
return <label style={{ color: 'red' }} title='未签到'>{item.Nav_User?.NAME + ' '}</label>
|
<Descriptions.Item label="动火地点">{data.JOB_CONTENT}</Descriptions.Item>
|
||||||
else
|
<Descriptions.Item label="动火方式">{data.Nav_Type?.NAME}</Descriptions.Item>
|
||||||
return item.Nav_User?.NAME + ' '
|
<Descriptions.Item label="动火具体事项">{data.JOB_CONTENT}</Descriptions.Item>
|
||||||
}
|
<Descriptions.Item label="作业监护人">{data.Nav_MonitorUser?.NAME}</Descriptions.Item>
|
||||||
})
|
<Descriptions.Item label="动火计划开始时间">{data.JOB_DATE}</Descriptions.Item>
|
||||||
}</Descriptions.Item>
|
<Descriptions.Item label="动火计划结束时间">{data.JOB_END_DATE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底内容">{data.DisclosureContent}</Descriptions.Item>
|
<Descriptions.Item label="存在的风险">{ data.Nav_Risks && data.Nav_Risks.map((item, i) => {
|
||||||
<Descriptions.Item label="交底人签字">{
|
return item.RISK_NAME + ' '
|
||||||
(data.Nav_User && data.Nav_User.FILE_PATH)?
|
})}</Descriptions.Item>
|
||||||
showUserSign(data.Nav_User, config.picServerHost):null
|
<Descriptions.Item label="附件">{showFiles(data.Nav_Files, config.picServerHost, this)}</Descriptions.Item>
|
||||||
|
{
|
||||||
|
data && data.Nav_Users?
|
||||||
|
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td width="100px" className={styles.fontBold}>序号</td>
|
||||||
|
<td className={styles.fontBold}>作业人员类别</td>
|
||||||
|
<td className={styles.fontBold}>姓名</td>
|
||||||
|
<td className={styles.fontBold}>证书编号</td>
|
||||||
|
<td className={styles.fontBold}>附件</td>
|
||||||
|
<td className={styles.fontBold}>签名</td>
|
||||||
|
</tr>
|
||||||
|
{
|
||||||
|
data.Nav_Users && data.Nav_Users.map((item, i) => {
|
||||||
|
return <tr>
|
||||||
|
<td width="100px">
|
||||||
|
{i + 1}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.Nav_UserType?.NAME}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.Nav_User?.NAME}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.CERTIFICATE_CODE}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{showFiles(item.Nav_UserFiles, config.picServerHost, this)}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{ item.DEAL_STATUS == 1?
|
||||||
|
showUserSign(item.Nav_User, config.picServerHost):null
|
||||||
|
}
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table> : null
|
||||||
|
}
|
||||||
|
{
|
||||||
|
data && data.Nav_Details?
|
||||||
|
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td width="100px" className={styles.fontBold}>序号</td>
|
||||||
|
<td className={styles.fontBold}>作业阶段</td>
|
||||||
|
<td className={styles.fontBold}>作业流程及安全措施</td>
|
||||||
|
<td className={styles.fontBold}>是否确认</td>
|
||||||
|
<td className={styles.fontBold}>附件</td>
|
||||||
|
</tr>
|
||||||
|
{
|
||||||
|
data.Nav_Details && data.Nav_Details.map((item, i) => {
|
||||||
|
return <tr>
|
||||||
|
<td width="100px">
|
||||||
|
{i + 1}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{enums.FOJobStepEnum.enums[data.JOB_STEP]}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.CONTENT}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{enums.FOYesOrNoEnum.enums[data.IS_CONFIRM]}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{showFiles(item.Nav_DetailFiles, config.picServerHost, this)}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table> : null
|
||||||
|
}
|
||||||
|
<FormPage {...this.state.tmpData} />
|
||||||
|
<Descriptions.Item label="动火作业现场条件验收情况">{data.COMPLETED_CONDITION}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="是否可以动火">{enums.FOYesOrNoEnum.enums[data.IS_FIRE]}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火实际开始时间">{data.ACT_DATE}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="附件"> {showFiles(data.Nav_FireFiles, config.picServerHost, this)}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="矿调度室人员">{data.Nav_DispatchUser?.NAME}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火部门负责人签名">{
|
||||||
|
|
||||||
|
data.USER_DEAL_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_FireUser, config.picServerHost)
|
||||||
|
:null
|
||||||
|
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
<Descriptions.Item label="被交底人签字">{
|
<Descriptions.Item label="安全管理人员签名">{
|
||||||
data.Nav_Person && data.Nav_Person.map((item, i) => {
|
|
||||||
if (item.DEAL_STATUS == 1) {
|
data.SAFE_DEAL_STATUS == 1?
|
||||||
showUserSign(item.Nav_User, config.picServerHost)
|
showUserSign(data.Nav_SafeUser, config.picServerHost)
|
||||||
}
|
:null
|
||||||
})
|
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="矿调度人员签名">{
|
||||||
|
|
||||||
|
data.DISPATCH_DEAL_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_DispatchUser, config.picServerHost)
|
||||||
|
:null
|
||||||
|
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火作业完工验收情况">{
|
||||||
|
data.COMPLETED_CONTENT
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="是否可以撤离">{
|
||||||
|
enums.FOYesOrNoEnum.enums[data.IS_LEAVE]
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火实际结束时间">{
|
||||||
|
data.ACT_END_DATE
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="离开现场时间">{
|
||||||
|
data.LEAVE_DATE
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="附件">{
|
||||||
|
showFiles(data.Nav_MonitorFiles, config.picServerHost, this)
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火部门负责人签字">{
|
||||||
|
data.USER_DEAL_FINISH_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_FireUser, config.picServerHost)
|
||||||
|
:null
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="安全生产管理人员签字">{
|
||||||
|
data.SAFE_DEAL_FINISH_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_SafeUser, config.picServerHost)
|
||||||
|
:null
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
</Descriptions>
|
</Descriptions>
|
||||||
</div> : null
|
</div> : null
|
||||||
|
|||||||
@ -3,11 +3,12 @@ import { Button,Descriptions, Popconfirm, Row, Col, Form, Input, Select, Table }
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
import { initFilter, extendRule, extendInclude,extendIgnoreDataRule, setDataFieldValue, guid, initQueryFilter,showFiles, GetFileModel,showUserSign } from "../../../utils/common";
|
||||||
import ReactToPrint from "react-to-print";
|
import ReactToPrint from "react-to-print";
|
||||||
import stylesStep from '../HI/StepForm.css';
|
import styles from '../HI/StepForm.css';
|
||||||
import config from "../../../config";
|
import config from "../../../config";
|
||||||
import XLSX from 'xlsx';
|
import XLSX from 'xlsx';
|
||||||
import { connect } from 'dva';
|
import { connect } from 'dva';
|
||||||
import moment from 'moment';
|
import moment from 'moment';
|
||||||
|
import FormPage from '../../../components/FormPage'
|
||||||
class FO045ShowPrint extends React.Component {
|
class FO045ShowPrint extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
@ -33,14 +34,14 @@ class FO045ShowPrint extends React.Component {
|
|||||||
onTableBtnAgree() {
|
onTableBtnAgree() {
|
||||||
this.props.dispatch({
|
this.props.dispatch({
|
||||||
type: 'app/getDataByPost',
|
type: 'app/getDataByPost',
|
||||||
url: 'FO/FOLeaderWellRecord/PersonalAgree',
|
url: 'FO/FOFireJobWb/IdentityUpdate',
|
||||||
payload: {
|
payload: {
|
||||||
ID: this.props.data.id,
|
ID: this.props.data.id,
|
||||||
TaskID: this.props.data.TaskID,
|
TaskID: this.props.data.TaskID,
|
||||||
},
|
},
|
||||||
onComplete: (ret) => {
|
onComplete: (ret) => {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
message.success('确认成功!');
|
message.success('提交成功!');
|
||||||
this.setState({ BtnAgreeDisplay: 'none' })
|
this.setState({ BtnAgreeDisplay: 'none' })
|
||||||
this.BtnClose();
|
this.BtnClose();
|
||||||
}
|
}
|
||||||
@ -60,7 +61,7 @@ class FO045ShowPrint extends React.Component {
|
|||||||
this.props.dispatch({
|
this.props.dispatch({
|
||||||
type: 'app/getDataByPost',
|
type: 'app/getDataByPost',
|
||||||
payload: json,
|
payload: json,
|
||||||
url: 'FO/FOLeaderWellRecord/GetEdit',
|
url: 'FO/FOFireJobWb/GetEdit',
|
||||||
onComplete: (ret) => {
|
onComplete: (ret) => {
|
||||||
if (ret) {
|
if (ret) {
|
||||||
if(this.props.data && this.props.data.loadDataDeal)
|
if(this.props.data && this.props.data.loadDataDeal)
|
||||||
@ -73,73 +74,201 @@ class FO045ShowPrint extends React.Component {
|
|||||||
}else{
|
}else{
|
||||||
this.setState({ BtnAgreeDisplay: 'inline' })
|
this.setState({ BtnAgreeDisplay: 'inline' })
|
||||||
}
|
}
|
||||||
|
this.onClickApprove(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
onClickApprove = (appVisible) => {
|
||||||
|
const newtmpData = {
|
||||||
|
data: { id: this.props.data.id, isShow: true, key: guid(), param: this.props.data.param, appVisible: appVisible, BtnAgreeDisplay: 'inline' },
|
||||||
|
formCode: "PF123",
|
||||||
|
}
|
||||||
|
this.setState({
|
||||||
|
tmpData: newtmpData,
|
||||||
|
});
|
||||||
|
}
|
||||||
onTableBtnExport() {
|
onTableBtnExport() {
|
||||||
let TableWrap = document.getElementById('tableId' + this.props.data.id);
|
let TableWrap = document.getElementById('tableId' + this.props.data.id);
|
||||||
let Table = TableWrap.getElementsByTagName('table')[0];
|
let Table = TableWrap.getElementsByTagName('table')[0];
|
||||||
const wb = XLSX.utils.table_to_book(Table);
|
const wb = XLSX.utils.table_to_book(Table);
|
||||||
XLSX.writeFile(wb, "领导带班下井记录.xlsx")
|
XLSX.writeFile(wb, "动火作业工作票(外包).xlsx")
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { data } = this.state;
|
const { data } = this.state;
|
||||||
|
const enums = this.props.data.enums ? this.props.data.enums : this.props.app.enums;
|
||||||
return <div>
|
return <div>
|
||||||
<div style={{ padding: '10px' }}>
|
<div style={{ padding: '10px' }}>
|
||||||
|
<Button onClick={() => this.onClickApprove(true)} style={{ marginRight: '8px' }} icon="export">审批详情</Button>
|
||||||
<ReactToPrint
|
<ReactToPrint
|
||||||
trigger={() => <Button type={'default'} icon={'printer'} style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }}>打印</Button>}
|
trigger={() => <Button type={'default'} icon={'printer'} style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }}>打印</Button>}
|
||||||
content={() => this.componentRef}
|
content={() => this.componentRef}
|
||||||
pageStyle=".printDIV { padding:0 40px;} img{width :120px}"
|
pageStyle=".printDIV { padding:0 40px;} img{width :120px}"
|
||||||
/>
|
/>
|
||||||
<Button style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }} onClick={() => this.onTableBtnExport()} icon="export" >导出</Button>
|
<Button style={{ marginLeft: '8px',display: data && data.FORM_STATUS === 2?"inline":"none" }} onClick={() => this.onTableBtnExport()} icon="export" >导出</Button>
|
||||||
<Button type="primary" style={{ marginLeft: '8px', display: this.state.BtnAgreeDisplay }} onClick={() => this.onTableBtnAgree()} icon="check" >确认</Button>
|
<Button type="primary" style={{ marginLeft: '8px', display: this.state.BtnAgreeDisplay }} onClick={() => this.onTableBtnAgree()} icon="check" >审阅</Button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
{/* */}
|
{/* */}
|
||||||
<div ref={el => (this.componentRef = el)} style={{ padding: '20px' }} id={'tableId' + this.props.data.id} className="printDIV">
|
<div ref={el => (this.componentRef = el)} style={{ padding: '20px' }} id={'tableId' + this.props.data.id} className="printDIV">
|
||||||
|
|
||||||
<h1 style={{ textAlign: 'center', margin: '15px' }}>领导带班下井记录</h1>
|
<h1 style={{ textAlign: 'center', margin: '15px' }}>动火作业工作票(外包)</h1>
|
||||||
{
|
{
|
||||||
data ?
|
data ?
|
||||||
<div>
|
<div>
|
||||||
<Descriptions size="middle" bordered className={stylesStep.description}>
|
<Descriptions size="middle" bordered className={styles.description}>
|
||||||
<Descriptions.Item label="编号">{data.CODE}</Descriptions.Item>
|
<Descriptions.Item label="公司">{data.Nav_Company?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底事项">{data.NAME}</Descriptions.Item>
|
<Descriptions.Item label="生产单元">{data.Nav_ProductionUnit?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底时间">{data.DISCLOSURE_DATE}</Descriptions.Item>
|
<Descriptions.Item label="发起时间">{data.CREATE_TIME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底地点">{data.JOB_LOCATION}</Descriptions.Item>
|
|
||||||
<Descriptions.Item label="交底人">{data.Nav_User ? data.Nav_User.NAME : ''}</Descriptions.Item>
|
<Descriptions.Item label="发起部门">{data.Nav_ApplyDepartment?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="被交底人">{
|
<Descriptions.Item label="发起人">{data.Nav_ApplyUser?.NAME}</Descriptions.Item>
|
||||||
data.Nav_Person && data.Nav_Person.map((item, i) => {
|
<Descriptions.Item label="工作票编号">{data.CODE}</Descriptions.Item>
|
||||||
if (i == (data.Nav_Person.length - 1)) {
|
<Descriptions.Item label="作业名称">{data.Nav_OperationStep?.NAME}</Descriptions.Item>
|
||||||
if (item.DEAL_STATUS == 0)
|
<Descriptions.Item label="审批层级">{enums.HMOperationTaskAuditEnum.enums[data.AUDIT_LEVEL]}</Descriptions.Item>
|
||||||
return <label style={{ color: 'red' }} title='未签到'> {item.Nav_User?.NAME}</label>
|
<Descriptions.Item label="作业风险等级">{enums.SKEvaluateLevelEnum.enums[data.EVALUATE_LEVEL]}</Descriptions.Item>
|
||||||
else
|
<Descriptions.Item label="施工单位">{data.DPARTMENT_NAME}</Descriptions.Item>
|
||||||
return item.Nav_User?.NAME
|
<Descriptions.Item label="施工单位负责人">{data.USER_NAME}</Descriptions.Item>
|
||||||
} else {
|
<Descriptions.Item label="负责人电话">{data.USER_PHONE}</Descriptions.Item>
|
||||||
if (item.DEAL_STATUS == 0)
|
<Descriptions.Item label="安全生产管理人员">{data.SAFE_USER_NAME}</Descriptions.Item>
|
||||||
return <label style={{ color: 'red' }} title='未签到'>{item.Nav_User?.NAME + ' '}</label>
|
<Descriptions.Item label="安全员电话">{data.SAFE_USER_PHONE}</Descriptions.Item>
|
||||||
else
|
<Descriptions.Item label="动火区域">{data.Nav_Area?.NAME}</Descriptions.Item>
|
||||||
return item.Nav_User?.NAME + ' '
|
<Descriptions.Item label="动火地点">{data.JOB_CONTENT}</Descriptions.Item>
|
||||||
}
|
<Descriptions.Item label="动火方式">{data.Nav_Type?.NAME}</Descriptions.Item>
|
||||||
})
|
<Descriptions.Item label="动火具体事项">{data.JOB_CONTENT}</Descriptions.Item>
|
||||||
}</Descriptions.Item>
|
<Descriptions.Item label="作业监护人">{data.Nav_MonitorUser?.NAME}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底内容">{data.DisclosureContent}</Descriptions.Item>
|
<Descriptions.Item label="动火计划开始时间">{data.JOB_DATE}</Descriptions.Item>
|
||||||
<Descriptions.Item label="交底人签字">{
|
<Descriptions.Item label="动火计划结束时间">{data.JOB_END_DATE}</Descriptions.Item>
|
||||||
(data.Nav_User && data.Nav_User.FILE_PATH)?
|
<Descriptions.Item label="存在的风险">{ data.Nav_Risks && data.Nav_Risks.map((item, i) => {
|
||||||
showUserSign(data.Nav_User, config.picServerHost):null
|
return item.RISK_NAME + ' '
|
||||||
|
})}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="附件">{showFiles(data.Nav_Files, config.picServerHost, this)}</Descriptions.Item>
|
||||||
|
{
|
||||||
|
data && data.Nav_Users?
|
||||||
|
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td width="100px" className={styles.fontBold}>序号</td>
|
||||||
|
<td className={styles.fontBold}>作业人员类别</td>
|
||||||
|
<td className={styles.fontBold}>姓名</td>
|
||||||
|
<td className={styles.fontBold}>证书编号</td>
|
||||||
|
<td className={styles.fontBold}>附件</td>
|
||||||
|
{/* <td className={styles.fontBold}>签名</td> */}
|
||||||
|
</tr>
|
||||||
|
{
|
||||||
|
data.Nav_Users && data.Nav_Users.map((item, i) => {
|
||||||
|
return <tr>
|
||||||
|
<td width="100px">
|
||||||
|
{i + 1}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.Nav_UserType?.NAME}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.USER_NAME}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.CERTIFICATE_CODE}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{showFiles(item.Nav_UserFiles, config.picServerHost, this)}
|
||||||
|
</td>
|
||||||
|
{/* <td>
|
||||||
|
{ item.DEAL_STATUS == 1?
|
||||||
|
showUserSign(item.Nav_User, config.picServerHost):null
|
||||||
|
}
|
||||||
|
</td> */}
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table> : null
|
||||||
|
}
|
||||||
|
{
|
||||||
|
data && data.Nav_Details?
|
||||||
|
<table style={{ width: '100%', textAlign: 'center', marginTop: '10px', borderTop: '1px solid #333', borderLeft: '1px solid #333' }} className={styles.PrintForm}>
|
||||||
|
<tbody>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td width="100px" className={styles.fontBold}>序号</td>
|
||||||
|
<td className={styles.fontBold}>作业阶段</td>
|
||||||
|
<td className={styles.fontBold}>作业流程及安全措施</td>
|
||||||
|
<td className={styles.fontBold}>是否确认</td>
|
||||||
|
<td className={styles.fontBold}>附件</td>
|
||||||
|
</tr>
|
||||||
|
{
|
||||||
|
data.Nav_Details && data.Nav_Details.map((item, i) => {
|
||||||
|
return <tr>
|
||||||
|
<td width="100px">
|
||||||
|
{i + 1}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{enums.FOJobStepEnum.enums[data.JOB_STEP]}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{item.CONTENT}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{enums.FOYesOrNoEnum.enums[data.IS_CONFIRM]}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{showFiles(item.Nav_DetailFiles, config.picServerHost, this)}
|
||||||
|
</td>
|
||||||
|
|
||||||
|
</tr>
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</tbody>
|
||||||
|
</table> : null
|
||||||
|
}
|
||||||
|
<FormPage {...this.state.tmpData} />
|
||||||
|
<Descriptions.Item label="动火作业现场条件验收情况">{data.COMPLETED_CONDITION}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="是否可以动火">{enums.FOYesOrNoEnum.enums[data.IS_FIRE]}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火实际开始时间">{data.ACT_DATE}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="附件"> {showFiles(data.Nav_FireFiles, config.picServerHost, this)}</Descriptions.Item>
|
||||||
|
|
||||||
|
<Descriptions.Item label="动火部门负责人签名">{
|
||||||
|
|
||||||
|
data.USER_DEAL_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_FireUser, config.picServerHost)
|
||||||
|
:null
|
||||||
|
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
<Descriptions.Item label="被交底人签字">{
|
<Descriptions.Item label="安全管理人员签名">{
|
||||||
data.Nav_Person && data.Nav_Person.map((item, i) => {
|
|
||||||
if (item.DEAL_STATUS == 1) {
|
data.SAFE_DEAL_STATUS == 1?
|
||||||
showUserSign(item.Nav_User, config.picServerHost)
|
showUserSign(data.Nav_SafeUser, config.picServerHost)
|
||||||
}
|
:null
|
||||||
})
|
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火作业完工验收情况">{
|
||||||
|
data.COMPLETED_CONTENT
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="是否可以撤离">{
|
||||||
|
enums.FOYesOrNoEnum.enums[data.IS_LEAVE]
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火实际结束时间">{
|
||||||
|
data.ACT_END_DATE
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="离开现场时间">{
|
||||||
|
data.LEAVE_DATE
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="附件">{
|
||||||
|
showFiles(data.Nav_MonitorFiles, config.picServerHost, this)
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="动火部门负责人签字">{
|
||||||
|
data.USER_DEAL_FINISH_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_FireUser, config.picServerHost)
|
||||||
|
:null
|
||||||
|
}</Descriptions.Item>
|
||||||
|
<Descriptions.Item label="安全生产管理人员签字">{
|
||||||
|
data.SAFE_DEAL_FINISH_STATUS == 1?
|
||||||
|
showUserSign(data.Nav_SafeUser, config.picServerHost)
|
||||||
|
:null
|
||||||
}</Descriptions.Item>
|
}</Descriptions.Item>
|
||||||
</Descriptions>
|
</Descriptions>
|
||||||
</div> : null
|
</div> : null
|
||||||
|
|||||||
@ -270,7 +270,7 @@ class SE018EditPage extends React.Component {
|
|||||||
<td colSpan={4} rowSpan={1} >{data && this.returnModel(data.Nav_Notify.TRAIN_MODEL)}</td>
|
<td colSpan={4} rowSpan={1} >{data && this.returnModel(data.Nav_Notify.TRAIN_MODEL)}</td>
|
||||||
<td colSpan={4} rowSpan={1} className={styles.fontBold}>考核方式</td>
|
<td colSpan={4} rowSpan={1} className={styles.fontBold}>考核方式</td>
|
||||||
{/* <td colSpan={4} rowSpan={1} >{data && data.Nav_Notify && data.Nav_Notify.Nav_TrainCheckType ? data.Nav_Notify.Nav_TrainCheckType.NAME : null}</td> */}
|
{/* <td colSpan={4} rowSpan={1} >{data && data.Nav_Notify && data.Nav_Notify.Nav_TrainCheckType ? data.Nav_Notify.Nav_TrainCheckType.NAME : null}</td> */}
|
||||||
<td colSpan={4} rowSpan={1} >{data.Nav_Notify.CHECKTYPE && enums.PlanCheckType.enums[data.Nav_Notify.CHECKTYPE]}</td>
|
<td colSpan={4} rowSpan={1} >{data && data.Nav_Notify && data.Nav_Notify.CHECKTYPE && this.props.app.enums.PlanCheckType.enums[data.Nav_Notify.CHECKTYPE]}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colSpan={4} rowSpan={1} className={styles.fontBold}>培训内容</td>
|
<td colSpan={4} rowSpan={1} className={styles.fontBold}>培训内容</td>
|
||||||
|
|||||||
@ -399,7 +399,7 @@ class SE018PaperPage extends React.Component {
|
|||||||
<td colSpan={4} rowSpan={1} >{notify ? this.returnModel(notify.TRAIN_MODEL) : null}</td>
|
<td colSpan={4} rowSpan={1} >{notify ? this.returnModel(notify.TRAIN_MODEL) : null}</td>
|
||||||
<td colSpan={4} rowSpan={1} className={styles.fontBold}>考核方式</td>
|
<td colSpan={4} rowSpan={1} className={styles.fontBold}>考核方式</td>
|
||||||
{/* <td colSpan={4} rowSpan={1} >{notify && notify.Nav_TrainCheckType ? notify.Nav_TrainCheckType.NAME : null}</td> */}
|
{/* <td colSpan={4} rowSpan={1} >{notify && notify.Nav_TrainCheckType ? notify.Nav_TrainCheckType.NAME : null}</td> */}
|
||||||
<td colSpan={4} rowSpan={1} >{notify && notify.CHECKTYPE && enums.PlanCheckType.enums[notify.CHECKTYPE]}</td>
|
<td colSpan={4} rowSpan={1} >{notify && notify.CHECKTYPE && this.props.app.enums.PlanCheckType.enums[notify.CHECKTYPE]}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td colSpan={4} rowSpan={1} className={styles.fontBold}>培训内容</td>
|
<td colSpan={4} rowSpan={1} className={styles.fontBold}>培训内容</td>
|
||||||
|
|||||||
57
src/files/edit/FO039.js
Normal file
57
src/files/edit/FO039.js
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
import { message } from "antd/lib/index";
|
||||||
|
import { getPropertyData, extendInclude, extendRule, getDataFieldValue, setDataFieldValue, initFilter, guid } from "../../utils/common";
|
||||||
|
import moment from 'moment';
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
// 编辑
|
||||||
|
export default {
|
||||||
|
onChange: ({ colInfo, getFieldValue, setFieldValueByBatch,setFieldValue, dispatch,login,updateSubTableData }) => {
|
||||||
|
if (!(colInfo.FIELD_NAME == 'Nav_User.NAME'))
|
||||||
|
return;
|
||||||
|
|
||||||
|
let code = getFieldValue('USER_ID')
|
||||||
|
let json = initFilter(login.OrgId,code);
|
||||||
|
dispatch({
|
||||||
|
type: 'app/getDataByPost',
|
||||||
|
url: 'FO/FOProfessionalResume/GetUserAge',
|
||||||
|
payload: json,
|
||||||
|
onlyData: false,
|
||||||
|
onComplete: (re) => {
|
||||||
|
if (re && re.IsSuccessful && re.Data) {
|
||||||
|
setFieldValue('AGE',re.Data.AGE)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
onSubChange: ({ row, getFieldValue, setFieldValueByBatch, pageCode, record, setDataState, colInfo, dispatch, stateData, saveRowRecord }) => {
|
||||||
|
if (colInfo.FIELD_NAME === "START_DATE" ||colInfo.FIELD_NAME === "END_DATE" ) {
|
||||||
|
let startDate = getDataFieldValue(record, 'START_DATE');
|
||||||
|
let endDate =getDataFieldValue(record, 'END_DATE');
|
||||||
|
if(startDate && endDate)
|
||||||
|
{
|
||||||
|
const start = new Date(startDate);
|
||||||
|
const end = new Date(endDate);
|
||||||
|
const years = end.getFullYear() - start.getFullYear();
|
||||||
|
const months = end.getMonth() - start.getMonth();
|
||||||
|
let yearsWithDecimal = (years + (months / 12)).toFixed(1); // 保留一位小数
|
||||||
|
if (yearsWithDecimal.endsWith('.0')) {
|
||||||
|
// 去掉末尾的.0,但不四舍五入
|
||||||
|
yearsWithDecimal = yearsWithDecimal.substring(0, yearsWithDecimal.length - 2);
|
||||||
|
|
||||||
|
}
|
||||||
|
record["WORK_YEAR"] = yearsWithDecimal;
|
||||||
|
saveRowRecord(record)
|
||||||
|
if(stateData && stateData.Nav_Details)
|
||||||
|
{
|
||||||
|
let year = 0;
|
||||||
|
stateData.Nav_Details.map(t=>{
|
||||||
|
year = Math.round(year + t.WORK_YEAR);
|
||||||
|
})
|
||||||
|
stateData.YEAR=year
|
||||||
|
setDataState(stateData)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
108
src/files/edit/FO043.js
Normal file
108
src/files/edit/FO043.js
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
import { message } from "antd/lib/index";
|
||||||
|
import { getPropertyData, extendInclude, extendRule, getDataFieldValue, setDataFieldValue, initFilter, guid } from "../../utils/common";
|
||||||
|
import moment from 'moment';
|
||||||
|
/**
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
// 编辑
|
||||||
|
export default {
|
||||||
|
onBeforeSaveHandleRecord(params) {
|
||||||
|
params.record.TaskID = params.data.TaskID //TaskID传递消息表ID
|
||||||
|
params.record.PUBLISH = params.customParams;
|
||||||
|
},
|
||||||
|
onBeforeEdit: ({ isNew,login,record, dispatch,stateData, setFieldEditable,setFieldVisible,setFieldValue,setFieldValueByBatch }) => {
|
||||||
|
if (isNew) {
|
||||||
|
let json = initFilter(login.OrgId);
|
||||||
|
extendRule(json, "ID", 1, login.userId);
|
||||||
|
extendInclude(json, 'Nav_Department.Nav_Unit');
|
||||||
|
dispatch({
|
||||||
|
type: 'app/getDataByPost',
|
||||||
|
url: 'FM/User/Get',
|
||||||
|
payload: json,
|
||||||
|
onComplete: (ret) => {
|
||||||
|
if (ret) {
|
||||||
|
let temps = [];
|
||||||
|
temps.push({ field: 'APPLY_USER_ID', value: ret.ID})
|
||||||
|
temps.push({ field: 'Nav_ApplyUser.NAME', value: ret.NAME })
|
||||||
|
temps.push({ field: 'APPLY_DEPARTMENT_ID', value: ret.DEPARTMENT_ID})
|
||||||
|
temps.push({ field: 'Nav_ApplyDepartment.NAME', value: ret.Nav_Department?.NAME })
|
||||||
|
temps.push({ field: 'PRODUCTION_UNIT_ID', value: ret.Nav_Department?.PRODUCTION_UNIT_ID})
|
||||||
|
temps.push({ field: 'Nav_ProductionUnit.NAME', value: ret.Nav_Department?.Nav_Unit?.NAME })
|
||||||
|
setFieldValueByBatch(temps);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
///发起人不能编辑
|
||||||
|
setFieldEditable('COMPLETED_CONDITION', false)
|
||||||
|
setFieldEditable('IS_FIRE', false)
|
||||||
|
setFieldEditable('ACT_DATE', false)
|
||||||
|
setFieldEditable('Nav_FireFiles', false)
|
||||||
|
setFieldEditable('Nav_DispatchUser.NAME', false)
|
||||||
|
setFieldEditable('COMPLETED_CONTENT', false)
|
||||||
|
setFieldEditable('IS_LEAVE', false)
|
||||||
|
setFieldEditable('ACT_END_DATE', false)
|
||||||
|
setFieldEditable('LEAVE_DATE', false)
|
||||||
|
setFieldEditable('Nav_MonitorFiles', false)
|
||||||
|
}
|
||||||
|
else if(stateData.FIRE_STATUS == 10)
|
||||||
|
{
|
||||||
|
setFieldEditable('COMPLETED_CONDITION', true)
|
||||||
|
setFieldEditable('IS_FIRE', true)
|
||||||
|
setFieldEditable('ACT_DATE', true)
|
||||||
|
setFieldEditable('Nav_FireFiles', true)
|
||||||
|
setFieldEditable('Nav_DispatchUser.NAME', true)
|
||||||
|
setFieldEditable('COMPLETED_CONTENT', false)
|
||||||
|
setFieldEditable('IS_LEAVE', false)
|
||||||
|
setFieldEditable('ACT_END_DATE', false)
|
||||||
|
setFieldEditable('LEAVE_DATE', false)
|
||||||
|
setFieldEditable('Nav_MonitorFiles', false)
|
||||||
|
}
|
||||||
|
else if(stateData.FIRE_STATUS == 18)
|
||||||
|
{
|
||||||
|
setFieldEditable('COMPLETED_CONDITION', false)
|
||||||
|
setFieldEditable('IS_FIRE', false)
|
||||||
|
setFieldEditable('ACT_DATE', false)
|
||||||
|
setFieldEditable('Nav_FireFiles', false)
|
||||||
|
setFieldEditable('Nav_DispatchUser', false)
|
||||||
|
setFieldEditable('COMPLETED_CONTENT', true)
|
||||||
|
setFieldEditable('IS_LEAVE', true)
|
||||||
|
setFieldEditable('ACT_END_DATE', true)
|
||||||
|
setFieldEditable('LEAVE_DATE', true)
|
||||||
|
setFieldEditable('Nav_MonitorFiles', true)
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
setFieldEditable('COMPLETED_CONDITION', false)
|
||||||
|
setFieldEditable('IS_FIRE', false)
|
||||||
|
setFieldEditable('ACT_DATE', false)
|
||||||
|
setFieldEditable('Nav_FireFiles', false)
|
||||||
|
setFieldEditable('Nav_DispatchUser.NAME', false)
|
||||||
|
setFieldEditable('COMPLETED_CONTENT', false)
|
||||||
|
setFieldEditable('IS_LEAVE', false)
|
||||||
|
setFieldEditable('ACT_END_DATE', false)
|
||||||
|
setFieldEditable('LEAVE_DATE', false)
|
||||||
|
setFieldEditable('Nav_MonitorFiles', false)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onChange: ({ colInfo, getFieldValue, setFieldValueByBatch, dispatch,login,updateSubTableData }) => {
|
||||||
|
if (!(colInfo.FIELD_NAME == 'Nav_OperationStep.NAME'))
|
||||||
|
return;
|
||||||
|
|
||||||
|
let code = getFieldValue('OPERATION_STEP_ID')
|
||||||
|
let json = initFilter(login.OrgId,code);
|
||||||
|
dispatch({
|
||||||
|
type: 'app/getDataByPost',
|
||||||
|
url: 'FO/FOFireJob/GetAnalyzeDetail',
|
||||||
|
payload: json,
|
||||||
|
onlyData: false,
|
||||||
|
onComplete: (re) => {
|
||||||
|
if (re && re.IsSuccessful && re.Data) {
|
||||||
|
let temps = [];
|
||||||
|
temps.push({ field: 'Nav_Details', value: re.Data.Nav_Details })
|
||||||
|
temps.push({ field: 'EVALUATE_LEVEL', value: re.Data.EVALUATE_LEVEL })
|
||||||
|
temps.push({ field: 'AUDIT_LEVEL', value: re.Data.AUDIT_LEVEL})
|
||||||
|
setFieldValueByBatch(temps);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
}
|
||||||
@ -404,7 +404,7 @@ export default function (componentName, formId, formParam, data, formCode, formD
|
|||||||
BI011TrainSafeAnalysis: <BI011TrainSafeAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
BI011TrainSafeAnalysis: <BI011TrainSafeAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI012NotificationTaskAnalysis: <BI012NotificationTaskAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
// BI012NotificationTaskAnalysis: <BI012NotificationTaskAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI013RiskAnalysisModel: <BI013RiskAnalysisModel formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
// BI013RiskAnalysisModel: <BI013RiskAnalysisModel formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI014RiskPerformanceModel: <BI014RiskPerformanceModel formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
BI014RiskPerformanceModel: <BI014RiskPerformanceModel formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI030FormRunAnalysis: <BI030FormRunAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
// BI030FormRunAnalysis: <BI030FormRunAnalysis formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI060MapeShow: <BI060MapeShow formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
// BI060MapeShow: <BI060MapeShow formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
// BI060MapePoint: <BI060MapePoint formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
// BI060MapePoint: <BI060MapePoint formId={formId} formParam={formParam} data={data} formCode={formCode} />,
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user