associationConfiguration.vue 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525
  1. <!--关联配置-->
  2. <template>
  3. <div class="associationConfiguration scrollbar-box">
  4. <el-form ref="form" :model="form" label-width="160px" :rules="rules">
  5. <div class="title-box">
  6. <p class="left-title">检查项信息</p>
  7. </div>
  8. <div>
  9. <el-form-item label="穿戴检查项" prop="checkIn" class="form-item" v-if="form.checkIn">
  10. <el-select v-model="form.checkIn" multiple placeholder="请选择穿戴检查项目" @change="radioChange" style="width:320px;">
  11. <el-option
  12. v-for="dict in onepcOutcheckIn"
  13. :key="dict.dictValue"
  14. :label="dict.dictLabel"
  15. :value="dict.dictValue"
  16. ></el-option>
  17. </el-select>
  18. </el-form-item>
  19. <el-form-item label="穿戴检查可跳过" prop="skipped" class="form-item">
  20. <el-radio-group v-model="form.skipped" style="width:260px;" @change="radioChange">
  21. <el-radio :label="1" style="width:100px;margin-left:50px;margin-top:4px;">是</el-radio>
  22. <el-radio :label="0" style="width:100px;margin-top:4px;">否</el-radio>
  23. </el-radio-group>
  24. </el-form-item>
  25. <el-form-item label="穿戴检查识别上限" prop="checkCount" class="form-item" v-if="form.skipped == 1 && form.checkIn[0]">
  26. <el-input placeholder="请输入内容" oninput="value=value.replace(/[^0-9.]/g,'')" maxlength="2" v-model="form.checkCount" style="width:320px;">
  27. <template slot="prepend" style="height:20px;">次</template>
  28. <div slot="append" style="display: flex;flex-direction: column;">
  29. <p class="el-icon-arrow-up" @click="addNum" style="line-height:18px;width:30px;font-size:14px;text-align: center;border-bottom:1px solid #E0E0E0;cursor: pointer;"></p>
  30. <p class="el-icon-arrow-down" @click="reduceNum" style="line-height:19px;width:30px;font-size:14px;text-align: center;cursor: pointer;"></p>
  31. </div>
  32. </el-input>
  33. </el-form-item>
  34. </div>
  35. <div>
  36. <el-form-item label="离开时检查项" prop="checkOutArr" class="form-item">
  37. <el-select v-model="form.checkOut" multiple placeholder="请选择离开检查项" style="width:320px;">
  38. <el-option
  39. v-for="dict in onepcOutcheck"
  40. :key="dict.dictValue"
  41. :label="dict.dictLabel"
  42. :value="dict.dictValue"
  43. ></el-option>
  44. </el-select>
  45. </el-form-item>
  46. <el-form-item label="签到有效时间" prop="signTime" class="form-item">
  47. <el-input placeholder="请输入内容" oninput="value=value.replace(/[^0-9.]/g,'')" maxlength="2" v-model="form.signTime" style="width:320px;">
  48. <template slot="prepend" style="height:20px;">小时</template>
  49. <div slot="append" style="display: flex;flex-direction: column;">
  50. <p class="el-icon-arrow-up" @click="addNumOne" style="line-height:18px;width:30px;font-size:14px;text-align: center;border-bottom:1px solid #E0E0E0;cursor: pointer;"></p>
  51. <p class="el-icon-arrow-down" @click="reduceNumOne" style="line-height:19px;width:30px;font-size:14px;text-align: center;cursor: pointer;"></p>
  52. </div>
  53. </el-input>
  54. </el-form-item>
  55. </div>
  56. <div class="title-box">
  57. <p class="left-title">检查项信息(巡查人员)</p>
  58. </div>
  59. <div>
  60. <el-form-item label="穿戴检查项" prop="inspectCheckIn" class="form-item" v-if="form.inspectCheckIn">
  61. <el-select v-model="form.inspectCheckIn" multiple placeholder="请选择穿戴检查项目" @change="radioChange2" style="width:320px;">
  62. <el-option
  63. v-for="dict in onepcOutcheckIn"
  64. :key="dict.dictValue"
  65. :label="dict.dictLabel"
  66. :value="dict.dictValue"
  67. ></el-option>
  68. </el-select>
  69. </el-form-item>
  70. <el-form-item label="穿戴检查可跳过" prop="inspectSkipped" class="form-item">
  71. <el-radio-group v-model="form.inspectSkipped" style="width:260px;" @change="radioChange2">
  72. <el-radio :label="1" style="width:100px;margin-left:50px;margin-top:4px;">是</el-radio>
  73. <el-radio :label="0" style="width:100px;margin-top:4px;">否</el-radio>
  74. </el-radio-group>
  75. </el-form-item>
  76. <el-form-item label="穿戴检查识别上限" prop="inspectCheckCount" class="form-item" v-if="form.inspectSkipped == 1 && form.inspectCheckIn[0]">
  77. <el-input placeholder="请输入内容" oninput="value=value.replace(/[^0-9.]/g,'')" maxlength="2" v-model="form.inspectCheckCount" style="width:320px;">
  78. <template slot="prepend" style="height:20px;">次</template>
  79. <div slot="append" style="display: flex;flex-direction: column;">
  80. <p class="el-icon-arrow-up" @click="addNum" style="line-height:18px;width:30px;font-size:14px;text-align: center;border-bottom:1px solid #E0E0E0;cursor: pointer;"></p>
  81. <p class="el-icon-arrow-down" @click="reduceNum" style="line-height:19px;width:30px;font-size:14px;text-align: center;cursor: pointer;"></p>
  82. </div>
  83. </el-input>
  84. </el-form-item>
  85. </div>
  86. <div>
  87. <el-form-item label="签到有效时间" prop="inspectSignTime" class="form-item">
  88. <el-input placeholder="请输入内容" oninput="value=value.replace(/[^0-9.]/g,'')" maxlength="2" v-model="form.inspectSignTime" style="width:320px;">
  89. <template slot="prepend" style="height:20px;">小时</template>
  90. <div slot="append" style="display: flex;flex-direction: column;">
  91. <p class="el-icon-arrow-up" @click="addNumOne" style="line-height:18px;width:30px;font-size:14px;text-align: center;border-bottom:1px solid #E0E0E0;cursor: pointer;"></p>
  92. <p class="el-icon-arrow-down" @click="reduceNumOne" style="line-height:19px;width:30px;font-size:14px;text-align: center;cursor: pointer;"></p>
  93. </div>
  94. </el-input>
  95. </el-form-item>
  96. </div>
  97. <div class="title-box">
  98. <p class="left-title">危险源信息</p>
  99. </div>
  100. <el-form-item label="气瓶存放总量" prop="bottleTotal" class="form-item input-number-none-box-left">
  101. <el-input
  102. oninput="value=value.replace(/[^0-9.]/g,'')"
  103. style="width:320px;"
  104. v-model="form.bottleTotal"
  105. placeholder="请输入数量"
  106. maxLength="3"
  107. clearable
  108. />
  109. </el-form-item>
  110. <el-form-item label="气瓶单人可存放总量" prop="bottleUserTotal" class="form-item input-number-none-box-left">
  111. <el-input
  112. oninput="value=value.replace(/[^0-9.]/g,'')"
  113. style="width:320px;"
  114. v-model="form.bottleUserTotal"
  115. placeholder="请输入数量"
  116. clearable
  117. maxLength="3"
  118. />
  119. </el-form-item>
  120. <div>
  121. <el-form-item label="危险源" prop="hazardId" class="form-item">
  122. <el-select placeholder="请选择危险源" v-model="hazardId" style="width:320px;" @change="hazardClick">
  123. <el-option
  124. v-for="dict in hazardList"
  125. :key="dict.id"
  126. :label="dict.text"
  127. :value="dict.id"
  128. ></el-option>
  129. </el-select>
  130. </el-form-item>
  131. </div>
  132. <div class="hazard-for-box" v-for="(item,index) in form.hazardRelations">
  133. <el-form-item label="危险源名称" :prop="'hazardRelations.'+ index +'.anotherName'" :rules="rules.anotherName"
  134. class="form-item" label-width="160px">
  135. <el-input placeholder="请输入危险源名称" maxlength="20" v-model="item.anotherName"/>
  136. </el-form-item>
  137. <el-form-item label="型号" :prop="'hazardRelations.'+ index +'.anotherCode'" :rules="rules.anotherCode"
  138. class="form-item" label-width="60px">
  139. <el-input placeholder="请输入型号" maxlength="10" v-model="item.anotherCode"/>
  140. </el-form-item>
  141. <el-form-item label="" class="form-item" label-width="20px">
  142. <span class="del-hazard el-icon-error" style="line-height:40px;font-size:24px;" @click="delHazard(index)"></span>
  143. </el-form-item>
  144. </div>
  145. <div class="bottom-button-box">
  146. <p class="reset-button-one left-button" @click="backPage">取消</p>
  147. <p class="inquire-button-one right-button" @click="upData">提交</p>
  148. </div>
  149. </el-form>
  150. </div>
  151. </template>
  152. <script>
  153. import { listHazard } from "@/api/permissionRequired";
  154. import { updateSubjectEditJoinHazard } from "@/api/laboratory/subject";
  155. import { getBottleInfo} from "@/api/gasManage3_0/gasManage";
  156. export default {
  157. name: "associationConfiguration",
  158. props:{
  159. subjectData:{},
  160. },
  161. data() {
  162. return {
  163. onepcOutcheckIn:[],
  164. onepcOutcheck:[],
  165. hazardList:[],
  166. form:{},
  167. rules:{
  168. anotherName:[
  169. {required: true, message: '请输入危险源名称', trigger: 'blur'},
  170. { required: true, message: "请输入危险源名称", validator: this.spaceJudgment, trigger: "blur" }
  171. ],
  172. anotherCode:[
  173. {required: true, message: '请输入型号', trigger: 'blur'},
  174. { required: true, message: "请输入型号", validator: this.spaceJudgment, trigger: "blur" }
  175. ],
  176. },
  177. hazardId:"",
  178. }
  179. },
  180. created() {
  181. },
  182. mounted(){
  183. let self = this;
  184. //获取气瓶存放总量
  185. this.getBottleInfo();
  186. this.getDicts("sub_check_in").then(response => {
  187. this.onepcOutcheckIn = response.data;
  188. });
  189. this.getDicts("lab_onepc_outcheck").then(response => {
  190. this.onepcOutcheck = response.data;
  191. });
  192. this.listHazard();
  193. if(this.subjectData.id){
  194. this.form.id = this.subjectData.id;
  195. }
  196. if(this.subjectData.signTime) {
  197. this.$set(this.form,'signTime',this.subjectData.signTime);
  198. }
  199. /** 检查项信息*/
  200. if(this.subjectData.checkIn){
  201. let list = this.subjectData.checkIn.split(",");
  202. this.$set(this.form,'checkIn',list);
  203. // this.form.checkIn = this.subjectData.checkIn.split(",");
  204. }else{
  205. this.$set(this.form,'checkIn',[]);
  206. }
  207. if(this.subjectData.checkOut){
  208. let list = this.subjectData.checkOut.split(",");
  209. this.$set(this.form,'checkOut',list);
  210. // this.form.checkOut = this.subjectData.checkOut.split(",");
  211. }
  212. if(this.subjectData.skipped && this.subjectData.skipped!=null){
  213. this.$set(this.form,'skipped',this.subjectData.skipped)
  214. }else{
  215. this.$set(this.form,'skipped',0)
  216. }
  217. if(this.subjectData.checkCount){
  218. this.$set(this.form,'checkCount',this.subjectData.checkCount)
  219. }else{
  220. this.$set(this.form,'checkCount',0)
  221. }
  222. /** 检查项信息-巡查人员*/
  223. if(this.subjectData.inspectCheckIn){
  224. let list = this.subjectData.inspectCheckIn.split(",");
  225. this.$set(this.form,'inspectCheckIn',list);
  226. }else{
  227. this.$set(this.form,'inspectCheckIn',[]);
  228. }
  229. if(this.subjectData.inspectSkipped && this.subjectData.inspectSkipped!=null){
  230. this.$set(this.form,'inspectSkipped',this.subjectData.inspectSkipped)
  231. }else{
  232. this.$set(this.form,'inspectSkipped',0)
  233. }
  234. if(this.subjectData.inspectSignTime) {
  235. this.$set(this.form,'inspectSignTime',this.subjectData.inspectSignTime);
  236. }
  237. if(this.subjectData.inspectCheckCount){
  238. this.$set(this.form,'inspectCheckCount',this.subjectData.inspectCheckCount)
  239. }else{
  240. this.$set(this.form,'inspectCheckCount',0)
  241. }
  242. if(this.subjectData.labHazardList){
  243. let list = [];
  244. for(let i=0;i<self.subjectData.labHazardList.length;i++){
  245. list.push({
  246. hazardId:self.subjectData.labHazardList[i].id,
  247. anotherName:self.subjectData.labHazardList[i].anotherName,
  248. anotherCode:self.subjectData.labHazardList[i].anotherCode
  249. })
  250. }
  251. this.$set(this.form,'hazardRelations',list)
  252. }
  253. this.radioChange();
  254. },
  255. methods:{
  256. //删除选中危险源
  257. delHazard(index){
  258. this.form.hazardRelations.splice(index, 1);
  259. this.$forceUpdate();
  260. },
  261. //危险源选中事件
  262. hazardClick(e){
  263. let self = this;
  264. for(let i=0;i<self.hazardList.length;i++){
  265. if(e == self.hazardList[i].id){
  266. this.form.hazardRelations.push({
  267. hazardId:self.hazardList[i].id,
  268. anotherName:self.hazardList[i].anotherName,
  269. anotherCode:self.hazardList[i].anotherCode
  270. });
  271. }
  272. }
  273. this.$forceUpdate();
  274. },
  275. radioChange(){
  276. if(this.form.skipped == 0){
  277. let obj = {
  278. checkIn:[
  279. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  280. ]
  281. };
  282. this.$set(this,'rules',obj);
  283. }else if(this.form.skipped == 1){
  284. if(this.form.checkIn[0]){
  285. let obj = {
  286. checkIn:[
  287. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  288. ]
  289. };
  290. this.$set(this,'rules',obj);
  291. }else{
  292. this.$set(this,'rules',{});
  293. this.$refs['form'].clearValidate();
  294. }
  295. }
  296. // if(e == 1){
  297. // this.$set(this,'rules',{});
  298. // this.$refs['form'].clearValidate();
  299. // }else if(e == 0){
  300. // let obj = {
  301. // checkIn:[
  302. // {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  303. // ]
  304. // }
  305. // this.$set(this,'rules',obj);
  306. // }
  307. },
  308. /**巡检人员 */
  309. radioChange2(){
  310. if(this.form.inspectSkipped == 0){
  311. let obj = {
  312. inspectCheckIn:[
  313. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  314. ]
  315. };
  316. this.$set(this,'rules',obj);
  317. }else if(this.form.inspectSkipped == 1){
  318. if(this.form.inspectCheckIn[0]){
  319. let obj = {
  320. inspectCheckIn:[
  321. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  322. ]
  323. };
  324. this.$set(this,'rules',obj);
  325. }else{
  326. this.$set(this,'rules',{});
  327. this.$refs['form'].clearValidate();
  328. }
  329. }
  330. },
  331. addNum(){
  332. if(this.form.checkCount<99){
  333. this.form.checkCount++
  334. }
  335. },
  336. reduceNum(){
  337. if(this.form.checkCount>2){
  338. this.form.checkCount--
  339. }
  340. },
  341. addNumOne(){
  342. if(this.form.signTime<99){
  343. this.form.signTime++
  344. }
  345. },
  346. reduceNumOne(){
  347. if(this.form.signTime>2){
  348. this.form.signTime--
  349. }
  350. },
  351. //获取气瓶存放总量
  352. getBottleInfo(){
  353. getBottleInfo({subjectId:this.subjectData.id}).then(response=>{
  354. let res=response.data;
  355. if(response.code==200){
  356. if(res.bottleTotal && res.bottleUserTotal){
  357. this.$set(this.form,'bottleUserTotal',res.bottleUserTotal);
  358. this.$set(this.form,'bottleTotal',res.bottleTotal);
  359. // this.form.bottleUserTotal=res.bottleUserTotal;
  360. // this.form.bottleTotal=res.bottleTotal;
  361. }
  362. }
  363. })
  364. },
  365. //获取危险源列表
  366. listHazard(){
  367. listHazard({}).then(response=>{
  368. for(let i=0;i<response.data.length;i++){
  369. response.data[i].text = response.data[i].anotherName+'-'+response.data[i].anotherCode
  370. }
  371. this.$set(this,'hazardList',response.data);
  372. })
  373. },
  374. upData(){
  375. let self = this;
  376. this.$refs["form"].validate(valid => {
  377. if (valid) {
  378. if(self.form.skipped == 1 && self.form.checkCount<2 && self.form.checkIn[0]){
  379. this.msgError('穿戴检查识别上限不能小于2')
  380. return
  381. }
  382. if(self.form.inspectSkipped == 1 && self.form.inspectCheckCount<2 && self.form.inspectCheckIn[0]){
  383. this.msgError('穿戴检查识别上限不能小于2')
  384. return
  385. }
  386. self.$confirm('是否确认提交?', "", {
  387. confirmButtonText: "确定",
  388. cancelButtonText: "取消",
  389. type: "warning"
  390. }).then(function() {
  391. self.updateSubjectEditJoinHazard();
  392. }).then(() => {}).catch(() => {});
  393. }
  394. })
  395. },
  396. updateSubjectEditJoinHazard(){
  397. let self = this;
  398. let obj = {
  399. id:self.form.id,
  400. skipped:self.form.skipped,
  401. inspectSkipped:self.form.inspectSkipped,
  402. }
  403. if(self.form.skipped == 1 && self.form.checkIn[0]){
  404. obj.checkCount = self.form.checkCount
  405. }
  406. if(self.form.checkIn) {
  407. obj.checkIn = self.form.checkIn.join() ;
  408. }
  409. if(self.form.signTime) {
  410. obj.signTime = self.form.signTime;
  411. }else{
  412. obj.signTime=0;
  413. }
  414. if(self.form.checkOut) {
  415. obj.checkOut = self.form.checkOut.join() ;
  416. }
  417. /**巡检人员 */
  418. if(self.form.inspectSkipped == 1 && self.form.inspectCheckIn[0]){
  419. obj.inspectCheckCount = self.form.inspectCheckCount
  420. }
  421. if(self.form.inspectCheckIn) {
  422. obj.inspectCheckIn = self.form.inspectCheckIn.join() ;
  423. }
  424. if(self.form.inspectSignTime) {
  425. obj.inspectSignTime = self.form.inspectSignTime;
  426. }else{
  427. obj.inspectSignTime=0;
  428. }
  429. if (self.form.hazardRelations[0]){
  430. obj.hazardRelations = self.form.hazardRelations
  431. }
  432. if(self.form.bottleUserTotal) {
  433. obj.bottleUserTotal = self.form.bottleUserTotal;
  434. }
  435. if(self.form.bottleTotal) {
  436. obj.bottleTotal = self.form.bottleTotal;
  437. }
  438. // if(self.form.hazardRelations) {
  439. // let list = self.form.hazardRelations;
  440. // let newList = [];
  441. // for(let i=0;i<list.length;i++){
  442. // let newObj = {
  443. // hazardId:list[i],
  444. // };
  445. // newList.push(newObj);
  446. // }
  447. // obj.hazardRelations = newList;
  448. // }
  449. updateSubjectEditJoinHazard(obj).then(response => {
  450. this.msgSuccess("修改成功");
  451. this.$parent.clickPage(1);
  452. });
  453. },
  454. //返回上一页
  455. backPage(){
  456. this.$parent.clickPage(1);
  457. },
  458. }
  459. }
  460. </script>
  461. <style lang="scss" scoped>
  462. .associationConfiguration{
  463. flex:1;
  464. display: flex;
  465. flex-direction: column;
  466. border-radius:10px!important;
  467. margin:5px 20px 20px 10px!important;
  468. box-shadow: 0 0 8px 1px rgba(0, 0, 0, 0.1) !important;
  469. *{
  470. margin:0;
  471. }
  472. .title-box{
  473. display: flex;
  474. margin:0 20px 30px;
  475. border-bottom:1px solid #E0E0E0;
  476. .left-title{
  477. flex:1;
  478. height:80px;
  479. line-height:80px;
  480. color:#0045AF;
  481. font-size:18px;
  482. }
  483. .right-button{
  484. margin:20px 0;
  485. }
  486. }
  487. .form-item{
  488. display: inline-block;
  489. overflow: hidden;
  490. min-height:70px;
  491. }
  492. .hazard-for-box{
  493. .del-hazard{
  494. color:#dedede;
  495. }
  496. .del-hazard:hover{
  497. cursor: pointer;
  498. color:#FF6666;
  499. }
  500. }
  501. .bottom-button-box{
  502. display: flex;
  503. width:400px;
  504. margin:10px auto 40px;
  505. .null-p{
  506. flex:1;
  507. }
  508. .left-button{
  509. margin-right:20px;
  510. }
  511. }
  512. }
  513. </style>