index.vue 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px">
  4. <el-form-item label="装置" prop="plantId">
  5. <el-select v-model="queryParams.plantId" @change="handleQuery,getAllRegion(queryParams.plantId)"
  6. placeholder="请选择装置" clearable size="small">
  7. <el-option
  8. v-for="plant in plantOperation"
  9. :key="plant.plantId"
  10. :label="plant.plantName"
  11. :value="plant.plantId"
  12. />
  13. </el-select>
  14. </el-form-item>
  15. <el-form-item label="区域" prop="regionId">
  16. <el-select v-model="queryParams.regionId" @change="handleQuery,getAllDeviceByRegionId(queryParams.regionId)"
  17. placeholder="请选择区域" clearable size="small">
  18. <el-option
  19. v-for="dict in regionOperation"
  20. :key="dict.regionId"
  21. :label="dict.regionName"
  22. :value="dict.regionId"
  23. />
  24. </el-select>
  25. </el-form-item>
  26. <el-form-item label="设备" prop="devId">
  27. <el-select v-model="queryParams.devId" @change="handleQuery" placeholder="请选择设备" clearable size="small">
  28. <el-option
  29. v-for="dict in deviceOperation"
  30. :key="dict.devId"
  31. :label="dict.devDescribe"
  32. :value="dict.devId"
  33. />
  34. </el-select>
  35. </el-form-item>
  36. <el-form-item label="群组编码" prop="groupCode">
  37. <el-input
  38. v-model="queryParams.groupCode"
  39. placeholder="请输入群组编码"
  40. clearable
  41. @keyup.enter.native="handleQuery"
  42. />
  43. </el-form-item>
  44. <el-form-item label="介质" prop="medium">
  45. <el-input
  46. v-model="queryParams.medium"
  47. placeholder="请输入介质"
  48. clearable
  49. @keyup.enter.native="handleQuery"
  50. />
  51. </el-form-item>
  52. <el-form-item label="泄漏程度" prop="leakageDegree">
  53. <el-select v-model="queryParams.leakageDegree" @change="handleQuery" placeholder="请选择泄漏程度" clearable
  54. size="small">
  55. <el-option
  56. v-for="dict in leakageDegreeOperation"
  57. :key="dict.dictValue"
  58. :label="dict.dictLabel"
  59. :value="dict.dictValue"
  60. />
  61. </el-select>
  62. </el-form-item>
  63. <el-form-item label="是/否不可达点" prop="unarrive">
  64. <el-select v-model="queryParams.unarrive" @change="handleQuery" placeholder="请选择是/否" clearable
  65. size="small">
  66. <el-option
  67. v-for="dict in yesOrNoOperation"
  68. :key="dict.dictValue"
  69. :label="dict.dictLabel"
  70. :value="dict.dictValue"
  71. />
  72. </el-select>
  73. </el-form-item>
  74. <el-form-item label="密封点类型" prop="pointType">
  75. <el-select v-model="queryParams.pointType" @change="handleQuery" placeholder="请选择密封点类型" clearable
  76. size="small">
  77. <el-option
  78. v-for="dict in pointOptions"
  79. :key="dict.dictValue"
  80. :label="dict.dictLabel"
  81. :value="dict.dictValue"
  82. />
  83. </el-select>
  84. </el-form-item>
  85. <el-form-item label="审核状态" prop="approveStatus">
  86. <el-select v-model="queryParams.approveStatus" @change="handleQuery" placeholder="请选择审核状态" clearable
  87. size="small">
  88. <el-option
  89. v-for="dict in approveStatusOperation"
  90. :key="dict.dictValue"
  91. :label="dict.dictLabel"
  92. :value="dict.dictValue"
  93. />
  94. </el-select>
  95. </el-form-item>
  96. <el-form-item>
  97. <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  98. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  99. </el-form-item>
  100. </el-form>
  101. <el-row :gutter="10" class="mb8">
  102. <el-col :span="1.5">
  103. <el-button
  104. type="primary"
  105. plain
  106. icon="el-icon-plus"
  107. size="mini"
  108. @click="handleAdd"
  109. v-hasPermi="['base:point:add']"
  110. >新增
  111. </el-button>
  112. </el-col>
  113. <el-col :span="1.5">
  114. <el-button
  115. type="success"
  116. plain
  117. icon="el-icon-edit"
  118. size="mini"
  119. :disabled="single"
  120. @click="handleUpdate"
  121. v-hasPermi="['base:point:edit']"
  122. >修改
  123. </el-button>
  124. </el-col>
  125. <el-col :span="1.5">
  126. <el-button
  127. type="danger"
  128. plain
  129. icon="el-icon-delete"
  130. size="mini"
  131. :disabled="multiple"
  132. @click="handleDelete"
  133. v-hasPermi="['base:point:remove']"
  134. >删除
  135. </el-button>
  136. </el-col>
  137. <el-col :span="1.5">
  138. <el-button
  139. type="warning"
  140. plain
  141. icon="el-icon-upload2"
  142. size="mini"
  143. @click="handleImport"
  144. v-hasPermi="['base:device:add']"
  145. >导入
  146. </el-button>
  147. </el-col>
  148. <el-col :span="1.5">
  149. <el-button
  150. type="warning"
  151. plain
  152. icon="el-icon-download"
  153. size="mini"
  154. @click="handleExport"
  155. v-hasPermi="['base:point:export']"
  156. >导出
  157. </el-button>
  158. </el-col>
  159. <el-col :span="1.5">
  160. <el-button
  161. type="info"
  162. plain
  163. icon="el-icon-position"
  164. size="mini"
  165. :disabled="multiple"
  166. @click="handleToApprove"
  167. >送审
  168. </el-button>
  169. </el-col>
  170. <el-col :span="1.5">
  171. <el-button
  172. type="info"
  173. plain
  174. icon="el-icon-position"
  175. size="mini"
  176. @click="handleApproveAll(1)"
  177. >全部送审
  178. </el-button>
  179. </el-col>
  180. <el-col :span="1.5">
  181. <el-button
  182. type="info"
  183. plain
  184. icon="el-icon-s-check"
  185. size="mini"
  186. :disabled="multiple"
  187. @click="handleApprove"
  188. v-hasPermi="['base:point:approve']"
  189. >审核
  190. </el-button>
  191. </el-col>
  192. <el-col :span="1.5">
  193. <el-button
  194. type="info"
  195. plain
  196. icon="el-icon-s-check"
  197. size="mini"
  198. @click="handleApproveAll(2)"
  199. v-hasPermi="['base:point:approve']"
  200. >全部审核
  201. </el-button>
  202. </el-col>
  203. <el-col :span="1.5">
  204. <el-button
  205. type="success"
  206. plain
  207. icon="el-icon-upload"
  208. size="mini"
  209. @click="habdleUpdload('上传PID图',1)"
  210. >上传PID图
  211. </el-button>
  212. </el-col>
  213. <el-col :span="1.5">
  214. <el-button
  215. type="success"
  216. plain
  217. icon="el-icon-upload"
  218. size="mini"
  219. @click="habdleUpdload('上传组件照片',0)"
  220. >上传组件照片
  221. </el-button>
  222. </el-col>
  223. <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
  224. </el-row>
  225. <el-table v-loading="loading" :data="pointList" :cell-style="tableCellStyle"
  226. @selection-change="handleSelectionChange" :height="clientHeight" border>
  227. <el-table-column type="selection" width="55" align="center"/>
  228. <el-table-column label="检测净值(ppm)" align="center" prop="netTestValue" width="110"
  229. :show-overflow-tooltip="true"/>
  230. <el-table-column label="泄漏程度" align="center" prop="leakageDegree" :formatter="leakageFormat"
  231. :show-overflow-tooltip="true"/>
  232. <el-table-column label="装置名称" align="center" prop="plantName" :show-overflow-tooltip="true"/>
  233. <el-table-column label="装置编码" align="center" prop="plantCode" :show-overflow-tooltip="true"/>
  234. <el-table-column label="装置类别" align="center" prop="plantType" :formatter="plantTypeFormat"/>
  235. <el-table-column label="区域名称" align="center" prop="regionName" :show-overflow-tooltip="true"/>
  236. <el-table-column label="区域编码" align="center" prop="regionCode" :show-overflow-tooltip="true"/>
  237. <el-table-column label="设备/管线名称" align="center" prop="devName" width="150" :show-overflow-tooltip="true"/>
  238. <el-table-column label="设备/管线编码" align="center" prop="devCode" width="150" :show-overflow-tooltip="true"/>
  239. <el-table-column label="介质" align="center" prop="medium" :show-overflow-tooltip="true"/>
  240. <el-table-column label="介质状态" align="center" prop="mediumType" :formatter="mediumTypeFormat"
  241. :show-overflow-tooltip="true"/>
  242. <el-table-column label="密封点类型" align="center" prop="pointType" width="100" :formatter="pointFormat"
  243. :show-overflow-tooltip="true"/>
  244. <el-table-column label="平台(层)" align="center" prop="layer" :show-overflow-tooltip="true"/>
  245. <el-table-column label="群组位置" align="center" prop="groupPosition" :show-overflow-tooltip="true"/>
  246. <el-table-column label="密封点位置" align="center" prop="pointPosition" width="110"
  247. :show-overflow-tooltip="true"/>
  248. <el-table-column label="群组编码" align="center" prop="groupCode" :show-overflow-tooltip="true"/>
  249. <el-table-column label="扩展编码" align="center" prop="extendCode" :show-overflow-tooltip="true"/>
  250. <el-table-column label="密封点子类型" align="center" prop="subPointType" width="110"
  251. :show-overflow-tooltip="true"/>
  252. <el-table-column label="公称直径(mm)" align="center" prop="dia" width="110" :show-overflow-tooltip="true"/>
  253. <el-table-column label="是否不可达点" align="center" prop="unarrive" width="110" :formatter="unarriveFormat"
  254. :show-overflow-tooltip="true"/>
  255. <el-table-column label="不可达原因" align="center" prop="unarriveReason" width="110"
  256. :show-overflow-tooltip="true"/>
  257. <el-table-column label="是否保温/保冷" align="center" prop="keepWarm" width="110" :formatter="keepWarmFormat"
  258. :show-overflow-tooltip="true"/>
  259. <el-table-column label="工艺温度(℃)" align="center" prop="temperature" width="110" :show-overflow-tooltip="true"/>
  260. <el-table-column label="工艺压力(Mpa)" align="center" prop="pressure" width="110" :show-overflow-tooltip="true"/>
  261. <el-table-column label="运行时间" align="center" prop="runTime" width="180">
  262. <template slot-scope="scope">
  263. <span>{{ parseTime(scope.row.runTime, '{y}-{m}-{d}') }}</span>
  264. </template>
  265. </el-table-column>
  266. <el-table-column label="PID图号" align="center" prop="pidNo" :show-overflow-tooltip="true">
  267. <template slot-scope="scope">
  268. <el-button
  269. v-if="scope.row.pidUrl"
  270. size="mini"
  271. type="text"
  272. icon="el-icon-view"
  273. @click="handleSee(scope.row,true)"
  274. >{{ $t('预览') }}
  275. </el-button>
  276. </template>
  277. </el-table-column>
  278. <el-table-column label="群组照片号" align="center" prop="picNo" width="110" :show-overflow-tooltip="true">
  279. <template slot-scope="scope">
  280. <el-button
  281. v-if="scope.row.picUrl"
  282. size="mini"
  283. type="text"
  284. icon="el-icon-view"
  285. @click="handleSee(scope.row,false)"
  286. >{{ $t('预览') }}
  287. </el-button>
  288. </template>
  289. </el-table-column>
  290. <el-table-column label="TOC质量分数" align="center" prop="tocMark" width="110" :show-overflow-tooltip="true"/>
  291. <el-table-column label="甲烷质量分数" align="center" prop="methaneMark" width="110"
  292. :show-overflow-tooltip="true"/>
  293. <el-table-column label="VOCs质量分数" align="center" prop="vocsMark" width="110" :show-overflow-tooltip="true"/>
  294. <el-table-column label="审核状态" align="center" fixed="left" prop="approveStatus"
  295. :formatter="approveStatusFormat" :show-overflow-tooltip="true"/>
  296. <el-table-column label="最后维护人" align="center" prop="updater" width="110" :show-overflow-tooltip="true"/>
  297. <el-table-column label="最后维护时间" align="center" prop="updatedate" width="180" :show-overflow-tooltip="true">
  298. <template slot-scope="scope">
  299. <span>{{ parseTime(scope.row.updatedate, '{y}-{m}-{d}') }}</span>
  300. </template>
  301. </el-table-column>
  302. <el-table-column label="描述" align="center" prop="remarks" width="180" :show-overflow-tooltip="true"/>
  303. <el-table-column label="操作" align="center" width="160px" fixed="right" class-name="small-padding fixed-width">
  304. <template slot-scope="scope">
  305. <el-button
  306. size="mini"
  307. type="text"
  308. icon="el-icon-edit"
  309. @click="handleUpdate(scope.row)"
  310. v-hasPermi="['base:point:edit']"
  311. >修改
  312. </el-button>
  313. <el-button
  314. size="mini"
  315. type="text"
  316. icon="el-icon-delete"
  317. @click="handleDelete(scope.row)"
  318. v-hasPermi="['base:point:remove']"
  319. >删除
  320. </el-button>
  321. <el-button
  322. size="mini"
  323. type="text"
  324. icon="el-icon-tickets"
  325. @click="openDetail(scope.row)"
  326. >详情
  327. </el-button>
  328. </template>
  329. </el-table-column>
  330. </el-table>
  331. <pagination
  332. v-show="total>0"
  333. :total="total"
  334. :page.sync="queryParams.pageNum"
  335. :limit.sync="queryParams.pageSize"
  336. @pagination="getList"
  337. />
  338. <!-- 添加或修改密封点对话框 -->
  339. <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body :before-close="cleanRegion">
  340. <el-form ref="form" :model="form" :rules="rules" label-width="120px">
  341. <el-row>
  342. <el-col :span="12">
  343. <el-form-item label="装置" prop="plantId">
  344. <el-select v-model="form.plantId" placeholder="请选择装置" clearable size="small" style="width: 100%"
  345. @change="getAllRegion(form.plantId)">
  346. <el-option
  347. v-for="dict in plantOperation"
  348. :key="dict.plantId"
  349. :label="dict.plantName"
  350. :value="dict.plantId"
  351. />
  352. </el-select>
  353. </el-form-item>
  354. </el-col>
  355. <el-col :span="12">
  356. <el-form-item label="区域" prop="regionId">
  357. <el-select v-model="form.regionId" placeholder="请选择区域" clearable size="small" style="width: 100%"
  358. @change="getAllDeviceByRegionId(form.regionId)">
  359. <el-option
  360. v-for="dict in regionOperation"
  361. :key="dict.regionId"
  362. :label="dict.regionName"
  363. :value="dict.regionId"
  364. />
  365. </el-select>
  366. </el-form-item>
  367. </el-col>
  368. </el-row>
  369. <el-row>
  370. <el-col :span="12">
  371. <el-form-item label="设备" prop="devId">
  372. <el-select v-model="form.devId" placeholder="请选择设备" clearable size="small" style="width: 100%">
  373. <el-option
  374. v-for="dict in deviceOperation"
  375. :key="dict.devId"
  376. :label="dict.devDescribe"
  377. :value="dict.devId"
  378. />
  379. </el-select>
  380. </el-form-item>
  381. </el-col>
  382. <el-col :span="12">
  383. <el-form-item label="介质状态" prop="mediumType">
  384. <el-select v-model="form.mediumType" placeholder="请选择介质状态" clearable size="small"
  385. style="width: 100%">
  386. <el-option
  387. v-for="dict in mediumTypeOptions"
  388. :key="dict.dictValue"
  389. :label="dict.dictLabel"
  390. :value="dict.dictValue"
  391. />
  392. </el-select>
  393. </el-form-item>
  394. </el-col>
  395. </el-row>
  396. <el-row>
  397. <el-col :span="12">
  398. <el-form-item label="密封点类型" prop="pointType">
  399. <el-select v-model="form.pointType" placeholder="请选择密封点类型" clearable size="small"
  400. style="width: 100%">
  401. <el-option
  402. v-for="dict in pointOptions"
  403. :key="dict.dictValue"
  404. :label="dict.dictLabel"
  405. :value="dict.dictValue"
  406. />
  407. </el-select>
  408. </el-form-item>
  409. </el-col>
  410. <el-col :span="12">
  411. <el-form-item label="介质" prop="medium">
  412. <el-input v-model="form.medium" placeholder="请输入介质"/>
  413. </el-form-item>
  414. </el-col>
  415. </el-row>
  416. <el-row>
  417. <el-col :span="12">
  418. <el-form-item label="公称直径(mm)" prop="dia">
  419. <el-input v-model="form.dia" placeholder="请输入公称直径(mm)"/>
  420. </el-form-item>
  421. </el-col>
  422. <el-col :span="12">
  423. <el-form-item label="密封点子类型" prop="subPointType">
  424. <el-input v-model="form.subPointType" placeholder="请输入密封点子类型"/>
  425. </el-form-item>
  426. </el-col>
  427. </el-row>
  428. <el-row>
  429. <el-col :span="12">
  430. <el-form-item label="平台(层)" prop="layer">
  431. <el-input v-model="form.layer" placeholder="请输入平台"/>
  432. </el-form-item>
  433. </el-col>
  434. <el-col :span="12">
  435. <el-form-item label="群组位置" prop="groupPosition">
  436. <el-input v-model="form.groupPosition" placeholder="请输入群组位置"/>
  437. </el-form-item>
  438. </el-col>
  439. </el-row>
  440. <el-row>
  441. <el-col :span="12">
  442. <el-form-item label="群组编码" prop="groupCode">
  443. <el-input v-model="form.groupCode" placeholder="请输入群组编码"/>
  444. </el-form-item>
  445. </el-col>
  446. <el-col :span="12">
  447. <el-form-item label="扩展编码" prop="extendCode">
  448. <el-input v-model="form.extendCode" placeholder="请输入扩展编码"/>
  449. </el-form-item>
  450. </el-col>
  451. </el-row>
  452. <el-row>
  453. <el-col :span="12">
  454. <el-form-item label="密封点位置" prop="pointPosition">
  455. <el-input v-model="form.pointPosition" placeholder="请输入密封点位置"/>
  456. </el-form-item>
  457. </el-col>
  458. <el-col :span="12">
  459. <el-form-item label="VOCs质量分数" prop="vocsMark">
  460. <el-input v-model="form.vocsMark" placeholder="请输入VOCs质量分数"/>
  461. </el-form-item>
  462. </el-col>
  463. </el-row>
  464. <el-row>
  465. <el-col :span="12">
  466. <el-form-item label="是/否不可达点" prop="unarrive">
  467. <el-select v-model="form.unarrive" placeholder="请选择是/否" clearable size="small" style="width: 100%">
  468. <el-option
  469. v-for="dict in yesOrNoOperation"
  470. :key="dict.dictValue"
  471. :label="dict.dictLabel"
  472. :value="dict.dictValue"
  473. />
  474. </el-select>
  475. </el-form-item>
  476. </el-col>
  477. <el-col :span="12">
  478. <el-form-item label="不可达原因" prop="unarriveReason">
  479. <el-input v-model="form.unarriveReason" placeholder="请输入不可达原因"/>
  480. </el-form-item>
  481. </el-col>
  482. </el-row>
  483. <el-row>
  484. <el-col :span="12">
  485. <el-form-item label="是否保温/保冷" prop="keepWarm">
  486. <el-select v-model="form.keepWarm" placeholder="请选择是/否" clearable size="small" style="width: 100%">
  487. <el-option
  488. v-for="dict in yesOrNoOperation"
  489. :key="dict.dictValue"
  490. :label="dict.dictLabel"
  491. :value="dict.dictValue"
  492. />
  493. </el-select>
  494. </el-form-item>
  495. </el-col>
  496. <el-col :span="12">
  497. <el-form-item label="工艺温度" prop="temperature">
  498. <el-input v-model="form.temperature" placeholder="请输入工艺温度"/>
  499. </el-form-item>
  500. </el-col>
  501. </el-row>
  502. <el-row>
  503. <el-col :span="12">
  504. <el-form-item label="工艺压力" prop="pressure">
  505. <el-input v-model="form.pressure" placeholder="请输入工艺压力"/>
  506. </el-form-item>
  507. </el-col>
  508. <el-col :span="12">
  509. <el-form-item label="运行时间" prop="runTime">
  510. <el-date-picker clearable
  511. v-model="form.runTime"
  512. type="date"
  513. value-format="yyyy-MM-dd"
  514. placeholder="请选择运行时间"
  515. style="width: 100%">
  516. </el-date-picker>
  517. </el-form-item>
  518. </el-col>
  519. </el-row>
  520. <el-row>
  521. <el-col :span="12">
  522. <el-form-item label="PID图号" prop="pidNo">
  523. <el-input v-model="form.pidNo" placeholder="请输入PID图号"/>
  524. </el-form-item>
  525. </el-col>
  526. <el-col :span="12">
  527. <el-form-item label="群组照片号" prop="picNo">
  528. <el-input v-model="form.picNo" placeholder="请输入群组照片号"/>
  529. </el-form-item>
  530. </el-col>
  531. </el-row>
  532. <el-row>
  533. <el-col :span="12">
  534. <el-form-item label="TOC质量分数" prop="tocMark">
  535. <el-input v-model="form.tocMark" placeholder="请输入TOC质量分数"/>
  536. </el-form-item>
  537. </el-col>
  538. <el-col :span="12">
  539. <el-form-item label="甲烷质量分数" prop="methaneMark">
  540. <el-input v-model="form.methaneMark" placeholder="请输入甲烷质量分数"/>
  541. </el-form-item>
  542. </el-col>
  543. </el-row>
  544. <el-row>
  545. <el-col :span="24">
  546. <el-form-item label="描述" prop="remarks">
  547. <el-input v-model="form.remarks" placeholder="请输入描述"/>
  548. </el-form-item>
  549. </el-col>
  550. </el-row>
  551. </el-form>
  552. <div slot="footer" class="dialog-footer">
  553. <el-button type="primary" @click="submitForm">确 定</el-button>
  554. <el-button @click="cancel">取 消</el-button>
  555. </div>
  556. </el-dialog>
  557. <!-- 用户导入对话框 -->
  558. <el-dialog v-dialogDrag :title="upload.title" :visible.sync="upload.open" width="400px" append-to-body>
  559. <el-upload
  560. ref="upload"
  561. :limit="1"
  562. accept=".xlsx, .xls"
  563. :headers="upload.headers"
  564. :action="upload.url"
  565. :disabled="upload.isUploading"
  566. :on-progress="handleFileUploadProgress"
  567. :on-success="handleFileSuccess"
  568. :auto-upload="false"
  569. drag
  570. >
  571. <i class="el-icon-upload"></i>
  572. <div class="el-upload__text">
  573. {{ $t('将文件拖到此处,或') }}
  574. <em>{{ $t('点击上传') }}</em>
  575. </div>
  576. <div class="el-upload__tip" slot="tip">
  577. <!--<el-checkbox v-model="upload.updateSupport" />是否更新已经存在的用户数据-->
  578. <el-link type="info" style="font-size:12px" @click="importTemplate">{{ $t('下载模板') }}</el-link>
  579. </div>
  580. <form ref="downloadFileForm" :action="upload.downloadAction" target="FORMSUBMIT">
  581. <input name="type" :value="upload.type" hidden/>
  582. </form>
  583. <div class="el-upload__tip" style="color:red" slot="tip">{{ $t('提示:仅允许导入“xls”或“xlsx”格式文件!') }}</div>
  584. </el-upload>
  585. <div slot="footer" class="dialog-footer">
  586. <el-button type="primary" @click="submitFileForm" v-loading.fullscreen.lock="fullscreenLoading">{{
  587. $t('确 定')
  588. }}
  589. </el-button>
  590. <el-button @click="upload.open = false">{{ $t('取 消') }}</el-button>
  591. </div>
  592. </el-dialog>
  593. <el-dialog v-dialogDrag :title="doc.title" :visible.sync="doc.open" width="400px" append-to-body>
  594. <el-upload
  595. ref="doc"
  596. :headers="doc.headers"
  597. :action="doc.url"
  598. :disabled="doc.isUploading"
  599. :on-progress="handleFileDocProgress"
  600. :on-success="handleFileDocSuccess"
  601. :auto-upload="true"
  602. accept=".jpg,.png"
  603. :limit="1"
  604. :on-exceed="handleExceed"
  605. :multiple="false"
  606. :file-list="fileList"
  607. list-type="picture"
  608. drag
  609. >
  610. <i class="el-icon-upload"></i>
  611. <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
  612. <div slot="tip" class="el-upload__tip">文件大小建议不超过5Mb</div>
  613. </el-upload>
  614. </el-dialog>
  615. <el-dialog v-dialogDrag :title="pic.title" :visible.sync="pic.open" width="500px" append-to-body>
  616. <div>
  617. <el-image
  618. style="width: 200px; height: 200px;margin:10px;border-radius: 5%"
  619. :key="pic.picUrl"
  620. :src="pic.picUrl"
  621. :preview-src-list="pic.picList"
  622. fit="cover"/>
  623. </div>
  624. </el-dialog>
  625. <point-detail v-if="detailVisible" ref="pointDetail"></point-detail>
  626. </div>
  627. </template>
  628. <script>
  629. import {
  630. listPoint,
  631. getPoint,
  632. delPoint,
  633. addPoint,
  634. updatePoint,
  635. handleApprove,
  636. handleApproveAll,
  637. handleUpload
  638. } from "@/api/base/point";
  639. import {getAllPlantName} from "@/api/base/plant";
  640. import {getAllRegion} from "@/api/base/region";
  641. import {getAllDeviceByRegionId} from "@/api/base/device";
  642. import {MessageBox} from "element-ui";
  643. import {getToken} from "@/utils/auth";
  644. import PointDetail from "@/views/base/point/pointDetail";
  645. import {deepClone} from "@/utils";
  646. export default {
  647. name: "Point",
  648. components: {PointDetail},
  649. data() {
  650. return {
  651. pic: {
  652. title: '图片预览',
  653. picUrl: '',
  654. numPages: null,
  655. open: false,
  656. pageNum: 1,
  657. pageTotalNum: 1,
  658. loadedRatio: 0,
  659. picList: [],
  660. },
  661. detailVisible: false,
  662. fullscreenLoading: false,
  663. // 用户导入参数
  664. upload: {
  665. downloadAction: process.env.VUE_APP_BASE_API + '/common/template',
  666. //下载模板类型
  667. type: "basePoint",
  668. // 是否显示弹出层(用户导入)
  669. open: false,
  670. // 弹出层标题(用户导入)
  671. title: "",
  672. // 是否禁用上传
  673. isUploading: false,
  674. // 是否更新已经存在的用户数据
  675. updateSupport: 0,
  676. // 设置上传的请求头部
  677. headers: {Authorization: "Bearer " + getToken()},
  678. // 上传的地址
  679. url: process.env.VUE_APP_BASE_API + "/base/point/importData"
  680. },
  681. doc: {
  682. file: "",
  683. // 是否显示弹出层(报告附件)
  684. open: false,
  685. // 弹出层标题(报告附件)
  686. title: "",
  687. // 是否禁用上传
  688. isUploading: false,
  689. // 是否更新已经存在的用户数据
  690. updateSupport: 0,
  691. // 报告附件上传位置编号
  692. ids: 0,
  693. // 设置上传的请求头部
  694. headers: {Authorization: "Bearer " + getToken()},
  695. // 上传的地址
  696. url: process.env.VUE_APP_BASE_API + "/base/point/uploadFile",
  697. },
  698. plantOperation: [],
  699. regionOperation: [],
  700. deviceOperation: [],
  701. plantTypeOptions: [],
  702. leakageDegreeOperation: [],
  703. // 遮罩层
  704. loading: true,
  705. // 选中数组
  706. ids: [],
  707. status: [],
  708. // 非单个禁用
  709. single: true,
  710. // 非多个禁用
  711. multiple: true,
  712. clientHeight: 300,
  713. // 显示搜索条件
  714. showSearch: false,
  715. yesOrNoOperation: [],
  716. pointOptions: [],
  717. mediumTypeOptions: [],
  718. fileList: [],
  719. approveStatusOperation: [],
  720. // 总条数
  721. total: 0,
  722. // 密封点表格数据
  723. pointList: [],
  724. // 弹出层标题
  725. title: "",
  726. // 是否显示弹出层
  727. open: false,
  728. pidFlag: 0,
  729. // 查询参数
  730. queryParams: {
  731. pageNum: 1,
  732. pageSize: 10,
  733. netTestValue: null,
  734. leakageDegree: null,
  735. plantId: null,
  736. regionId: null,
  737. devId: null,
  738. medium: null,
  739. mediumType: null,
  740. pointType: null,
  741. layer: null,
  742. groupPosition: null,
  743. pointPosition: null,
  744. groupCode: null,
  745. extendCode: null,
  746. subPointType: null,
  747. dia: null,
  748. unarrive: null,
  749. unarriveReason: null,
  750. keepWarm: null,
  751. temperature: null,
  752. pressure: null,
  753. runTime: null,
  754. pidNo: null,
  755. pidUrl: null,
  756. picNo: null,
  757. picUrl: null,
  758. tocMark: null,
  759. methaneMark: null,
  760. vocsMark: null,
  761. remarks: null,
  762. approveStatus: null,
  763. approveTime: null,
  764. deptId: null,
  765. createrCode: null,
  766. createdate: null,
  767. updaterCode: null,
  768. updatedate: null
  769. },
  770. // 表单参数
  771. form: {},
  772. // 表单校验
  773. rules: {
  774. plantId: [
  775. {required: true, message: this.$t('请选择') + this.$t('装置'), trigger: "blur"}
  776. ],
  777. regionId: [
  778. {required: true, message: this.$t('请选择') + this.$t('区域'), trigger: "blur"}
  779. ],
  780. devId: [
  781. {required: true, message: this.$t('请选择') + this.$t('设备'), trigger: "blur"}
  782. ],
  783. groupCode: [
  784. {required: true, message: this.$t('群组编码') + this.$t('不能为空'), trigger: "blur"}
  785. ],
  786. extendCode: [
  787. {required: true, message: this.$t('密封点扩展号编码') + this.$t('不能为空'), trigger: "blur"}
  788. ],
  789. pointType: [
  790. {required: true, message: this.$t('请选择') + this.$t('密封点类型'), trigger: "blur"}
  791. ],
  792. unarrive: [
  793. {required: true, message: this.$t('请选择') + this.$t('是否不可达点'), trigger: "blur"}
  794. ],
  795. mediumType: [
  796. {required: true, message: this.$t('请选择') + this.$t('介质状态'), trigger: "blur"}
  797. ],
  798. }
  799. };
  800. },
  801. created() {
  802. this.getDicts("plant_type").then(response => {
  803. this.plantTypeOptions = response.data;
  804. });
  805. //设置表格高度对应屏幕高度
  806. this.$nextTick(() => {
  807. this.clientHeight = (document.body.clientHeight - 80) * 0.8
  808. });
  809. this.getDicts("yes_no").then(response => {
  810. this.yesOrNoOperation = response.data;
  811. });
  812. this.getDicts("base_approve_status").then(response => {
  813. this.approveStatusOperation = response.data;
  814. });
  815. this.getDicts("leakage_degree").then(response => {
  816. this.leakageDegreeOperation = response.data;
  817. });
  818. this.getDicts("point_type").then(response => {
  819. this.pointOptions = response.data;
  820. });
  821. this.getDicts("medium_type").then(response => {
  822. this.mediumTypeOptions = response.data;
  823. });
  824. this.getList();
  825. getAllPlantName().then(response => {
  826. this.plantOperation = response.data;
  827. })
  828. },
  829. methods: {
  830. handleSee(row, flag) {
  831. this.pic.picList = []
  832. this.pic.open = true
  833. if (flag) {
  834. this.pic.title = row.pidNo
  835. this.pic.picUrl = process.env.VUE_APP_BASE_API + row.pidUrl;
  836. } else {
  837. this.pic.title = row.picNo
  838. this.pic.picUrl = process.env.VUE_APP_BASE_API + row.picUrl;
  839. }
  840. this.pic.picList.push(this.pic.picUrl)
  841. },
  842. //附件上传中处理
  843. handleFileDocProgress(event, file, fileList) {
  844. this.doc.file = file;
  845. },
  846. //附件上传成功处理
  847. handleFileDocSuccess(response, file, fileList) {
  848. let data = {};
  849. if (this.pidFlag == 1)
  850. data.pidUrl = response.msg;
  851. else
  852. data.picUrl = response.msg;
  853. data.fileName = file.name;
  854. data.pidFlag = this.pidFlag;
  855. console.log(data)
  856. handleUpload(data).then(() => {
  857. this.getList();
  858. })
  859. this.fileList = [];
  860. this.doc.open = false;
  861. },
  862. handleExceed(files, fileList) {
  863. this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
  864. },
  865. openDetail(row) {
  866. this.detailVisible = true;
  867. row.mediumTypeOptions = this.mediumTypeOptions;
  868. row.plantOperation = this.plantOperation;
  869. this.$nextTick(() => {
  870. this.$refs.pointDetail.init(row);
  871. })
  872. },
  873. // 提交上传文件
  874. submitFileForm() {
  875. this.$refs.upload.submit();
  876. this.fullscreenLoading = true;
  877. },
  878. /** 导入按钮操作 */
  879. handleImport() {
  880. this.upload.title = this.$t('用户导入');
  881. this.upload.open = true;
  882. },
  883. /** 下载模板操作 */
  884. importTemplate() {
  885. this.$refs['downloadFileForm'].submit()
  886. },
  887. // 文件上传中处理
  888. handleFileUploadProgress(event, file, fileList) {
  889. this.upload.isUploading = true;
  890. },
  891. // 文件上传成功处理
  892. handleFileSuccess(response, file, fileList) {
  893. this.upload.open = false;
  894. this.upload.isUploading = false;
  895. this.$refs.upload.clearFiles();
  896. this.fullscreenLoading = false;
  897. console.log(response)
  898. if (response.data === 0) {
  899. this.$alert(this.$t('导入失败!') + response.msg, this.$t('导入结果'), {dangerouslyUseHTMLString: true});
  900. } else if (response.data[0] != null) {
  901. this.$alert(this.$t('成功导入') + response.msg + this.$t('条数据') + "," + this.$t('第') + response.data + this.$t('行数据出现错误导入失败') + "。", this.$t('导入结果'), {dangerouslyUseHTMLString: true});
  902. } else {
  903. this.$alert(this.$t('成功导入') + response.msg + this.$t('条数据'), this.$t('导入结果'), {dangerouslyUseHTMLString: true});
  904. }
  905. this.getList();
  906. },
  907. getAllRegion(val) {
  908. this.form.regionId = '';
  909. this.queryParams.regionId = '';
  910. this.form.devId = '';
  911. this.queryParams.devId = '';
  912. if (val != null && val != '') {
  913. getAllRegion(val).then(response => {
  914. this.regionOperation = response.data;
  915. }
  916. )
  917. } else {
  918. this.regionOperation = [];
  919. this.deviceOperation = [];
  920. }
  921. },
  922. getAllDeviceByRegionId(val) {
  923. this.form.devId = '';
  924. this.queryParams.devId = '';
  925. if (val != null && val != '') {
  926. getAllDeviceByRegionId(val).then(response => {
  927. this.deviceOperation = response.data;
  928. }
  929. )
  930. } else {
  931. this.deviceOperation = [];
  932. }
  933. },
  934. tableCellStyle({row, column, rowIndex, columnIndex}) {
  935. if (columnIndex === 1 && row.approveStatus == 2) {
  936. return "color:#13C2C2;";
  937. }
  938. if (columnIndex === 1 && row.approveStatus == 1) {
  939. return "color:#0000FF;";
  940. }
  941. if (columnIndex === 1 && row.approveStatus == 0) {
  942. return "color:#ff0000;";
  943. }
  944. if (columnIndex === 3 && row.leakageDegree == 1) {
  945. return "color:#00ff00;font-size:200%";
  946. }
  947. if (columnIndex === 3 && row.leakageDegree == 2) {
  948. return "color:#FFDF00;font-size:200%";
  949. }
  950. if (columnIndex === 3 && row.leakageDegree == 3) {
  951. return "color:#ff0000;font-size:200%";
  952. }
  953. },
  954. leakageFormat(row, column) {
  955. return row.leakageDegree ? "●" : null;
  956. },
  957. pointFormat(row, column) {
  958. return this.selectDictLabel(this.pointOptions, row.pointType);
  959. },
  960. mediumTypeFormat(row, column) {
  961. return this.selectDictLabel(this.mediumTypeOptions, row.mediumType);
  962. },
  963. unarriveFormat(row, column) {
  964. return this.selectDictLabel(this.yesOrNoOperation, row.unarrive);
  965. },
  966. keepWarmFormat(row, column) {
  967. return this.selectDictLabel(this.yesOrNoOperation, row.keepWarm);
  968. },
  969. approveStatusFormat(row, column) {
  970. return this.selectDictLabel(this.approveStatusOperation, row.approveStatus);
  971. },
  972. plantTypeFormat(row, column) {
  973. return this.selectDictLabel(this.plantTypeOptions, row.plantType);
  974. },
  975. /** 查询密封点列表 */
  976. getList() {
  977. this.loading = true;
  978. listPoint(this.queryParams).then(response => {
  979. this.pointList = response.rows;
  980. this.total = response.total;
  981. this.loading = false;
  982. });
  983. },
  984. // 取消按钮
  985. cancel() {
  986. this.open = false;
  987. this.reset();
  988. },
  989. cleanRegion(done) {
  990. this.reset();
  991. done(true);
  992. },
  993. // 表单重置
  994. reset() {
  995. this.form = {
  996. pointId: null,
  997. netTestValue: null,
  998. leakageDegree: null,
  999. plantId: null,
  1000. regionId: null,
  1001. devId: null,
  1002. medium: null,
  1003. mediumType: null,
  1004. pointType: null,
  1005. layer: null,
  1006. groupPosition: null,
  1007. pointPosition: null,
  1008. groupCode: null,
  1009. extendCode: null,
  1010. subPointType: null,
  1011. dia: null,
  1012. unarrive: null,
  1013. unarriveReason: null,
  1014. keepWarm: null,
  1015. temperature: null,
  1016. pressure: null,
  1017. runTime: null,
  1018. pidNo: null,
  1019. pidUrl: null,
  1020. picNo: null,
  1021. picUrl: null,
  1022. tocMark: null,
  1023. methaneMark: null,
  1024. vocsMark: null,
  1025. remarks: null,
  1026. approveStatus: 0,
  1027. approveTime: null,
  1028. deptId: null,
  1029. delFlag: null,
  1030. createrCode: null,
  1031. createdate: null,
  1032. updaterCode: null,
  1033. updatedate: null
  1034. };
  1035. this.resetForm("form");
  1036. this.regionOperation = [];
  1037. this.deviceOperation = [];
  1038. },
  1039. /** 搜索按钮操作 */
  1040. handleQuery() {
  1041. this.queryParams.pageNum = 1;
  1042. this.getList();
  1043. },
  1044. /** 重置按钮操作 */
  1045. resetQuery() {
  1046. this.resetForm("queryForm");
  1047. this.handleQuery();
  1048. this.regionOperation = [];
  1049. this.deviceOperation = [];
  1050. },
  1051. // 多选框选中数据
  1052. handleSelectionChange(selection) {
  1053. this.ids = selection.map(item => item.pointId)
  1054. this.status = selection.map(item => item.approveStatus)
  1055. this.single = selection.length !== 1
  1056. this.multiple = !selection.length
  1057. },
  1058. /** 新增按钮操作 */
  1059. handleAdd() {
  1060. this.reset();
  1061. this.open = true;
  1062. this.title = "添加密封点";
  1063. },
  1064. /** 修改按钮操作 */
  1065. handleUpdate(row) {
  1066. this.reset();
  1067. const pointId = row.pointId || this.ids
  1068. if (row.approveStatus != 0) {
  1069. MessageBox.alert('已送审/已审核的数据不可删除!', '注意!', {
  1070. confirmButtonText: '确定',
  1071. })
  1072. return
  1073. }
  1074. getPoint(pointId).then(response => {
  1075. this.form = response.data;
  1076. getAllRegion(this.form.plantId).then(response => {
  1077. this.regionOperation = response.data;
  1078. }
  1079. );
  1080. getAllDeviceByRegionId(this.form.regionId).then(response => {
  1081. this.deviceOperation = response.data;
  1082. }
  1083. )
  1084. this.open = true;
  1085. this.title = "修改密封点";
  1086. });
  1087. },
  1088. /** 提交按钮 */
  1089. submitForm() {
  1090. this.$refs["form"].validate(valid => {
  1091. if (valid) {
  1092. if (this.form.pointId != null) {
  1093. updatePoint(this.form).then(response => {
  1094. this.$modal.msgSuccess("修改成功");
  1095. this.open = false;
  1096. this.getList();
  1097. });
  1098. } else {
  1099. addPoint(this.form).then(response => {
  1100. this.$modal.msgSuccess("新增成功");
  1101. this.open = false;
  1102. this.getList();
  1103. });
  1104. }
  1105. }
  1106. });
  1107. },
  1108. /** 删除按钮操作 */
  1109. handleDelete(row) {
  1110. const ids = row.pointId || this.ids;
  1111. if (row.approveStatus === undefined) {
  1112. for (let i = 0; i < this.status.length; i++) {
  1113. if (this.status[i] != 0) {
  1114. MessageBox.alert('已送审/已审核的数据不可删除!', '注意!', {
  1115. confirmButtonText: '确定',
  1116. })
  1117. return
  1118. }
  1119. }
  1120. } else if (row.approveStatus != 0) {
  1121. MessageBox.alert('已送审/已审核的数据不可删除!', '注意!', {
  1122. confirmButtonText: '确定',
  1123. })
  1124. return
  1125. }
  1126. this.$modal.confirm('是否确认删除数据项?').then(function () {
  1127. return delPoint(ids);
  1128. }).then(() => {
  1129. this.getList();
  1130. this.$modal.msgSuccess("删除成功");
  1131. }).catch(() => {
  1132. });
  1133. },
  1134. /** 导出按钮操作 */
  1135. handleExport() {
  1136. this.download('base/point/export', {
  1137. ...this.queryParams
  1138. }, `密封点台账_${new Date().getTime()}.xlsx`)
  1139. },
  1140. handleToApprove() {
  1141. let data = {}
  1142. data.pointIds = this.ids;
  1143. data.approveStatus = 1;
  1144. handleApprove(data).then(() => {
  1145. this.getList();
  1146. });
  1147. },
  1148. handleApprove() {
  1149. let data = {}
  1150. data.pointIds = this.ids;
  1151. data.approveStatus = 2;
  1152. handleApprove(data).then(() => {
  1153. this.getList();
  1154. });
  1155. },
  1156. handleApproveAll(status) {
  1157. let data = deepClone(this.queryParams);
  1158. data.approveStatus = status
  1159. handleApproveAll(data).then(response => {
  1160. this.$modal.msgSuccess(response.msg);
  1161. this.getList();
  1162. });
  1163. },
  1164. habdleUpdload(title, flag) {
  1165. this.doc.open = true;
  1166. this.doc.title = title;
  1167. this.pidFlag = flag;
  1168. this.fileList = [];
  1169. }
  1170. }
  1171. };
  1172. </script>