import { Button, Descriptions, Row, Col, Form, Input, Select, Table, Modal } from 'antd'; import { message } from "antd/lib/index"; import React from 'react'; import moment from 'moment'; import { initFilter, extendRule, extendInclude, extendOrder, setDataFieldValue, guid, showFiles, GetFileModel } from "../../../utils/common"; import ReactToPrint from "react-to-print"; import styles from '../HI/StepForm.css'; import config from "../../../config"; import XLSX from 'xlsx'; import { connect } from 'dva'; import FormPage from '../../../components/FormPage' class HM061ShowPrint extends React.Component { constructor(props) { super(props); this.state = { data: null, tmpData: {}, BtnSignDisplay: 'none', loading: false, fileForm: { title: "", visible: false, }, }; }; componentDidMount() { if (this.props.data?.id) this.loadData(this.props.data?.id); } componentWillReceiveProps(NextProps) { if (NextProps.data?.id && this.props.data?.id != NextProps.data?.id) { this.loadData(NextProps.data?.id); } } loadData = (dataId) => { let json = initFilter(this.props.login.OrgId); extendRule(json, 'ID', 1, dataId); extendInclude(json, 'Nav_Request'); extendInclude(json, 'Nav_Identifyings.Nav_Identifying'); extendInclude(json, 'Nav_Files.Nav_ImgFile'); extendInclude(json, 'Nav_Detail.Nav_Users.Nav_User'); extendInclude(json, 'Nav_Detail.Nav_User'); extendInclude(json, 'Nav_Detail.Nav_Area'); extendInclude(json, 'Nav_Areas.Nav_Area'); extendInclude(json, 'Nav_LiableUser'); this.props.dispatch({ type: 'app/getDataByPost', payload: json, url: 'HM/RiskTask/Get', onComplete: (ret) => { if (ret) { if (this.props.data && this.props.data.loadDataDeal) { this.props.data.loadDataDeal(1); } this.onClickApprove(false); for (let i = 0; i < ret.Nav_Detail.length; i++) { ret.Nav_Detail.sort((a, b) => { return a.Nav_Area.NAME > b.Nav_Area.NAME ? 1 : -1; }); } for (let i = 0; i < ret.Nav_Detail.length; i++) { ret.Nav_Detail[i].Nav_Users.sort((a, b) => { return a.ROW_NO > b.ROW_NO ? 1 : -1; }); } this.setState({ data: ret }) this.props.dispatch({ type: 'app/getDataByPost', url: 'HM/HMRiskTask/GetUserDealStatus', payload: { ID: this.props.data.id, }, onComplete: (result) => { if (result != null && this.props.data.TaskID != null) { if (result) { this.setState({ BtnSignDisplay: 'inline' }) } } } }) } } }); } onTableBtnExport() { let TableWrap = document.getElementById('tableId' + this.props.data.id); let Table = TableWrap.getElementsByTagName('table')[0]; const wb = XLSX.utils.table_to_book(Table); XLSX.writeFile(wb, "风险任务表.xlsx") } onPersonalAgree() { this.setState({ loading: true }); this.props.dispatch({ type: 'app/getDataByPost', url: 'HM/HMRiskTask/UserSignin', payload: { ID: this.props.data.id, TaskID: this.props.data.TaskID, }, onComplete: (ret) => { if (ret) { message.success('确认成功!'); this.setState({ BtnSignDisplay: 'none' }) this.BtnClose(); } } }) } renderLevel(level) { let str = ''; if (level == undefined) { return str; } if (level.indexOf('0') >= 0) { str += '部门 '; } if (level.indexOf('1') >= 0) { str += '车间 '; } if (level.indexOf('2') >= 0) { str += '班组 '; } if (level.indexOf('3') >= 0) { str += '公司 '; } return str; } onClickApprove = (appVisible) => { const newtmpData = { data: { id: this.props.data.id, isShow: true, key: guid(), appVisible: appVisible, BtnAgreeDisplay: 'inline' }, formCode: "PF123", } this.setState({ tmpData: newtmpData, }); } BtnClose = () => { if (typeof this.props.data.onCancel != "undefined" && typeof this.props.data.onCancel == 'function') this.props.data.onCancel(); } render() { const { data } = this.state; return
| 辨识区域 | 层级 | 辨识人员 | 记录人 |
| {item.Nav_Area?.NAME} | {this.props.app.enums.FMDepartmentType.enums[item.LEVEL]} | { item.Nav_Users && item.Nav_Users.map((item1, i) => { if (i == (item1.Nav_User.length - 1)) { if (item1.DEAL_STATUS == 0) return else return item1.Nav_User.NAME } else { if (item1.DEAL_STATUS == 0) return else return item1.Nav_User.NAME + ' ' } }) } | {item.Nav_User?.NAME} |