QualityMng.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. //水质管理
  2. import ChartModule from '@/components/ManagementPage/chartModule';
  3. // import SearchModule from '@/components/ManagementPage/searchModule';
  4. import PageContent from '@/components/PageContent';
  5. import PageTitle from '@/components/PageTitle';
  6. import {
  7. queryChartListByCode,
  8. queryProcessSection,
  9. querySectionCode,
  10. } from '@/services/OperationManagement';
  11. import { UnityAction } from '@/utils/utils';
  12. import { useParams, useRequest } from '@umijs/max';
  13. import { Empty, Spin, Table } from 'antd';
  14. import dayjs from 'dayjs';
  15. import { useEffect, useMemo, useRef, useState } from 'react';
  16. function Quality() {
  17. const { projectId } = useParams();
  18. const [currentCode, setCode] = useState(null);
  19. // const [processId, setProcessId] = useState(null);
  20. const timerRef = useRef({
  21. s_time: dayjs().subtract(1, 'day').format('YYYY-MM-DD HH:mm:ss'),
  22. e_time: dayjs().format('YYYY-MM-DD HH:mm:ss'),
  23. });
  24. const { data: codeList, run: queryCodeList } = useRequest(querySectionCode, {
  25. manual: true,
  26. onSuccess(res) {
  27. if (res && res.length > 0) {
  28. setCode(res[0]);
  29. }
  30. },
  31. });
  32. // 获取工艺段列表
  33. useRequest(queryProcessSection, {
  34. defaultParams: [projectId],
  35. onSuccess(res) {
  36. // setProcessId(res.data[0].id);
  37. queryCodeList(res[0].id, 2, projectId * 1);
  38. },
  39. });
  40. const mainRes = useRequest(
  41. () => {
  42. return queryChartListByCode(
  43. {
  44. project_id: Number(projectId),
  45. start_time: timerRef.current.s_time,
  46. end_time: timerRef.current.e_time,
  47. },
  48. codeList?.map((item) => item.metric_code),
  49. );
  50. },
  51. {
  52. manual: true,
  53. },
  54. );
  55. const column = useMemo(() => {
  56. const col = { title: '时间', dataIndex: 'time', width: '250px' };
  57. let other = codeList?.map((item) => {
  58. return {
  59. title: item.metric,
  60. dataIndex: item.metric_code,
  61. width: '200px',
  62. };
  63. });
  64. return other && other.length > 0 ? [col, ...other] : [];
  65. }, [codeList]);
  66. //图表配置
  67. const chartProps = useMemo(() => {
  68. let xData = [],
  69. dataList = [];
  70. if (!mainRes.data || !currentCode) return;
  71. let yName = currentCode.metric;
  72. let data = [...mainRes.data].reverse();
  73. xData = data.map((item) => item.time);
  74. // dataList.push({
  75. // type: 0,
  76. // name: '出水水量',
  77. // data: data.map((item) => item.permeate),
  78. // });
  79. // dataList.push({
  80. // type: 1,
  81. // name: '进水水量',
  82. // data: data.map((item) => item.feed),
  83. // });
  84. dataList.push({
  85. type: 2,
  86. name: currentCode.metric,
  87. data: data.map((item) => item[currentCode.metric_code]),
  88. });
  89. return {
  90. yName,
  91. xData,
  92. dataList,
  93. typeList: codeList?.map((item) => item.metric),
  94. currentType: currentCode.metric,
  95. };
  96. }, [mainRes.data, currentCode]);
  97. useEffect(() => {
  98. if (codeList) {
  99. mainRes.run();
  100. }
  101. }, [codeList]);
  102. const onChange = (name) => {
  103. const code = codeList.find((item) => item.metric == name);
  104. if (code) setCode(code);
  105. };
  106. return (
  107. <PageContent closeable={false}>
  108. <PageTitle onReturn={() => UnityAction.sendMsg('menuItem', '首页')}>
  109. 水质监测
  110. </PageTitle>
  111. <div className="card-box" style={{ padding: 20, marginTop: 40 }}>
  112. <PageTitle>数据曲线</PageTitle>
  113. <Spin spinning={mainRes.loading}>
  114. <div style={{ height: 500, marginTop: 20 }}>
  115. {mainRes?.data ? (
  116. <ChartModule {...chartProps} onChange={onChange} />
  117. ) : (
  118. <Empty />
  119. )}
  120. </div>
  121. </Spin>
  122. <div style={{ marginTop: 30 }}>
  123. <PageTitle>数据列表</PageTitle>
  124. <Table
  125. columns={column}
  126. style={{ marginTop: 20 }}
  127. dataSource={mainRes?.data}
  128. scroll={{ x: 2500 }}
  129. />
  130. </div>
  131. </div>
  132. </PageContent>
  133. );
  134. }
  135. export default Quality;