main.data.ts 29 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553
  1. import { BasicColumn } from '/@/components/Table';
  2. import { FormSchema } from '/@/components/Table';
  3. import { rules } from '/@/utils/helper/validator';
  4. import { reactive } from 'vue';
  5. import type { EChartsOption } from 'echarts';
  6. import { useGlobSetting } from '/@/hooks/setting';
  7. import { cloneDeep } from 'lodash-es';
  8. type CtrlLockOpenType = {
  9. CtrlLockOpen: boolean | undefined;
  10. CtrlExplosionVentOpen: boolean | undefined;
  11. };
  12. export type PointMonitorType = {
  13. valueName: string;
  14. valueCode: string;
  15. value: number | string;
  16. warnMin_201: number | string;
  17. warnMin_104: number | string;
  18. readTime: string;
  19. };
  20. export const columns: BasicColumn[] = [
  21. {
  22. title: '名称',
  23. dataIndex: 'strname',
  24. width: 120,
  25. },
  26. {
  27. title: '安装位置',
  28. dataIndex: 'strinstallpos',
  29. width: 100,
  30. },
  31. {
  32. title: '是否为常闭型',
  33. dataIndex: 'bnormalclose',
  34. width: 100,
  35. // customRender: render.renderAvatar,
  36. },
  37. {
  38. title: '净宽',
  39. dataIndex: 'fclearwidth',
  40. width: 80,
  41. },
  42. {
  43. title: '净高',
  44. dataIndex: 'fclearheight',
  45. width: 100,
  46. },
  47. {
  48. title: '风门道数',
  49. dataIndex: 'ndoorcount',
  50. width: 100,
  51. },
  52. {
  53. title: '所属分站',
  54. width: 150,
  55. dataIndex: 'stationname',
  56. },
  57. {
  58. title: '点表',
  59. width: 100,
  60. dataIndex: 'strtype',
  61. },
  62. {
  63. title: '监测类型',
  64. dataIndex: 'monitorflag',
  65. width: 100,
  66. },
  67. {
  68. title: '是否模拟数据',
  69. dataIndex: 'testflag',
  70. width: 100,
  71. },
  72. ];
  73. export const recycleColumns: BasicColumn[] = [
  74. {
  75. title: '名称',
  76. dataIndex: 'strname',
  77. width: 100,
  78. },
  79. {
  80. title: '是否为常闭型',
  81. dataIndex: 'bnormalclose',
  82. width: 100,
  83. },
  84. ];
  85. export const searchFormSchema: FormSchema[] = [
  86. {
  87. label: '名称',
  88. field: 'strname',
  89. component: 'Input',
  90. colProps: { span: 6 },
  91. },
  92. {
  93. label: '安装位置',
  94. field: 'strinstallpos',
  95. component: 'Input',
  96. colProps: { span: 6 },
  97. },
  98. {
  99. label: '是否为常闭型',
  100. field: 'bnormalclose',
  101. component: 'JDictSelectTag',
  102. componentProps: {
  103. dictCode: 'user_status',
  104. placeholder: '请选择读写类型',
  105. stringToNumber: true,
  106. },
  107. colProps: { span: 6 },
  108. },
  109. ];
  110. export const formSchema: FormSchema[] = [
  111. {
  112. label: '',
  113. field: 'id',
  114. component: 'Input',
  115. show: false,
  116. },
  117. {
  118. label: '名称',
  119. field: 'strname',
  120. component: 'Input',
  121. },
  122. {
  123. label: '安装位置',
  124. field: 'strinstallpos',
  125. component: 'Input',
  126. },
  127. {
  128. label: '是否为常闭型',
  129. field: 'bnormalclose',
  130. component: 'RadioGroup',
  131. defaultValue: 1,
  132. componentProps: () => {
  133. return {
  134. options: [
  135. { label: '是', value: 1, key: '1' },
  136. { label: '否', value: 0, key: '2' },
  137. ],
  138. };
  139. },
  140. },
  141. {
  142. label: '净宽',
  143. field: 'fclearwidth',
  144. component: 'Input',
  145. },
  146. {
  147. label: '净高',
  148. field: 'fclearheight',
  149. component: 'Input',
  150. },
  151. {
  152. label: '风门道数',
  153. field: 'ndoorcount',
  154. component: 'Input',
  155. },
  156. {
  157. label: '所属分站',
  158. field: 'stationname',
  159. component: 'JDictSelectTag',
  160. componentProps: {
  161. dictCode: 'user_status',
  162. placeholder: '请选择状态',
  163. stringToNumber: true,
  164. },
  165. },
  166. {
  167. label: '点表',
  168. field: 'strtype',
  169. component: 'JDictSelectTag',
  170. componentProps: {
  171. dictCode: 'user_status',
  172. placeholder: '请选择状态',
  173. stringToNumber: true,
  174. },
  175. },
  176. {
  177. label: '监测类型',
  178. field: 'monitorflag',
  179. component: 'JDictSelectTag',
  180. componentProps: {
  181. dictCode: 'user_status',
  182. placeholder: '请选择状态',
  183. stringToNumber: true,
  184. },
  185. },
  186. {
  187. label: '是否模拟数据',
  188. field: 'testflag',
  189. component: 'RadioGroup',
  190. defaultValue: 1,
  191. componentProps: () => {
  192. return {
  193. options: [
  194. { label: '是', value: 1, key: '1' },
  195. { label: '否', value: 0, key: '2' },
  196. ],
  197. };
  198. },
  199. },
  200. ];
  201. export const tableColumns = [
  202. {
  203. title: '',
  204. dataIndex: 'isCheck',
  205. customCell: (_, index) => {
  206. if (index % 2 == 0) {
  207. return { rowSpan: 2 };
  208. } else {
  209. return { rowSpan: 0 };
  210. }
  211. },
  212. },
  213. {
  214. title: '安装位置',
  215. dataIndex: 'address',
  216. customCell: (_, index) => {
  217. if (index % 2 == 0) {
  218. return { rowSpan: 2 };
  219. } else {
  220. return { rowSpan: 0 };
  221. }
  222. },
  223. },
  224. {
  225. title: '运行风机',
  226. dataIndex: 'childName',
  227. },
  228. {
  229. title: '风机静压(Pa)',
  230. dataIndex: 'yc2',
  231. },
  232. {
  233. title: '风机全压(Pa)',
  234. dataIndex: 'dqPa',
  235. },
  236. {
  237. title: '电机流量(m³/s)',
  238. dataIndex: 'fanM3',
  239. },
  240. {
  241. title: '电机速度(rpm/s)',
  242. dataIndex: 'fanSD',
  243. },
  244. {
  245. title: '电机电压(V)',
  246. dataIndex: 'fanU',
  247. },
  248. {
  249. title: '电机电流(A)',
  250. dataIndex: 'fanA',
  251. },
  252. {
  253. title: '电机频率(Hz/s)',
  254. dataIndex: 'fanPL',
  255. },
  256. {
  257. title: '电机功率(KW/s)',
  258. dataIndex: 'fanGL',
  259. },
  260. {
  261. title: '振动X1(mm/s)',
  262. dataIndex: 'zdX1',
  263. },
  264. {
  265. title: '振动Y1(mm/s)',
  266. dataIndex: 'zdY1',
  267. },
  268. ];
  269. export const dataColumns = () => {
  270. return [
  271. {
  272. id: 'UXC',
  273. name: '电机轴温设定(℃)',
  274. id2: 'bearingFront2_F1',
  275. },
  276. { id: 'VXC', name: '电机定温设定(℃)', id2: 'bearingBack2_F1' },
  277. {
  278. id: 'WXC',
  279. name: '电机前轴温度(℃)',
  280. id2: 'stator2A_F1',
  281. },
  282. {
  283. id: 'QZC',
  284. name: '电机后轴温度(℃)',
  285. id2: 'stator2B_F1',
  286. },
  287. { id: 'ZCZ1C', name: '电机定子1温度(℃)', id2: 'fIA2_F1' },
  288. { id: 'ZCZ2C', name: '电机定子2温度(℃)', id2: 'fIB2_F1' },
  289. { id: 'FTZ1C', name: '电机定3温度(℃)', id2: 'fIC2_F1' },
  290. ];
  291. };
  292. export const stateColumns = () => {
  293. return [
  294. // {
  295. // id: 'lubeBoxTemperatureF1High',
  296. // name: '润滑站油箱油温高报警',
  297. // flag: false,
  298. // },
  299. {
  300. id: 'lubeBoxTemperatureF1Low',
  301. name: '润滑站1油箱油温低报警',
  302. flag: true,
  303. },
  304. {
  305. id: 'lubeTemperatureF1High',
  306. name: '润滑站1供油油温高报警',
  307. flag: true,
  308. },
  309. // {
  310. // id: 'lubeTemperatureF1Low',
  311. // name: '润滑站1供油油温低报警',
  312. // flag: false,
  313. // },
  314. { id: 'lubePaF1High', name: '润滑站1供油油压高报警', flag: true },
  315. { id: 'lubePaF1Low', name: '润滑站1供油油压低报警', flag: true },
  316. // { id: "ch4_F1High", name: "瓦斯值1高报警", flag: false },
  317. { id: 'singleDoorF1Warn', name: '侧开风门单模报警', flag: true },
  318. { id: 'lubeF1SlightFault', name: '稀油润滑站轻故障', flag: true },
  319. { id: 'lubeF1SevereFault', name: '稀油润滑站重故障', flag: true },
  320. { id: 'f1B1Fault', name: '变频器1故障', flag: true },
  321. { id: 'f1B2Fault', name: '变频器2故障', flag: true },
  322. { id: 'f1Fault', name: '通风机故障', flag: true },
  323. ];
  324. };
  325. export const faultDeviceHeader = [
  326. {
  327. title: '测点名称',
  328. code: 'valueName',
  329. width: '200px',
  330. },
  331. {
  332. title: '实时数据',
  333. code: 'value',
  334. width: '110px',
  335. },
  336. {
  337. title: '预警限值',
  338. code: 'warnMin_104',
  339. width: '110px',
  340. },
  341. {
  342. title: '报警限值',
  343. code: 'warnMin_201',
  344. width: '110px',
  345. },
  346. ];
  347. export const rightFaultDeviceColumns = [
  348. {
  349. title: '中端X',
  350. dataIndex: 'Fault_cd_ZX', // 测点名称
  351. width: 120,
  352. },
  353. {
  354. title: '中端X',
  355. dataIndex: 'Fault_ZX_val', // 中端X实时监测值
  356. width: 120,
  357. },
  358. ];
  359. export const modalTypeArr = {
  360. centerBtnArr: [
  361. {
  362. key: 'startSmoke',
  363. value: '启动/停止',
  364. permission: 'fan:startSmoke',
  365. },
  366. {
  367. key: 'startFan',
  368. value: '启动/停止',
  369. permission: 'fan:startFan',
  370. },
  371. {
  372. key: 'startFan',
  373. value: '启动/停止',
  374. permission: 'fan:startAndResetFan',
  375. },
  376. {
  377. key: 'resetFan',
  378. value: '一键复位',
  379. permission: 'fan:resetFan',
  380. },
  381. {
  382. key: 'changeSmoke',
  383. value: '不停风倒机',
  384. permission: 'fan:changeSmoke',
  385. },
  386. {
  387. key: 'changeDirection',
  388. value: '一键反风',
  389. permission: 'fan:changeDirection',
  390. },
  391. {
  392. key: 'frequency',
  393. value: '一键调频',
  394. permission: 'fan:frequency',
  395. },
  396. {
  397. key: 'fbm',
  398. value: '防爆门控制',
  399. permission: 'fan:fbm',
  400. },
  401. {
  402. key: 'kkjc',
  403. value: '工况辅助决策',
  404. permission: 'fan:kkjc',
  405. },
  406. {
  407. key: 'zhlk',
  408. value: '自主联控',
  409. permission: 'fan:zhlk',
  410. },
  411. ],
  412. };
  413. export const fbmControlData = <CtrlLockOpenType>reactive({
  414. CtrlLockOpen: false, // 远程开锁 true 为打开状态, false 为关闭状态
  415. CtrlExplosionVentOpen: false, // 远程开门 true 为打开状态, false 为关闭状态
  416. });
  417. // export const assistanceData = {
  418. // '30': {
  419. // angle: 0,
  420. // Hz: 30.0, //频率
  421. // a: -0.17624, //二次项系数
  422. // b: 34.59747, //一次项系数
  423. // c: 938.98517, //常数项系数
  424. // min: 93.0, //风量下限
  425. // max: 132.0, //风量上限
  426. // },
  427. // '31': {
  428. // angle: 0,
  429. // Hz: 31.0,
  430. // a: -0.17624,
  431. // b: 35.055694,
  432. // c: 851.596922,
  433. // min: 96.1,
  434. // max: 136.4,
  435. // },
  436. // '32': {
  437. // angle: 0,
  438. // Hz: 32.0,
  439. // a: -0.17624,
  440. // b: 35.513918,
  441. // c: 768.749733,
  442. // min: 99.2,
  443. // max: 140.8,
  444. // },
  445. // '33': {
  446. // angle: 0,
  447. // Hz: 33.0,
  448. // a: -0.17624,
  449. // b: 35.972142,
  450. // c: 690.443603,
  451. // min: 102.3,
  452. // max: 145.2,
  453. // },
  454. // '34': {
  455. // angle: 0,
  456. // Hz: 34.0,
  457. // a: -0.17624,
  458. // b: 36.430366,
  459. // c: 616.678531,
  460. // min: 105.4,
  461. // max: 149.6,
  462. // },
  463. // '35': {
  464. // angle: 0,
  465. // Hz: 35.0,
  466. // a: -0.17624,
  467. // b: 36.88859,
  468. // c: 547.454517,
  469. // min: 108.5,
  470. // max: 154.0,
  471. // },
  472. // '36': {
  473. // angle: 0,
  474. // Hz: 36.0,
  475. // a: -0.17624,
  476. // b: 37.346814,
  477. // c: 482.771563,
  478. // min: 111.6,
  479. // max: 158.4,
  480. // },
  481. // '37': {
  482. // angle: 0,
  483. // Hz: 37.0,
  484. // a: -0.17624,
  485. // b: 37.805038,
  486. // c: 422.629667,
  487. // min: 114.7,
  488. // max: 162.8,
  489. // },
  490. // '38': {
  491. // angle: 0,
  492. // Hz: 38.0,
  493. // a: -0.17624,
  494. // b: 38.263262,
  495. // c: 367.028829,
  496. // min: 117.8,
  497. // max: 167.2,
  498. // },
  499. // '39': {
  500. // angle: 0,
  501. // Hz: 39.0,
  502. // a: -0.17624,
  503. // b: 38.721486,
  504. // c: 315.96905,
  505. // min: 120.9,
  506. // max: 171.6,
  507. // },
  508. // '40': {
  509. // angle: 0,
  510. // Hz: 40.0,
  511. // a: -0.17624,
  512. // b: 39.17971,
  513. // c: 269.45033,
  514. // min: 124.0,
  515. // max: 176.0,
  516. // },
  517. // '41': {
  518. // angle: 0,
  519. // Hz: 41.0,
  520. // a: -0.17624,
  521. // b: 39.637934,
  522. // c: 227.472668,
  523. // min: 127.1,
  524. // max: 180.4,
  525. // },
  526. // '42': {
  527. // angle: 0,
  528. // Hz: 42.0,
  529. // a: -0.17624,
  530. // b: 40.096158,
  531. // c: 190.036065,
  532. // min: 130.2,
  533. // max: 184.8,
  534. // },
  535. // '43': {
  536. // angle: 0,
  537. // Hz: 43.0,
  538. // a: -0.17624,
  539. // b: 40.554382,
  540. // c: 157.140521,
  541. // min: 133.3,
  542. // max: 189.2,
  543. // },
  544. // '44': {
  545. // angle: 0,
  546. // Hz: 44.0,
  547. // a: -0.17624,
  548. // b: 41.012606,
  549. // c: 128.786035,
  550. // min: 136.4,
  551. // max: 193.6,
  552. // },
  553. // '45': {
  554. // angle: 0,
  555. // Hz: 45.0,
  556. // a: -0.17624,
  557. // b: 41.47083,
  558. // c: 104.972607,
  559. // min: 139.5,
  560. // max: 198.0,
  561. // },
  562. // '46': {
  563. // angle: 0,
  564. // Hz: 46.0,
  565. // a: -0.17624,
  566. // b: 41.929054,
  567. // c: 85.700239,
  568. // min: 142.6,
  569. // max: 202.4,
  570. // },
  571. // '47': {
  572. // angle: 0,
  573. // Hz: 47.0,
  574. // a: -0.17624,
  575. // b: 42.387278,
  576. // c: 70.968929,
  577. // min: 145.7,
  578. // max: 206.8,
  579. // },
  580. // '48': {
  581. // angle: 0,
  582. // Hz: 48.0,
  583. // a: -0.17624,
  584. // b: 42.845502,
  585. // c: 60.778677,
  586. // min: 148.8,
  587. // max: 211.2,
  588. // },
  589. // '49': {
  590. // angle: 0,
  591. // Hz: 49.0,
  592. // a: -0.17624,
  593. // b: 43.303726,
  594. // c: 55.129484,
  595. // min: 151.9,
  596. // max: 215.6,
  597. // },
  598. // '50': {
  599. // angle: 0,
  600. // Hz: 50.0,
  601. // a: -0.17624,
  602. // b: 43.76195,
  603. // c: 54.02135,
  604. // min: 155.0,
  605. // max: 220.0,
  606. // },
  607. // };
  608. export const assistanceData = {
  609. '30': {
  610. angle: 0,
  611. Hz: 30.0, //频率
  612. a: -0.17624, //二次项系数
  613. b: 43.40947, //一次项系数
  614. c: 97.60705999999982, //常数项系数
  615. min: 93.0, //风量下限
  616. max: 132.0, //风量上限
  617. },
  618. '31': {
  619. angle: 0,
  620. Hz: 31.0,
  621. a: -0.17624,
  622. b: 43.427094,
  623. c: 95.43614590000016,
  624. min: 96.1,
  625. max: 136.4,
  626. },
  627. '32': {
  628. angle: 0,
  629. Hz: 32.0,
  630. a: -0.17624,
  631. b: 43.444718,
  632. c: 93.26435059999994,
  633. min: 99.2,
  634. max: 140.8,
  635. },
  636. '33': {
  637. angle: 0,
  638. Hz: 33.0,
  639. a: -0.17624,
  640. b: 43.462342,
  641. c: 91.09167409999964,
  642. min: 102.3,
  643. max: 145.2,
  644. },
  645. '34': {
  646. angle: 0,
  647. Hz: 34.0,
  648. a: -0.17624,
  649. b: 43.479966000000005,
  650. c: 88.91811639999969,
  651. min: 105.4,
  652. max: 149.6,
  653. },
  654. '35': {
  655. angle: 0,
  656. Hz: 35.0,
  657. a: -0.17624,
  658. b: 43.49759,
  659. c: 86.74367749999965,
  660. min: 108.5,
  661. max: 154.0,
  662. },
  663. '36': {
  664. angle: 0,
  665. Hz: 36.0,
  666. a: -0.17624,
  667. b: 43.515214,
  668. c: 84.56835739999997,
  669. min: 111.6,
  670. max: 158.4,
  671. },
  672. '37': {
  673. angle: 0,
  674. Hz: 37.0,
  675. a: -0.17624,
  676. b: 43.532838,
  677. c: 82.3921561000002,
  678. min: 114.7,
  679. max: 162.8,
  680. },
  681. '38': {
  682. angle: 0,
  683. Hz: 38.0,
  684. a: -0.17624,
  685. b: 43.550462,
  686. c: 80.21507359999941,
  687. min: 117.8,
  688. max: 167.2,
  689. },
  690. '39': {
  691. angle: 0,
  692. Hz: 39.0,
  693. a: -0.17624,
  694. b: 43.568086,
  695. c: 78.0371098999999,
  696. min: 120.9,
  697. max: 171.6,
  698. },
  699. '40': {
  700. angle: 0,
  701. Hz: 40.0,
  702. a: -0.17624,
  703. b: 43.58571,
  704. c: 75.85826499999985,
  705. min: 124.0,
  706. max: 176.0,
  707. },
  708. '41': {
  709. angle: 0,
  710. Hz: 41.0,
  711. a: -0.17624,
  712. b: 43.603334,
  713. c: 73.67853890000015,
  714. min: 127.1,
  715. max: 180.4,
  716. },
  717. '42': {
  718. angle: 0,
  719. Hz: 42.0,
  720. a: -0.17624,
  721. b: 43.620958,
  722. c: 71.4979315999999,
  723. min: 130.2,
  724. max: 184.8,
  725. },
  726. '43': {
  727. angle: 0,
  728. Hz: 43.0,
  729. a: -0.17624,
  730. b: 43.638582,
  731. c: 69.31644309999956,
  732. min: 133.3,
  733. max: 189.2,
  734. },
  735. '44': {
  736. angle: 0,
  737. Hz: 44.0,
  738. a: -0.17624,
  739. b: 43.656206000000005,
  740. c: 67.13407339999958,
  741. min: 136.4,
  742. max: 193.6,
  743. },
  744. '45': {
  745. angle: 0,
  746. Hz: 45.0,
  747. a: -0.17624,
  748. b: 43.67383,
  749. c: 64.9508224999995,
  750. min: 139.5,
  751. max: 198.0,
  752. },
  753. '46': {
  754. angle: 0,
  755. Hz: 46.0,
  756. a: -0.17624,
  757. b: 43.691454,
  758. c: 62.76669039999979,
  759. min: 142.6,
  760. max: 202.4,
  761. },
  762. '47': {
  763. angle: 0,
  764. Hz: 47.0,
  765. a: -0.17624,
  766. b: 43.709078,
  767. c: 60.58167709999998,
  768. min: 145.7,
  769. max: 206.8,
  770. },
  771. '48': {
  772. angle: 0,
  773. Hz: 48.0,
  774. a: -0.17624,
  775. b: 43.726702,
  776. c: 58.39578259999962,
  777. min: 148.8,
  778. max: 211.2,
  779. },
  780. '49': {
  781. angle: 0,
  782. Hz: 49.0,
  783. a: -0.17624,
  784. b: 43.744326,
  785. c: 56.20900689999962,
  786. min: 151.9,
  787. max: 215.6,
  788. },
  789. '50': {
  790. angle: 0,
  791. Hz: 50.0,
  792. a: -0.17624,
  793. b: 43.76195,
  794. c: 54.021349999999984,
  795. min: 155.0,
  796. max: 220.0,
  797. },
  798. };
  799. export const setOption = (deviceType?) => {
  800. debugger;
  801. let yMax = 4500;
  802. const { sysOrgCode } = useGlobSetting();
  803. // const sysOrgCode = 'sdmtjtdltmk';
  804. if (sysOrgCode == 'sdmtjtdltmk') {
  805. // 这里判断白家渠还是五当沟
  806. if (deviceType == 'fanmain_bjq') {
  807. yMax = 5500;
  808. } else if (deviceType == 'fanmain_wdg') {
  809. yMax = 1200;
  810. }
  811. } else {
  812. yMax = 4500;
  813. }
  814. return reactive<EChartsOption>({
  815. title: {
  816. text: '风机运行工况辅助曲线图',
  817. textStyle: {
  818. color: '#BF954D',
  819. },
  820. left: 'center',
  821. top: 0,
  822. },
  823. // backgroundColor: '#39deff',
  824. tooltip: {
  825. trigger: 'axis',
  826. axisPointer: {
  827. type: 'cross',
  828. label: {
  829. backgroundColor: '#6a7985',
  830. },
  831. },
  832. },
  833. toolbox: {
  834. show: true,
  835. },
  836. grid: {
  837. left: 8,
  838. right: 50,
  839. bottom: 0,
  840. containLabel: true,
  841. },
  842. xAxis: {
  843. type: 'category',
  844. name: 'm³/s',
  845. nameTextStyle: {
  846. fontWeight: 600,
  847. fontSize: 13,
  848. },
  849. splitLine: { show: true, lineStyle: { color: 'rgba(21,80,126,.5)' } },
  850. axisLabel: {
  851. margin: 20,
  852. fontSize: 14,
  853. color: '#f1f1f199',
  854. },
  855. boundaryGap: false,
  856. data: [],
  857. },
  858. yAxis: {
  859. type: 'value',
  860. axisLine: {
  861. show: true,
  862. lineStyle: {
  863. color: '#006c9d',
  864. },
  865. },
  866. splitLine: { show: true, lineStyle: { color: 'rgba(21,80,126,.5)' } },
  867. axisLabel: {
  868. show: true,
  869. fontSize: 14,
  870. formatter: '{value}',
  871. color: '#0071A5',
  872. },
  873. min: 0,
  874. max: yMax, //武当沟
  875. name: 'Pa',
  876. nameTextStyle: {
  877. fontWeight: 600,
  878. fontSize: 13,
  879. },
  880. },
  881. series: [],
  882. });
  883. };
  884. // export const option = reactive<EChartsOption>({
  885. // title: {
  886. // text: '风机运行工况辅助曲线图',
  887. // textStyle: {
  888. // color: '#BF954D',
  889. // },
  890. // left: 'center',
  891. // top: 0,
  892. // },
  893. // // backgroundColor: '#39deff',
  894. // tooltip: {
  895. // trigger: 'axis',
  896. // axisPointer: {
  897. // type: 'cross',
  898. // label: {
  899. // backgroundColor: '#6a7985',
  900. // },
  901. // },
  902. // },
  903. // toolbox: {
  904. // show: true,
  905. // },
  906. // grid: {
  907. // left: 8,
  908. // right: 50,
  909. // bottom: 0,
  910. // containLabel: true,
  911. // },
  912. // xAxis: {
  913. // type: 'category',
  914. // name: 'm³/s',
  915. // nameTextStyle: {
  916. // fontWeight: 600,
  917. // fontSize: 13,
  918. // },
  919. // splitLine: { show: true, lineStyle: { color: 'rgba(21,80,126,.5)' } },
  920. // axisLabel: {
  921. // margin: 20,
  922. // fontSize: 14,
  923. // color: '#f1f1f199',
  924. // },
  925. // boundaryGap: false,
  926. // data: [],
  927. // },
  928. // yAxis: {
  929. // type: 'value',
  930. // axisLine: {
  931. // show: true,
  932. // lineStyle: {
  933. // color: '#006c9d',
  934. // },
  935. // },
  936. // splitLine: { show: true, lineStyle: { color: 'rgba(21,80,126,.5)' } },
  937. // axisLabel: {
  938. // show: true,
  939. // fontSize: 14,
  940. // formatter: '{value}',
  941. // color: '#0071A5',
  942. // },
  943. // min: 0,
  944. // // max: 5500, //白家渠
  945. // max: 1200, //武当沟
  946. // name: 'Pa',
  947. // nameTextStyle: {
  948. // fontWeight: 600,
  949. // fontSize: 13,
  950. // },
  951. // },
  952. // series: [],
  953. // });
  954. export const initData1 = () => {
  955. const assistanceData = {
  956. '30': {
  957. angle: 0,
  958. Hz: 30.0, //频率
  959. a: -0.17624, //二次项系数
  960. b: 43.40947, //一次项系数
  961. c: 97.60705999999982, //常数项系数
  962. min: 93.0, //风量下限
  963. max: 171.0, //风量上限
  964. },
  965. '31': {
  966. angle: 0,
  967. Hz: 31.0,
  968. a: -0.17624,
  969. b: 43.427094,
  970. c: 95.43614590000016,
  971. min: 96.1,
  972. max: 174.4,
  973. },
  974. '32': {
  975. angle: 0,
  976. Hz: 32.0,
  977. a: -0.17624,
  978. b: 43.444718,
  979. c: 93.26435059999994,
  980. min: 99.2,
  981. max: 177.8,
  982. },
  983. '33': {
  984. angle: 0,
  985. Hz: 33.0,
  986. a: -0.17624,
  987. b: 43.462342,
  988. c: 91.09167409999964,
  989. min: 102.3,
  990. max: 180.2,
  991. },
  992. '34': {
  993. angle: 0,
  994. Hz: 34.0,
  995. a: -0.17624,
  996. b: 43.479966000000005,
  997. c: 88.91811639999969,
  998. min: 105.4,
  999. max: 182.0,
  1000. },
  1001. '35': {
  1002. angle: 0,
  1003. Hz: 35.0,
  1004. a: -0.17624,
  1005. b: 43.49759,
  1006. c: 86.74367749999965,
  1007. min: 108.5,
  1008. max: 184.5,
  1009. },
  1010. '36': {
  1011. angle: 0,
  1012. Hz: 36.0,
  1013. a: -0.17624,
  1014. b: 43.515214,
  1015. c: 84.56835739999997,
  1016. min: 111.6,
  1017. max: 187.0,
  1018. },
  1019. '37': {
  1020. angle: 0,
  1021. Hz: 37.0,
  1022. a: -0.17624,
  1023. b: 43.532838,
  1024. c: 82.3921561000002,
  1025. min: 114.7,
  1026. max: 190.8,
  1027. },
  1028. '38': {
  1029. angle: 0,
  1030. Hz: 38.0,
  1031. a: -0.17624,
  1032. b: 43.550462,
  1033. c: 80.21507359999941,
  1034. min: 117.8,
  1035. max: 193.0,
  1036. },
  1037. '39': {
  1038. angle: 0,
  1039. Hz: 39.0,
  1040. a: -0.17624,
  1041. b: 43.568086,
  1042. c: 78.0371098999999,
  1043. min: 120.9,
  1044. max: 195.6,
  1045. },
  1046. '40': {
  1047. angle: 0,
  1048. Hz: 40.0,
  1049. a: -0.17624,
  1050. b: 43.58571,
  1051. c: 75.85826499999985,
  1052. min: 123.0,
  1053. max: 197.0,
  1054. },
  1055. '41': {
  1056. angle: 0,
  1057. Hz: 41.0,
  1058. a: -0.17624,
  1059. b: 43.603334,
  1060. c: 73.67853890000015,
  1061. min: 125.1,
  1062. max: 199.4,
  1063. },
  1064. '42': {
  1065. angle: 0,
  1066. Hz: 42.0,
  1067. a: -0.17624,
  1068. b: 43.620958,
  1069. c: 71.4979315999999,
  1070. min: 128.2,
  1071. max: 202.8,
  1072. },
  1073. '43': {
  1074. angle: 0,
  1075. Hz: 43.0,
  1076. a: -0.17624,
  1077. b: 43.638582,
  1078. c: 69.31644309999956,
  1079. min: 130.3,
  1080. max: 205.8,
  1081. },
  1082. '44': {
  1083. angle: 0,
  1084. Hz: 44.0,
  1085. a: -0.17624,
  1086. b: 43.656206000000005,
  1087. c: 67.13407339999958,
  1088. min: 132.4,
  1089. max: 208.5,
  1090. },
  1091. '45': {
  1092. angle: 0,
  1093. Hz: 45.0,
  1094. a: -0.17624,
  1095. b: 43.67383,
  1096. c: 64.9508224999995,
  1097. min: 134.5,
  1098. max: 211.8,
  1099. },
  1100. '46': {
  1101. angle: 0,
  1102. Hz: 46.0,
  1103. a: -0.17624,
  1104. b: 43.691454,
  1105. c: 62.76669039999979,
  1106. min: 136.6,
  1107. max: 214.4,
  1108. },
  1109. '47': {
  1110. angle: 0,
  1111. Hz: 47.0,
  1112. a: -0.17624,
  1113. b: 43.709078,
  1114. c: 60.58167709999998,
  1115. min: 138.7,
  1116. max: 217.8,
  1117. },
  1118. '48': {
  1119. angle: 0,
  1120. Hz: 48.0,
  1121. a: -0.17624,
  1122. b: 43.726702,
  1123. c: 58.39578259999962,
  1124. min: 140.8,
  1125. max: 219.2,
  1126. },
  1127. '49': {
  1128. angle: 0,
  1129. Hz: 49.0,
  1130. a: -0.17624,
  1131. b: 43.744326,
  1132. c: 56.20900689999962,
  1133. min: 143.9,
  1134. max: 221.6,
  1135. },
  1136. '50': {
  1137. angle: 0,
  1138. Hz: 50.0,
  1139. a: -0.17624,
  1140. b: 43.76195,
  1141. c: 54.021349999999984,
  1142. min: 146.0,
  1143. max: 223.0,
  1144. },
  1145. };
  1146. const num = 21;
  1147. const a = -0.17624; //-0.17624,
  1148. const m = 2770.6411125432646,
  1149. n = -124.15442010894235;
  1150. let i = 21;
  1151. const data = [];
  1152. for (const key in assistanceData) {
  1153. i -= 1;
  1154. const p = i;
  1155. const item = assistanceData[key];
  1156. item['b'] = 2 * a * (n + p);
  1157. item['c'] = a * (n + p) * (n + p) + m - i * 50;
  1158. // if (sysOrgCode == 'sdmtjtdltmk') {
  1159. // // 大柳塔井整体向右下移动
  1160. // item['min'] = item['min'] + 20;
  1161. // item['max'] = item['max'] + 20;
  1162. // item['b'] = 2 * a * (n + p) + 3;
  1163. // item['c'] = a * (n + p) * (n + p) + m - i * 60;
  1164. // } else {
  1165. // item['b'] = 2 * a * (n + p);
  1166. // item['c'] = a * (n + p) * (n + p) + m - i * 50;
  1167. // // //白家渠
  1168. // // a = -0.13424;
  1169. // // item['a'] = Math.round((a + 0.002 * (num - i)) * 10000) / 10000;
  1170. // // item['min'] = item['min'] + 50 + (num - i) * 2;
  1171. // // item['max'] = item['max'] + 65 + (num - i) * 3.5;
  1172. // // item['b'] = 2 * item['a'] * (n + p) + 8.8;
  1173. // // item['c'] = item['a'] * (n + p) * (n + p) + m - i * 60;
  1174. // // //武当沟
  1175. // // a = -0.17724;
  1176. // // item['a'] = Math.round((a - 0.002 * (num - i)) * 10000) / 10000;
  1177. // // item['min'] = item['min'] - 40 - (num - i) * 1;
  1178. // // item['max'] = item['max'] - 60 - (num - i) * 0.5;
  1179. // // item['b'] = 2 * item['a'] * (n + p) - 16.5;
  1180. // // item['c'] = item['a'] * (n + p) * (n + p) + m - i * 40;
  1181. // }
  1182. data.push(item);
  1183. }
  1184. console.log(data);
  1185. return data;
  1186. };
  1187. // 大柳塔武当沟
  1188. export const initData = (deviceType?) => {
  1189. const { sysOrgCode } = useGlobSetting();
  1190. // const sysOrgCode = 'sdmtjtdltmk';
  1191. if (sysOrgCode == 'sdmtjtdltmk') {
  1192. // 这里判断白家渠还是五当沟
  1193. return initDataDlt(deviceType);
  1194. } else {
  1195. return initData1();
  1196. }
  1197. };
  1198. // 大柳塔白家渠
  1199. export const initDataDlt = (deviceType?) => {
  1200. if (deviceType == 'fanmain_bjq') {
  1201. const num = 2;
  1202. const obj = {
  1203. angle: 0,
  1204. Hz: -0,
  1205. a: -0.0656,
  1206. b: 17.398283350755946,
  1207. c: 3241.38254718147,
  1208. min: 300,
  1209. max: 1100.0,
  1210. };
  1211. const a = -0.0656,
  1212. m = 17.398283350755946,
  1213. n = 3241.38254718147;
  1214. const maxList = [339.4, 359.4, 379.4, 399.4, 419.4];
  1215. const minList = [143, 152, 161, 170, 180];
  1216. const data = [];
  1217. for (let i = -2; i <= num; i++) {
  1218. const item = cloneDeep(obj);
  1219. item['Hz'] = 0 + i * 3;
  1220. item['c'] = n + 5 * i;
  1221. item['b'] = m + i * 2;
  1222. item['max'] = maxList[i + 2];
  1223. item['min'] = minList[i + 2];
  1224. data.push(item);
  1225. }
  1226. return data;
  1227. } else if (deviceType == 'fanmain_wdg') {
  1228. // 武当沟
  1229. const num = 2;
  1230. const obj = {
  1231. angle: 0,
  1232. Hz: -0,
  1233. a: -0.1424,
  1234. b: 26.316238660115914,
  1235. c: -370.62808803303426,
  1236. min: 300,
  1237. max: 1100.0,
  1238. };
  1239. const a = -0.1424,
  1240. m = 26.086238660115914,
  1241. n = -370.62808803303426;
  1242. const maxList = [138, 148, 158, 168, 178];
  1243. const minList = [90, 95, 100, 105, 110];
  1244. const data = [];
  1245. for (let i = -2; i <= num; i++) {
  1246. const item = cloneDeep(obj);
  1247. item['Hz'] = 0 + i * 3;
  1248. item['c'] = n + 1 * i;
  1249. item['b'] = m + i * 1.3;
  1250. item['max'] = maxList[i + 2];
  1251. item['min'] = minList[i + 2];
  1252. data.push(item);
  1253. }
  1254. return data;
  1255. }
  1256. };
  1257. export const fanInfoData = reactive({
  1258. fj: '一号回风井',
  1259. xh: 'FBCDZ No.29',
  1260. gl: '2×500',
  1261. edgl: '740',
  1262. eddy: '10000',
  1263. eddl: '38.4',
  1264. flfw: '110~260',
  1265. fyfw: '200~4100',
  1266. fbdj: 'ExdI',
  1267. ccrq: '2010.07',
  1268. sccj: '南阳防爆',
  1269. tjfs: '变频调节',
  1270. plfw: '30~50',
  1271. });
  1272. export const fanInfo = [
  1273. {
  1274. title: '风井',
  1275. code: 'fj',
  1276. value: '一号回风井',
  1277. },
  1278. {
  1279. title: '型号',
  1280. code: 'xh',
  1281. value: 'FBCDZ No.29',
  1282. },
  1283. {
  1284. title: '功率(kW)',
  1285. code: 'gl',
  1286. value: '2×500',
  1287. },
  1288. {
  1289. title: '额定转速(r/min)',
  1290. code: 'edgl',
  1291. value: '740',
  1292. },
  1293. {
  1294. title: '额定电压(V)',
  1295. code: 'eddy',
  1296. value: '10000',
  1297. },
  1298. {
  1299. title: '额定电流(A)',
  1300. code: 'eddl',
  1301. value: '38.4',
  1302. },
  1303. {
  1304. title: '风量范围(m³/s)',
  1305. code: 'flfw',
  1306. value: '110~260',
  1307. },
  1308. {
  1309. title: '风压范围(Pa)',
  1310. code: 'fyfw',
  1311. value: '200~4100',
  1312. },
  1313. {
  1314. title: '防爆等级',
  1315. code: 'fbdj',
  1316. value: 'ExdI',
  1317. },
  1318. {
  1319. title: '出厂日期',
  1320. code: 'ccrq',
  1321. value: '2010.07',
  1322. },
  1323. {
  1324. title: '生产厂家',
  1325. code: 'sccj',
  1326. value: '南阳防爆',
  1327. },
  1328. {
  1329. title: '调节方式',
  1330. code: 'tjfs',
  1331. value: '变频调节',
  1332. },
  1333. {
  1334. title: '频率可调范围(Hz)',
  1335. code: 'plfw',
  1336. value: '30~50',
  1337. },
  1338. ];
  1339. export const getSchamas = (): FormSchema[] => {
  1340. return [
  1341. {
  1342. field: 'fj',
  1343. component: 'Input',
  1344. label: '风井',
  1345. colProps: {
  1346. span: 6,
  1347. },
  1348. },
  1349. {
  1350. field: 'xh',
  1351. component: 'Input',
  1352. label: '型号',
  1353. colProps: {
  1354. span: 6,
  1355. },
  1356. },
  1357. {
  1358. field: 'gl',
  1359. component: 'Input',
  1360. label: '功率(kW)',
  1361. colProps: {
  1362. span: 6,
  1363. },
  1364. },
  1365. {
  1366. field: 'edgl',
  1367. component: 'Input',
  1368. label: '额定转速(r/min)',
  1369. colProps: {
  1370. span: 6,
  1371. },
  1372. },
  1373. {
  1374. field: 'eddy',
  1375. component: 'Input',
  1376. label: '额定电压(V)',
  1377. colProps: {
  1378. span: 6,
  1379. },
  1380. },
  1381. {
  1382. field: 'eddl',
  1383. component: 'Input',
  1384. label: '额定电流(A)',
  1385. colProps: {
  1386. span: 6,
  1387. },
  1388. },
  1389. {
  1390. field: 'flfw',
  1391. component: 'Input',
  1392. label: '风量范围(m³/s)',
  1393. colProps: {
  1394. span: 6,
  1395. },
  1396. },
  1397. {
  1398. field: 'fyfw',
  1399. component: 'Input',
  1400. label: '风压范围(Pa)',
  1401. colProps: {
  1402. span: 6,
  1403. },
  1404. },
  1405. {
  1406. field: 'fbdj',
  1407. component: 'Select',
  1408. label: '防爆等级',
  1409. colProps: {
  1410. span: 6,
  1411. },
  1412. componentProps: {
  1413. options: [
  1414. {
  1415. label: 'ExdI',
  1416. value: 'ExdI',
  1417. key: '1',
  1418. },
  1419. ],
  1420. },
  1421. },
  1422. {
  1423. field: 'ccrq',
  1424. component: 'Input',
  1425. label: '出厂日期',
  1426. colProps: {
  1427. span: 6,
  1428. },
  1429. },
  1430. {
  1431. field: 'sccj',
  1432. component: 'Input',
  1433. label: '生产厂家',
  1434. colProps: {
  1435. span: 6,
  1436. },
  1437. },
  1438. {
  1439. field: 'tjfs',
  1440. component: 'Select',
  1441. label: '调节方式',
  1442. colProps: {
  1443. span: 6,
  1444. },
  1445. componentProps: {
  1446. options: [
  1447. {
  1448. label: '变频调节',
  1449. value: '变频调节',
  1450. key: '1',
  1451. },
  1452. ],
  1453. },
  1454. },
  1455. {
  1456. field: 'plfw',
  1457. component: 'Input',
  1458. label: '频率可调范围(Hz)',
  1459. colProps: {
  1460. span: 6,
  1461. },
  1462. },
  1463. ];
  1464. };
  1465. export const getSchamas1 = (): FormSchema[] => {
  1466. return [
  1467. {
  1468. field: 'Hz',
  1469. component: 'InputNumber',
  1470. label: '频率(Hz)',
  1471. required: true,
  1472. colProps: {
  1473. span: 6,
  1474. },
  1475. },
  1476. {
  1477. field: 'a',
  1478. component: 'InputNumber',
  1479. label: '二次项系数',
  1480. required: true,
  1481. colProps: {
  1482. span: 6,
  1483. },
  1484. },
  1485. {
  1486. field: 'b',
  1487. component: 'InputNumber',
  1488. label: '一次项系数',
  1489. required: true,
  1490. colProps: {
  1491. span: 6,
  1492. },
  1493. },
  1494. {
  1495. field: 'c',
  1496. component: 'InputNumber',
  1497. label: '常数项系数',
  1498. required: true,
  1499. colProps: {
  1500. span: 6,
  1501. },
  1502. },
  1503. {
  1504. field: 'min',
  1505. component: 'InputNumber',
  1506. label: '风量下限(m³/s)',
  1507. required: true,
  1508. colProps: {
  1509. span: 6,
  1510. },
  1511. },
  1512. {
  1513. field: 'max',
  1514. component: 'InputNumber',
  1515. label: '风量上限(m³/s)',
  1516. required: true,
  1517. colProps: {
  1518. span: 6,
  1519. },
  1520. },
  1521. ];
  1522. };
  1523. export const lineFormData = reactive({
  1524. Hz: null,
  1525. a: null,
  1526. b: null,
  1527. c: null,
  1528. min: null,
  1529. max: null,
  1530. });