yearapprove.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637
  1. <template>
  2. <!-- 添加或修改特种设备申请对话框 -->
  3. <el-dialog :title="$t('提交申请')" :visible.sync="visible" width="1200px" append-to-body>
  4. <el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="" label-width="80px">
  5. <el-form-item :label="$t('申请设备')">
  6. <el-table
  7. :data="devList"
  8. border
  9. style="width: 100%">
  10. <el-table-column
  11. prop="plantCode"
  12. header-align="center"
  13. align="center"
  14. :label="$t('plantName')">
  15. </el-table-column>
  16. <el-table-column
  17. prop="devno"
  18. header-align="center"
  19. align="center"
  20. :label="$t('tagNo')">
  21. </el-table-column>
  22. <el-table-column
  23. prop="useno"
  24. header-align="center"
  25. align="center"
  26. :show-overflow-tooltip="true"
  27. :label="$t('useNo')">
  28. </el-table-column>
  29. <el-table-column
  30. prop="regno"
  31. header-align="center"
  32. align="center"
  33. :show-overflow-tooltip="true"
  34. :label="$t('regNo')">
  35. </el-table-column>
  36. <el-table-column
  37. prop="medium"
  38. header-align="center"
  39. align="center"
  40. :label="$t('介质')">
  41. </el-table-column>
  42. <el-table-column :label="$t('容器管理')" header-align="center">
  43. <el-table-column
  44. prop="pj1"
  45. header-align="center"
  46. align="center"
  47. label="1">
  48. <template slot-scope="scope" slot="header">
  49. <el-tooltip effect="dark" :content="$t('管理制度、操作规程、运行记录')" placement="top">
  50. <span>1</span>
  51. </el-tooltip>
  52. </template>
  53. </el-table-column>
  54. <el-table-column
  55. prop="pj2"
  56. header-align="center"
  57. align="center"
  58. label="2">
  59. <template slot-scope="scope" slot="header">
  60. <el-tooltip effect="dark" :content="$t('设计文件、竣工图样、产品合格证、质量证明文件、安装使用说明')" placement="top">
  61. <span>2</span>
  62. </el-tooltip>
  63. </template>
  64. </el-table-column>
  65. <el-table-column
  66. prop="pj3"
  67. header-align="center"
  68. align="center"
  69. label="3">
  70. <template slot-scope="scope" slot="header">
  71. <el-tooltip effect="dark" :content="$t('监督检验证书以及安装、改造、修理等资料')" placement="top">
  72. <span>3</span>
  73. </el-tooltip>
  74. </template>
  75. </el-table-column>
  76. <el-table-column
  77. prop="pj4"
  78. header-align="center"
  79. align="center"
  80. label="4">
  81. <template slot-scope="scope" slot="header">
  82. <el-tooltip effect="dark" :content="$t('使用登记证,使用登记表是否与实际相符')" placement="top">
  83. <span>4</span>
  84. </el-tooltip>
  85. </template>
  86. </el-table-column>
  87. <el-table-column
  88. prop="pj5"
  89. header-align="center"
  90. align="center"
  91. label="5">
  92. <template slot-scope="scope" slot="header">
  93. <el-tooltip effect="dark" :content="$t('日常维护保养、定期安全检查记录')" placement="top">
  94. <span>5</span>
  95. </el-tooltip>
  96. </template>
  97. </el-table-column>
  98. <el-table-column
  99. prop="pj6"
  100. header-align="center"
  101. align="center"
  102. label="6">
  103. <template slot-scope="scope" slot="header">
  104. <el-tooltip effect="dark" :content="$t('年度检查、定期检验报告齐全,报告中问题解决')" placement="top">
  105. <span>6</span>
  106. </el-tooltip>
  107. </template>
  108. </el-table-column>
  109. <el-table-column
  110. prop="pj7"
  111. header-align="center"
  112. align="center"
  113. label="7">
  114. <template slot-scope="scope" slot="header">
  115. <el-tooltip effect="dark" :content="$t('作业人员定期培训情况')" placement="top">
  116. <span>7</span>
  117. </el-tooltip>
  118. </template>
  119. </el-table-column>
  120. </el-table-column>
  121. <el-table-column :label="$t('容器本体及运行情况')" header-align="center">
  122. <el-table-column
  123. prop="pj8"
  124. header-align="center"
  125. align="center"
  126. label="8">
  127. <template slot-scope="scope" slot="header">
  128. <el-tooltip effect="dark" :content="$t('设备铭牌、漆色、标志、使用证号码')" placement="top">
  129. <span>8</span>
  130. </el-tooltip>
  131. </template>
  132. </el-table-column>
  133. <el-table-column
  134. prop="pj9"
  135. header-align="center"
  136. align="center"
  137. label="9">
  138. <template slot-scope="scope" slot="header">
  139. <el-tooltip effect="dark" :content="$t('本体裂、过热、变形、泄漏、损伤情况')" placement="top">
  140. <span>9</span>
  141. </el-tooltip>
  142. </template>
  143. </el-table-column>
  144. <el-table-column
  145. prop="pj10"
  146. header-align="center"
  147. align="center"
  148. label="10">
  149. <template slot-scope="scope" slot="header">
  150. <el-tooltip effect="dark" :content="$t('接口部位、焊接接头等裂纹、泄漏、损伤情况')" placement="top">
  151. <span>10</span>
  152. </el-tooltip>
  153. </template>
  154. </el-table-column>
  155. <el-table-column
  156. prop="pj11"
  157. header-align="center"
  158. align="center"
  159. label="11">
  160. <template slot-scope="scope" slot="header">
  161. <el-tooltip effect="dark" :content="$t('外表面腐蚀、异常结霜、结露情况')" placement="top">
  162. <span>11</span>
  163. </el-tooltip>
  164. </template>
  165. </el-table-column>
  166. <el-table-column
  167. prop="pj12"
  168. header-align="center"
  169. align="center"
  170. label="12">
  171. <template slot-scope="scope" slot="header">
  172. <el-tooltip effect="dark" :content="$t('保温层、隔热层、衬里情况')" placement="top">
  173. <span>12</span>
  174. </el-tooltip>
  175. </template>
  176. </el-table-column>
  177. <el-table-column
  178. prop="pj13"
  179. header-align="center"
  180. align="center"
  181. label="13">
  182. <template slot-scope="scope" slot="header">
  183. <el-tooltip effect="dark" :content="$t('检漏孔、信号孔')" placement="top">
  184. <span>13</span>
  185. </el-tooltip>
  186. </template>
  187. </el-table-column>
  188. <el-table-column
  189. prop="pj14"
  190. header-align="center"
  191. align="center"
  192. label="14">
  193. <template slot-scope="scope" slot="header">
  194. <el-tooltip effect="dark" :content="$t('容器与相邻管道、构件间异常振动、响声、摩擦')" placement="top">
  195. <span>14</span>
  196. </el-tooltip>
  197. </template>
  198. </el-table-column>
  199. <el-table-column
  200. prop="pj15"
  201. header-align="center"
  202. align="center"
  203. label="15">
  204. <template slot-scope="scope" slot="header">
  205. <el-tooltip effect="dark" :content="$t('支承、支座、基础、紧固螺栓')" placement="top">
  206. <span>15</span>
  207. </el-tooltip>
  208. </template>
  209. </el-table-column>
  210. <el-table-column
  211. prop="pj16"
  212. header-align="center"
  213. align="center"
  214. label="16">
  215. <template slot-scope="scope" slot="header">
  216. <el-tooltip effect="dark" :content="$t('遮阳罩、操作台紧固')" placement="top">
  217. <span>16</span>
  218. </el-tooltip>
  219. </template>
  220. </el-table-column>
  221. <el-table-column
  222. prop="pj17"
  223. header-align="center"
  224. align="center"
  225. label="17">
  226. <template slot-scope="scope" slot="header">
  227. <el-tooltip effect="dark" :content="$t('罐体与底盘等连接')" placement="top">
  228. <span>17</span>
  229. </el-tooltip>
  230. </template>
  231. </el-table-column>
  232. <el-table-column
  233. prop="pj18"
  234. header-align="center"
  235. align="center"
  236. label="18">
  237. <template slot-scope="scope" slot="header">
  238. <el-tooltip effect="dark" :content="$t('波板、罐内扶梯与罐体连接')" placement="top">
  239. <span>18</span>
  240. </el-tooltip>
  241. </template>
  242. </el-table-column>
  243. <el-table-column
  244. prop="pj19"
  245. header-align="center"
  246. align="center"
  247. label="19">
  248. <template slot-scope="scope" slot="header">
  249. <el-tooltip effect="dark" :content="$t('罐车拉紧带、鞍座、中间支座')" placement="top">
  250. <span>19</span>
  251. </el-tooltip>
  252. </template>
  253. </el-table-column>
  254. <el-table-column
  255. prop="pj20"
  256. header-align="center"
  257. align="center"
  258. label="20">
  259. <template slot-scope="scope" slot="header">
  260. <el-tooltip effect="dark" :content="$t('气液相管及其它管路')" placement="top">
  261. <span>20</span>
  262. </el-tooltip>
  263. </template>
  264. </el-table-column>
  265. <el-table-column
  266. prop="pj21"
  267. header-align="center"
  268. align="center"
  269. label="21">
  270. <template slot-scope="scope" slot="header">
  271. <el-tooltip effect="dark" :content="$t('疏水、排放、排污装置')" placement="top">
  272. <span>21</span>
  273. </el-tooltip>
  274. </template>
  275. </el-table-column>
  276. <el-table-column
  277. prop="pj22"
  278. header-align="center"
  279. align="center"
  280. label="22">
  281. <template slot-scope="scope" slot="header">
  282. <el-tooltip effect="dark" :content="$t('设备运行稳定情况')" placement="top">
  283. <span>22</span>
  284. </el-tooltip>
  285. </template>
  286. </el-table-column>
  287. <el-table-column
  288. prop="pj23"
  289. header-align="center"
  290. align="center"
  291. label="23">
  292. <template slot-scope="scope" slot="header">
  293. <el-tooltip effect="dark" :content="$t('接地装置')" placement="top">
  294. <span>23</span>
  295. </el-tooltip>
  296. </template>
  297. </el-table-column>
  298. <el-table-column
  299. prop="pj24"
  300. header-align="center"
  301. align="center"
  302. label="24">
  303. <template slot-scope="scope" slot="header">
  304. <el-tooltip effect="dark" :content="$t('安全状况等级为4级的压力容器的监控措施')" placement="top">
  305. <span>24</span>
  306. </el-tooltip>
  307. </template>
  308. </el-table-column>
  309. </el-table-column>
  310. <el-table-column :label="$t('安全附件或设施')" header-align="center">
  311. <el-table-column
  312. prop="pj25"
  313. header-align="center"
  314. align="center"
  315. label="25">
  316. <template slot-scope="scope" slot="header">
  317. <el-tooltip effect="dark" :content="$t('安全阀')" placement="top">
  318. <span>25</span>
  319. </el-tooltip>
  320. </template>
  321. </el-table-column>
  322. <el-table-column
  323. prop="pj26"
  324. header-align="center"
  325. align="center"
  326. label="26">
  327. <template slot-scope="scope" slot="header">
  328. <el-tooltip effect="dark" :content="$t('压力表')" placement="top">
  329. <span>26</span>
  330. </el-tooltip>
  331. </template>
  332. </el-table-column>
  333. <el-table-column
  334. prop="pj27"
  335. header-align="center"
  336. align="center"
  337. label="27">
  338. <template slot-scope="scope" slot="header">
  339. <el-tooltip effect="dark" :content="$t('爆破片')" placement="top">
  340. <span>27</span>
  341. </el-tooltip>
  342. </template>
  343. </el-table-column>
  344. <el-table-column
  345. prop="pj28"
  346. header-align="center"
  347. align="center"
  348. label="28">
  349. <template slot-scope="scope" slot="header">
  350. <el-tooltip effect="dark" :content="$t('测温仪表')" placement="top">
  351. <span>28</span>
  352. </el-tooltip>
  353. </template>
  354. </el-table-column>
  355. <el-table-column
  356. prop="pj29"
  357. header-align="center"
  358. align="center"
  359. label="29">
  360. <template slot-scope="scope" slot="header">
  361. <el-tooltip effect="dark" :content="$t('液位计')" placement="top">
  362. <span>29</span>
  363. </el-tooltip>
  364. </template>
  365. </el-table-column>
  366. <el-table-column
  367. prop="pj30"
  368. header-align="center"
  369. align="center"
  370. label="30">
  371. <template slot-scope="scope" slot="header">
  372. <el-tooltip effect="dark" :content="$t('快开门安全联锁装置')" placement="top">
  373. <span>30</span>
  374. </el-tooltip>
  375. </template>
  376. </el-table-column>
  377. <el-table-column
  378. prop="pj31"
  379. header-align="center"
  380. align="center"
  381. label="31">
  382. <template slot-scope="scope" slot="header">
  383. <el-tooltip effect="dark" :content="$t('紧急切断装置')" placement="top">
  384. <span>31</span>
  385. </el-tooltip>
  386. </template>
  387. </el-table-column>
  388. </el-table-column>
  389. <el-table-column :label="$t('其他')" header-align="center">
  390. <el-table-column
  391. prop="pj32"
  392. header-align="center"
  393. align="center"
  394. label="32">
  395. <template slot-scope="scope" slot="header">
  396. <el-tooltip effect="dark" :content="$t('装卸软管、装卸阀门')" placement="top">
  397. <span>32</span>
  398. </el-tooltip>
  399. </template>
  400. </el-table-column>
  401. </el-table-column>
  402. <el-table-column
  403. fixed="right"
  404. prop="con"
  405. header-align="center"
  406. align="center"
  407. :label="$t('结论')"
  408. :formatter="conFormat">
  409. </el-table-column>
  410. </el-table>
  411. </el-form-item>
  412. <el-form-item :label="$t('检查一')" prop="inspectorOne">
  413. <el-select v-model="dataForm.inspectorOne" filterable :placeholder="$t('请选择')+$t('检查人员一')">
  414. <el-option
  415. v-for="item in userOption"
  416. :key="item.userId"
  417. :label="item.nickName"
  418. :value="item.userId"
  419. :disabled="item.disabled">
  420. </el-option>
  421. </el-select>
  422. </el-form-item>
  423. <el-form-item :label="$t('检查二')" prop="inspectorTwo">
  424. <el-select v-model="dataForm.inspectorTwo" filterable :placeholder="$t('请选择')+$t('检查人员二')">
  425. <el-option
  426. v-for="item in userOption"
  427. :key="item.userId"
  428. :label="item.nickName"
  429. :value="item.userId"
  430. :disabled="item.disabled">
  431. </el-option>
  432. </el-select>
  433. </el-form-item>
  434. <el-form-item :label="$t('检查三')" prop="inspectorThree">
  435. <el-select v-model="dataForm.inspectorThree" filterable :placeholder="$t('请选择')+$t('检查人员三')">
  436. <el-option
  437. v-for="item in userOption"
  438. :key="item.userId"
  439. :label="item.nickName"
  440. :value="item.userId"
  441. :disabled="item.disabled">
  442. </el-option>
  443. </el-select>
  444. </el-form-item>
  445. <el-form-item :label="$t('审核人员')" prop="auditor">
  446. <el-select v-model="dataForm.auditor" filterable :placeholder="$t('请选择')+$t('审核人员')">
  447. <el-option
  448. v-for="item in userOption"
  449. :key="item.userId"
  450. :label="item.nickName"
  451. :value="item.userId"
  452. :disabled="item.disabled">
  453. </el-option>
  454. </el-select>
  455. </el-form-item>
  456. <el-form-item :label="$t('审批人员')" prop="approver">
  457. <el-select v-model="dataForm.approver" filterable :placeholder="$t('请选择')+$t('审批人员')">
  458. <el-option
  459. v-for="item in userOption"
  460. :key="item.userId"
  461. :label="item.nickName"
  462. :value="item.userId"
  463. :disabled="item.disabled">
  464. </el-option>
  465. </el-select>
  466. </el-form-item>
  467. <el-form-item :label="$t('检查日期')" prop="checkDate">
  468. <el-date-picker
  469. v-model="dataForm.checkDate"
  470. type="date"
  471. value-format="yyyy-MM-dd"
  472. :placeholder="$t('请选择')+$t('检查日期')">
  473. </el-date-picker>
  474. </el-form-item>
  475. </el-form>
  476. <div slot="footer" class="dialog-footer">
  477. <el-button type="primary" @click="submitForm">{{ $t('提交') }}</el-button>
  478. <el-button @click="cancel">{{ $t('取 消') }}</el-button>
  479. </div>
  480. </el-dialog>
  481. </template>
  482. <script>
  483. import {getToken} from "@/utils/auth";
  484. import {
  485. addYearApprove
  486. } from "@/api/sems/approve";
  487. import {listPostUser} from "@/api/system/user";
  488. export default {
  489. name: "tapprove-add",
  490. data() {
  491. return {
  492. visible: false,
  493. devList: [],
  494. userOption:[],
  495. fileTips: '',
  496. showDelay: false,
  497. dataForm: {
  498. id: 0,
  499. devType: 1,
  500. approveType: 7,
  501. devId: '',
  502. inspectorOne: '',
  503. inspectorTwo: '',
  504. inspectorThree: '',
  505. auditor: '',
  506. approver: '',
  507. checkDate: ''
  508. },
  509. conOptions: [],
  510. doc: {
  511. file: "",
  512. // 是否显示弹出层(报告附件)
  513. open: false,
  514. // 弹出层标题(报告附件)
  515. title: "",
  516. // 是否禁用上传
  517. isUploading: false,
  518. // 是否更新已经存在的用户数据
  519. updateSupport: 0,
  520. // 报告附件上传位置编号
  521. ids: 0,
  522. // 设置上传的请求头部
  523. headers: { Authorization: "Bearer " + getToken() },
  524. // 上传的地址
  525. url: process.env.VUE_APP_BASE_API + "/sems/specfile/uploadFile",
  526. commonfileList: null,
  527. pType: 'traning',
  528. pId: null
  529. },
  530. dataRule: {
  531. approveType: [
  532. { required: true, message: this.$t('approveType') + this.$t('notEmpty'), trigger: 'blur' }
  533. ],
  534. content: [
  535. { required: true, message: this.$t('content') + this.$t('notEmpty'), trigger: 'blur' }
  536. ]
  537. },
  538. approveOption: [],
  539. belong: '',
  540. fileList: [],
  541. };
  542. },
  543. watch: {
  544. // 根据名称筛选部门树
  545. deptName(val) {
  546. this.$refs.tree.filter(val);
  547. }
  548. },
  549. created() {
  550. this.getDicts("REPORT_CON").then(response => {
  551. this.conOptions = response.data;
  552. });
  553. },
  554. methods: {
  555. init (rows, type) {
  556. this.visible = true
  557. this.fileList = []
  558. this.devList = rows
  559. listPostUser(this.queryParams).then(response => {
  560. this.userOption = response;
  561. });
  562. //这里的devId是指的report的Id
  563. for (let i = 0; i < rows.length; i++) {
  564. if (i == 0){
  565. this.dataForm.devId = rows[i].id
  566. }else {
  567. this.dataForm.devId += ',' + rows[i].id
  568. }
  569. }
  570. },
  571. // 设备类型:字典翻译
  572. devTypeFormat(row, column) {
  573. return this.selectDictLabel(this.devTypeOptions, row.devType);
  574. },
  575. // 审批类型字典翻译
  576. approveTypeFormat(row, column) {
  577. return this.selectDictLabel(this.approveTypeOptions, row.approveType);
  578. },
  579. // 检查结论字典翻译
  580. conFormat(row, column) {
  581. return this.selectDictLabel(this.conOptions, row.con);
  582. },
  583. // 取消按钮
  584. cancel() {
  585. this.visible = false;
  586. this.reset();
  587. },
  588. // 表单重置
  589. reset() {
  590. this.form = {
  591. id: 0,
  592. devType: 1,
  593. approveType: 7,
  594. devId: '',
  595. inspectorOne: '',
  596. inspectorTwo: '',
  597. inspectorThree: '',
  598. auditor: '',
  599. approver: '',
  600. checkDate: ''
  601. };
  602. this.resetForm("form");
  603. },
  604. /** 搜索按钮操作 */
  605. handleQuery() {
  606. this.queryParams.pageNum = 1;
  607. this.getList();
  608. },
  609. /** 重置按钮操作 */
  610. resetQuery() {
  611. this.resetForm("queryForm");
  612. this.handleQuery();
  613. },
  614. /** 提交按钮 */
  615. submitForm() {
  616. this.$refs["dataForm"].validate(valid => {
  617. if (valid) {
  618. this.dataForm.reportId = this.dataForm.devId
  619. addYearApprove(this.dataForm).then(response => {
  620. this.msgSuccess(this.$t('申请成功'));
  621. this.visible = false;
  622. });
  623. }
  624. });
  625. },
  626. }
  627. }
  628. </script>
  629. <style scoped>
  630. </style>