index.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491
  1. <!-- eslint-disable vue/multi-word-component-names -->
  2. <template>
  3. <div class="gas-verify">
  4. <CustomHeader> 瓦斯抽采达标能力核定 </CustomHeader>
  5. <div class="flex mt-90px">
  6. <div class="nav-l"> 瓦斯抽采达标生产能力:{{ data.gasExtractionSystemCapacityResultLarge }} t/a </div>
  7. <div class="nav">
  8. <Tabs v-model:active-key="actived" :tabBarStyle="{ color: 'red' }">
  9. <TabPane key="product" tab="矿井瓦斯抽采达标生产能力核定" />
  10. <TabPane key="extract" tab="矿井瓦斯抽采能力核定" />
  11. </Tabs>
  12. </div>
  13. <div class="nav-r"> 瓦斯抽采能力:{{ data.gasExtractionSystemCapacityResultSmall }} m<sup>3</sup>/min </div>
  14. </div>
  15. <div class="flex">
  16. <div :style="{ flex: 1 }">
  17. 矿井瓦斯抽采系统能力统计图
  18. <Bar :chart-data="productChartData" x-axis-prop-type="x" series-prop-type="y" height="300px" />
  19. 矿井瓦斯抽采能力统计图
  20. <Bar :chart-data="extractChartData" x-axis-prop-type="x" series-prop-type="y" height="300px" />
  21. </div>
  22. <div class="gas-verify__content">
  23. <div v-show="true">
  24. <div class="flex flex-justify-between flex-items-center">
  25. <FormTitle class="flex-grow-1" icon="pump" title="矿井基本信息" />
  26. <Button class="mr-10px" @click="addPubFormSchema">添加回风井</Button>
  27. <Button class="mr-10px" @click="calculateBasicForm">计算</Button>
  28. <Button type="primary" @click="submitBasicForm">提交</Button>
  29. </div>
  30. <BasicForm :schemas="publicFormSchema" @register="regBasicForm" />
  31. </div>
  32. <div v-show="actived === 'product'">
  33. <div class="flex flex-justify-between flex-items-center">
  34. <FormTitle class="flex-grow-1" icon="pump" :title="`根据矿井实际抽采瓦斯量核定:${data.gasExtractionVolumeVerificationTotal}`" />
  35. <Button type="primary" @click="submitGasvalForm">提交</Button>
  36. </div>
  37. <BasicForm :schemas="valFormSchema" @register="regGasvalForm" />
  38. </div>
  39. <div v-show="actived === 'product'">
  40. <div class="flex flex-justify-between flex-items-center">
  41. <FormTitle class="flex-grow-1" icon="pump" :title="`根据矿井瓦斯抽采率核定:${data.gasExtractionRateVerificationTotal}`" />
  42. <Button class="mr-10px" @click="calculateGasrateForm">计算</Button>
  43. <Button type="primary" @click="submitGasrateForm">提交</Button>
  44. </div>
  45. <BasicForm :schemas="rateFormSchema" @register="regGasrateForm" />
  46. </div>
  47. <div v-show="false">
  48. <div class="flex flex-justify-between flex-items-center">
  49. <FormTitle class="flex-grow-1" icon="pump" title="核定区域信息" />
  50. <Button type="primary" @click="submitCheckForm">提交</Button>
  51. </div>
  52. <BasicForm :schemas="checkFormSchema" @register="regCheckForm" />
  53. </div>
  54. <div class="flex flex-justify-between flex-items-center">
  55. <FormTitle
  56. class="flex-grow-1"
  57. :title="
  58. {
  59. extract: `按瓦斯抽采泵站装机能力核定:${data.gasExtractionPumpStationCapacitySmall}`,
  60. product: `按矿井瓦斯抽采泵站装机能力核定:${data.gasExtractionMainPipelineCapacityLarge}`,
  61. }[actived]
  62. "
  63. />
  64. <Button type="primary" @click="editPumpHandler()">添加</Button>
  65. </div>
  66. <BasicTable class="mb-20px" :columns="pumpTableColumns" :data-source="pumpTableData" @register="regPumpTable">
  67. <template #action="{ record }">
  68. <a class="mr-5px" @click.prevent="editPumpHandler(record)">编辑</a>
  69. <Popconfirm @confirm="deletePumpHandler(record)"><a>删除</a></Popconfirm>
  70. </template>
  71. </BasicTable>
  72. <div class="flex flex-justify-between flex-items-center">
  73. <FormTitle
  74. class="flex-grow-1"
  75. :title="
  76. {
  77. extract: `按矿井瓦斯主管道系统能力核定:${data.gasExtractionMainPipelineCapacitySmall}`,
  78. product: `按矿井瓦斯抽采主管道系统能力核定:${data.gasExtractionMainPipelineCapacityLarge}`,
  79. }[actived]
  80. "
  81. />
  82. <Button type="primary" @click="editPipeHandler()">添加</Button>
  83. </div>
  84. <BasicTable :columns="pipeTableColumns" :data-source="pipeTableData" @register="regPipeTable">
  85. <template #action="{ record }">
  86. <a class="mr-5px" @click.prevent="editPipeHandler(record)">编辑</a>
  87. <Popconfirm @confirm="deletePipeHandler(record)"><a>删除</a></Popconfirm>
  88. </template>
  89. </BasicTable>
  90. <!-- <BasicTable :columns="workfaceTableColumns" :data-source="[{ ccbz: `1111` }, { ccbz: `2222` }]" @register="regTable">
  91. <template #action="{ record }">
  92. <a class="mr-5px" @click.prevent="openModal()">编辑</a>
  93. <a>删除</a>
  94. </template>
  95. </BasicTable> -->
  96. <BasicModal @register="regPipeModal" title="能力核定表单" @ok="submitPipeForm">
  97. <BasicForm :schemas="pipeFormSchema" @register="regPipeForm" />
  98. </BasicModal>
  99. <BasicModal @register="regPumpModal" title="能力核定表单" @ok="submitPumpForm">
  100. <BasicForm :schemas="pumpFormSchema" @register="regPumpForm" />
  101. </BasicModal>
  102. </div>
  103. </div>
  104. </div>
  105. </template>
  106. <script lang="ts" setup>
  107. import CustomHeader from '/@/components/vent/customHeader.vue';
  108. import { computed, nextTick, ref } from 'vue';
  109. import { message, TabPane, Tabs, Button, Popconfirm } from 'ant-design-vue';
  110. import { onMounted } from 'vue';
  111. import FormTitle from '@/views/vent/gas/components/form/formTitle.vue';
  112. import { useForm, BasicForm, FormSchema } from '/@/components/Form';
  113. import Bar from '/@/components/chart/Bar.vue';
  114. import {
  115. getGasMainAllInfo,
  116. getGasMainpipesystemAllInfo,
  117. getGasPumpstationAllInfo,
  118. deleteGasMainpipesystem,
  119. deleteGasPumpstation,
  120. updateGasMain,
  121. updateGasMainpipesystem,
  122. updateGasPumpstation,
  123. } from './gasPumpSetting.api';
  124. import {
  125. publicFormSchema,
  126. valFormSchema,
  127. rateFormSchema,
  128. pumpTableColumns,
  129. pipeTableColumns,
  130. checkFormSchema,
  131. pipeFormSchema,
  132. pumpFormSchema,
  133. // workfaceTableColumns,
  134. } from './gasPumpSetting.data';
  135. import { BasicTable, useTable } from '/@/components/Table';
  136. import { BasicModal, useModal } from '/@/components/Modal';
  137. import { get, inRange, isNil } from 'lodash-es';
  138. const actived = ref<'extract' | 'product'>('product');
  139. /** 计算参数相关的表单通用配置 */
  140. const formProps = {
  141. showActionButtonGroup: false,
  142. labelCol: { span: 10 },
  143. baseColProps: {
  144. flex: '20%',
  145. },
  146. };
  147. function submitHandler() {
  148. const data1 = ctxBasicForm.getFieldsValue();
  149. const data2 = ctxGasvalForm.getFieldsValue();
  150. const data3 = ctxGasrateForm.getFieldsValue();
  151. const airVolumeStr = get(data1, 'returnAirVolume', []).join(',');
  152. updateGasMain({
  153. ...data3,
  154. ...data2,
  155. ...data1,
  156. returnAirVolume: airVolumeStr,
  157. })
  158. .then(() => {
  159. message.success('提交成功');
  160. refresh();
  161. })
  162. .catch(() => {
  163. message.error('操作失败');
  164. });
  165. }
  166. const [regBasicForm, ctxBasicForm] = useForm(formProps);
  167. function submitBasicForm() {
  168. ctxBasicForm.validate().then(() => {
  169. submitHandler();
  170. });
  171. }
  172. /** 计算部分可以自动计算的参数 */
  173. function calculateBasicForm() {
  174. const { returnAirVolume } = data.value;
  175. const { mineGasExtractionRate } = ctxBasicForm.getFieldsValue();
  176. if (returnAirVolume && Array.isArray(returnAirVolume)) {
  177. const airVolumeArr = returnAirVolume.map((e) => parseFloat(e));
  178. ctxBasicForm.setFieldsValue({
  179. mineMaxTotalReturnAirVolume: airVolumeArr.reduce((t, n) => t + n, 0),
  180. });
  181. }
  182. // 根据抽采率生成总回瓦斯浓度
  183. if (mineGasExtractionRate) {
  184. const n = parseInt(mineGasExtractionRate);
  185. const config: [[number, number], number][] = [
  186. [[0, 35], 0.35],
  187. [[34.99, 40], 0.375],
  188. [[39.99, 45], 0.425],
  189. [[44.99, 50], 0.475],
  190. [[49.99, 55], 0.525],
  191. [[54.99, 60], 0.575],
  192. [[59.99, 100], 0.7],
  193. ];
  194. config.forEach((e) => {
  195. if (inRange(n, e[0][0], e[0][1])) {
  196. ctxBasicForm.setFieldsValue({
  197. mineTotalReturnAirGasConcentration: e[1],
  198. });
  199. }
  200. });
  201. }
  202. }
  203. /** 根据矿井实际抽采瓦斯量核定的表单数据 */
  204. const [regGasvalForm, ctxGasvalForm] = useForm(formProps);
  205. function submitGasvalForm() {
  206. ctxGasvalForm.validate().then(() => {
  207. submitHandler();
  208. });
  209. }
  210. /** 根据矿井瓦斯抽采率核定的表单数据 */
  211. const [regGasrateForm, ctxGasrateForm] = useForm(formProps);
  212. function submitGasrateForm() {
  213. ctxGasrateForm.validate().then(() => {
  214. submitHandler();
  215. });
  216. }
  217. /** 计算部分可以自动计算的参数 */
  218. function calculateGasrateForm() {
  219. const { mineGasExtractionRate } = ctxGasrateForm.getFieldsValue();
  220. // 根据抽采率生成最大绝对涌出量
  221. if (mineGasExtractionRate) {
  222. const n = parseInt(mineGasExtractionRate);
  223. const config: [[number, number], number][] = [
  224. [[0, 35], 20],
  225. [[34.99, 40], 30],
  226. [[39.99, 45], 60],
  227. [[44.99, 50], 120],
  228. [[49.99, 55], 230],
  229. [[54.99, 60], 400],
  230. [[59.99, 100], 500],
  231. ];
  232. config.forEach((e) => {
  233. if (inRange(n, e[0][0], e[0][1])) {
  234. ctxGasrateForm.setFieldsValue({
  235. maxAllowableAbsoluteGasEmission: e[1],
  236. });
  237. }
  238. });
  239. }
  240. }
  241. /** 核定区域信息的表单数据 */
  242. // const checkFormModel = ref<any>({});
  243. const [regCheckForm, ctxCheckForm] = useForm(formProps);
  244. function submitCheckForm() {
  245. ctxCheckForm.validate().then(() => {
  246. submitHandler();
  247. });
  248. }
  249. /** 矿井基本信息的表单配置,需要动态添加回风井。根据表单数据设置矿井基本信息的表单配置 */
  250. function resetPublicFormSchema() {
  251. const airVolumeArr = data.value.returnAirVolume;
  252. const extra: FormSchema[] = airVolumeArr.map((num, inx) => {
  253. return {
  254. label: `回风井${inx + 1}`,
  255. field: `__${inx + 1}`,
  256. defaultValue: num,
  257. component: 'Input',
  258. componentProps: {
  259. onChange: ({ target }) => {
  260. airVolumeArr[inx] = target.value;
  261. },
  262. },
  263. };
  264. });
  265. ctxBasicForm.resetSchema([...publicFormSchema, ...extra]);
  266. }
  267. /** 添加一项公用参数表单项 */
  268. function addPubFormSchema() {
  269. if (!data.value.returnAirVolume) return;
  270. data.value.returnAirVolume.push('0');
  271. resetPublicFormSchema();
  272. }
  273. /** 生产能力核定/抽采能力核定的数据,也是组件的数据依赖其一 */
  274. const data = ref<Record<string, any>>({});
  275. /** 按矿井瓦斯抽采主管道系统能力核定的表格 */
  276. const pipeTableData = ref<any[]>([]);
  277. const [regPipeModal, ctxPipeModal] = useModal();
  278. const [regPipeTable] = useTable({
  279. pagination: false,
  280. });
  281. const [regPipeForm, ctxPipeForm] = useForm({
  282. showActionButtonGroup: false,
  283. labelCol: { span: 10 },
  284. });
  285. function submitPipeForm() {
  286. ctxPipeForm.validate().then((data) => {
  287. updateGasMainpipesystem(data)
  288. .then(() => {
  289. ctxPipeModal.closeModal();
  290. refresh();
  291. })
  292. .catch(() => {
  293. message.error('操作失败');
  294. });
  295. });
  296. }
  297. function editPipeHandler(record?: Record<string, any>) {
  298. ctxPipeModal.openModal();
  299. nextTick(() => {
  300. if (record) {
  301. ctxPipeForm.setFieldsValue(record);
  302. } else {
  303. ctxPipeForm.resetFields();
  304. }
  305. });
  306. }
  307. function deletePipeHandler({ id }) {
  308. deleteGasMainpipesystem({ id })
  309. .then(() => {
  310. refresh();
  311. })
  312. .catch(() => {
  313. message.error('操作失败');
  314. });
  315. }
  316. /** 按矿井瓦斯抽采泵站装机能力核定的表格 */
  317. const pumpTableData = ref<any[]>([]);
  318. const [regPumpModal, ctxPumpModal] = useModal();
  319. const [regPumpTable] = useTable({
  320. pagination: false,
  321. });
  322. const [regPumpForm, ctxPumpForm] = useForm({
  323. showActionButtonGroup: false,
  324. labelCol: { span: 10 },
  325. });
  326. function submitPumpForm() {
  327. ctxPumpForm.validate().then((data) => {
  328. updateGasPumpstation(data)
  329. .then(() => {
  330. ctxPumpModal.closeModal();
  331. refresh();
  332. })
  333. .catch(() => {
  334. message.error('操作失败');
  335. });
  336. });
  337. }
  338. function editPumpHandler(record?: Record<string, any>) {
  339. ctxPumpModal.openModal();
  340. nextTick(() => {
  341. if (record) {
  342. ctxPumpForm.setFieldsValue(record);
  343. } else {
  344. ctxPumpForm.resetFields();
  345. }
  346. });
  347. }
  348. function deletePumpHandler({ id }) {
  349. deleteGasPumpstation({ id })
  350. .then(() => {
  351. refresh();
  352. })
  353. .catch(() => {
  354. message.error('操作失败');
  355. });
  356. }
  357. function refresh() {
  358. Promise.all([getGasMainAllInfo({}), getGasMainpipesystemAllInfo({}), getGasPumpstationAllInfo({})]).then((res) => {
  359. const [r1, r2, r3] = res.map((e) => e.obj);
  360. r1[0].returnAirVolume = r1[0].returnAirVolume.split(',');
  361. ctxBasicForm.setFieldsValue(r1[0]);
  362. ctxGasvalForm.setFieldsValue(r1[0]);
  363. ctxGasrateForm.setFieldsValue(r1[0]);
  364. pipeTableData.value = r2;
  365. pumpTableData.value = r3;
  366. data.value = r1[0];
  367. resetPublicFormSchema();
  368. });
  369. }
  370. // function getNum(data, path, defaultValue) {
  371. // const r = get(data, path);
  372. // return isNil(r) ? defaultValue : parseFloat(r);
  373. // }
  374. const productChartData = computed(() => {
  375. return [
  376. {
  377. x: '抽采系统能力',
  378. y: data.value.gasExtractionSystemCapacityResultSmall || 0,
  379. },
  380. {
  381. x: '实际抽采量',
  382. y: data.value.gasExtractionVolumeVerificationTotal || 0,
  383. },
  384. {
  385. x: '瓦斯抽采率',
  386. y: data.value.gasExtractionRateVerificationTotal || 0,
  387. },
  388. // {
  389. // x: '防突抽采',
  390. // y: data.value.ftcc || 0,
  391. // },
  392. ];
  393. });
  394. const extractChartData = computed(() => {
  395. const keyMap = {
  396. extract: ['gasExtractionPumpStationCapacitySmall', 'gasExtractionMainPipelineCapacitySmall'],
  397. product: ['gasExtractionMainPipelineCapacityLarge', 'gasExtractionMainPipelineCapacityLarge'],
  398. };
  399. return [
  400. {
  401. x: '瓦斯抽采泵装机能力',
  402. y: get(data.value, keyMap[actived.value][0], 0),
  403. },
  404. {
  405. x: '瓦斯抽采主管道系统能力',
  406. y: get(data.value, keyMap[actived.value][1], 0),
  407. },
  408. ];
  409. });
  410. onMounted(() => {
  411. refresh();
  412. });
  413. </script>
  414. <style lang="less" scoped>
  415. @import '/@/design/theme.less';
  416. .gas-verify {
  417. --image-verify-nav-bg-l: url('/@/assets/images/vent/gas/verify-nav-bg-l.png');
  418. --image-verify-nav-bg-r: url('/@/assets/images/vent/gas/verify-nav-bg-r.png');
  419. --image-verify-nav-bg: url('/@/assets/images/vent/gas/verify-nav-bg.png');
  420. color: var(--vent-font-color);
  421. padding: 0 20px;
  422. .nav-l {
  423. flex: 1;
  424. height: 83px;
  425. padding-top: 31px;
  426. text-align: center;
  427. background-repeat: no-repeat;
  428. background-size: 100% 85px;
  429. background-position: center 12px;
  430. background-image: var(--image-verify-nav-bg-l);
  431. }
  432. .nav {
  433. flex: 3;
  434. height: 83px;
  435. padding: 20px 40px 0 40px;
  436. background-repeat: no-repeat;
  437. background-size: 100% 70px;
  438. background-position: center 0;
  439. background-image: var(--image-verify-nav-bg);
  440. }
  441. .nav-r {
  442. flex: 1;
  443. height: 83px;
  444. padding-top: 31px;
  445. text-align: center;
  446. background-repeat: no-repeat;
  447. background-size: 100% 85px;
  448. background-position: center 12px;
  449. background-image: var(--image-verify-nav-bg-r);
  450. }
  451. .gas-verify__content {
  452. flex: 4;
  453. height: 740px;
  454. overflow-y: auto;
  455. }
  456. }
  457. :deep(.zxm-tabs-ink-bar) {
  458. display: none;
  459. }
  460. :deep(.form-title) {
  461. background-size: 800px 100%;
  462. }
  463. </style>