alarm.data.ts 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777
  1. import { reactive } from 'vue';
  2. import { BasicColumn, FormSchema } from '/@/components/Table';
  3. import echarts from '/@/utils/lib/echarts';
  4. import type { EChartsOption } from 'echarts';
  5. import { getThemifyImagesURL } from '/@/utils/ui';
  6. import { render } from '/@/utils/common/renderUtils';
  7. export const formConfig = {
  8. labelAlign: 'left',
  9. showAdvancedButton: false,
  10. showResetButton: false,
  11. baseColProps: {
  12. // offset: 0.5,
  13. xs: 24,
  14. sm: 24,
  15. md: 24,
  16. lg: 9,
  17. xl: 7,
  18. xxl: 4,
  19. },
  20. schemas: [
  21. {
  22. label: '预警等级',
  23. labelWidth: 200,
  24. field: 'leveltype',
  25. colProps: { span: 10 },
  26. component: 'JDictSelectTag',
  27. componentProps: { dictCode: 'leveltype' },
  28. },
  29. ],
  30. };
  31. export const ventTunColumns: BasicColumn[] = [
  32. {
  33. title: '巷道名称',
  34. dataIndex: 'strName',
  35. width: 120,
  36. align: 'center',
  37. },
  38. {
  39. title: '断面积',
  40. dataIndex: 'fArea',
  41. width: 80,
  42. align: 'center',
  43. },
  44. {
  45. title: '风速(m/s)',
  46. dataIndex: 'fRealV',
  47. width: 80,
  48. align: 'center',
  49. },
  50. {
  51. title: '风量(m³/min)',
  52. dataIndex: 'fRealQMin',
  53. width: 80,
  54. align: 'center',
  55. },
  56. {
  57. title: '按需分风风阻',
  58. dataIndex: 'oldHTotal',
  59. width: 80,
  60. align: 'center',
  61. },
  62. {
  63. title: '实时解算风阻',
  64. dataIndex: 'dHTotal',
  65. width: 80,
  66. align: 'center',
  67. },
  68. {
  69. title: '风阻分析',
  70. dataIndex: 'analyse',
  71. customRender: ({ record }) => {
  72. if (record) {
  73. const p = ((record['dHTotal'] - record['oldHTotal']) / record['oldHTotal']) * 100;
  74. if (p == 0) {
  75. return '正常';
  76. } else if (p > 0 && p <= 1) {
  77. return '低风险';
  78. } else if (p > 1 && p <= 3) {
  79. return '一般风险';
  80. } else if (p > 3 && p <= 5) {
  81. return '较大风险';
  82. } else {
  83. return '重大风险';
  84. }
  85. }
  86. },
  87. width: 100,
  88. align: 'center',
  89. },
  90. ];
  91. export const levelColumns: BasicColumn[] = [
  92. {
  93. title: '设备名称',
  94. dataIndex: 'devicename',
  95. width: 100,
  96. align: 'center',
  97. },
  98. {
  99. title: '报警类型',
  100. dataIndex: 'nwartype',
  101. customRender: ({ record }) => {
  102. return render.renderDict(record.nwartype, 'leveltype');
  103. },
  104. width: 100,
  105. align: 'center',
  106. },
  107. {
  108. title: '报警开始时间',
  109. dataIndex: 'starttime',
  110. width: 100,
  111. align: 'center',
  112. },
  113. // {
  114. // title: '报警持续时间',
  115. // dataIndex: 'warntime',
  116. // width: 100,
  117. // align: 'center',
  118. // },
  119. // {
  120. // title: '持续时间(s)',
  121. // dataIndex: 'timelength',
  122. // width: 100,
  123. // align: 'center',
  124. // },
  125. {
  126. title: '报警描述',
  127. dataIndex: 'wardescrip',
  128. width: 100,
  129. align: 'center',
  130. },
  131. ];
  132. export const levelHisColumns: BasicColumn[] = [
  133. {
  134. title: '设备名称',
  135. dataIndex: 'devicename',
  136. width: 100,
  137. align: 'center',
  138. },
  139. {
  140. title: '报警类型',
  141. dataIndex: 'nwartype',
  142. customRender: ({ record }) => {
  143. return render.renderDict(record.nwartype, 'leveltype');
  144. },
  145. width: 100,
  146. align: 'center',
  147. },
  148. {
  149. title: '报警开始时间',
  150. dataIndex: 'starttime',
  151. width: 100,
  152. align: 'center',
  153. },
  154. {
  155. title: '报警持续时间',
  156. dataIndex: 'warntime',
  157. width: 100,
  158. align: 'center',
  159. },
  160. // {
  161. // title: '持续时间(s)',
  162. // dataIndex: 'timelength',
  163. // width: 100,
  164. // align: 'center',
  165. // },
  166. {
  167. title: '报警描述',
  168. dataIndex: 'wardescrip',
  169. width: 100,
  170. align: 'center',
  171. },
  172. ];
  173. export const iconsMonitor = reactive({
  174. fanmain: {
  175. url: getThemifyImagesURL('vent/alarm-icons/zhushan.png'),
  176. // level: 100,
  177. text: '',
  178. allText: '总数',
  179. warnText: '报警数',
  180. closeText: '断开数',
  181. allCount: 0,
  182. warnCount: 0,
  183. closeCount: 0,
  184. },
  185. fanlocal: {
  186. url: getThemifyImagesURL('vent/alarm-icons/js.png'),
  187. // level: 100,
  188. text: '',
  189. allText: '总数',
  190. warnText: '报警数',
  191. closeText: '断开数',
  192. allCount: 0,
  193. warnCount: 0,
  194. closeCount: 0,
  195. },
  196. fanlocaldp: {
  197. url: getThemifyImagesURL('vent/alarm-icons/js.png'),
  198. // level: 100,
  199. text: '',
  200. allText: '总数',
  201. warnText: '报警数',
  202. closeText: '断开数',
  203. allCount: 0,
  204. warnCount: 0,
  205. closeCount: 0,
  206. },
  207. gate: {
  208. url: getThemifyImagesURL('vent/alarm-icons/fm.png'),
  209. // level: 100,
  210. text: '',
  211. allText: '总数',
  212. warnText: '报警数',
  213. closeText: '断开数',
  214. allCount: 0,
  215. warnCount: 0,
  216. closeCount: 0,
  217. },
  218. window: {
  219. url: getThemifyImagesURL('vent/alarm-icons/fc.png'),
  220. // level: 100,
  221. text: '',
  222. allText: '总数',
  223. warnText: '报警数',
  224. closeText: '断开数',
  225. allCount: 0,
  226. warnCount: 0,
  227. closeCount: 0,
  228. },
  229. windrect: {
  230. url: getThemifyImagesURL('vent/alarm-icons/cf.png'),
  231. // level: 100,
  232. text: '',
  233. allText: '总数',
  234. warnText: '报警数',
  235. closeText: '断开数',
  236. allCount: 0,
  237. warnCount: 0,
  238. closeCount: 0,
  239. },
  240. forcFan: {
  241. url: getThemifyImagesURL('vent/alarm-icons/yafeng.png'),
  242. // level: 100,
  243. text: '',
  244. allText: '总数',
  245. warnText: '报警数',
  246. closeText: '断开数',
  247. allCount: 0,
  248. warnCount: 0,
  249. closeCount: 0,
  250. },
  251. spray: {
  252. url: getThemifyImagesURL('vent/alarm-icons/penlin.png'),
  253. // level: 100,
  254. text: '',
  255. allText: '总数',
  256. warnText: '报警数',
  257. closeText: '断开数',
  258. allCount: 0,
  259. warnCount: 0,
  260. closeCount: 0,
  261. },
  262. dustdev: {
  263. url: getThemifyImagesURL('vent/alarm-icons/penfen.png'),
  264. // level: 100,
  265. text: '',
  266. allText: '总数',
  267. warnText: '报警数',
  268. closeText: '断开数',
  269. allCount: 0,
  270. warnCount: 0,
  271. closeCount: 0,
  272. },
  273. nitrogen: {
  274. url: getThemifyImagesURL('vent/alarm-icons/zhudan.png'),
  275. // level: 100,
  276. text: '',
  277. allText: '总数',
  278. warnText: '报警数',
  279. closeText: '断开数',
  280. allCount: 0,
  281. warnCount: 0,
  282. closeCount: 0,
  283. },
  284. pulping: {
  285. url: getThemifyImagesURL('vent/alarm-icons/zhujiang.png'),
  286. // level: 100,
  287. text: '',
  288. allText: '总数',
  289. warnText: '报警数',
  290. closeText: '断开数',
  291. allCount: 0,
  292. warnCount: 0,
  293. closeCount: 0,
  294. },
  295. atomizing: {
  296. url: getThemifyImagesURL('vent/alarm-icons/pw.png'),
  297. // level: 100,
  298. text: '',
  299. allText: '总数',
  300. warnText: '报警数',
  301. closeText: '断开数',
  302. allCount: 0,
  303. warnCount: 0,
  304. closeCount: 0,
  305. },
  306. dustsensor: {
  307. url: getThemifyImagesURL('vent/alarm-icons/ccq.png'),
  308. // level: 100,
  309. text: '',
  310. allText: '总数',
  311. warnText: '报警数',
  312. closeText: '断开数',
  313. allCount: 0,
  314. warnCount: 0,
  315. closeCount: 0,
  316. },
  317. gas: {
  318. url: getThemifyImagesURL('vent/alarm-icons/wasichoucaig.png'),
  319. // level: 100,
  320. text: '',
  321. allText: '总数',
  322. warnText: '报警数',
  323. closeText: '断开数',
  324. allCount: 0,
  325. warnCount: 0,
  326. closeCount: 0,
  327. },
  328. pump: {
  329. url: getThemifyImagesURL('vent/alarm-icons/wasibeng.png'),
  330. // level: 100,
  331. text: '',
  332. allText: '总数',
  333. warnText: '报警数',
  334. closeText: '断开数',
  335. allCount: 0,
  336. warnCount: 0,
  337. closeCount: 0,
  338. },
  339. modelsensor: {
  340. url: getThemifyImagesURL('vent/alarm-icons/cf.png'),
  341. // level: 100,
  342. text: '',
  343. allText: '总数',
  344. warnText: '报警数',
  345. closeText: '断开数',
  346. allCount: 0,
  347. warnCount: 0,
  348. closeCount: 0,
  349. },
  350. });
  351. export function setScatterEcharts(el: HTMLElement) {
  352. // 基于准备好的dom,初始化echarts实例
  353. const wwbzl = echarts.init(el, 'light', { renderer: 'svg' });
  354. // 小气泡
  355. const img =
  356. '';
  357. const img2 =
  358. '';
  359. //字符串截取
  360. const wordLength = (value) => {
  361. let ret = ''; //拼接加\n返回的类目项
  362. const maxLength = 4; //每项显示文字个数
  363. const valLength = value.length; //X轴类目项的文字个数
  364. const rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数
  365. if (rowN > 1) {
  366. //如果类目项的文字大于3,
  367. for (let i = 0; i < rowN; i++) {
  368. let temp = ''; //每次截取的字符串
  369. const start = i * maxLength; //开始截取的位置
  370. const end = start + maxLength; //结束截取的位置
  371. //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧
  372. temp = value.substring(start, end) + '\n';
  373. ret += temp; //凭借最终的字符串
  374. }
  375. return ret;
  376. } else {
  377. return value;
  378. }
  379. };
  380. //
  381. const data = [
  382. {
  383. name: '报警',
  384. value: '308',
  385. color0: '#ff0000',
  386. color1: '#920000',
  387. },
  388. {
  389. name: '重大风险',
  390. value: '427',
  391. color0: '#ff3300',
  392. color1: '#9e2000',
  393. },
  394. {
  395. name: '较大风险',
  396. value: '874',
  397. color0: '#ff5e00',
  398. color1: '#bf4600',
  399. },
  400. {
  401. name: '一般风险',
  402. value: '193',
  403. color0: '#ffb700',
  404. color1: '#bf8900',
  405. },
  406. {
  407. name: '低风险',
  408. value: '355',
  409. color0: '#09caff',
  410. color1: '#008fac',
  411. },
  412. ];
  413. //偏移量
  414. const offsetData = [
  415. [90, 53],
  416. [35, 73],
  417. [20, 28],
  418. [60, 18],
  419. [0, 48],
  420. ];
  421. //symbolSize 散点气泡大小
  422. const symbolSizeData = [100, 85, 75, 70, 60];
  423. //
  424. //循环定义series的data值
  425. const datas = <EChartsOption[]>[];
  426. for (let i = 0; i < data.length; i++) {
  427. const item = data[i];
  428. //var itemToStyle = datalist[i];
  429. datas.push({
  430. name: wordLength(item.name) + '\n' + item.value + '人',
  431. value: offsetData[i],
  432. symbolSize: symbolSizeData[i],
  433. label: {
  434. textStyle: {
  435. fontSize: 13,
  436. color: '#fff',
  437. textShadowColor: '#000',
  438. textShadowBlur: 3,
  439. textShadowOffsetX: 1,
  440. textShadowOffsetY: 1,
  441. },
  442. },
  443. itemStyle: {
  444. normal: {
  445. color: new echarts.graphic.RadialGradient(0.3, 0.5, 0.7, [
  446. {
  447. offset: 0,
  448. color: item.color0,
  449. },
  450. {
  451. offset: 1,
  452. color: item.color1,
  453. },
  454. ]),
  455. opacity: 0.9,
  456. shadowColor: '#ffffff33',
  457. shadowBlur: 10,
  458. shadowOffsetX: 1,
  459. shadowOffsetY: 1,
  460. },
  461. },
  462. });
  463. }
  464. const option = {
  465. // backgroundColor: "transparent",
  466. //backgroundColor: '#0e2147',
  467. grid: {
  468. show: false,
  469. top: -5,
  470. bottom: 0,
  471. },
  472. xAxis: [
  473. {
  474. gridIndex: 0,
  475. type: 'value',
  476. show: false,
  477. max: 100,
  478. nameLocation: 'middle',
  479. nameGap: 5,
  480. },
  481. ],
  482. yAxis: [
  483. {
  484. gridIndex: 0,
  485. min: 0,
  486. show: false,
  487. max: 100,
  488. nameLocation: 'middle',
  489. nameGap: 30,
  490. },
  491. ],
  492. series: [
  493. {
  494. type: 'scatter',
  495. symbol: 'circle',
  496. symbolSize: 120,
  497. label: {
  498. normal: {
  499. show: true,
  500. formatter: '{b}',
  501. color: '#fff',
  502. textStyle: {
  503. fontSize: '20',
  504. },
  505. },
  506. },
  507. animationDurationUpdate: 1000,
  508. animationEasingUpdate: 1000,
  509. animationDelay: function (idx) {
  510. // 越往后的数据延迟越大
  511. return 100;
  512. },
  513. itemStyle: {
  514. normal: {
  515. color: '#00acea',
  516. },
  517. },
  518. data: datas,
  519. },
  520. ],
  521. graphic: [
  522. {
  523. type: 'image',
  524. id: 'logo',
  525. left: '45%',
  526. bottom: '30%',
  527. z: -10,
  528. bounding: 'raw',
  529. origin: [675, 5],
  530. // position: [100, 0], // 平移,默认值为 [0, 0]。
  531. style: {
  532. image: img2,
  533. width: 120,
  534. height: 120,
  535. opacity: 0.4,
  536. },
  537. },
  538. {
  539. type: 'image',
  540. id: 'logo1',
  541. right: '14%',
  542. bottom: '0',
  543. z: -10,
  544. bounding: 'raw',
  545. origin: [275, 5],
  546. style: {
  547. image: img2,
  548. width: 80,
  549. height: 80,
  550. opacity: 0.4,
  551. },
  552. },
  553. {
  554. type: 'image',
  555. id: 'logo2',
  556. left: '10%',
  557. bottom: '2%',
  558. z: -10,
  559. bounding: 'raw',
  560. origin: [875, 15],
  561. style: {
  562. image: img2,
  563. width: 60,
  564. height: 60,
  565. opacity: 0.4,
  566. },
  567. },
  568. {
  569. type: 'image',
  570. id: 'logo3',
  571. left: '36%',
  572. bottom: 0,
  573. z: -10,
  574. bounding: 'raw',
  575. origin: [975, 5],
  576. style: {
  577. image: img2,
  578. width: 40,
  579. height: 40,
  580. opacity: 0.4,
  581. },
  582. },
  583. {
  584. type: 'image',
  585. id: 'logo4',
  586. left: '32%',
  587. bottom: '10%',
  588. z: -10,
  589. bounding: 'raw',
  590. origin: [76, 76],
  591. style: {
  592. image: img2,
  593. width: 50,
  594. height: 50,
  595. opacity: 0.4,
  596. },
  597. },
  598. {
  599. type: 'image',
  600. id: 'logo5',
  601. left: '40%',
  602. bottom: '35%',
  603. z: -10,
  604. bounding: 'raw',
  605. origin: [76, 76],
  606. style: {
  607. image: img2,
  608. width: 90,
  609. height: 90,
  610. opacity: 0.4,
  611. },
  612. },
  613. ],
  614. };
  615. let rotation = 0;
  616. setInterval(function () {
  617. wwbzl.setOption({
  618. graphic: [
  619. {
  620. id: 'logo',
  621. rotation: -(rotation += Math.PI / 860) % (Math.PI * 2),
  622. },
  623. {
  624. id: 'logo1',
  625. rotation: -(rotation += Math.PI / 640) % (Math.PI * 2),
  626. },
  627. {
  628. id: 'logo2',
  629. rotation: -(rotation += Math.PI / 360) % (Math.PI * 2),
  630. },
  631. {
  632. id: 'logo3',
  633. rotation: -(rotation += Math.PI / 720) % (Math.PI * 2),
  634. },
  635. ],
  636. });
  637. }, 30);
  638. // 使用刚指定的配置项和数据显示图表。
  639. wwbzl.setOption(option);
  640. window.addEventListener('resize', function () {
  641. wwbzl.resize();
  642. });
  643. }
  644. export const xAxisData = [
  645. { key: '低风险', valueKey: 'blue' },
  646. { key: '一般风险', valueKey: 'yellow' },
  647. { key: '较大风险', valueKey: 'alarm' },
  648. { key: '重大风险', valueKey: 'orange' },
  649. { key: '报警', valueKey: 'red' },
  650. ];
  651. export const chartsColumns = [
  652. {
  653. legend: '低风险',
  654. seriesName: '(Pa)',
  655. ymax: 50,
  656. ymin: 0,
  657. yname: '个',
  658. linetype: 'bar',
  659. yaxispos: 'left',
  660. color: '#cd5fff',
  661. sort: 1,
  662. dataIndex: '',
  663. xRotate: 0,
  664. },
  665. ];
  666. export const option = {
  667. grid: {
  668. top: '20px',
  669. bottom: 15,
  670. right: 20,
  671. left: 10,
  672. containLabel: true,
  673. },
  674. yAxis: {
  675. show: false,
  676. },
  677. };
  678. export const colors = [
  679. // [{ color: 'rgba(46,144,165, 1 )' }, { color: 'rgba(46,144,165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  680. // [{ color: 'rgba(46, 144, 165, 1 )' }, { color: 'rgba(46, 144, 165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  681. // [{ color: 'rgba(46, 144, 165, 1 )' }, { color: 'rgba(46, 144, 165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  682. // [{ color: 'rgba(46, 144, 165, 1 )' }, { color: 'rgba(46, 144, 165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  683. // [{ color: 'rgba(46, 144, 165, 1 )' }, { color: 'rgba(46, 144, 165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  684. [{ color: 'rgba(46,144,165, 1 )' }, { color: 'rgba(46,144,165, 0.8 )' }, { color: 'rgba(46, 144, 165, 0.08 )' }],
  685. [{ color: 'rgba(254,254,53, 1 )' }, { color: 'rgba(254,254,53, 0.8 )' }, { color: 'rgba(254,254,53, 0.08 )' }],
  686. [{ color: 'rgba(234,179,105, 1 )' }, { color: 'rgba(234,179,105, 0.8 )' }, { color: 'rgba(234,179,105, 0.08 )' }],
  687. [{ color: 'rgba(254,111,0, 1 )' }, { color: 'rgba(254,111,0, 0.8 )' }, { color: 'rgba(254,111,0, 0.08 )' }],
  688. [{ color: 'rgba(255,0,0, 1 )' }, { color: 'rgba(255,0,0, 0.8 )' }, { color: 'rgba(255,0,0, 0.08 )' }],
  689. ];
  690. export const fontColor = ['rgba(46,144,165, 1 )', 'rgba(254,254,53, 1 )', 'rgba(234,179,105, 1 )', 'rgba(254,111,0, 1 )', 'rgba(255,0,0, 1 )'];
  691. export const dustMonitor = [
  692. {
  693. title: '压力传感器',
  694. code: '',
  695. },
  696. {
  697. title: '无线洒水降尘装置',
  698. code: '',
  699. },
  700. {
  701. title: '粉尘浓度传感器',
  702. code: '',
  703. },
  704. ];
  705. export const fireMonitor = [
  706. {
  707. // title: '最高温度(℃)',
  708. title: '温度',
  709. code: '',
  710. level: null,
  711. value: '正常',
  712. },
  713. {
  714. title: '烟雾',
  715. code: '',
  716. level: null,
  717. value: '正常',
  718. },
  719. {
  720. title: '火焰',
  721. code: '',
  722. level: null,
  723. value: '-',
  724. },
  725. {
  726. title: 'CO最大值(ppm)',
  727. code: '',
  728. level: null,
  729. value: '0',
  730. },
  731. // {
  732. // title: 'CH₄最大值(%)',
  733. // code: '',
  734. // level:null,
  735. // value: 0,
  736. // },
  737. // {
  738. // title: 'C₂H₄最大值(ppm)',
  739. // code: '',
  740. // level:null,
  741. // value: 0,
  742. // },
  743. // {
  744. // title: 'CO₂最大值(%)',
  745. // code: '',
  746. // level:null,
  747. // value: 0,
  748. // },
  749. // {
  750. // title: '上隅角O₂最小值(%)',
  751. // code: '',
  752. // level:null,
  753. // value: 0,
  754. // },
  755. ];