deviceDialog.vue 75 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354
  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>{{ form.sheBeiZhuangTa }}</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. },
  757. data () {
  758. const { userId, position, level, deptList } = this.$store.getters
  759. return {
  760. tabItems: [
  761. { label: '维护项目', name: 'two', ref: 'MaintenanceRef', data: 'maintenanceItemPoList', component: 'Maintenance', isKeepAlive: false },
  762. { label: '附属设备及配件', name: 'three', ref: 'MoreDevicesRef', data: 'accessoriesDevicePoList', component: 'MoreDevices', isKeepAlive: false },
  763. { label: '使用与维护记录', name: 'four', component: 'MaintenanceRecord', isKeepAlive: true },
  764. { label: '校准记录', name: 'five', component: 'CalibrationCheckRecord', isKeepAlive: true },
  765. { label: '维修记录', name: 'six', component: 'RepairRecord', isKeepAlive: true },
  766. { label: '停用、报废记录', name: 'seven', component: 'ScrappedRecord', isKeepAlive: true }
  767. ],
  768. filter: [{
  769. descVal: '1',
  770. includeSub: true,
  771. old: 'position',
  772. partyId: this.$store.getters.userInfo.employee.positions,
  773. partyName: '',
  774. scriptContent: '',
  775. type: 'user',
  776. userType: 'position'
  777. }],
  778. isFirstyiXiaoRiQi: true,
  779. isFirstbianZhiBuMen: true,
  780. isSheKou: false,
  781. readonly: false,
  782. activeName: 'one',
  783. dialogVisible: true,
  784. userId: userId,
  785. position: position,
  786. deptList: deptList,
  787. level: level.second || level.first,
  788. org: level.first || '',
  789. loading: false,
  790. title: '设备档案卡',
  791. toolbars: [
  792. { key: 'save', label: '保存' },
  793. { key: 'cancel', label: '退出', type: 'danger', icon: 'ibps-icon-close' }
  794. ],
  795. initWidth: '1480px',
  796. isEdit: false,
  797. isFinished: false,
  798. preParams: {},
  799. Ids: [],
  800. form: {
  801. gouJinRiQi: '', // 购进日期
  802. changShang: '', // 厂家/品牌
  803. guiGeXingHao: '', // 规格型号
  804. jieShouRiQi: '', // 接收日期
  805. qiYongRiQi: '', // 投入日期
  806. cunFangDiDian: '',
  807. cunFangWeiZhi: '', // 放置地点
  808. jieShouZhuangTai: '', // 接收时状态
  809. guanLiRen: '', // 保管人
  810. weiHuFangShi: '', // 设备分组
  811. bianZhiRen: '', // 建档人
  812. bianZhiBuMen: '', // 建档部门
  813. bianZhiShiJian: '', // 建档时间
  814. shiFouGuoShen: '',
  815. sheBeiLeiXing: '', // 设备类型
  816. sheBeiZhuangTa: '', // 设备状态
  817. sheBeiShiBieH: '', // 设备编号
  818. shiFouXiaoZhun: '', // 是否校准
  819. gongYingShang: '',
  820. shiFouQiJianH: '', // 供应商id
  821. lianXiFangShi: '', // 供应商电话
  822. xiaoZhunYouXia: '', // 校准有效期至
  823. chuChangRiQi: '', // 出厂日期
  824. sheBeiMingCheng: '', // 设备名称
  825. sheBeiMingChen: '', // 设备名称id
  826. yiXiaoRiQi: '', // 最近校准时间
  827. heChaXiaoZhun: '', // 使用年限
  828. shiJiShiYongF: '', // 关机时间
  829. kaiShiShiYong: '', // 开机时间
  830. zhengShuBianHa: '', // 校准证书编号
  831. xiaoZhunWuCha: '', // 是否限用
  832. xiaoZhunZQ: '', // 检定/校准周期
  833. shiYongKeShi: '', // 检定/校准单位
  834. yuanSheBeiBian: '', // 原设备编号
  835. jianKongYiJu: '', // 是否24H开机
  836. biXuDeHuanJin: '', // 核查人
  837. biXuSheShi: '', // 核查日期
  838. ziChanYuanZhi: '', // 资产原值
  839. ziChanBianHao: '', // 固定资产号
  840. shiFouWeiHu: '', // 是否维护
  841. jiShenXuHao: '', // 出厂编号
  842. yanShouRiQi: '', // 验收日期
  843. huanJingYaoQiu: '', // 环境要求
  844. dianYuanYaoQiu: '', // 电源要求
  845. zhuCeZhengHao: '', // 注册证号
  846. yqzp: '', // 附件上传
  847. faPiao: '', // 资质证书
  848. fuJianShang: '', // 设备使用说明书
  849. beiZhu: '', // 设备图片
  850. caiGouHeTong: '', // 限用范围
  851. zhuanYeBuMen: '',
  852. wenJianXiLei: '', // 附件细类
  853. xiLeiId: '',
  854. quanXianLeiXing: '',
  855. diDian: '',
  856. buMen: '', // 图片id
  857. ceLiangGongZuo: '', // 测量范围
  858. jianDingXiao: '', // 检定/校准参数
  859. xiuZhengZhiXiu: '', // 修正值
  860. zuiDaYunCha: '', // U/精确度/最大允差
  861. shiWuShuoMing: '' // 校准机构
  862. },
  863. rules: {
  864. sheBeiMingCheng: [
  865. { required: true, message: '设备名称不能为空', trigger: 'blur' }
  866. ],
  867. sheBeiShiBieH: [
  868. { required: true, message: '设备编号不能为空', trigger: 'blur' }
  869. ],
  870. yuanSheBeiBian: [
  871. { required: true, message: '原设备编号不能为空', trigger: 'blur' }
  872. ],
  873. sheBeiLeiXing: [
  874. { required: true, message: '设备类型不能为空', trigger: 'blur' }
  875. ],
  876. sheBeiZhuangTa: [
  877. { required: true, message: '设备状态不能为空', trigger: 'blur' }
  878. ],
  879. guiGeXingHao: [
  880. { required: true, message: '规格型号不能为空', trigger: 'blur' }
  881. ],
  882. bianZhiBuMen: [
  883. { required: true, message: '建档部门不能为空', trigger: 'blur' }
  884. ],
  885. bianZhiRen: [
  886. { required: true, message: '建档人不能为空', trigger: 'blur' }
  887. ],
  888. bianZhiShiJian: [
  889. { required: true, message: '建档时间不能为空', trigger: 'blur' }
  890. ],
  891. jieShouZhuangTai: [
  892. { required: true, message: '接收时状态不能为空', trigger: 'blur' }
  893. ],
  894. guanLiRen: [
  895. { required: true, message: '保管人不能为空', trigger: 'blur' }
  896. ],
  897. cunFangWeiZhi: [
  898. { required: true, message: '放置地点不能为空', trigger: 'blur' }
  899. ],
  900. shiFouXiaoZhun: [
  901. { required: true, message: '是否校准不能为空', trigger: 'blur' }
  902. ],
  903. sheBeiMingChen: [
  904. { required: true, message: '请选择设备', trigger: 'blur' }
  905. ],
  906. chuChangRiQi: [
  907. { required: true, message: '出厂日期不能为空', trigger: 'blur' }
  908. ]
  909. }
  910. }
  911. },
  912. computed: {
  913. photos () {
  914. if (this.form.beiZhu) {
  915. const photos = JSON.parse(this.form.beiZhu)
  916. photos.forEach(item => {
  917. item.url = getImage(item.id)
  918. })
  919. return photos
  920. }
  921. return []
  922. }
  923. },
  924. watch: {
  925. photos: {
  926. handler (val) {
  927. this.form.buMen = val.map(item => item.id).join(',')
  928. }
  929. },
  930. 'form.xiaoZhunWuCha': {
  931. handler (val, old) {
  932. if (!old) return
  933. if (val === '否') {
  934. this.form.sheBeiZhuangTa = '合格'
  935. } else if (val === '是') {
  936. this.form.caiGouHeTong = ''
  937. this.form.sheBeiZhuangTa = '限用'
  938. }
  939. }
  940. },
  941. 'form.cunFangWeiZhi': {
  942. async handler (val) {
  943. if (!val) return
  944. const sql = `select fang_jian_ming_ha from t_jjqfjb where id_='${val}'`
  945. const { variables: { data }} = await this.$common.request('sql', sql)
  946. this.form.cunFangDiDian = data[0].fang_jian_ming_ha
  947. }
  948. },
  949. 'form.sheBeiMingChen': {
  950. async handler (val) {
  951. if (this.isEdit) return
  952. const sql = `select * from t_yqsbysb where id_='${val}'`
  953. const { variables: { data }} = await this.$common.request('sql', sql)
  954. if (data.length > 0) {
  955. this.form.sheBeiMingCheng = data[0].ming_cheng_str_
  956. this.form.guiGeXingHao = data[0].xing_hao_gui_ge_
  957. this.form.jiShenXuHao = data[0].chu_chang_bian_ha
  958. this.form.changShang = data[0].sheng_chan_chang_
  959. this.form.yuanSheBeiBian = data[0].she_bei_bian_hao_
  960. }
  961. }
  962. },
  963. // 根据编制部门动态获取对应文件存放处数据
  964. // 'form.bianZhiBuMen': {
  965. // handler (value) {
  966. // if (value) {
  967. // if (this.isFirstbianZhiBuMen) {
  968. // this.isFirstbianZhiBuMen = false
  969. // return
  970. // }
  971. // this.handleData(value)
  972. // }
  973. // }
  974. // },
  975. // 根据最近检定时间动态计算对应有效期至
  976. 'form.yiXiaoRiQi': {
  977. handler (value) {
  978. if (value) {
  979. if (this.isFirstyiXiaoRiQi) {
  980. this.isFirstyiXiaoRiQi = false
  981. return
  982. }
  983. const zhouQi = this.form.xiaoZhunZQ || 0
  984. const result = this.$common.getFormatDate('string', 10, this.$common.getDate('month', Number(zhouQi), value))
  985. this.form.xiaoZhunYouXia = result
  986. }
  987. }
  988. }
  989. },
  990. mounted () {
  991. console.log(this.params)
  992. this.init()
  993. },
  994. methods: {
  995. // 根据供应商自动带出供应商名称和电话
  996. shiFouQiJianHChange (key, data) {
  997. this.form.lianXiFangShi = data.lian_xi_dian_hua_
  998. this.form.gongYingShang = data.gong_ying_shang_m
  999. },
  1000. changeData (...args) {
  1001. this.form[args[0]] = args[1]
  1002. },
  1003. handleData (departmentId) {
  1004. // JSON_UNQUOTE( JSON_EXTRACT( AUTHORITY_NAME, '$.chaYue' ) )
  1005. const sql = `select
  1006. id_ AS leiXingId,
  1007. AUTHORITY_NAME AS chaYueValue
  1008. FROM
  1009. ibps_cat_type
  1010. WHERE
  1011. category_key_ = 'FILE_TYPE'
  1012. AND AUTHORITY_NAME LIKE '%"${departmentId}"%'
  1013. AND name_ = '设备使用说明书'`
  1014. // console.log(sql)
  1015. const { deptList = [] } = this.$store.getters || {}
  1016. const dept = deptList.find((i) => i.positionId === departmentId)
  1017. this.$common.request('sql', sql).then((res) => {
  1018. const { data = [] } = res.variables || {}
  1019. this.form.wenJianXiLei = `外部文件 / ${dept?.positionName} / 设备使用说明书`
  1020. if (!data.length) {
  1021. return
  1022. }
  1023. const { leiXingId, chaYueValue } = data[0] || {}
  1024. this.form.xiLeiId = leiXingId
  1025. this.form.quanXianLeiXing = JSON.parse(chaYueValue).chaYue
  1026. this.form.zhuanYeBuMen = departmentId
  1027. })
  1028. },
  1029. handleClick () {
  1030. },
  1031. handleActionEvent ({ key }) {
  1032. switch (key) {
  1033. case 'cancel':
  1034. this.closeDialog(true)
  1035. break
  1036. case 'save':
  1037. this.goSave('close')
  1038. break
  1039. default:
  1040. break
  1041. }
  1042. },
  1043. // 获取人员部门
  1044. getPersonPosition (id) {
  1045. const userList = this.$store.getters.userList
  1046. const bianzhiUserid = userList.find(i => i.userId === id)
  1047. if (bianzhiUserid) {
  1048. return bianzhiUserid.positionId
  1049. }
  1050. },
  1051. isDateMoreThenSecondDay (firstTime, secondTime) {
  1052. if (!firstTime || !secondTime) {
  1053. return false
  1054. }
  1055. return new Date(firstTime).getTime() > new Date(secondTime).getTime()
  1056. },
  1057. async checkRequired (flag) {
  1058. if (this.form.xiaoZhunWuCha === '是' && !this.form.caiGouHeTong) {
  1059. throw new Error('请填写限用范围!')
  1060. }
  1061. if (this.form.accessoriesDevicePoList.length > 0) {
  1062. for (let i = 0; i < this.form.accessoriesDevicePoList.length; i++) {
  1063. const item = this.form.accessoriesDevicePoList[i]
  1064. if (!item.mingCheng) {
  1065. throw new Error(`附属设备及配件第${i + 1}行名称缺失!`)
  1066. }
  1067. if (!item.guiGeXingHao1) {
  1068. throw new Error(`附属设备及配件第${i + 1}行规格型号缺失!`)
  1069. }
  1070. if (!item.danWei) {
  1071. throw new Error(`附属设备及配件第${i + 1}行单位缺失!`)
  1072. }
  1073. if (!item.shuLiang) {
  1074. throw new Error(`附属设备及配件第${i + 1}行数量缺失!`)
  1075. }
  1076. }
  1077. }
  1078. const sysDeviceNo = this.form.sheBeiShiBieH
  1079. const originalDeviceNo = this.form.yuanSheBeiBian
  1080. const position = this.form.diDian
  1081. 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`
  1082. const result = await this.$common.request('sql', sql)
  1083. const { data = [] } = result.variables || {}
  1084. if (data[0].num > 0) {
  1085. throw new Error(`系统当前已经存在此原设备编号,请更换另一个编号!`)
  1086. }
  1087. const exFactoryTime = this.form.chuChangRiQi
  1088. const reviceTime = this.form.jieShouRiQi
  1089. const useTime = this.form.qiYongRiQi
  1090. // 如果有出厂日期,则接收日期必须在出厂日期之后,投入日期必须在出厂日期之后
  1091. // 校验接收日期是否在投入日期之前
  1092. if (exFactoryTime && reviceTime) {
  1093. if (this.isDateMoreThenSecondDay(exFactoryTime, reviceTime)) {
  1094. throw new Error(`该设备的接收日期不得早于出厂日期!`)
  1095. }
  1096. }
  1097. if (exFactoryTime && useTime) {
  1098. if (this.isDateMoreThenSecondDay(exFactoryTime, useTime)) {
  1099. throw new Error(`该设备的投入日期不得早于出厂日期!`)
  1100. }
  1101. }
  1102. if (reviceTime && useTime) {
  1103. if (this.isDateMoreThenSecondDay(reviceTime, useTime)) {
  1104. throw new Error(`该设备的投入日期不得早于接收日期!`)
  1105. }
  1106. }
  1107. },
  1108. async goAdd () {
  1109. try {
  1110. this.loading = true
  1111. await saveEquipmentCard(this.form)
  1112. this.$message.success('添加成功')
  1113. this.closeDialog(true)
  1114. this.loading = false
  1115. } catch (error) {
  1116. console.log(error)
  1117. this.$message.warning('添加失败')
  1118. this.loading = false
  1119. }
  1120. },
  1121. async subForm (id, table, parentData) {
  1122. const sql1 = `select id_ from ${table} where parent_id_='${id}'`
  1123. const { variables: { data }} = await this.$common.request('sql', sql1)
  1124. const pre_list = data.length > 0 ? data.map(item => item.id_) : []
  1125. const update_list = []
  1126. const add_list = []
  1127. parentData.forEach(item => {
  1128. if (item.id) {
  1129. update_list.push(item)
  1130. } else {
  1131. add_list.push(item)
  1132. }
  1133. })
  1134. const delete_list = pre_list.filter(id => !update_list.map(item => item.id).includes(id))
  1135. return {
  1136. add_list,
  1137. update_list,
  1138. delete_list
  1139. }
  1140. },
  1141. async goEdit (flag) {
  1142. try {
  1143. this.loading = true
  1144. await saveEquipmentCard(this.form)
  1145. this.$message.success('修改成功')
  1146. this.closeDialog(true)
  1147. this.loading = false
  1148. } catch (error) {
  1149. this.$message.warning(error.message)
  1150. this.loading = false
  1151. throw new Error(error.message)
  1152. }
  1153. },
  1154. goSave (flag) {
  1155. this.$refs.form.validate(async (valid) => {
  1156. if (valid) {
  1157. try {
  1158. // 维护项目
  1159. this.form.maintenanceItemPoList = this.$refs.MaintenanceRef?.[0]?.listDataCopy || this.form.maintenanceItemPoList || []
  1160. // 附属设备及配件
  1161. this.form.accessoriesDevicePoList = this.$refs.MoreDevicesRef?.[0]?.listDataCopy || this.form.accessoriesDevicePoList || []
  1162. await this.checkRequired()
  1163. if (this.isEdit) {
  1164. this.goEdit(flag)
  1165. } else {
  1166. this.goAdd()
  1167. }
  1168. } catch (error) {
  1169. this.$message.warning(error.message)
  1170. }
  1171. } else {
  1172. return this.$message.warning('请填写必填项!')
  1173. }
  1174. })
  1175. },
  1176. // 刷新
  1177. async goRefresh () {
  1178. },
  1179. // 关闭当前窗口
  1180. closeDialog (needRefresh) {
  1181. this.dialogVisible = false
  1182. if (needRefresh) {
  1183. this.$emit('close')
  1184. }
  1185. },
  1186. // 检查设备编号是否重复
  1187. async checkIsRepeat (id) {
  1188. const sql = `select id_ from t_sbdj where she_bei_shi_bie_h='${id}' limit 1`
  1189. const { variables: { data }} = await this.$common.request('sql', sql)
  1190. return data.length > 0
  1191. },
  1192. generateRandomString () {
  1193. return `JYK-${Math.floor(Math.random() * 88888) + 10000}`
  1194. },
  1195. async init () {
  1196. this.loading = true
  1197. this.isEdit = !!(this.params && this.params.id)
  1198. this.isSheKou = this.deptList[0].positionId === '1166372468122714112' // 判断是否是蛇口医院
  1199. // 加载tab
  1200. const sql = `select tabs_option_ from t_ipcc where org_ = '${this.org}' limit 1`
  1201. const { variables: { data: optionData }} = await this.$common.request('sql', sql)
  1202. if (optionData.length > 0 && optionData?.[0]?.tabs_option_) {
  1203. const optionArr = optionData[0].tabs_option_.split(',')
  1204. const newTab = []
  1205. for (let i = 0; i < optionArr.length; i++) {
  1206. const item = optionArr[i]
  1207. const t = this.tabItems.find(j => j.label === item)
  1208. if (t) {
  1209. newTab.push(t)
  1210. }
  1211. }
  1212. this.tabItems = newTab
  1213. }
  1214. console.log('tab', this.tabItems)
  1215. if (this.isEdit) {
  1216. const { data } = await getequipmentCard({ id: this.params.id })
  1217. this.form = data
  1218. } else {
  1219. this.isFirstbianZhiBuMen = false
  1220. this.isFirstyiXiaoRiQi = false
  1221. // 随机生成一个不重复的设备编号
  1222. this.form.sheBeiShiBieH = this.generateRandomString()
  1223. for (; await this.checkIsRepeat(this.form.sheBeiShiBieH);) {
  1224. this.form.sheBeiShiBieH = this.generateRandomString()
  1225. }
  1226. this.form.jieShouRiQi = dayjs().format('YYYY-MM-DD')
  1227. this.form.qiYongRiQi = dayjs().format('YYYY-MM-DD')
  1228. this.form.xiaoZhunWuCha = '否'
  1229. this.form.jieShouZhuangTai = '新设备'
  1230. this.form.bianZhiRen = this.userId
  1231. const pos = this.position.split(',')
  1232. this.form.bianZhiBuMen = pos[pos.length - 1]
  1233. this.form.bianZhiShiJian = dayjs().format('YYYY-MM-DD HH:mm')
  1234. this.form.shiFouGuoShen = '已完成'
  1235. this.form.sheBeiLeiXing = '检验系统'
  1236. this.form.sheBeiZhuangTa = '合格'
  1237. this.form.shiFouXiaoZhun = '是'
  1238. this.form.jianKongYiJu = '否'
  1239. this.form.shiFouWeiHu = '是'
  1240. this.form.diDian = this.level
  1241. }
  1242. this.loading = false
  1243. }
  1244. }
  1245. }
  1246. </script>
  1247. <style lang="scss" scoped>
  1248. .paper-detail-dialog {
  1249. ::v-deep {
  1250. .el-dialog__header {
  1251. text-align: center;
  1252. }
  1253. }
  1254. .dialog-title{
  1255. display: flex;
  1256. align-items: center;
  1257. justify-content: center;
  1258. div{
  1259. z-index: 99999999;
  1260. position: absolute;
  1261. right:8vw;
  1262. }
  1263. .dialogtitle{
  1264. font-size: 22px;
  1265. font-family: SimHei;
  1266. font-weight: bold;
  1267. color: #222;
  1268. }
  1269. }
  1270. .container {
  1271. display: flex;
  1272. width: 100%;
  1273. justify-content: center;
  1274. .el-row{
  1275. margin: 0 !important;
  1276. }
  1277. .required{
  1278. color: #606266 !important;
  1279. &::before{
  1280. content: '*';
  1281. margin: 0 4px 0 -7.5px;
  1282. color: #F56C6C;
  1283. }
  1284. }
  1285. .left{
  1286. height: calc(100vh - 100px);
  1287. box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  1288. padding:20px;
  1289. overflow-y: auto;
  1290. .form{
  1291. margin-left: -20px;
  1292. }
  1293. .item{
  1294. width: 100%;
  1295. }
  1296. .title{
  1297. margin: 16px 0 6px -16px;
  1298. }
  1299. .tabs{
  1300. margin-top: 40px;
  1301. }
  1302. .question-icon{
  1303. margin-left: 2px;
  1304. }
  1305. }
  1306. }
  1307. }
  1308. ::v-deep {
  1309. .el-form-item__label{
  1310. text-align: left;
  1311. font-size: 12px !important;
  1312. }
  1313. .el-form-item__content{
  1314. font-size: 12px !important;
  1315. display: flex;
  1316. }
  1317. .el-table th {
  1318. background-color:#f5f7fa !important;
  1319. }
  1320. .el-tabs__header {
  1321. margin: 0 0 30px !important;
  1322. }
  1323. .ibps-image{
  1324. width: 100%;
  1325. .ibps-p-0{
  1326. width: 100%;
  1327. .list-group{
  1328. display: flex;
  1329. align-items: center;
  1330. gap: 20px;
  1331. flex-wrap: wrap;
  1332. }
  1333. }
  1334. }
  1335. }
  1336. </style>