1452 lines
43 KiB
JavaScript
1452 lines
43 KiB
JavaScript
import React from "react";
|
||
import { connect } from "dva";
|
||
import { initFilter, extendRule, extendOrder } from "../../../utils/common";
|
||
import { ChartPieShow, ChartBarShow } from "../../../utils/commonEcharsShow";
|
||
import {
|
||
Table,
|
||
Button,
|
||
Row,
|
||
Col,
|
||
Modal,
|
||
Icon,
|
||
Form,
|
||
DatePicker,
|
||
Progress,
|
||
message,
|
||
Divider,
|
||
} from "antd";
|
||
import echarts from "echarts";
|
||
import styles from "../HI/StepForm1.css";
|
||
import moment from "moment";
|
||
import { T } from "antd/lib/upload/utils";
|
||
import FormPage from "../../FormPage";
|
||
|
||
class BI007FormRunAnalysisNew extends React.Component {
|
||
constructor(props) {
|
||
super(props);
|
||
this.state = {
|
||
selectStartTime: moment(this.getStartDate(), "YYYY-MM-DD 00:00:00"),
|
||
selectEndTime: moment(this.getEndDate(), "YYYY-MM-DD 23:59:59"),
|
||
visible: false,
|
||
unfinishVisible: false,
|
||
noticeTitle: "",
|
||
tmpData: {},
|
||
tableKey: "1",
|
||
startTime: this.getDate(),
|
||
endTime: moment(new Date()).format("YYYYMMDD"),
|
||
timeType: 5,
|
||
totalCount: 0,
|
||
finishCount: 0,
|
||
overtimeCount: 0,
|
||
unfinishCount: 0,
|
||
dtotalCount: 0,
|
||
dfinishCount: 0,
|
||
dovertimeCount: 0,
|
||
dunfinishCount: 0,
|
||
drate: "0%",
|
||
dnormalRate: "0%",
|
||
weekColor: "black",
|
||
monthColor: "orange",
|
||
threeMonthColor: "black",
|
||
sixMonthColor: "black",
|
||
yearColor: "black",
|
||
retData: [],
|
||
allData: [],
|
||
unFinishData: [],
|
||
groupData: [],
|
||
detailData: [],
|
||
newData: [],
|
||
detailDataH: [],
|
||
displayHr: "none",
|
||
displaydetail: "none",
|
||
columns: [
|
||
{
|
||
width: "100px",
|
||
title: "车间(人数)",
|
||
dataIndex: "DEPARTMENT_NAME",
|
||
key: "DEPARTMENT_NAME",
|
||
// render: (text, record) => (
|
||
// <span>
|
||
// <a onClick={() => this.showEditModal(record.DEPARTMENT_ID,record.DEPARTMENT_NAME)}>{record.DEPARTMENT_NAME}</a>
|
||
// </span>
|
||
// ),
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "总任务数",
|
||
dataIndex: "TOTAL_QTY",
|
||
key: "TOTAL_QTY",
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "正常已办",
|
||
dataIndex: "FINISH_QTY",
|
||
key: "FINISH_QTY",
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "超时已办",
|
||
dataIndex: "OVER_FINISH_QTY",
|
||
key: "OVER_FINISH_QTY",
|
||
},
|
||
{
|
||
width: "50px",
|
||
title: "未完成",
|
||
dataIndex: "UNFINISH_QTY",
|
||
key: "UNFINISH_QTY",
|
||
render: (text, record) => (
|
||
<span>
|
||
<a onClick={() => this.showUnfinishModal(record,1)}>
|
||
{record.UNFINISH_QTY}
|
||
</a>
|
||
</span>
|
||
),
|
||
},
|
||
{
|
||
width: "50px",
|
||
title: "完成率",
|
||
dataIndex: "FINISH_RATE",
|
||
key: "FINISH_RATE",
|
||
render: (text, record) => (
|
||
<span>{record.FINISH_RATE}%</span>
|
||
),
|
||
},
|
||
{
|
||
width: "70px",
|
||
title: "及时完成率",
|
||
dataIndex: "NORMAL_FINISH_RATE",
|
||
key: "NORMAL_FINISH_RATE",
|
||
render: (text, record) => (
|
||
<span>{record.NORMAL_FINISH_RATE}%</span>
|
||
// <span>
|
||
// <a onClick={() => this.showEditModal(record.DEPARTMENT_ID,record.DEPARTMENT_NAME)}>{record.DEPARTMENT_NAME}</a>
|
||
// </span>
|
||
),
|
||
},
|
||
],
|
||
detailColumns: [
|
||
{
|
||
width: "60px",
|
||
title: "班组(人数)",
|
||
dataIndex: "DEPARTMENT_NAME",
|
||
key: "DEPARTMENT_NAME",
|
||
// render: (text, record) => (
|
||
// <span>
|
||
// <a onClick={() => this.showEditModal(record.DEPARTMENT_ID,record.DEPARTMENT_NAME)}>{record.DEPARTMENT_NAME}</a>
|
||
// </span>
|
||
// ),
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "总任务数",
|
||
dataIndex: "TOTAL_QTY",
|
||
key: "TOTAL_QTY",
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "正常已办",
|
||
dataIndex: "FINISH_QTY",
|
||
key: "FINISH_QTY",
|
||
},
|
||
{
|
||
width: "60px",
|
||
title: "超时已办",
|
||
dataIndex: "OVER_FINISH_QTY",
|
||
key: "OVER_FINISH_QTY",
|
||
},
|
||
{
|
||
width: "50px",
|
||
title: "未完成",
|
||
dataIndex: "UNFINISH_QTY",
|
||
key: "UNFINISH_QTY",
|
||
render: (text, record) => (
|
||
<span>
|
||
<a onClick={() => this.showUnfinishModal(record,2)}>
|
||
{record.UNFINISH_QTY}
|
||
</a>
|
||
</span>
|
||
),
|
||
},
|
||
// {
|
||
// width: "50px",
|
||
// title: "未完成",
|
||
// dataIndex: "UNFINISH_QTY",
|
||
// key: "UNFINISH_QTY",
|
||
// },
|
||
{
|
||
width: "100px",
|
||
title: "完成率",
|
||
dataIndex: "FINISH_RATE",
|
||
key: "FINISH_RATE",
|
||
render: (text, record) => (
|
||
<Progress percent={record.FINISH_RATE.split("%")[0]} />
|
||
// <span>
|
||
// <a onClick={() => this.showEditModal(record.DEPARTMENT_ID,record.DEPARTMENT_NAME)}>{record.DEPARTMENT_NAME}</a>
|
||
// </span>
|
||
),
|
||
},
|
||
{
|
||
width: "100px",
|
||
title: "及时完成率",
|
||
dataIndex: "NORMAL_FINISH_RATE",
|
||
key: "NORMAL_FINISH_RATE",
|
||
render: (text, record) => (
|
||
<Progress
|
||
percent={record.NORMAL_FINISH_RATE.split("%")[0]}
|
||
strokeColor={{
|
||
from: "rgba(82, 196, 26)",
|
||
to: "rgba(82, 196, 26)",
|
||
}}
|
||
/>
|
||
// <span>
|
||
// <a onClick={() => this.showEditModal(record.DEPARTMENT_ID,record.DEPARTMENT_NAME)}>{record.DEPARTMENT_NAME}</a>
|
||
// </span>
|
||
),
|
||
},
|
||
],
|
||
unfinishColumns: [
|
||
{
|
||
width: "50px",
|
||
title: "序号",
|
||
dataIndex: "ROW_NO",
|
||
key: "ROW_NO",
|
||
// render:(value,record,index)=>{
|
||
|
||
// },
|
||
},
|
||
{
|
||
width: "100px",
|
||
title: "车间/班组(人数)",
|
||
dataIndex: "DEPARTMENT_NAME",
|
||
key: "DEPARTMENT_NAME",
|
||
// render:(value,record,index)=>{
|
||
|
||
// },
|
||
},
|
||
{
|
||
width: "100px",
|
||
title: "待办名称",
|
||
dataIndex: "NOTICE_TITLE",
|
||
key: "NOTICE_TITLE",
|
||
// render:(value,record,index)=>{
|
||
|
||
// },
|
||
},
|
||
{
|
||
width: "200px",
|
||
title: "待办人",
|
||
dataIndex: "USER_NAME",
|
||
key: "USER_NAME",
|
||
},
|
||
{
|
||
width: "100px",
|
||
title: "开始时间",
|
||
dataIndex: "TASK_STARTDT",
|
||
key: "TASK_STARTDT",
|
||
},
|
||
{
|
||
width: "100px",
|
||
title: "结束时间",
|
||
dataIndex: "TASK_ENDDT",
|
||
key: "TASK_ENDDT",
|
||
},
|
||
{
|
||
width: "80px",
|
||
title: "状态",
|
||
dataIndex: "STATUS_NAME",
|
||
key: "STATUS_NAME",
|
||
},
|
||
],
|
||
};
|
||
}
|
||
|
||
componentDidMount() {
|
||
this.loadData();
|
||
}
|
||
showUnfinishModal = (record,num) => {
|
||
var orgId = this.props.login ? this.props.login.OrgId : "";
|
||
let json = initFilter(orgId, "", "TASK_STARTDT");
|
||
let startTime = this.state.selectStartTime.format("YYYY-MM-DD 00:00:00");
|
||
let endTime = this.state.selectEndTime.format("YYYY-MM-DD 23:59:59");
|
||
extendRule(json, "CREATE_DATE", 6, startTime);
|
||
extendRule(json, "CREATE_DATE", 4, endTime);
|
||
extendRule(json, "NOTICE_STATUS", 1, 0);
|
||
extendRule(json, "NOTICE_TYPE", 2, 2);
|
||
if(num === 1)
|
||
{
|
||
extendRule(json, "SHOP_DEPARTMENT_ID", 1, record.DEPARTMENT_ID);
|
||
}
|
||
else
|
||
{
|
||
extendRule(json, "CLASS_DEPARTMENT_ID", 1, record.DEPARTMENT_ID);
|
||
}
|
||
this.props.dispatch({
|
||
type: "app/getDataByPost",
|
||
payload: json,
|
||
url: "BI/NotificationTaskNew/OrderEntities",
|
||
onComplete: (ret) => {
|
||
if (ret) {
|
||
let newDataTemp = [];
|
||
let i = 1;
|
||
ret.forEach((t) => {
|
||
t.ROW_NO = i;
|
||
t.DEPARTMENT_NAME = record.DEPARTMENT_NAME;
|
||
t.STATUS_NAME = "未完成";
|
||
newDataTemp.push(t);
|
||
i++;
|
||
});
|
||
this.setState({ unfinishVisible: true, unFinishData: newDataTemp });
|
||
}
|
||
},
|
||
});
|
||
};
|
||
showEditModal = (departmentId, departmentName) => {
|
||
const newtmpData = {
|
||
data: {
|
||
id: departmentId,
|
||
name: departmentName,
|
||
onCancel: this.handleCancel,
|
||
tableKey: this.state.tableKey,
|
||
homeReload: true,
|
||
},
|
||
formCode: "BI007_RUNANALYSIS",
|
||
};
|
||
this.setState(
|
||
{
|
||
id: departmentId,
|
||
name: departmentName,
|
||
noticeTitle: departmentName + "安全生产标准化运行情况",
|
||
tmpData: newtmpData,
|
||
currActivatedMenu: "",
|
||
},
|
||
() =>
|
||
this.setState({
|
||
visible: true,
|
||
})
|
||
);
|
||
};
|
||
showFormModal = (record) => {
|
||
const { newData } = this.state;
|
||
let newDataTemp = [];
|
||
let temp = newData.filter(
|
||
(t) =>
|
||
t.DEPARTMENT_ID === record.departmentId &&
|
||
t.SOURCE_FORMCODE === record.formCode
|
||
);
|
||
if (temp.length > 0) {
|
||
let i = 1;
|
||
temp.forEach((t) => {
|
||
t.ROW_NO = i;
|
||
t.formName = record.formName;
|
||
newDataTemp.push(t);
|
||
i++;
|
||
});
|
||
} else {
|
||
newDataTemp = [];
|
||
}
|
||
this.setState({ displaydetail: "block", detailDataH: newDataTemp });
|
||
};
|
||
// showEditModal = (dataId, formCode, TaskID, title, taskCode) => {
|
||
|
||
// const newtmpData = {
|
||
// data: {
|
||
// id: dataId, TaskID: TaskID, onCancel: this.handleCancel, taskCode: taskCode, tableKey: this.state.tableKey,
|
||
// homeReload: true
|
||
// },
|
||
// formCode: formCode,
|
||
// }
|
||
// this.setState({
|
||
// noticeTitle: title,
|
||
// taskCode: taskCode,
|
||
// tmpData: newtmpData,
|
||
// currActivatedMenu: ''
|
||
// }, () => this.setState({
|
||
// visible: true
|
||
// }));
|
||
// }
|
||
getStartDate = () => {
|
||
let date = new Date();
|
||
let y = date.getFullYear();
|
||
let m = date.getMonth() + 1;
|
||
let d = date.getDate();
|
||
// 当前日期
|
||
let nowDate =
|
||
y + "-" + (m < 10 ? "0" + m : m) + "-" + (d < 10 ? "0" + d : d);
|
||
let pastDate = moment(nowDate)
|
||
.add(-1, "month")
|
||
.format("YYYY-MM-DD 00:00:00");
|
||
return pastDate;
|
||
};
|
||
|
||
getEndDate = () => {
|
||
let date = new Date();
|
||
let y = date.getFullYear();
|
||
let m = date.getMonth() + 1;
|
||
let d = date.getDate();
|
||
// 当前日期
|
||
let nowDate =
|
||
y + "-" + (m < 10 ? "0" + m : m) + "-" + (d < 10 ? "0" + d : d);
|
||
let pastDate = moment(nowDate).format("YYYY-MM-DD 23:59:59");
|
||
return pastDate;
|
||
};
|
||
|
||
getDate = (type) => {
|
||
let date = new Date();
|
||
let y = date.getFullYear();
|
||
let m = date.getMonth() + 1;
|
||
let d = date.getDate();
|
||
// 当前日期
|
||
let nowDate =
|
||
y + "-" + (m < 10 ? "0" + m : m) + "-" + (d < 10 ? "0" + d : d);
|
||
let pastDate = moment(nowDate).add(-1, "month").format("YYYYMMDD");
|
||
let weekColor = "black";
|
||
let monthColor = "orange";
|
||
let threeMonthColor = "black";
|
||
let sixMonthColor = "black";
|
||
let yearColor = "black";
|
||
let timeType = 5;
|
||
if (type === "Week") {
|
||
pastDate = moment(nowDate).add(-7, "d").format("YYYYMMDD");
|
||
weekColor = "orange";
|
||
monthColor = "black";
|
||
threeMonthColor = "black";
|
||
sixMonthColor = "black";
|
||
yearColor = "black";
|
||
timeType = 1;
|
||
}
|
||
if (type === "ThreeMonth") {
|
||
pastDate = moment(nowDate).add(-3, "month").format("YYYYMMDD");
|
||
weekColor = "black";
|
||
monthColor = "black";
|
||
threeMonthColor = "orange";
|
||
sixMonthColor = "black";
|
||
yearColor = "black";
|
||
timeType = 10;
|
||
}
|
||
if (type === "SixMonth") {
|
||
pastDate = moment(nowDate).add(-6, "month").format("YYYYMMDD");
|
||
weekColor = "black";
|
||
monthColor = "black";
|
||
threeMonthColor = "black";
|
||
sixMonthColor = "orange";
|
||
yearColor = "black";
|
||
timeType = 15;
|
||
}
|
||
if (type === "Year") {
|
||
pastDate = moment(nowDate).add(-1, "year").format("YYYYMMDD");
|
||
weekColor = "black";
|
||
monthColor = "black";
|
||
threeMonthColor = "black";
|
||
sixMonthColor = "black";
|
||
yearColor = "orange";
|
||
timeType = 20;
|
||
}
|
||
this.setState(
|
||
{
|
||
startTime: pastDate,
|
||
timeType: timeType,
|
||
weekColor: weekColor,
|
||
monthColor: monthColor,
|
||
threeMonthColor: threeMonthColor,
|
||
sixMonthColor: sixMonthColor,
|
||
yearColor: yearColor,
|
||
},
|
||
() => {
|
||
if (type) {
|
||
this.loadData();
|
||
}
|
||
}
|
||
);
|
||
return pastDate;
|
||
};
|
||
getDepartId = () => {};
|
||
//加载数据赋值
|
||
loadData = () => {
|
||
// this.ksRun();
|
||
// this.xkRun();
|
||
var orgId = this.props.login ? this.props.login.OrgId : "";
|
||
const jsonTemp = initFilter(orgId);
|
||
extendRule(
|
||
jsonTemp,
|
||
"NAME",
|
||
1,
|
||
this.props?.login?.currActivatedMenu?.MENU_FORM_PARAMS
|
||
);
|
||
this.props.dispatch({
|
||
type: "app/getDataByPost",
|
||
payload: jsonTemp,
|
||
url: "FM/Department/OrderEntities",
|
||
onComplete: (retDepart) => {
|
||
if (retDepart) {
|
||
// this.getClassDepartment(retDepart[0].ID);
|
||
this.getShopDepartment(retDepart[0].ID);
|
||
} else {
|
||
message.error(
|
||
"未找到部门" +
|
||
this.props?.login?.currActivatedMenu?.MENU_FORM_PARAMS +
|
||
",请先维护"
|
||
);
|
||
}
|
||
},
|
||
});
|
||
};
|
||
//
|
||
workTicket = () => {
|
||
const { retData } = this.state;
|
||
let teamName = [];
|
||
let wattingQty = [];
|
||
let finishQty = [];
|
||
let overFinishQty = [];
|
||
let totalQty = [];
|
||
retData.forEach((item) => {
|
||
teamName.push(item.DEPARTMENT_NAME);
|
||
wattingQty.push(item.UNFINISH_QTY);
|
||
finishQty.push(item.FINISH_QTY);
|
||
overFinishQty.push(item.OVER_FINISH_QTY);
|
||
totalQty.push(item.TOTAL_QTY);
|
||
});
|
||
//图标2
|
||
let workTickets = document.getElementById("workTicket");
|
||
if (workTickets) {
|
||
let myChart = echarts.init(workTickets);
|
||
myChart.setOption({
|
||
// title: {
|
||
// text: "部门级-安全事务完成情况",
|
||
// left: 'center'
|
||
// },
|
||
tooltip: {
|
||
trigger: "axis",
|
||
axisPointer: {
|
||
// 坐标轴指示器,坐标轴触发有效
|
||
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
|
||
},
|
||
},
|
||
grid: {
|
||
left: "3%",
|
||
right: "4%",
|
||
top: "10%",
|
||
bottom: "10%",
|
||
containLabel: true,
|
||
},
|
||
xAxis: {
|
||
type: "category",
|
||
data: teamName,
|
||
axisLine: {
|
||
show: false,
|
||
// lineStyle: {
|
||
// color: 'rgba(192, 192, 102)'
|
||
// }
|
||
},
|
||
axisTick: {
|
||
show: false,
|
||
},
|
||
axisLabel: {
|
||
color: "#000",
|
||
rotate: 40,
|
||
formatter: function (value) {
|
||
// 自定义文字超出部分 ...
|
||
if (value.length > 5) {
|
||
return `${value.slice(0, 5)}...`;
|
||
}
|
||
return value;
|
||
},
|
||
},
|
||
},
|
||
legend: {
|
||
data: ["正常已办", "超时已办", "未完成"],
|
||
bottom: "0px",
|
||
},
|
||
yAxis: {
|
||
type: "value",
|
||
splitLine: {
|
||
show: false,
|
||
lineStyle: {
|
||
color: "#172749",
|
||
},
|
||
},
|
||
axisLine: {
|
||
show: false,
|
||
// lineStyle: {
|
||
// color: 'rgba(192, 192, 102)'
|
||
// }
|
||
},
|
||
axisTick: {
|
||
show: false,
|
||
},
|
||
},
|
||
series: [
|
||
// {
|
||
// name: '总数',
|
||
// type: 'bar',
|
||
// stack: '',
|
||
// label: {
|
||
// show: true,
|
||
// position: 'top',
|
||
// color: '#000',
|
||
// },
|
||
// data: totalQty,
|
||
// barGap: '-100%',
|
||
// z: -1,
|
||
// itemStyle: {
|
||
// normal: {
|
||
// color: '#CCCCCC'//rgba(128, 128, 128, 0.3)
|
||
// }
|
||
// },
|
||
// },
|
||
{
|
||
name: "正常已办",
|
||
type: "bar",
|
||
stack: "总量",
|
||
label: {
|
||
show: true,
|
||
position: "inside",
|
||
color: "#000",
|
||
},
|
||
emphasis: {
|
||
//折线图的高亮状态。
|
||
focus: "series", //聚焦当前高亮的数据所在的系列的所有图形。
|
||
},
|
||
data: finishQty,
|
||
barGap: "-100%",
|
||
z: -1,
|
||
itemStyle: {
|
||
// 渐变色 1、指明颜色渐变的方向 2、指明不同百分比之下颜色的值
|
||
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
|
||
{ offset: 0, color: "#01AEF6" },
|
||
{ offset: 1, color: "rgba(16,36,95,0.6)" }, //rgba(16,36,95,0.6) #9999FF
|
||
]),
|
||
// normal: {
|
||
// color: '#5B9BD5',
|
||
// }
|
||
},
|
||
},
|
||
{
|
||
name: "超时已办",
|
||
type: "bar",
|
||
stack: "总量",
|
||
label: {
|
||
show: true,
|
||
position: "inside",
|
||
color: "#000",
|
||
},
|
||
emphasis: {
|
||
//折线图的高亮状态。
|
||
focus: "series", //聚焦当前高亮的数据所在的系列的所有图形。
|
||
},
|
||
data: overFinishQty,
|
||
barGap: "-100%",
|
||
z: -1,
|
||
itemStyle: {
|
||
// 渐变色 1、指明颜色渐变的方向 2、指明不同百分比之下颜色的值
|
||
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [
|
||
{ offset: 0, color: "#ED7D31" },
|
||
{ offset: 1, color: "#FFFF33" }, //rgba(255,255,0,0.6)
|
||
]),
|
||
// normal: {
|
||
// color: '#ED7D31',
|
||
// }
|
||
},
|
||
},
|
||
{
|
||
name: "未完成",
|
||
type: "bar",
|
||
stack: "总量",
|
||
label: {
|
||
show: true,
|
||
position: "inside",
|
||
color: "#000",
|
||
},
|
||
emphasis: {
|
||
//折线图的高亮状态。
|
||
focus: "series", //聚焦当前高亮的数据所在的系列的所有图形。
|
||
},
|
||
data: wattingQty,
|
||
barGap: "-100%",
|
||
z: -1,
|
||
itemStyle: {
|
||
normal: {
|
||
color: "#CCCCCC", //rgba(128, 128, 128, 0.3)
|
||
},
|
||
},
|
||
},
|
||
],
|
||
});
|
||
}
|
||
}; //主要工作分布图(饼图)
|
||
// mainJobPie2Old = () => {
|
||
// const {retData} = this.state;
|
||
// // let data = { "IsSuccessful": true, "Data": [{ "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "安全检查", "COUNT": 3, "COLOR": "#CD0505" }, { "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "作业现场", "COUNT": 2, "COLOR": "#FCD149" }, { "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "应急管理", "COUNT": 1, "COLOR": "#60A9F8" }], "TotalCount": 0, "ErrorMessage": null }
|
||
|
||
// let moduleData = []
|
||
// let showData = []
|
||
// let dataColor = ["#FFFF00","#FF3300","#FF9900","#669900","#33FFFF","#CCCC66","#003399","#FFFFCC"]
|
||
// retData.forEach(item => {
|
||
// moduleData.push(item.DEPARTMENT_NAME)
|
||
// let valueTemp=item.FINISH_QTY+item.OVER_FINISH_QTY
|
||
// showData.push({ value: valueTemp, name: item.DEPARTMENT_NAME })
|
||
// // let agb=`rgb(${Math.floor(Math.random()*256)},${Math.floor(Math.random()*256)},${Math.floor(Math.random()*256)})`;
|
||
// // dataColor.push(agb)
|
||
// })
|
||
// let myChart = echarts.init(document.getElementById('mainJobPie2'));
|
||
// myChart.setOption({
|
||
// // title: {
|
||
// // text: "部门级-安全事务完成率",
|
||
// // left: 'center'
|
||
// // },
|
||
// tooltip: {
|
||
// trigger: 'item',
|
||
// //formatter: '{a} <br/>{b} : {c} ({d}%)'
|
||
// formatter: '{b} : {c} ({d}%)'
|
||
// },
|
||
// legend: {
|
||
// bottom: '10px',
|
||
// data: moduleData
|
||
// },
|
||
// series: [
|
||
// {
|
||
// name: '主要工作分布',
|
||
// type: 'pie',
|
||
// radius: '55%',
|
||
// center: ['50%', '42%'],
|
||
// label: {
|
||
// formatter: '{b}:({d}%)',
|
||
// normal:{
|
||
// show: true,
|
||
// position:'inner',
|
||
// formatter: '{d}%',
|
||
// }
|
||
// },
|
||
// data: showData,
|
||
// color: dataColor,
|
||
// emphasis: {
|
||
// itemStyle: {
|
||
// shadowBlur: 10,
|
||
// shadowOffsetX: 0,
|
||
// //shadowColor: 'rgba(0, 0, 0, 0.5)'
|
||
// }
|
||
// }
|
||
// }
|
||
// ]
|
||
// });
|
||
// }
|
||
mainJobPie2 = () => {
|
||
const { retData } = this.state;
|
||
// let data = { "IsSuccessful": true, "Data": [{ "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "安全检查", "COUNT": 3, "COLOR": "#CD0505" }, { "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "作业现场", "COUNT": 2, "COLOR": "#FCD149" }, { "USER_ID": "37c527b6-86cf-4549-8b2d-8528af5600d1", "DEPARTMENT_ID": "e3061909-1a7e-b60c-bc71-1845b79c4a11", "MODULE": "应急管理", "COUNT": 1, "COLOR": "#60A9F8" }], "TotalCount": 0, "ErrorMessage": null }
|
||
|
||
let month = [];
|
||
let company = [];
|
||
let department = [];
|
||
let totalCount = [];
|
||
let retDataTemp = retData.filter(
|
||
(m) => m.PARENT_DEPARTMENT_ID !== null
|
||
);
|
||
retDataTemp.forEach((item) => {
|
||
month.push(item.DEPARTMENT_NAME);
|
||
company.push(item.FINISH_RATE);
|
||
department.push(item.NORMAL_FINISH_RATE);
|
||
totalCount.push(item.FINISH_QTY + item.OVER_FINISH_QTY);
|
||
});
|
||
let myChart = echarts.init(document.getElementById("mainJobPie2"));
|
||
myChart.setOption({
|
||
tooltip: {
|
||
trigger: "axis",
|
||
axisPointer: {
|
||
// 坐标轴指示器,坐标轴触发有效
|
||
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
|
||
},
|
||
transitionDuration: 0,
|
||
formatter: function (params) {
|
||
return (
|
||
params[0].marker +
|
||
params[0].seriesName +
|
||
" : " +
|
||
params[0].value +
|
||
"</br>" +
|
||
params[1].marker +
|
||
params[1].seriesName +
|
||
" : " +
|
||
params[1].value + "%"+
|
||
"</br>" +
|
||
params[2].marker +
|
||
params[2].seriesName +
|
||
" : " +
|
||
params[2].value+ "%"
|
||
);
|
||
},
|
||
},
|
||
title: {
|
||
text: "安全任务完成率",
|
||
left: "center",
|
||
top: "5%",
|
||
},
|
||
legend: {
|
||
data: ["完成数", "完成率", "及时完成率"],
|
||
left: "center",
|
||
align: "left",
|
||
bottom: "2%",
|
||
textStyle: {
|
||
color: "#000",
|
||
},
|
||
itemWidth: 10,
|
||
itemHeight: 10,
|
||
// itemGap: 35,
|
||
},
|
||
grid: {
|
||
left: "3%",
|
||
right: "4%",
|
||
top: "15%",
|
||
containLabel: true,
|
||
},
|
||
xAxis: {
|
||
type: "category",
|
||
data: month,
|
||
axisLabel: {
|
||
showMaxLabel: true,
|
||
},
|
||
},
|
||
yAxis: [
|
||
{
|
||
type: "value",
|
||
position: "left",
|
||
splitLine: {
|
||
show: true,
|
||
lineStyle: {
|
||
color: ["#f2f2f2"],
|
||
// opacity:0.2
|
||
// zlevel: -1,
|
||
},
|
||
},
|
||
axisLine: {
|
||
lineStyle: {
|
||
color: "#0c3b71",
|
||
},
|
||
},
|
||
axisLabel: {
|
||
color: "rgb(170,170,170)",
|
||
formatter: "{value} ",
|
||
},
|
||
},
|
||
{
|
||
type: "value",
|
||
position: "right",
|
||
splitLine: {
|
||
show: false,
|
||
lineStyle: {
|
||
color: ["#f2f2f2"],
|
||
},
|
||
},
|
||
axisLine: {
|
||
lineStyle: {
|
||
color: "#f2f2f2",
|
||
},
|
||
},
|
||
axisLabel: {
|
||
color: "rgb(170,170,170)",
|
||
formatter: "{value} %",
|
||
},
|
||
},
|
||
],
|
||
series: [
|
||
{
|
||
name: "完成数",
|
||
type: "bar",
|
||
color: "#72b85b",
|
||
data: totalCount,
|
||
barWidth: "20%",
|
||
barGap: "10%",
|
||
stack: null,
|
||
},
|
||
{
|
||
name: "完成率",
|
||
type: "line",
|
||
color: "#4b9bf3",
|
||
data: company,
|
||
yAxisIndex: 1,
|
||
smooth: true,
|
||
// zlevel:100,
|
||
},
|
||
{
|
||
name: "及时完成率",
|
||
type: "line",
|
||
color: "#FCD149",
|
||
data: department,
|
||
yAxisIndex: 1,
|
||
smooth: true,
|
||
// zlevel:100,
|
||
},
|
||
],
|
||
});
|
||
};
|
||
compare = (val1, val2) => {
|
||
return val2.NUM - val1.NUM;
|
||
};
|
||
getClassDepartment = (dataTemp) => {
|
||
var orgId = this.props.login ? this.props.login.OrgId : "";
|
||
const jsonTemp = initFilter(orgId);
|
||
extendRule(jsonTemp, "DEPARTMENT_TYPE", 1, 2);
|
||
// extendRule(jsonTemp, 'Nav_Parent.PARENT_ID', 1, this.props.data.id);
|
||
extendRule(
|
||
jsonTemp,
|
||
"Nav_Parent.Nav_Parent.NAME",
|
||
1,
|
||
this.props?.login?.currActivatedMenu?.MENU_FORM_PARAMS
|
||
);
|
||
extendOrder(jsonTemp, "PARENT_ID", 0);
|
||
extendOrder(jsonTemp, "NAME", 0);
|
||
this.props.dispatch({
|
||
type: "app/getDataByPost",
|
||
payload: jsonTemp,
|
||
url: "FM/Department/OrderEntities",
|
||
onComplete: (retDepart) => {
|
||
if (retDepart) {
|
||
let tempDepart = [];
|
||
for (const t of retDepart) {
|
||
let tempNow = {
|
||
DEPARTMENT_ID: t.ID,
|
||
DEPARTMENT_NAME: t.NAME,
|
||
TOTAL_QTY: 0,
|
||
FINISH_QTY: 0,
|
||
OVER_FINISH_QTY: 0,
|
||
UNFINISH_QTY: 0,
|
||
FINISH_RATE: "0%",
|
||
NORMAL_FINISH_RATE: "0%",
|
||
};
|
||
tempDepart.push(tempNow);
|
||
}
|
||
// retDepart.forEach(t=>{
|
||
|
||
// })
|
||
|
||
// let json = initFilter(orgId,departId,'',1,'',this.state.selectStartTime,this.state.selectEndTime);
|
||
// extendRule(json, 'TYPE', 1, this.state.timeType);
|
||
// extendRule(json, 'DEPARTMENT_TYPE', 1, 2);
|
||
// extendRule(json, 'PARENT_DEPARTMENT_ID', 1, this.props.data.id);
|
||
// extendOrder(json, "PARENT_DEPARTMENT_ID", 0);
|
||
// extendOrder(json, "FINISH_RATE", 1);
|
||
if (dataTemp) {
|
||
let temp = [];
|
||
for (const t of tempDepart) {
|
||
let group = dataTemp.filter(
|
||
(m) => m.DEPARTMENT_ID === t.DEPARTMENT_ID
|
||
);
|
||
if (group.length > 0) {
|
||
t.TOTAL_QTY = group[0].TOTAL_QTY;
|
||
t.FINISH_QTY = group[0].FINISH_QTY;
|
||
t.OVER_FINISH_QTY = group[0].OVER_FINISH_QTY;
|
||
t.UNFINISH_QTY = group[0].UNFINISH_QTY;
|
||
t.FINISH_RATE = group[0].FINISH_RATE + "%";
|
||
t.NORMAL_FINISH_RATE = group[0].NORMAL_FINISH_RATE + "%";
|
||
t.NUM =
|
||
group[0].TOTAL_QTY === 0
|
||
? 0
|
||
: group[0].FINISH_QTY / group[0].TOTAL_QTY;
|
||
}
|
||
temp.push(t);
|
||
}
|
||
temp = temp.sort(this.compare);
|
||
this.setState({
|
||
detailData: temp,
|
||
});
|
||
}
|
||
// this.props.dispatch({
|
||
// type: 'app/getDataByPost',
|
||
// payload: json,
|
||
// url: 'BI/BIStatiscialAnalysisController/GetDepartmentAnalyze',
|
||
// onComplete: (ret) => {
|
||
// if (ret) {
|
||
|
||
// }
|
||
// }
|
||
// })
|
||
}
|
||
},
|
||
});
|
||
};
|
||
|
||
getShopDepartment = (departId) => {
|
||
var orgId = this.props.login ? this.props.login.OrgId : "";
|
||
const jsonTemp = initFilter(orgId);
|
||
extendRule(jsonTemp, "DEPARTMENT_TYPE", 1, 1);
|
||
// extendRule(jsonTemp, 'PARENT_ID', 1, this.props.data.id);
|
||
extendRule(
|
||
jsonTemp,
|
||
"Nav_Parent.NAME",
|
||
1,
|
||
this.props?.login?.currActivatedMenu?.MENU_FORM_PARAMS
|
||
);
|
||
this.props.dispatch({
|
||
type: "app/getDataByPost",
|
||
payload: jsonTemp,
|
||
url: "FM/Department/OrderEntities",
|
||
onComplete: (retDepart) => {
|
||
if (retDepart) {
|
||
let tempDepart = [];
|
||
for (const t of retDepart) {
|
||
let tempNow = {
|
||
DEPARTMENT_ID: t.ID,
|
||
DEPARTMENT_NAME: t.NAME,
|
||
TOTAL_QTY: 0,
|
||
FINISH_QTY: 0,
|
||
OVER_FINISH_QTY: 0,
|
||
UNFINISH_QTY: 0,
|
||
FINISH_RATE: "0%",
|
||
NORMAL_FINISH_RATE: "0%",
|
||
};
|
||
tempDepart.push(tempNow);
|
||
}
|
||
let startTime = this.state.selectStartTime.format(
|
||
"YYYY-MM-DD 00:00:00"
|
||
);
|
||
let endTime = this.state.selectEndTime.format("YYYY-MM-DD 23:59:59");
|
||
let json = initFilter(orgId, departId, "", 1, "", startTime, endTime);
|
||
// extendRule(json, 'TYPE', 1, this.state.timeType);
|
||
// extendRule(json, 'DEPARTMENT_TYPE', 1, 1);
|
||
// extendRule(json, 'PARENT_DEPARTMENT_ID', 1, this.props.data.id);
|
||
this.props.dispatch({
|
||
type: "app/getDataByPost",
|
||
payload: json,
|
||
url: "BI/BIStatiscialAnalysisController/GetDepartmentAnalyzeNew",
|
||
onComplete: (ret) => {
|
||
if (ret) {
|
||
let temp = [];
|
||
if (ret) {
|
||
let t1 = 0;
|
||
let t2 = 0;
|
||
let t3 = 0;
|
||
let t4 = 0;
|
||
for (const t of tempDepart) {
|
||
let group = ret.filter(
|
||
(m) => m.DEPARTMENT_ID === t.DEPARTMENT_ID
|
||
);
|
||
if (group.length > 0) {
|
||
t.TOTAL_QTY = group[0].TOTAL_QTY;
|
||
t.FINISH_QTY = group[0].FINISH_QTY;
|
||
t.OVER_FINISH_QTY = group[0].OVER_FINISH_QTY;
|
||
t.UNFINISH_QTY = group[0].UNFINISH_QTY;
|
||
t.FINISH_RATE = group[0].FINISH_RATE;
|
||
t.NORMAL_FINISH_RATE = group[0].NORMAL_FINISH_RATE;
|
||
t1 = t1 + group[0].TOTAL_QTY;
|
||
t2 = t2 + group[0].FINISH_QTY;
|
||
t3 = t3 + group[0].OVER_FINISH_QTY;
|
||
t4 = t4 + group[0].UNFINISH_QTY;
|
||
}
|
||
temp.push(t);
|
||
}
|
||
let t5 =
|
||
t1 === 0 ? "0%" : (((t2 + t3) / t1) * 100).toFixed(0) + "%";
|
||
let t6 = t1 === 0 ? "0%" : ((t2 / t1) * 100).toFixed(0) + "%";
|
||
this.setState(
|
||
{
|
||
retData: temp,
|
||
allData: ret,
|
||
totalCount: t1,
|
||
finishCount: t2,
|
||
overtimeCount: t3,
|
||
unfinishCount: t4,
|
||
rate: t5,
|
||
normalRate: t6,
|
||
},
|
||
() => {
|
||
this.getClassDepartment(ret);
|
||
// this.workTicket();
|
||
this.mainJobPie2();
|
||
}
|
||
);
|
||
// ret.groupData.forEach(t=>{
|
||
// t.unDoneCount = t.TotalCount-t.doneCount -t.timeOverCount;
|
||
// t.allDoneRate = ((t.doneCount +t.timeOverCount)/t.TotalCount*100).toFixed(0)+"%";
|
||
// t.doneRate = (t.doneCount/t.TotalCount*100).toFixed(0)+"%";
|
||
// temp.push(t);
|
||
// })
|
||
}
|
||
}
|
||
},
|
||
});
|
||
}
|
||
},
|
||
});
|
||
};
|
||
closeModal = () => {
|
||
// 退出弹窗
|
||
this.clearData();
|
||
};
|
||
clearData = () => {
|
||
let newtmpData = { ...this.state.tmpData };
|
||
newtmpData["data"].id = "";
|
||
newtmpData["data"].homeReload = false;
|
||
newtmpData.formCode = "";
|
||
this.setState({
|
||
visible: false,
|
||
tmpData: newtmpData,
|
||
});
|
||
};
|
||
handleCancel = () => {
|
||
// 退出弹窗
|
||
this.clearData();
|
||
};
|
||
startChange = (value) => {
|
||
this.setState({
|
||
selectStartTime: value,
|
||
startTime: value.format("YYYYMMDD"),
|
||
});
|
||
};
|
||
endChange = (value) => {
|
||
this.setState({
|
||
selectEndTime: value,
|
||
endTime: value.format("YYYYMMDD"),
|
||
});
|
||
};
|
||
clearUnfinishData = () => {
|
||
this.setState({
|
||
unfinishVisible: false,
|
||
unFinishData: [], //newtmpData
|
||
});
|
||
};
|
||
render() {
|
||
const {
|
||
startTime,
|
||
endTime,
|
||
finishCount,
|
||
overtimeCount,
|
||
totalCount,
|
||
unfinishCount,
|
||
weekColor,
|
||
monthColor,
|
||
threeMonthColor,
|
||
sixMonthColor,
|
||
yearColor,
|
||
} = this.state;
|
||
const formItemLayout = {
|
||
labelCol: { span: 10 },
|
||
wrapperCol: { span: 14 },
|
||
};
|
||
let allFinishRate =
|
||
totalCount === 0
|
||
? 0
|
||
: (((finishCount + overtimeCount) / totalCount) * 100).toFixed(0);
|
||
let finishRate =
|
||
totalCount === 0 ? 0 : ((finishCount / totalCount) * 100).toFixed(0);
|
||
return (
|
||
<div>
|
||
{/* className='route-home' ,boxShadow:'inset 0 0 10px #ccc' */}
|
||
<div
|
||
style={{
|
||
backgroundColor: "white",
|
||
width: "1200px",
|
||
top: "0",
|
||
bottom: "0",
|
||
left: "0",
|
||
right: "0",
|
||
margin: "auto",
|
||
borderStyle: "solid",
|
||
borderColor: "#ccc",
|
||
borderWidth: "1px",
|
||
}}
|
||
>
|
||
<Modal
|
||
visible={this.state.unfinishVisible}
|
||
title="未完成明细"
|
||
maskClosable={false}
|
||
onCancel={this.clearUnfinishData}
|
||
footer={null}
|
||
className="antd-modal-fullscreen"
|
||
closeModal={this.clearUnfinishData}
|
||
>
|
||
<Table
|
||
dataSource={this.state.unFinishData}
|
||
columns={this.state.unfinishColumns}
|
||
pagination={false}
|
||
bordered
|
||
loading={this.state.showLoading}
|
||
size="small"
|
||
/>
|
||
</Modal>
|
||
<Modal
|
||
visible={this.state.visible}
|
||
title={this.state.noticeTitle}
|
||
maskClosable={false}
|
||
onCancel={this.handleCancel}
|
||
footer={null}
|
||
className="antd-modal-fullscreen"
|
||
closeModal={this.closeModal}
|
||
// forceRender={true}
|
||
>
|
||
<FormPage {...this.state.tmpData} />
|
||
</Modal>
|
||
{/* {this.props.data.name} */}
|
||
<h1
|
||
style={{
|
||
textAlign: "center",
|
||
marginTop: "30px",
|
||
fontWeight: "bold",
|
||
}}
|
||
>
|
||
{this.props?.login?.currActivatedMenu?.MENU_FORM_PARAMS}{" "}
|
||
安全生产标准化运行情况
|
||
</h1>
|
||
<Row style={{ textAlign: "center", fontSize: "15px" }}>
|
||
{" "}
|
||
<span>
|
||
({startTime}-{endTime})
|
||
</span>
|
||
</Row>
|
||
<br></br>
|
||
<div
|
||
style={{
|
||
display: "flex",
|
||
alignItems: "center",
|
||
flexDirection: "row",
|
||
justifyContent: "center",
|
||
}}
|
||
>
|
||
<div
|
||
style={{
|
||
display: "felx",
|
||
alignItems: "center",
|
||
flexDirection: "row",
|
||
fontSize: "14px",
|
||
marginRight: "20px",
|
||
}}
|
||
>
|
||
{/* <Form.Item label={"查询时间"}> */}
|
||
查询时间:
|
||
<DatePicker
|
||
style={{ width: "120px" }}
|
||
// defaultValue={moment(this.state.startTime, 'YYYY-MM-DD 00:00:00')}
|
||
value={this.state.selectStartTime}
|
||
format="YYYY-MM-DD"
|
||
onChange={this.startChange}
|
||
/>
|
||
{/* </Form.Item> */}
|
||
</div>
|
||
|
||
<div
|
||
style={{
|
||
display: "felx",
|
||
alignItems: "center",
|
||
flexDirection: "row",
|
||
fontSize: "14px",
|
||
marginRight: "20px",
|
||
}}
|
||
>
|
||
{/* <Form.Item label={"至"} > */}
|
||
至:
|
||
<DatePicker
|
||
style={{ width: "120px" }}
|
||
// defaultValue={moment(this.state.endTime, 'YYYY-MM-DD 23:59:59')}
|
||
value={this.state.selectEndTime}
|
||
format="YYYY-MM-DD"
|
||
onChange={this.endChange}
|
||
/>
|
||
{/* </Form.Item> */}
|
||
</div>
|
||
<div>
|
||
<Button
|
||
type="primary"
|
||
loading={this.state.searchLoading}
|
||
onClick={() => this.loadData()}
|
||
>
|
||
查询
|
||
</Button>
|
||
</div>
|
||
</div>
|
||
<div
|
||
style={{
|
||
display: "flex",
|
||
alignItems: "center",
|
||
justifyContent: "center",
|
||
marginTop: "20px",
|
||
// marginBottom: "20px",
|
||
}}
|
||
>
|
||
<div className={styles.menuPie}>
|
||
<li>
|
||
总任务数
|
||
<br />
|
||
<div className={styles.dataStyle}>{totalCount}</div>
|
||
</li>
|
||
<Divider
|
||
type="vertical"
|
||
style={{ width: "1px", height: "70px", margin: "9px 0px" }}
|
||
/>
|
||
<li>
|
||
正常已办
|
||
<br />
|
||
<div className={styles.dataStyle1}>{finishCount}</div>
|
||
</li>
|
||
<Divider
|
||
type="vertical"
|
||
style={{ width: "1px", height: "70px", margin: "9px 0px" }}
|
||
/>
|
||
<li>
|
||
超时已办
|
||
<br />
|
||
<div className={styles.dataStyle3}>{overtimeCount}</div>
|
||
</li>
|
||
<Divider
|
||
type="vertical"
|
||
style={{ width: "1px", height: "70px", margin: "9px 0px" }}
|
||
/>
|
||
<li>
|
||
未完成数
|
||
<br />
|
||
<div className={styles.dataStyle2}>{unfinishCount}</div>
|
||
{/* <a href="#" style={{ color: "red" }}> */}
|
||
{/* </a> */}
|
||
</li>
|
||
<Divider
|
||
type="vertical"
|
||
style={{ width: "1px", height: "70px", margin: "9px 0px" }}
|
||
/>
|
||
<li>
|
||
完成率
|
||
<br />
|
||
<div className={styles.dataStyle3}>{allFinishRate}%</div>
|
||
{/* <a href="#" style={{ color: "red" }}> */}
|
||
{/* </a> */}
|
||
</li>
|
||
<Divider
|
||
type="vertical"
|
||
style={{ width: "1px", height: "70px", margin: "9px 0px" }}
|
||
/>
|
||
<li>
|
||
及时完成率
|
||
<br />
|
||
<div className={styles.dataStyle3}>{finishRate}%</div>
|
||
</li>
|
||
</div>
|
||
</div>
|
||
<hr
|
||
style={{
|
||
border: "1px dashed #ccc",
|
||
marginBottom: "20px",
|
||
marginTop: "20px",
|
||
}}
|
||
></hr>
|
||
<Row
|
||
style={{
|
||
display: "flex",
|
||
alignItems: "center",
|
||
justifyContent: "center",
|
||
}}
|
||
>
|
||
<div
|
||
style={{
|
||
display: "flex",
|
||
justifyContent: "space-around",
|
||
alignItems: "center",
|
||
width: "1100px",
|
||
border: "1px solid #e7e6e4",
|
||
}}
|
||
>
|
||
<Col span={24}>
|
||
{/* <h3 style={{textAlign:'center',fontWeight:'bold'}}>{this.props.data.name}安全任务完成率</h3> */}
|
||
<div
|
||
id="mainJobPie2"
|
||
style={{
|
||
height: "350px",
|
||
backgroundColor: "white",
|
||
}}
|
||
></div>
|
||
</Col>
|
||
</div>
|
||
</Row>
|
||
<Row
|
||
style={{
|
||
marginTop: "20px",
|
||
display: "flex",
|
||
alignItems: "center",
|
||
justifyContent: "center",
|
||
}}
|
||
>
|
||
<div
|
||
style={{
|
||
display: "flex",
|
||
justifyContent: "space-around",
|
||
alignItems: "center",
|
||
width: "1100px",
|
||
}}
|
||
>
|
||
<Col span={24}>
|
||
<h2
|
||
style={{
|
||
textAlign: "center",
|
||
fontWeight: "bold",
|
||
// marginLeft: "20px",
|
||
}}
|
||
>
|
||
<Icon type="appstore" /> 车间统计分析
|
||
</h2>
|
||
<Table
|
||
style={{ textAlign: "center" }}
|
||
// scroll={{ y: 400 }}
|
||
dataSource={this.state.retData}
|
||
columns={this.state.columns}
|
||
pagination={false}
|
||
loading={false}
|
||
size="small"
|
||
bordered
|
||
/>
|
||
</Col>
|
||
</div>
|
||
|
||
{/* <Col span={7}>
|
||
<h3 style={{textAlign:'center',fontWeight:'bold'}}>{this.props.data.name}安全任务完成情况</h3>
|
||
<div id="workTicket" style={{ height: '350px',marginLeft:"40px" ,marginRight:"10px" ,backgroundColor:"white",borderStyle:'solid',borderColor:'#ccc',borderWidth:'1px'}}></div>
|
||
</Col> */}
|
||
</Row>
|
||
<hr
|
||
style={{
|
||
border: "1px dashed #ccc",
|
||
marginBottom: "20px",
|
||
marginTop: "20px",
|
||
}}
|
||
></hr>
|
||
<Row
|
||
style={{
|
||
marginTop: "20px",
|
||
display: "flex",
|
||
alignItems: "center",
|
||
justifyContent: "center",
|
||
marginBottom:'20px'
|
||
}}
|
||
>
|
||
<div
|
||
style={{
|
||
display: "flex",
|
||
justifyContent: "space-around",
|
||
alignItems: "center",
|
||
width: "1100px",
|
||
}}
|
||
>
|
||
<Col span={24}>
|
||
<h2
|
||
style={{
|
||
textAlign: "center",
|
||
fontWeight: "bold",
|
||
}}
|
||
>
|
||
<Icon type="appstore" /> 班组统计分析
|
||
</h2>
|
||
<Table
|
||
style={{ textAlign: "center" }}
|
||
// scroll={{ y: 400 }}
|
||
dataSource={this.state.detailData}
|
||
columns={this.state.detailColumns}
|
||
pagination={false}
|
||
loading={false}
|
||
size="small"
|
||
bordered
|
||
/>
|
||
</Col>
|
||
</div>
|
||
</Row>
|
||
</div>
|
||
</div>
|
||
);
|
||
}
|
||
}
|
||
export default connect(({ login, app }) => ({ login, app }))(
|
||
BI007FormRunAnalysisNew
|
||
);
|