deviceDialog.vue 75 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363
  1. <template>
  2. <el-dialog
  3. v-loading="loading"
  4. :title="title"
  5. :visible.sync="dialogVisible"
  6. :close-on-click-modal="false"
  7. :close-on-press-escape="false"
  8. :show-close="false"
  9. append-to-body
  10. fullscreen
  11. class="dialog paper-detail-dialog"
  12. top="0"
  13. >
  14. <div slot="title" class="dialog-title">
  15. <span class="dialogtitle">{{ title }}</span>
  16. <div>
  17. <ibps-toolbar :actions="toolbars" @action-event="handleActionEvent" />
  18. </div>
  19. </div>
  20. <div class="container">
  21. <div class="left" :style="{width:initWidth}">
  22. <div class="form">
  23. <el-form ref="form" label-width="100px" :model="form" :rules="rules" :hide-required-asterisk="true">
  24. <el-row type="flex" justify="center" :gutter="20">
  25. <el-col :span="16">
  26. <el-row :gutter="20">
  27. <el-col v-if="isEdit" :span="8">
  28. <el-form-item label="设备名称:" prop="sheBeiMingCheng">
  29. <template slot="label">
  30. <span class="required">设备名称:</span>
  31. </template>
  32. <el-input v-model="form.sheBeiMingCheng" size="mini" />
  33. </el-form-item>
  34. </el-col>
  35. <el-col v-if="!isEdit" :span="8">
  36. <el-form-item label="设备名称:" prop="sheBeiMingChen">
  37. <template slot="label">
  38. <span class="required">设备名称:</span>
  39. </template>
  40. <ibps-custom-dialog
  41. v-model="form.sheBeiMingChen"
  42. size="mini"
  43. template-key="sbysdhk"
  44. :disabled="false"
  45. type="dialog"
  46. class="custom-dialog"
  47. placeholder="请选择"
  48. icon="el-icon-search"
  49. style="width:100%"
  50. />
  51. </el-form-item>
  52. </el-col>
  53. </el-row>
  54. <el-row :gutter="20">
  55. <el-col :span="8">
  56. <el-form-item label="建档部门:" prop="bianZhiBuMen">
  57. <template slot="label">
  58. <span class="required">建档部门:</span>
  59. </template>
  60. <ibps-user-selector
  61. v-model="form.bianZhiBuMen"
  62. type="position"
  63. readonly-text="text"
  64. :disabled="false"
  65. :multiple="false"
  66. size="mini"
  67. :filter="filter"
  68. filtrate
  69. style="width:100%"
  70. />
  71. </el-form-item>
  72. </el-col>
  73. <el-col :span="8">
  74. <el-form-item label="建档人:" prop="bianZhiRen">
  75. <ibps-user-selector
  76. v-model="form.bianZhiRen"
  77. type="user"
  78. readonly-text="text"
  79. :disabled="true"
  80. :multiple="false"
  81. size="mini"
  82. style="width:100%"
  83. :filter="filter"
  84. filtrate
  85. />
  86. </el-form-item>
  87. </el-col>
  88. <el-col :span="8">
  89. <el-form-item label="建档时间:" prop="bianZhiShiJian">
  90. <template slot="label">
  91. <span class="required">建档时间:</span>
  92. </template>
  93. <el-date-picker
  94. v-model="form.bianZhiShiJian"
  95. style="width:100%"
  96. type="datetime"
  97. placeholder="选择日期时间"
  98. default-time="12:00:00"
  99. :readonly="readonly"
  100. value-format="yyyy-MM-dd HH:mm"
  101. size="mini"
  102. />
  103. </el-form-item>
  104. </el-col>
  105. </el-row>
  106. <el-row :gutter="20">
  107. <el-col :span="8">
  108. <el-form-item label="设备编号:" prop="sheBeiShiBieH">
  109. <template slot="label">
  110. <span>设备编号</span>
  111. <el-tooltip effect="dark" content="设备编号由系统自动生成。" placement="top">
  112. <i class="el-icon-question question-icon">:</i>
  113. </el-tooltip>
  114. </template>
  115. <span>{{ form.sheBeiShiBieH }}</span>
  116. </el-form-item>
  117. </el-col>
  118. <el-col :span="8">
  119. <el-form-item label="原设备编号:" prop="yuanSheBeiBian">
  120. <template slot="label">
  121. <span class="required">原设备编号:</span>
  122. </template>
  123. <el-input v-model="form.yuanSheBeiBian" size="mini" />
  124. </el-form-item>
  125. </el-col>
  126. <el-col :span="8">
  127. <el-form-item label="设备状态:" prop="sheBeiZhuangTa">
  128. <span>{{ showState }}</span>
  129. </el-form-item>
  130. </el-col>
  131. </el-row>
  132. <el-row :gutter="20">
  133. <el-col :span="8">
  134. <el-form-item label="设备类型:" prop="sheBeiLeiXing">
  135. <el-select v-model="form.sheBeiLeiXing" placeholder="请选择" size="mini" style="width:100%">
  136. <el-option
  137. v-for="item in ['检验系统','通用设备','软件','信息系统']"
  138. :key="item"
  139. :label="item"
  140. :value="item"
  141. />
  142. </el-select>
  143. </el-form-item>
  144. </el-col>
  145. <el-col :span="8">
  146. <el-form-item label="规格型号:" prop="guiGeXingHao">
  147. <template slot="label">
  148. <span class="required">规格型号:</span>
  149. </template>
  150. <el-input v-model="form.guiGeXingHao" size="mini" />
  151. </el-form-item>
  152. </el-col>
  153. <el-col :span="8">
  154. <el-form-item label="接收时状态:" prop="jieShouZhuangTai">
  155. <template slot="label">
  156. <span class="required">接收时状态:</span>
  157. </template>
  158. <el-select v-model="form.jieShouZhuangTai" placeholder="请选择" size="mini" style="width:100%">
  159. <el-option
  160. v-for="item in ['新设备','二手或翻新设备']"
  161. :key="item"
  162. :label="item"
  163. :value="item"
  164. />
  165. </el-select>
  166. </el-form-item>
  167. </el-col>
  168. </el-row>
  169. <el-row :gutter="20">
  170. <el-col :span="8">
  171. <el-form-item label="保管人:" prop="guanLiRen">
  172. <template slot="label">
  173. <span class="required">保管人:</span>
  174. </template>
  175. <ibps-user-selector
  176. v-model="form.guanLiRen"
  177. type="user"
  178. readonly-text="text"
  179. :disabled="false"
  180. :multiple="false"
  181. size="mini"
  182. :filter="filter"
  183. filtrate
  184. style="width:100%"
  185. />
  186. </el-form-item>
  187. </el-col>
  188. <el-col :span="8">
  189. <el-form-item label="放置地点:" prop="cunFangWeiZhi">
  190. <template slot="label">
  191. <span class="required">放置地点:</span>
  192. </template>
  193. <ibps-custom-dialog
  194. v-model="form.cunFangWeiZhi"
  195. size="mini"
  196. template-key="fjxzkdd"
  197. :disabled="false"
  198. type="dialog"
  199. class="custom-dialog"
  200. placeholder="请选择"
  201. icon="el-icon-search"
  202. style="width:100%"
  203. />
  204. </el-form-item>
  205. </el-col>
  206. <el-col :span="8">
  207. <el-form-item label="固定资产号:">
  208. <el-input v-model="form.ziChanBianHao" size="mini" />
  209. </el-form-item>
  210. </el-col>
  211. </el-row>
  212. <el-row :gutter="20">
  213. <el-col :span="8">
  214. <el-form-item label="厂家/品牌:">
  215. <el-input v-model="form.changShang" size="mini" />
  216. </el-form-item>
  217. </el-col>
  218. <el-col :span="8">
  219. <el-form-item label="出厂日期:" prop="chuChangRiQi">
  220. <template slot="label">
  221. <span class="required">出厂日期</span>
  222. </template>
  223. <el-date-picker
  224. v-model="form.chuChangRiQi"
  225. style="width:100%"
  226. type="date"
  227. placeholder="选择日期"
  228. :readonly="readonly"
  229. value-format="yyyy-MM-dd"
  230. size="mini"
  231. />
  232. </el-form-item>
  233. </el-col>
  234. <el-col :span="8">
  235. <el-form-item label="出厂编号:">
  236. <el-input v-model="form.jiShenXuHao" size="mini" />
  237. </el-form-item>
  238. </el-col>
  239. </el-row>
  240. <el-row :gutter="20">
  241. <el-col :span="8">
  242. <el-form-item label="供应商:">
  243. <ibps-custom-dialog
  244. v-model="form.shiFouQiJianH"
  245. size="mini"
  246. template-key="gysxxdhk"
  247. :disabled="false"
  248. type="dialog"
  249. class="custom-dialog"
  250. placeholder="请选择"
  251. icon="el-icon-search"
  252. style="width:100%"
  253. @change-link-data="shiFouQiJianHChange"
  254. />
  255. </el-form-item>
  256. </el-col>
  257. <el-col :span="8">
  258. <el-form-item label="供应商电话:">
  259. <el-input v-model="form.lianXiFangShi" size="mini" />
  260. </el-form-item>
  261. </el-col>
  262. <el-col :span="8">
  263. <el-form-item label="注册证号:">
  264. <el-input v-model="form.zhuCeZhengHao" size="mini" />
  265. </el-form-item>
  266. </el-col>
  267. </el-row>
  268. </el-col>
  269. <el-col :span="8">
  270. <el-row v-if="photos.length>0">
  271. <el-col>
  272. <el-carousel trigger="click" height="250px" indicator-position="none">
  273. <el-carousel-item v-if="photos.length==0">
  274. <el-empty description="暂无图片" />
  275. </el-carousel-item>
  276. <template v-else>
  277. <el-carousel-item v-for="item in photos" :key="item.id">
  278. <el-image
  279. style="width: 100%; height: 100%"
  280. :src="item.url"
  281. fit="contain"
  282. :preview-src-list="photos.map(item=>item.url)"
  283. />
  284. </el-carousel-item>
  285. </template>
  286. </el-carousel>
  287. </el-col>
  288. </el-row>
  289. </el-col>
  290. </el-row>
  291. </el-form>
  292. </div>
  293. <div class="tabs">
  294. <el-row>
  295. <el-col>
  296. <el-tabs v-model="activeName" @tab-click="handleClick">
  297. <el-tab-pane label="基本信息" name="one">
  298. <el-form label-width="100px" :model="form" :hide-required-asterisk="true">
  299. <el-row :gutter="20">
  300. <!-- 第一列 -->
  301. <el-col :span="8">
  302. <el-row>
  303. <el-col>
  304. <el-form-item label="购进日期:">
  305. <el-date-picker
  306. v-model="form.gouJinRiQi"
  307. style="width:100%"
  308. type="date"
  309. placeholder="选择日期"
  310. :readonly="readonly"
  311. value-format="yyyy-MM-dd"
  312. size="mini"
  313. />
  314. </el-form-item>
  315. </el-col>
  316. </el-row>
  317. <el-row>
  318. <el-col>
  319. <el-form-item label="接收日期:">
  320. <el-date-picker
  321. v-model="form.jieShouRiQi"
  322. style="width:100%"
  323. type="date"
  324. placeholder="选择日期"
  325. :readonly="readonly"
  326. value-format="yyyy-MM-dd"
  327. size="mini"
  328. />
  329. </el-form-item>
  330. </el-col>
  331. </el-row>
  332. <el-row>
  333. <el-col>
  334. <el-form-item label="验收日期:">
  335. <el-date-picker
  336. v-model="form.yanShouRiQi"
  337. style="width:100%"
  338. type="date"
  339. placeholder="选择日期"
  340. :readonly="readonly"
  341. value-format="yyyy-MM-dd"
  342. size="mini"
  343. />
  344. </el-form-item>
  345. </el-col>
  346. </el-row>
  347. <el-row>
  348. <el-col>
  349. <el-form-item label="投入日期:">
  350. <el-date-picker
  351. v-model="form.qiYongRiQi"
  352. style="width:100%"
  353. type="date"
  354. placeholder="选择日期"
  355. :readonly="readonly"
  356. value-format="yyyy-MM-dd"
  357. size="mini"
  358. />
  359. </el-form-item>
  360. </el-col>
  361. </el-row>
  362. <el-row>
  363. <el-col>
  364. <el-form-item label="核查日期:">
  365. <el-date-picker
  366. v-model="form.biXuSheShi"
  367. style="width:100%"
  368. type="date"
  369. placeholder="选择日期"
  370. :readonly="readonly"
  371. value-format="yyyy-MM-dd"
  372. size="mini"
  373. />
  374. </el-form-item>
  375. </el-col>
  376. </el-row>
  377. <el-row>
  378. <el-col>
  379. <el-form-item label="核查人:">
  380. <ibps-user-selector
  381. v-model="form.biXuDeHuanJin"
  382. type="user"
  383. readonly-text="text"
  384. :disabled="false"
  385. :multiple="false"
  386. size="mini"
  387. style="width:100%"
  388. :filter="filter"
  389. filtrate
  390. />
  391. </el-form-item>
  392. </el-col>
  393. </el-row>
  394. <el-row>
  395. <el-col>
  396. <el-form-item label="电源要求:">
  397. <el-input v-model="form.dianYuanYaoQiu" size="mini" />
  398. </el-form-item>
  399. </el-col>
  400. </el-row>
  401. <el-row>
  402. <el-col>
  403. <el-form-item label="环境要求:">
  404. <el-input v-model="form.huanJingYaoQiu" size="mini" />
  405. </el-form-item>
  406. </el-col>
  407. </el-row>
  408. <el-row>
  409. <el-col>
  410. <el-form-item label="使用年限(年):">
  411. <el-input v-model="form.heChaXiaoZhun" size="mini" type="number" />
  412. </el-form-item>
  413. </el-col>
  414. </el-row>
  415. <el-row>
  416. <el-col>
  417. <el-form-item label="资产原值(元):">
  418. <el-input v-model="form.ziChanYuanZhi" size="mini" type="number" />
  419. </el-form-item>
  420. </el-col>
  421. </el-row>
  422. </el-col>
  423. <!-- 第二列 -->
  424. <el-col :span="8">
  425. <el-row>
  426. <el-col>
  427. <el-form-item label="是否维护:">
  428. <el-select v-model="form.shiFouWeiHu" placeholder="请选择" size="mini" style="width:100%">
  429. <el-option
  430. v-for="item in ['是','否']"
  431. :key="item"
  432. :label="item"
  433. :value="item"
  434. />
  435. </el-select>
  436. </el-form-item>
  437. </el-col>
  438. </el-row>
  439. <el-row>
  440. <el-col>
  441. <el-form-item label="设备分组:">
  442. <ibps-custom-dialog
  443. v-model="form.weiHuFangShi"
  444. size="mini"
  445. template-key="sbbqdhk"
  446. multiple
  447. :disabled="false"
  448. type="dialog"
  449. class="custom-dialog"
  450. placeholder="请选择"
  451. icon="el-icon-search"
  452. style="width:100%"
  453. />
  454. </el-form-item>
  455. </el-col>
  456. </el-row>
  457. <el-row>
  458. <el-col>
  459. <el-form-item label="是否24H开机:">
  460. <el-select v-model="form.jianKongYiJu" placeholder="请选择" size="mini" style="width:100%">
  461. <el-option
  462. v-for="item in ['是','否']"
  463. :key="item"
  464. :label="item"
  465. :value="item"
  466. />
  467. </el-select>
  468. </el-form-item>
  469. </el-col>
  470. </el-row>
  471. <el-row v-if="form.jianKongYiJu==='否'">
  472. <el-col>
  473. <el-form-item label="开机时间:">
  474. <el-time-picker
  475. v-model="form.kaiShiShiYong"
  476. placeholder="任意时间点"
  477. size="mini"
  478. style="width:100%"
  479. value-format="HH:mm:ss"
  480. />
  481. </el-form-item>
  482. </el-col>
  483. </el-row>
  484. <el-row v-if="form.jianKongYiJu==='否'">
  485. <el-col>
  486. <el-form-item label="关机时间:">
  487. <el-time-picker
  488. v-model="form.shiJiShiYongF"
  489. placeholder="任意时间点"
  490. size="mini"
  491. style="width:100%"
  492. value-format="HH:mm:ss"
  493. />
  494. </el-form-item>
  495. </el-col>
  496. </el-row>
  497. <!-- <el-row>
  498. <el-col>
  499. <el-form-item label="是否限用:">
  500. <el-select v-model="form.xiaoZhunWuCha" placeholder="请选择" size="mini" style="width:100%">
  501. <el-option
  502. v-for="item in ['是','否']"
  503. :key="item"
  504. :label="item"
  505. :value="item"
  506. />
  507. </el-select>
  508. </el-form-item>
  509. </el-col>
  510. </el-row>
  511. <el-row v-if="form.xiaoZhunWuCha==='是'">
  512. <el-col>
  513. <el-form-item label="限用范围:">
  514. <el-input v-model="form.caiGouHeTong" size="mini" />
  515. </el-form-item>
  516. </el-col>
  517. </el-row> -->
  518. <el-row>
  519. <!-- todo -->
  520. <el-col>
  521. <el-alert
  522. title="开关机时间配置说明"
  523. type="success"
  524. description="日保养、按需保养、这些周期,如果配置了开关机时间,在设备使用与维护时会自动带出"
  525. :closable="false"
  526. />
  527. </el-col>
  528. </el-row>
  529. </el-col>
  530. <!-- 第三列 -->
  531. <el-col :span="8">
  532. <el-row>
  533. <el-col>
  534. <el-form-item label="是否校准:" prop="shiFouXiaoZhun">
  535. <el-select v-model="form.shiFouXiaoZhun" placeholder="请选择" size="mini" style="width:100%">
  536. <el-option
  537. v-for="item in ['是','否']"
  538. :key="item"
  539. :label="item"
  540. :value="item"
  541. />
  542. </el-select>
  543. </el-form-item>
  544. </el-col>
  545. </el-row>
  546. <el-row v-if="form.shiFouXiaoZhun==='是'">
  547. <el-col>
  548. <el-form-item label="检定/校准周期(月):" label-width="140">
  549. <el-input v-model="form.xiaoZhunZQ" size="mini" type="number" style="width:100%" />
  550. </el-form-item>
  551. </el-col>
  552. </el-row>
  553. <el-row v-if="form.shiFouXiaoZhun==='是'">
  554. <el-col>
  555. <el-form-item label="检定/校准单位:">
  556. <ibps-custom-dialog
  557. v-model="form.shiYongKeShi"
  558. size="mini"
  559. template-key="gysxxdhk"
  560. :disabled="false"
  561. type="dialog"
  562. class="custom-dialog"
  563. placeholder="请选择"
  564. icon="el-icon-search"
  565. style="width:100%"
  566. />
  567. </el-form-item>
  568. </el-col>
  569. </el-row>
  570. <el-row v-if="form.shiFouXiaoZhun==='是'">
  571. <el-col>
  572. <el-form-item label="最近校准时间:">
  573. <el-date-picker
  574. v-model="form.yiXiaoRiQi"
  575. style="width:100%"
  576. type="date"
  577. placeholder="选择日期"
  578. :readonly="readonly"
  579. value-format="yyyy-MM-dd"
  580. size="mini"
  581. />
  582. </el-form-item>
  583. </el-col>
  584. </el-row>
  585. <el-row v-if="form.shiFouXiaoZhun==='是'">
  586. <el-col>
  587. <el-form-item label="校准有效期至:">
  588. <el-date-picker
  589. v-model="form.xiaoZhunYouXia"
  590. style="width:100%"
  591. type="date"
  592. placeholder="选择日期"
  593. :readonly="readonly"
  594. value-format="yyyy-MM-dd"
  595. size="mini"
  596. />
  597. </el-form-item>
  598. </el-col>
  599. </el-row>
  600. <el-row v-if="form.shiFouXiaoZhun==='是'">
  601. <el-col>
  602. <el-form-item label="校准证书编号:">
  603. <el-input v-model="form.zhengShuBianHa" size="mini" />
  604. </el-form-item>
  605. </el-col>
  606. </el-row>
  607. <el-row v-if="false">
  608. <el-col>
  609. <el-form-item label="校准机构:">
  610. <el-input v-model="form.shiWuShuoMing" size="mini" />
  611. </el-form-item>
  612. </el-col>
  613. </el-row>
  614. <el-row v-if="form.shiFouXiaoZhun==='是' && !isSheKou">
  615. <el-col>
  616. <el-form-item label="检定/校准参数:">
  617. <el-input v-model="form.jianDingXiao" size="mini" />
  618. </el-form-item>
  619. </el-col>
  620. </el-row>
  621. <el-row v-if="form.shiFouXiaoZhun==='是' && !isSheKou">
  622. <el-col>
  623. <el-form-item label="测量范围:">
  624. <el-input v-model="form.ceLiangGongZuo" size="mini" />
  625. </el-form-item>
  626. </el-col>
  627. </el-row>
  628. <el-row v-if="form.shiFouXiaoZhun==='是' && !isSheKou">
  629. <el-col>
  630. <el-form-item label="U/精确度/最大允差:" label-width="130">
  631. <el-input v-model="form.zuiDaYunCha" size="mini" style="width:100%" />
  632. </el-form-item>
  633. </el-col>
  634. </el-row>
  635. <el-row v-if="form.shiFouXiaoZhun==='是' && !isSheKou">
  636. <el-col>
  637. <el-form-item label="修正值:">
  638. <el-input v-model="form.xiuZhengZhiXiu" size="mini" />
  639. </el-form-item>
  640. </el-col>
  641. </el-row>
  642. </el-col>
  643. </el-row>
  644. <el-row :gutter="20">
  645. <el-col :span="24">
  646. <el-alert :closable="false" type="success" style="margin-bottom:20px">设备照片及相关附件</el-alert>
  647. </el-col>
  648. <el-col :span="24">
  649. <el-form-item label="设备图片:">
  650. <ibps-image
  651. v-model="form.beiZhu"
  652. height="160"
  653. width="160"
  654. accept=".jpg,.jpeg,.png,.gif,.bmp,.webp"
  655. multiple
  656. download
  657. :disabled="readonly"
  658. size=""
  659. />
  660. </el-form-item>
  661. </el-col>
  662. <el-col :span="24">
  663. <el-form-item label="附件上传:">
  664. <ibps-attachment
  665. v-model="form.yqzp"
  666. :download="true"
  667. multiple
  668. accept="*"
  669. :readonly="false"
  670. style="width:100%"
  671. />
  672. </el-form-item>
  673. </el-col>
  674. <el-col :span="24">
  675. <el-form-item label="资质证书:">
  676. <ibps-attachment
  677. v-model="form.faPiao"
  678. :download="true"
  679. multiple
  680. accept="*"
  681. :readonly="false"
  682. style="width:100%"
  683. />
  684. </el-form-item>
  685. </el-col>
  686. <el-col :span="24">
  687. <el-form-item label="设备说明书:">
  688. <ibps-attachment
  689. v-model="form.fuJianShang"
  690. :download="true"
  691. multiple
  692. accept="*"
  693. :readonly="false"
  694. style="width:100%"
  695. />
  696. </el-form-item>
  697. </el-col>
  698. <!-- <el-col :span="24">
  699. <el-form-item label="说明书分类:">
  700. <SelectType :field="{}" @change-data="changeData" />
  701. </el-form-item>
  702. </el-col>
  703. <el-col :span="24">
  704. <el-form-item label="文件路径:">
  705. <span>{{ form.wenJianXiLei }}</span>
  706. </el-form-item>
  707. </el-col> -->
  708. </el-row>
  709. </el-form>
  710. </el-tab-pane>
  711. <el-tab-pane v-for="item in tabItems" :key="item.name" :label="item.label" :name="item.name" :disabled="item.isKeepAlive&&!isEdit">
  712. <template v-if="item.isKeepAlive">
  713. <!-- 使用 v-if 配合 keep-alive 实现按需加载 -->
  714. <keep-alive>
  715. <component :is="item.component" v-if="activeName===item.name" :params="form" />
  716. </keep-alive>
  717. </template>
  718. <template v-else>
  719. <component :is="item.component" :ref="item.ref" :list-data="form[item.data]" />
  720. </template>
  721. </el-tab-pane>
  722. </el-tabs>
  723. </el-col>
  724. </el-row>
  725. </div>
  726. </div>
  727. </div>
  728. </el-dialog>
  729. </template>
  730. <script>
  731. import dayjs from 'dayjs'
  732. import ibpsUserSelector from '@/business/platform/org/selector'
  733. import { getequipmentCard, saveEquipmentCard } from '@/api/platform/device/device'
  734. import Maintenance from './maintenance.vue'
  735. import MoreDevices from './moreDevices.vue'
  736. import ScrappedRecord from './scrappedRecord.vue'
  737. import MaintenanceRecord from './maintenanceRecord.vue'
  738. import RepairRecord from './repairRecord.vue'
  739. import CalibrationCheckRecord from './calibrationCheckRecord.vue'
  740. import IbpsAttachment from '@/business/platform/file/attachment/selector'
  741. import SelectType from '@/views/component/selectType.vue'
  742. import { getImage } from '@/api/platform/file/attachment'
  743. export default {
  744. components: {
  745. ibpsUserSelector, Maintenance, MoreDevices, ScrappedRecord, MaintenanceRecord, RepairRecord, CalibrationCheckRecord, IbpsAttachment, SelectType,
  746. IbpsCustomDialog: () => import('@/business/platform/data/templaterender/custom-dialog'),
  747. IbpsImage: () => import('@/business/platform/file/image')
  748. },
  749. props: {
  750. params: {
  751. type: Object,
  752. default: function () {
  753. return {}
  754. }
  755. },
  756. stateList: {
  757. type: Object,
  758. default: function () {
  759. return { '停用': '停用', '报废': '报废', '合格': '合格' }
  760. }
  761. }
  762. },
  763. data () {
  764. const { userId, position, level, deptList } = this.$store.getters
  765. return {
  766. tabItems: [
  767. { label: '维护项目', name: 'two', ref: 'MaintenanceRef', data: 'maintenanceItemPoList', component: 'Maintenance', isKeepAlive: false },
  768. { label: '附属设备及配件', name: 'three', ref: 'MoreDevicesRef', data: 'accessoriesDevicePoList', component: 'MoreDevices', isKeepAlive: false },
  769. { label: '使用与维护记录', name: 'four', component: 'MaintenanceRecord', isKeepAlive: true },
  770. { label: '校准记录', name: 'five', component: 'CalibrationCheckRecord', isKeepAlive: true },
  771. { label: '维修记录', name: 'six', component: 'RepairRecord', isKeepAlive: true },
  772. { label: '停用、报废记录', name: 'seven', component: 'ScrappedRecord', isKeepAlive: true }
  773. ],
  774. filter: [{
  775. descVal: '1',
  776. includeSub: true,
  777. old: 'position',
  778. partyId: this.$store.getters.userInfo.employee.positions,
  779. partyName: '',
  780. scriptContent: '',
  781. type: 'user',
  782. userType: 'position'
  783. }],
  784. isFirstyiXiaoRiQi: true,
  785. isFirstbianZhiBuMen: true,
  786. isSheKou: false,
  787. readonly: false,
  788. activeName: 'one',
  789. dialogVisible: true,
  790. userId: userId,
  791. position: position,
  792. deptList: deptList,
  793. level: level.second || level.first,
  794. org: level.first || '',
  795. loading: false,
  796. title: '设备档案卡',
  797. toolbars: [
  798. { key: 'save', label: '保存' },
  799. { key: 'cancel', label: '退出', type: 'danger', icon: 'ibps-icon-close' }
  800. ],
  801. initWidth: '1480px',
  802. isEdit: false,
  803. isFinished: false,
  804. preParams: {},
  805. Ids: [],
  806. form: {
  807. gouJinRiQi: '', // 购进日期
  808. changShang: '', // 厂家/品牌
  809. guiGeXingHao: '', // 规格型号
  810. jieShouRiQi: '', // 接收日期
  811. qiYongRiQi: '', // 投入日期
  812. cunFangDiDian: '',
  813. cunFangWeiZhi: '', // 放置地点
  814. jieShouZhuangTai: '', // 接收时状态
  815. guanLiRen: '', // 保管人
  816. weiHuFangShi: '', // 设备分组
  817. bianZhiRen: '', // 建档人
  818. bianZhiBuMen: '', // 建档部门
  819. bianZhiShiJian: '', // 建档时间
  820. shiFouGuoShen: '',
  821. sheBeiLeiXing: '', // 设备类型
  822. sheBeiZhuangTa: '', // 设备状态
  823. sheBeiShiBieH: '', // 设备编号
  824. shiFouXiaoZhun: '', // 是否校准
  825. gongYingShang: '',
  826. shiFouQiJianH: '', // 供应商id
  827. lianXiFangShi: '', // 供应商电话
  828. xiaoZhunYouXia: '', // 校准有效期至
  829. chuChangRiQi: '', // 出厂日期
  830. sheBeiMingCheng: '', // 设备名称
  831. sheBeiMingChen: '', // 设备名称id
  832. yiXiaoRiQi: '', // 最近校准时间
  833. heChaXiaoZhun: '', // 使用年限
  834. shiJiShiYongF: '', // 关机时间
  835. kaiShiShiYong: '', // 开机时间
  836. zhengShuBianHa: '', // 校准证书编号
  837. xiaoZhunWuCha: '', // 是否限用
  838. xiaoZhunZQ: '', // 检定/校准周期
  839. shiYongKeShi: '', // 检定/校准单位
  840. yuanSheBeiBian: '', // 原设备编号
  841. jianKongYiJu: '', // 是否24H开机
  842. biXuDeHuanJin: '', // 核查人
  843. biXuSheShi: '', // 核查日期
  844. ziChanYuanZhi: '', // 资产原值
  845. ziChanBianHao: '', // 固定资产号
  846. shiFouWeiHu: '', // 是否维护
  847. jiShenXuHao: '', // 出厂编号
  848. yanShouRiQi: '', // 验收日期
  849. huanJingYaoQiu: '', // 环境要求
  850. dianYuanYaoQiu: '', // 电源要求
  851. zhuCeZhengHao: '', // 注册证号
  852. yqzp: '', // 附件上传
  853. faPiao: '', // 资质证书
  854. fuJianShang: '', // 设备使用说明书
  855. beiZhu: '', // 设备图片
  856. caiGouHeTong: '', // 限用范围
  857. zhuanYeBuMen: '',
  858. wenJianXiLei: '', // 附件细类
  859. xiLeiId: '',
  860. quanXianLeiXing: '',
  861. diDian: '',
  862. buMen: '', // 图片id
  863. ceLiangGongZuo: '', // 测量范围
  864. jianDingXiao: '', // 检定/校准参数
  865. xiuZhengZhiXiu: '', // 修正值
  866. zuiDaYunCha: '', // U/精确度/最大允差
  867. shiWuShuoMing: '' // 校准机构
  868. },
  869. rules: {
  870. sheBeiMingCheng: [
  871. { required: true, message: '设备名称不能为空', trigger: 'blur' }
  872. ],
  873. sheBeiShiBieH: [
  874. { required: true, message: '设备编号不能为空', trigger: 'blur' }
  875. ],
  876. yuanSheBeiBian: [
  877. { required: true, message: '原设备编号不能为空', trigger: 'blur' }
  878. ],
  879. sheBeiLeiXing: [
  880. { required: true, message: '设备类型不能为空', trigger: 'blur' }
  881. ],
  882. sheBeiZhuangTa: [
  883. { required: true, message: '设备状态不能为空', trigger: 'blur' }
  884. ],
  885. guiGeXingHao: [
  886. { required: true, message: '规格型号不能为空', trigger: 'blur' }
  887. ],
  888. bianZhiBuMen: [
  889. { required: true, message: '建档部门不能为空', trigger: 'blur' }
  890. ],
  891. bianZhiRen: [
  892. { required: true, message: '建档人不能为空', trigger: 'blur' }
  893. ],
  894. bianZhiShiJian: [
  895. { required: true, message: '建档时间不能为空', trigger: 'blur' }
  896. ],
  897. jieShouZhuangTai: [
  898. { required: true, message: '接收时状态不能为空', trigger: 'blur' }
  899. ],
  900. guanLiRen: [
  901. { required: true, message: '保管人不能为空', trigger: 'blur' }
  902. ],
  903. cunFangWeiZhi: [
  904. { required: true, message: '放置地点不能为空', trigger: 'blur' }
  905. ],
  906. shiFouXiaoZhun: [
  907. { required: true, message: '是否校准不能为空', trigger: 'blur' }
  908. ],
  909. sheBeiMingChen: [
  910. { required: true, message: '请选择设备', trigger: 'blur' }
  911. ],
  912. chuChangRiQi: [
  913. { required: true, message: '出厂日期不能为空', trigger: 'blur' }
  914. ]
  915. }
  916. }
  917. },
  918. computed: {
  919. photos () {
  920. if (this.form.beiZhu) {
  921. const photos = JSON.parse(this.form.beiZhu)
  922. photos.forEach(item => {
  923. item.url = getImage(item.id)
  924. })
  925. return photos
  926. }
  927. return []
  928. },
  929. showState () {
  930. return this.stateList[this.form.sheBeiZhuangTa] || this.form.sheBeiZhuangTa
  931. }
  932. },
  933. watch: {
  934. photos: {
  935. handler (val) {
  936. this.form.buMen = val.map(item => item.id).join(',')
  937. }
  938. },
  939. 'form.xiaoZhunWuCha': {
  940. handler (val, old) {
  941. if (!old) return
  942. if (val === '否') {
  943. this.form.sheBeiZhuangTa = '合格'
  944. } else if (val === '是') {
  945. this.form.caiGouHeTong = ''
  946. this.form.sheBeiZhuangTa = '限用'
  947. }
  948. }
  949. },
  950. 'form.cunFangWeiZhi': {
  951. async handler (val) {
  952. if (!val) return
  953. const sql = `select fang_jian_ming_ha from t_jjqfjb where id_='${val}'`
  954. const { variables: { data }} = await this.$common.request('sql', sql)
  955. this.form.cunFangDiDian = data[0].fang_jian_ming_ha
  956. }
  957. },
  958. 'form.sheBeiMingChen': {
  959. async handler (val) {
  960. if (this.isEdit) return
  961. const sql = `select * from t_yqsbysb where id_='${val}'`
  962. const { variables: { data }} = await this.$common.request('sql', sql)
  963. if (data.length > 0) {
  964. this.form.sheBeiMingCheng = data[0].ming_cheng_str_
  965. this.form.guiGeXingHao = data[0].xing_hao_gui_ge_
  966. this.form.jiShenXuHao = data[0].chu_chang_bian_ha
  967. this.form.changShang = data[0].sheng_chan_chang_
  968. this.form.yuanSheBeiBian = data[0].she_bei_bian_hao_
  969. }
  970. }
  971. },
  972. // 根据编制部门动态获取对应文件存放处数据
  973. // 'form.bianZhiBuMen': {
  974. // handler (value) {
  975. // if (value) {
  976. // if (this.isFirstbianZhiBuMen) {
  977. // this.isFirstbianZhiBuMen = false
  978. // return
  979. // }
  980. // this.handleData(value)
  981. // }
  982. // }
  983. // },
  984. // 根据最近检定时间动态计算对应有效期至
  985. 'form.yiXiaoRiQi': {
  986. handler (value) {
  987. if (value) {
  988. if (this.isFirstyiXiaoRiQi) {
  989. this.isFirstyiXiaoRiQi = false
  990. return
  991. }
  992. const zhouQi = this.form.xiaoZhunZQ || 0
  993. const result = this.$common.getFormatDate('string', 10, this.$common.getDate('month', Number(zhouQi), value))
  994. this.form.xiaoZhunYouXia = result
  995. }
  996. }
  997. }
  998. },
  999. mounted () {
  1000. console.log(this.params)
  1001. this.init()
  1002. },
  1003. methods: {
  1004. // 根据供应商自动带出供应商名称和电话
  1005. shiFouQiJianHChange (key, data) {
  1006. this.form.lianXiFangShi = data.lian_xi_dian_hua_
  1007. this.form.gongYingShang = data.gong_ying_shang_m
  1008. },
  1009. changeData (...args) {
  1010. this.form[args[0]] = args[1]
  1011. },
  1012. handleData (departmentId) {
  1013. // JSON_UNQUOTE( JSON_EXTRACT( AUTHORITY_NAME, '$.chaYue' ) )
  1014. const sql = `select
  1015. id_ AS leiXingId,
  1016. AUTHORITY_NAME AS chaYueValue
  1017. FROM
  1018. ibps_cat_type
  1019. WHERE
  1020. category_key_ = 'FILE_TYPE'
  1021. AND AUTHORITY_NAME LIKE '%"${departmentId}"%'
  1022. AND name_ = '设备使用说明书'`
  1023. // console.log(sql)
  1024. const { deptList = [] } = this.$store.getters || {}
  1025. const dept = deptList.find((i) => i.positionId === departmentId)
  1026. this.$common.request('sql', sql).then((res) => {
  1027. const { data = [] } = res.variables || {}
  1028. this.form.wenJianXiLei = `外部文件 / ${dept?.positionName} / 设备使用说明书`
  1029. if (!data.length) {
  1030. return
  1031. }
  1032. const { leiXingId, chaYueValue } = data[0] || {}
  1033. this.form.xiLeiId = leiXingId
  1034. this.form.quanXianLeiXing = JSON.parse(chaYueValue).chaYue
  1035. this.form.zhuanYeBuMen = departmentId
  1036. })
  1037. },
  1038. handleClick () {
  1039. },
  1040. handleActionEvent ({ key }) {
  1041. switch (key) {
  1042. case 'cancel':
  1043. this.closeDialog(true)
  1044. break
  1045. case 'save':
  1046. this.goSave('close')
  1047. break
  1048. default:
  1049. break
  1050. }
  1051. },
  1052. // 获取人员部门
  1053. getPersonPosition (id) {
  1054. const userList = this.$store.getters.userList
  1055. const bianzhiUserid = userList.find(i => i.userId === id)
  1056. if (bianzhiUserid) {
  1057. return bianzhiUserid.positionId
  1058. }
  1059. },
  1060. isDateMoreThenSecondDay (firstTime, secondTime) {
  1061. if (!firstTime || !secondTime) {
  1062. return false
  1063. }
  1064. return new Date(firstTime).getTime() > new Date(secondTime).getTime()
  1065. },
  1066. async checkRequired (flag) {
  1067. if (this.form.xiaoZhunWuCha === '是' && !this.form.caiGouHeTong) {
  1068. throw new Error('请填写限用范围!')
  1069. }
  1070. if (this.form.accessoriesDevicePoList.length > 0) {
  1071. for (let i = 0; i < this.form.accessoriesDevicePoList.length; i++) {
  1072. const item = this.form.accessoriesDevicePoList[i]
  1073. if (!item.mingCheng) {
  1074. throw new Error(`附属设备及配件第${i + 1}行名称缺失!`)
  1075. }
  1076. if (!item.guiGeXingHao1) {
  1077. throw new Error(`附属设备及配件第${i + 1}行规格型号缺失!`)
  1078. }
  1079. if (!item.danWei) {
  1080. throw new Error(`附属设备及配件第${i + 1}行单位缺失!`)
  1081. }
  1082. if (!item.shuLiang) {
  1083. throw new Error(`附属设备及配件第${i + 1}行数量缺失!`)
  1084. }
  1085. }
  1086. }
  1087. const sysDeviceNo = this.form.sheBeiShiBieH
  1088. const originalDeviceNo = this.form.yuanSheBeiBian
  1089. const position = this.form.diDian
  1090. const sql = `select count(1) as num from t_sbdj where yuan_she_bei_bian = '${originalDeviceNo}' and di_dian_ = '${position}' and she_bei_shi_bie_h <> '${sysDeviceNo}' limit 1`
  1091. const result = await this.$common.request('sql', sql)
  1092. const { data = [] } = result.variables || {}
  1093. if (data[0].num > 0) {
  1094. throw new Error(`系统当前已经存在此原设备编号,请更换另一个编号!`)
  1095. }
  1096. const exFactoryTime = this.form.chuChangRiQi
  1097. const reviceTime = this.form.jieShouRiQi
  1098. const useTime = this.form.qiYongRiQi
  1099. // 如果有出厂日期,则接收日期必须在出厂日期之后,投入日期必须在出厂日期之后
  1100. // 校验接收日期是否在投入日期之前
  1101. if (exFactoryTime && reviceTime) {
  1102. if (this.isDateMoreThenSecondDay(exFactoryTime, reviceTime)) {
  1103. throw new Error(`该设备的接收日期不得早于出厂日期!`)
  1104. }
  1105. }
  1106. if (exFactoryTime && useTime) {
  1107. if (this.isDateMoreThenSecondDay(exFactoryTime, useTime)) {
  1108. throw new Error(`该设备的投入日期不得早于出厂日期!`)
  1109. }
  1110. }
  1111. if (reviceTime && useTime) {
  1112. if (this.isDateMoreThenSecondDay(reviceTime, useTime)) {
  1113. throw new Error(`该设备的投入日期不得早于接收日期!`)
  1114. }
  1115. }
  1116. },
  1117. async goAdd () {
  1118. try {
  1119. this.loading = true
  1120. await saveEquipmentCard(this.form)
  1121. this.$message.success('添加成功')
  1122. this.closeDialog(true)
  1123. this.loading = false
  1124. } catch (error) {
  1125. console.log(error)
  1126. this.$message.warning('添加失败')
  1127. this.loading = false
  1128. }
  1129. },
  1130. async subForm (id, table, parentData) {
  1131. const sql1 = `select id_ from ${table} where parent_id_='${id}'`
  1132. const { variables: { data }} = await this.$common.request('sql', sql1)
  1133. const pre_list = data.length > 0 ? data.map(item => item.id_) : []
  1134. const update_list = []
  1135. const add_list = []
  1136. parentData.forEach(item => {
  1137. if (item.id) {
  1138. update_list.push(item)
  1139. } else {
  1140. add_list.push(item)
  1141. }
  1142. })
  1143. const delete_list = pre_list.filter(id => !update_list.map(item => item.id).includes(id))
  1144. return {
  1145. add_list,
  1146. update_list,
  1147. delete_list
  1148. }
  1149. },
  1150. async goEdit (flag) {
  1151. try {
  1152. this.loading = true
  1153. await saveEquipmentCard(this.form)
  1154. this.$message.success('修改成功')
  1155. this.closeDialog(true)
  1156. this.loading = false
  1157. } catch (error) {
  1158. this.$message.warning(error.message)
  1159. this.loading = false
  1160. throw new Error(error.message)
  1161. }
  1162. },
  1163. goSave (flag) {
  1164. this.$refs.form.validate(async (valid) => {
  1165. if (valid) {
  1166. try {
  1167. // 维护项目
  1168. this.form.maintenanceItemPoList = this.$refs.MaintenanceRef?.[0]?.listDataCopy || this.form.maintenanceItemPoList || []
  1169. // 附属设备及配件
  1170. this.form.accessoriesDevicePoList = this.$refs.MoreDevicesRef?.[0]?.listDataCopy || this.form.accessoriesDevicePoList || []
  1171. await this.checkRequired()
  1172. if (this.isEdit) {
  1173. this.goEdit(flag)
  1174. } else {
  1175. this.goAdd()
  1176. }
  1177. } catch (error) {
  1178. this.$message.warning(error.message)
  1179. }
  1180. } else {
  1181. return this.$message.warning('请填写必填项!')
  1182. }
  1183. })
  1184. },
  1185. // 刷新
  1186. async goRefresh () {
  1187. },
  1188. // 关闭当前窗口
  1189. closeDialog (needRefresh) {
  1190. this.dialogVisible = false
  1191. if (needRefresh) {
  1192. this.$emit('close')
  1193. }
  1194. },
  1195. // 检查设备编号是否重复
  1196. async checkIsRepeat (id) {
  1197. const sql = `select id_ from t_sbdj where she_bei_shi_bie_h='${id}' limit 1`
  1198. const { variables: { data }} = await this.$common.request('sql', sql)
  1199. return data.length > 0
  1200. },
  1201. generateRandomString () {
  1202. return `JYK-${Math.floor(Math.random() * 88888) + 10000}`
  1203. },
  1204. async init () {
  1205. this.loading = true
  1206. this.isEdit = !!(this.params && this.params.id)
  1207. this.isSheKou = this.deptList[0].positionId === '1166372468122714112' // 判断是否是蛇口医院
  1208. // 加载tab
  1209. const sql = `select tabs_option_ from t_ipcc where org_ = '${this.org}' limit 1`
  1210. const { variables: { data: optionData }} = await this.$common.request('sql', sql)
  1211. if (optionData.length > 0 && optionData?.[0]?.tabs_option_) {
  1212. const optionArr = optionData[0].tabs_option_.split(',')
  1213. const newTab = []
  1214. for (let i = 0; i < optionArr.length; i++) {
  1215. const item = optionArr[i]
  1216. const t = this.tabItems.find(j => j.label === item)
  1217. if (t) {
  1218. newTab.push(t)
  1219. }
  1220. }
  1221. this.tabItems = newTab
  1222. }
  1223. console.log('tab', this.tabItems)
  1224. if (this.isEdit) {
  1225. const { data } = await getequipmentCard({ id: this.params.id })
  1226. this.form = data
  1227. } else {
  1228. this.isFirstbianZhiBuMen = false
  1229. this.isFirstyiXiaoRiQi = false
  1230. // 随机生成一个不重复的设备编号
  1231. this.form.sheBeiShiBieH = this.generateRandomString()
  1232. for (; await this.checkIsRepeat(this.form.sheBeiShiBieH);) {
  1233. this.form.sheBeiShiBieH = this.generateRandomString()
  1234. }
  1235. this.form.jieShouRiQi = dayjs().format('YYYY-MM-DD')
  1236. this.form.qiYongRiQi = dayjs().format('YYYY-MM-DD')
  1237. this.form.xiaoZhunWuCha = '否'
  1238. this.form.jieShouZhuangTai = '新设备'
  1239. this.form.bianZhiRen = this.userId
  1240. const pos = this.position.split(',')
  1241. this.form.bianZhiBuMen = pos[pos.length - 1]
  1242. this.form.bianZhiShiJian = dayjs().format('YYYY-MM-DD HH:mm')
  1243. this.form.shiFouGuoShen = '已完成'
  1244. this.form.sheBeiLeiXing = '检验系统'
  1245. this.form.sheBeiZhuangTa = '合格'
  1246. this.form.shiFouXiaoZhun = '是'
  1247. this.form.jianKongYiJu = '否'
  1248. this.form.shiFouWeiHu = '是'
  1249. this.form.diDian = this.level
  1250. }
  1251. this.loading = false
  1252. }
  1253. }
  1254. }
  1255. </script>
  1256. <style lang="scss" scoped>
  1257. .paper-detail-dialog {
  1258. ::v-deep {
  1259. .el-dialog__header {
  1260. text-align: center;
  1261. }
  1262. }
  1263. .dialog-title{
  1264. display: flex;
  1265. align-items: center;
  1266. justify-content: center;
  1267. div{
  1268. z-index: 99999999;
  1269. position: absolute;
  1270. right:8vw;
  1271. }
  1272. .dialogtitle{
  1273. font-size: 22px;
  1274. font-family: SimHei;
  1275. font-weight: bold;
  1276. color: #222;
  1277. }
  1278. }
  1279. .container {
  1280. display: flex;
  1281. width: 100%;
  1282. justify-content: center;
  1283. .el-row{
  1284. margin: 0 !important;
  1285. }
  1286. .required{
  1287. color: #606266 !important;
  1288. &::before{
  1289. content: '*';
  1290. margin: 0 4px 0 -7.5px;
  1291. color: #F56C6C;
  1292. }
  1293. }
  1294. .left{
  1295. height: calc(100vh - 100px);
  1296. box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  1297. padding:20px;
  1298. overflow-y: auto;
  1299. .form{
  1300. margin-left: -20px;
  1301. }
  1302. .item{
  1303. width: 100%;
  1304. }
  1305. .title{
  1306. margin: 16px 0 6px -16px;
  1307. }
  1308. .tabs{
  1309. margin-top: 40px;
  1310. }
  1311. .question-icon{
  1312. margin-left: 2px;
  1313. }
  1314. }
  1315. }
  1316. }
  1317. ::v-deep {
  1318. .el-form-item__label{
  1319. text-align: left;
  1320. font-size: 12px !important;
  1321. }
  1322. .el-form-item__content{
  1323. font-size: 12px !important;
  1324. display: flex;
  1325. }
  1326. .el-table th {
  1327. background-color:#f5f7fa !important;
  1328. }
  1329. .el-tabs__header {
  1330. margin: 0 0 30px !important;
  1331. }
  1332. .ibps-image{
  1333. width: 100%;
  1334. .ibps-p-0{
  1335. width: 100%;
  1336. .list-group{
  1337. display: flex;
  1338. align-items: center;
  1339. gap: 20px;
  1340. flex-wrap: wrap;
  1341. }
  1342. }
  1343. }
  1344. }
  1345. </style>