associationConfiguration.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  1. <!--关联配置-->
  2. <template>
  3. <div class="associationConfiguration scrollbar-box">
  4. <el-form v-if="versionField() != 'xiBeiNongLinDaXue'" 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="请输入型号" disabled 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. <el-form v-if="versionField() == 'xiBeiNongLinDaXue'" ref="form" :model="form" label-width="160px" :rules="rules">
  151. <div class="title-box">
  152. <p class="left-title">危险源信息</p>
  153. </div>
  154. <el-form-item label="气瓶存放总量" prop="bottleTotal" class="form-item input-number-none-box-left">
  155. <el-input
  156. oninput="value=value.replace(/[^0-9.]/g,'')"
  157. style="width:320px;"
  158. v-model="form.bottleTotal"
  159. placeholder="请输入数量"
  160. maxLength="3"
  161. clearable
  162. />
  163. </el-form-item>
  164. <el-form-item label="气瓶单人可存放总量" prop="bottleUserTotal" class="form-item input-number-none-box-left">
  165. <el-input
  166. oninput="value=value.replace(/[^0-9.]/g,'')"
  167. style="width:320px;"
  168. v-model="form.bottleUserTotal"
  169. placeholder="请输入数量"
  170. clearable
  171. maxLength="3"
  172. />
  173. </el-form-item>
  174. <div>
  175. <el-form-item label="危险源" prop="hazardId" class="form-item">
  176. <el-select placeholder="请选择危险源" v-model="hazardId" style="width:320px;" @change="hazardClick">
  177. <el-option
  178. v-for="dict in hazardList"
  179. :key="dict.id"
  180. :label="dict.text"
  181. :value="dict.id"
  182. ></el-option>
  183. </el-select>
  184. </el-form-item>
  185. </div>
  186. <div class="hazard-for-box" v-for="(item,index) in form.hazardRelations">
  187. <el-form-item label="危险源名称" :prop="'hazardRelations.'+ index +'.anotherName'" :rules="rules.anotherName"
  188. class="form-item" label-width="160px">
  189. <el-input placeholder="请输入危险源名称" maxlength="20" v-model="item.anotherName"/>
  190. </el-form-item>
  191. <el-form-item label="型号" :prop="'hazardRelations.'+ index +'.anotherCode'" :rules="rules.anotherCode"
  192. class="form-item" label-width="60px">
  193. <el-input placeholder="请输入型号" disabled maxlength="10" v-model="item.anotherCode"/>
  194. </el-form-item>
  195. <el-form-item label="" class="form-item" label-width="20px">
  196. <span class="del-hazard el-icon-error" style="line-height:40px;font-size:24px;" @click="delHazard(index)"></span>
  197. </el-form-item>
  198. </div>
  199. <div class="bottom-button-box">
  200. <p class="reset-button-one left-button" @click="backPage">取消</p>
  201. <p class="inquire-button-one right-button" @click="upData">提交</p>
  202. </div>
  203. </el-form>
  204. </div>
  205. </template>
  206. <script>
  207. import { listHazard } from "@/api/permissionRequired";
  208. import { updateSubjectEditJoinHazard } from "@/api/laboratory/subject";
  209. import { getBottleInfo} from "@/api/gasManage3_0/gasManage";
  210. export default {
  211. name: "associationConfiguration",
  212. props:{
  213. subjectData:{},
  214. },
  215. data() {
  216. return {
  217. onepcOutcheckIn:[],
  218. onepcOutcheck:[],
  219. hazardList:[],
  220. form:{},
  221. rules:{
  222. anotherName:[
  223. {required: true, message: '请输入危险源名称', trigger: 'blur'},
  224. { required: true, message: "请输入危险源名称", validator: this.spaceJudgment, trigger: "blur" }
  225. ],
  226. anotherCode:[
  227. {required: true, message: '请输入型号', trigger: 'blur'},
  228. { required: true, message: "请输入型号", validator: this.spaceJudgment, trigger: "blur" }
  229. ],
  230. },
  231. hazardId:"",
  232. }
  233. },
  234. created() {
  235. },
  236. mounted(){
  237. let self = this;
  238. //获取气瓶存放总量
  239. this.getBottleInfo();
  240. this.getDicts("sub_check_in").then(response => {
  241. this.onepcOutcheckIn = response.data;
  242. });
  243. this.getDicts("lab_onepc_outcheck").then(response => {
  244. this.onepcOutcheck = response.data;
  245. });
  246. this.listHazard();
  247. if(this.subjectData.id){
  248. this.form.id = this.subjectData.id;
  249. }
  250. if(this.subjectData.signTime) {
  251. this.$set(this.form,'signTime',this.subjectData.signTime);
  252. }
  253. /** 检查项信息*/
  254. if(this.subjectData.checkIn){
  255. let list = this.subjectData.checkIn.split(",");
  256. this.$set(this.form,'checkIn',list);
  257. // this.form.checkIn = this.subjectData.checkIn.split(",");
  258. }else{
  259. this.$set(this.form,'checkIn',[]);
  260. }
  261. if(this.subjectData.checkOut){
  262. let list = this.subjectData.checkOut.split(",");
  263. this.$set(this.form,'checkOut',list);
  264. // this.form.checkOut = this.subjectData.checkOut.split(",");
  265. }
  266. if(this.subjectData.skipped && this.subjectData.skipped!=null){
  267. this.$set(this.form,'skipped',this.subjectData.skipped)
  268. }else{
  269. this.$set(this.form,'skipped',0)
  270. }
  271. if(this.subjectData.checkCount){
  272. this.$set(this.form,'checkCount',this.subjectData.checkCount)
  273. }else{
  274. this.$set(this.form,'checkCount',0)
  275. }
  276. /** 检查项信息-巡查人员*/
  277. if(this.subjectData.inspectCheckIn){
  278. let list = this.subjectData.inspectCheckIn.split(",");
  279. this.$set(this.form,'inspectCheckIn',list);
  280. }else{
  281. this.$set(this.form,'inspectCheckIn',[]);
  282. }
  283. if(this.subjectData.inspectSkipped && this.subjectData.inspectSkipped!=null){
  284. this.$set(this.form,'inspectSkipped',this.subjectData.inspectSkipped)
  285. }else{
  286. this.$set(this.form,'inspectSkipped',0)
  287. }
  288. if(this.subjectData.inspectSignTime) {
  289. this.$set(this.form,'inspectSignTime',this.subjectData.inspectSignTime);
  290. }
  291. if(this.subjectData.inspectCheckCount){
  292. this.$set(this.form,'inspectCheckCount',this.subjectData.inspectCheckCount)
  293. }else{
  294. this.$set(this.form,'inspectCheckCount',0)
  295. }
  296. if(this.subjectData.labHazardList){
  297. let list = [];
  298. for(let i=0;i<self.subjectData.labHazardList.length;i++){
  299. list.push({
  300. hazardId:self.subjectData.labHazardList[i].id,
  301. anotherName:self.subjectData.labHazardList[i].anotherName,
  302. anotherCode:self.subjectData.labHazardList[i].anotherCode
  303. })
  304. }
  305. this.$set(this.form,'hazardRelations',list)
  306. }
  307. this.radioChange();
  308. },
  309. methods:{
  310. //删除选中危险源
  311. delHazard(index){
  312. this.form.hazardRelations.splice(index, 1);
  313. this.$forceUpdate();
  314. },
  315. //危险源选中事件
  316. hazardClick(e){
  317. let self = this;
  318. for(let i=0;i<self.hazardList.length;i++){
  319. if(e == self.hazardList[i].id){
  320. this.form.hazardRelations.push({
  321. hazardId:self.hazardList[i].id,
  322. anotherName:self.hazardList[i].anotherName,
  323. anotherCode:self.hazardList[i].anotherCode
  324. });
  325. }
  326. }
  327. this.$forceUpdate();
  328. },
  329. radioChange(){
  330. if(this.form.skipped == 0){
  331. let obj = {
  332. checkIn:[
  333. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  334. ]
  335. };
  336. this.$set(this,'rules',obj);
  337. }else if(this.form.skipped == 1){
  338. if(this.form.checkIn[0]){
  339. let obj = {
  340. checkIn:[
  341. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  342. ]
  343. };
  344. this.$set(this,'rules',obj);
  345. }else{
  346. this.$set(this,'rules',{});
  347. this.$refs['form'].clearValidate();
  348. }
  349. }
  350. // if(e == 1){
  351. // this.$set(this,'rules',{});
  352. // this.$refs['form'].clearValidate();
  353. // }else if(e == 0){
  354. // let obj = {
  355. // checkIn:[
  356. // {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  357. // ]
  358. // }
  359. // this.$set(this,'rules',obj);
  360. // }
  361. },
  362. /**巡检人员 */
  363. radioChange2(){
  364. if(this.form.inspectSkipped == 0){
  365. let obj = {
  366. inspectCheckIn:[
  367. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  368. ]
  369. };
  370. this.$set(this,'rules',obj);
  371. }else if(this.form.inspectSkipped == 1){
  372. if(this.form.inspectCheckIn[0]){
  373. let obj = {
  374. inspectCheckIn:[
  375. {required: true, message: '请选择穿戴检查项目', trigger: 'blur'}
  376. ]
  377. };
  378. this.$set(this,'rules',obj);
  379. }else{
  380. this.$set(this,'rules',{});
  381. this.$refs['form'].clearValidate();
  382. }
  383. }
  384. },
  385. addNum(){
  386. if(this.form.checkCount<99){
  387. this.form.checkCount++
  388. }
  389. },
  390. reduceNum(){
  391. if(this.form.checkCount>2){
  392. this.form.checkCount--
  393. }
  394. },
  395. addNumOne(){
  396. if(this.form.signTime<99){
  397. this.form.signTime++
  398. }
  399. },
  400. reduceNumOne(){
  401. if(this.form.signTime>2){
  402. this.form.signTime--
  403. }
  404. },
  405. //获取气瓶存放总量
  406. getBottleInfo(){
  407. getBottleInfo({subjectId:this.subjectData.id}).then(response=>{
  408. let res=response.data;
  409. if(response.code==200){
  410. if(res.bottleTotal && res.bottleUserTotal){
  411. this.$set(this.form,'bottleUserTotal',res.bottleUserTotal);
  412. this.$set(this.form,'bottleTotal',res.bottleTotal);
  413. // this.form.bottleUserTotal=res.bottleUserTotal;
  414. // this.form.bottleTotal=res.bottleTotal;
  415. }
  416. }
  417. })
  418. },
  419. //获取危险源列表
  420. listHazard(){
  421. listHazard({}).then(response=>{
  422. for(let i=0;i<response.data.length;i++){
  423. response.data[i].text = response.data[i].anotherName+'-'+response.data[i].anotherCode
  424. }
  425. this.$set(this,'hazardList',response.data);
  426. })
  427. },
  428. upData(){
  429. let self = this;
  430. this.$refs["form"].validate(valid => {
  431. if (valid) {
  432. if(self.form.skipped == 1 && self.form.checkCount<2 && self.form.checkIn[0]){
  433. this.msgError('穿戴检查识别上限不能小于2')
  434. return
  435. }
  436. if(self.form.inspectSkipped == 1 && self.form.inspectCheckCount<2 && self.form.inspectCheckIn[0]){
  437. this.msgError('穿戴检查识别上限不能小于2')
  438. return
  439. }
  440. for(let i=0;i<self.form.hazardRelations.length;i++){
  441. let num = 0;
  442. for(let o=0;o<self.form.hazardRelations.length;o++){
  443. if(self.form.hazardRelations[i].anotherName == self.form.hazardRelations[o].anotherName){
  444. num++
  445. }
  446. if(num > 1){
  447. this.msgError('危险源名称重复:'+self.form.hazardRelations[i].anotherName);
  448. return
  449. }
  450. }
  451. }
  452. self.$confirm('是否确认提交?', "", {
  453. confirmButtonText: "确定",
  454. cancelButtonText: "取消",
  455. type: "warning"
  456. }).then(function() {
  457. self.updateSubjectEditJoinHazard();
  458. }).then(() => {}).catch(() => {});
  459. }
  460. })
  461. },
  462. updateSubjectEditJoinHazard(){
  463. let self = this;
  464. let obj = {
  465. id:self.form.id,
  466. skipped:self.form.skipped,
  467. inspectSkipped:self.form.inspectSkipped,
  468. }
  469. if(self.form.skipped == 1 && self.form.checkIn[0]){
  470. obj.checkCount = self.form.checkCount
  471. }
  472. if(self.form.checkIn) {
  473. obj.checkIn = self.form.checkIn.join() ;
  474. }
  475. if(self.form.signTime) {
  476. obj.signTime = self.form.signTime;
  477. }else{
  478. obj.signTime=0;
  479. }
  480. if(self.form.checkOut) {
  481. obj.checkOut = self.form.checkOut.join() ;
  482. }
  483. /**巡检人员 */
  484. if(self.form.inspectSkipped == 1 && self.form.inspectCheckIn[0]){
  485. obj.inspectCheckCount = self.form.inspectCheckCount
  486. }
  487. if(self.form.inspectCheckIn) {
  488. obj.inspectCheckIn = self.form.inspectCheckIn.join() ;
  489. }
  490. if(self.form.inspectSignTime) {
  491. obj.inspectSignTime = self.form.inspectSignTime;
  492. }else{
  493. obj.inspectSignTime=0;
  494. }
  495. if (self.form.hazardRelations[0]){
  496. obj.hazardRelations = self.form.hazardRelations
  497. }
  498. if(self.form.bottleUserTotal) {
  499. obj.bottleUserTotal = self.form.bottleUserTotal;
  500. }
  501. if(self.form.bottleTotal) {
  502. obj.bottleTotal = self.form.bottleTotal;
  503. }
  504. // if(self.form.hazardRelations) {
  505. // let list = self.form.hazardRelations;
  506. // let newList = [];
  507. // for(let i=0;i<list.length;i++){
  508. // let newObj = {
  509. // hazardId:list[i],
  510. // };
  511. // newList.push(newObj);
  512. // }
  513. // obj.hazardRelations = newList;
  514. // }
  515. updateSubjectEditJoinHazard(obj).then(response => {
  516. this.msgSuccess("修改成功");
  517. this.$parent.clickPage(1);
  518. });
  519. },
  520. //返回上一页
  521. backPage(){
  522. this.$parent.clickPage(1);
  523. },
  524. }
  525. }
  526. </script>
  527. <style lang="scss" scoped>
  528. .associationConfiguration{
  529. flex:1;
  530. display: flex;
  531. flex-direction: column;
  532. border-radius:10px!important;
  533. margin:5px 20px 20px 10px!important;
  534. box-shadow: 0 0 8px 1px rgba(0, 0, 0, 0.1) !important;
  535. *{
  536. margin:0;
  537. }
  538. .title-box{
  539. display: flex;
  540. margin:0 20px 30px;
  541. border-bottom:1px solid #E0E0E0;
  542. .left-title{
  543. flex:1;
  544. height:80px;
  545. line-height:80px;
  546. color:#0045AF;
  547. font-size:18px;
  548. }
  549. .right-button{
  550. margin:20px 0;
  551. }
  552. }
  553. .form-item{
  554. display: inline-block;
  555. overflow: hidden;
  556. min-height:70px;
  557. }
  558. .hazard-for-box{
  559. .del-hazard{
  560. color:#dedede;
  561. }
  562. .del-hazard:hover{
  563. cursor: pointer;
  564. color:#FF6666;
  565. }
  566. }
  567. .bottom-button-box{
  568. display: flex;
  569. width:400px;
  570. margin:10px auto 40px;
  571. .null-p{
  572. flex:1;
  573. }
  574. .left-button{
  575. margin-right:20px;
  576. }
  577. }
  578. }
  579. </style>