examineDetail.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718
  1. <!-- 安全检查-检查详情 -->
  2. <template>
  3. <view class="examine">
  4. <scroll-view scroll-y @scrolltolower="scrollGet" class="info-max-box">
  5. <view class="basics">
  6. <view class="basics_li">
  7. <text>学院:</text>
  8. <text>{{infoData.collegeName}}</text>
  9. </view>
  10. <view class="basics_li">
  11. <text>实验室:</text>
  12. <text>{{infoData.subjectName}}-{{infoData.roomNumber}}</text>
  13. </view>
  14. <view class="basics_li">
  15. <text>楼栋:</text>
  16. <text>{{infoData.buildName?infoData.buildName:'-'}}</text>
  17. </view>
  18. <view class="basics_li">
  19. <text>检查类型:</text>
  20. <text>{{infoData.checkType==1?'校园巡查':(infoData.checkType==2?'实验室自查':'')}}</text>
  21. </view>
  22. <view class="basics_li">
  23. <text>检查范围:</text>
  24. <text>{{infoData.checkRange==1?'全校':(infoData.checkRange==2?'学院':'实验室')}}</text>
  25. </view>
  26. <view class="basics_li" >
  27. <text>计划标题:</text>
  28. <text>{{infoData.title}}</text>
  29. </view>
  30. <view class="demand" style="border:none;">
  31. <text>检查要求:</text>
  32. <text>{{infoData.checkDemand?infoData.checkDemand:''}}</text>
  33. </view>
  34. </view>
  35. <view class="attachment" v-if="infoData.isAttachment==1">
  36. <view class="attachment_t">
  37. <text>材料附件</text>
  38. <text>点击文件标题查看</text>
  39. </view>
  40. <view class="attachment_li" v-for="item in attachmentList">
  41. <img src="@/pages_safetyExamine/images/icon_djc_wj.png"/>
  42. <text @click="attachmentPreview(item)">{{item.fileName}}</text>
  43. <!-- <img class="attachment_li_del" src="@/images/Version3.3.3/icon_fjgk_sc.png"/> -->
  44. </view>
  45. </view>
  46. <view class="basics" v-if="manageStatus==2">
  47. <view class="basics_li">
  48. <text>检查结果:</text>
  49. <text>{{infoData.checkResult==0?'不符合':(infoData.checkResult==1?'符合':'')}}</text>
  50. </view>
  51. <view class="basics_li" v-if="infoData.checkResult==0">
  52. <text>整改期限:</text>
  53. <text>{{infoData.rectifyDeadline}}</text>
  54. </view>
  55. <view class="basics_li" v-if="infoData.checkResult==0">
  56. <text>整改通知:</text>
  57. <text style="color: #0183FA;" @click="rectifyInform">{{infoData.rectifyNotice == 1?'整改告知书':(infoData.rectifyNotice == 2?'整改通知书':'')}}</text>
  58. </view>
  59. <view class="basics_li">
  60. <text>检查者:</text>
  61. <text>{{infoData.checkUser}}</text>
  62. </view>
  63. <view class="basics_li" style="border:none;">
  64. <text>检查时间:</text>
  65. <text>{{infoData.checkTime}}</text>
  66. </view>
  67. </view>
  68. <view class="inconformity" @click="inconformityFun()" v-if="manageStatus==2 && infoData.checkResult==0">不符合项<img v-if="inconformityStatus" src="@/pages_safetyExamine/images/icon_bfhx_xq.png"/><img v-if="!inconformityStatus" src="@/pages_safetyExamine/images/icon_bfhx_sq.png"/></view>
  69. <view v-for="(item,index) in infoData.checkHazardDtoList" v-if="manageStatus==2 && infoData.checkResult==0">
  70. <view class="danger">
  71. <view class="sort">{{index+1}}</view>
  72. <view class="grade" :style="item.switch?'border-bottom: 1rpx solid #D8D8D8;':'border:none;'">
  73. <text>第{{index+1}}项隐患</text>
  74. <text style="color: #0183FA;" @click="dangerItem(item)">{{item.rectifyStatus==1?'已完成':(item.rectifyStatus==2?'待整改':(item.rectifyStatus==3?'待复核':(item.rectifyStatus==4?'暂无法整改':'')))}} >></text>
  75. </view>
  76. <view v-if="item.switch">
  77. <view class="grade">
  78. <text>隐患等级:</text>
  79. <text>{{item.hazardLevel==2?'一般隐患':(item.hazardLevel==1?'重大隐患':(item.hazardLevel==3?'管理问题':''))}}</text>
  80. </view>
  81. <view class="project">
  82. <view class="project_t">检查项目:</view>
  83. <view class="project_b">{{item.hazardCheckProStr}}</view>
  84. <view class="project_b2" v-if="item.hazardCheckCount>0">此检查项在当前实验室累计出现{{item.hazardCheckCount}}次隐患</view>
  85. </view>
  86. <view class="project">
  87. <view class="project_t">检查要点:</view>
  88. <view class="project_b">{{item.hazardCheckPoint}}</view>
  89. </view>
  90. <view class="project">
  91. <view class="project_t">隐患描述:</view>
  92. <view class="project_b">{{item.hazardDescribe}}</view>
  93. </view>
  94. <view class="picture">
  95. <view class="picture_t">隐患照片</view>
  96. <view class="picture_b" @click="lockImg(item.uploadDtoList)">
  97. <img :src="baseUrl+imgItem.fileUrl" v-for="(imgItem,imgIndex) in item.uploadDtoList"/>
  98. </view>
  99. </view>
  100. </view>
  101. </view>
  102. <view class="pack_up" @click="switchFun(item)">{{item.switch?'收起':'展开'}}<img v-if="item.switch" src="@/pages_safetyExamine/images/icon_06_1.png"/><img v-if="!item.switch" src="@/pages_safetyExamine/images/icon_06.png"/></view>
  103. </view>
  104. </scroll-view>
  105. <view class="report" @click="rectifyReport" v-if="manageStatus==2 && infoData.checkResult==0">整改报告</view>
  106. <view class="bottom_btn" v-if="manageStatus==0 && isSelfData==1" @click="handleClick('','startInspect')">开始检查</view>
  107. </view>
  108. </template>
  109. <script>
  110. import { config } from '@/api/request/config.js'
  111. import {checkSign,queryDeptSignByUserId,findCheckManage,findByPlanIdAttachment} from '@/api/index.js'
  112. export default {
  113. name: "rectifyList",
  114. components: {
  115. },
  116. data() {
  117. return {
  118. baseUrl:config.base_url,
  119. manageStatus:0,//0 待检查 1 检查中 2已检查
  120. pageType:0,
  121. inconformityStatus:false,
  122. infoData:{},
  123. isSelfData:'',
  124. attachmentList:[],
  125. }
  126. },
  127. onLoad(option) {
  128. if(option.id){
  129. this.id=option.id
  130. this.findCheckManage()
  131. }
  132. if(option.manageStatus){//检查状态
  133. this.manageStatus=option.manageStatus;
  134. }
  135. if(option.isSelfData){//0没有权限 1 有权限
  136. this.isSelfData=option.isSelfData;
  137. }
  138. if(option.manageStatus==0 || option.manageStatus==1){
  139. uni.setNavigationBarTitle({
  140. title:'待检查'
  141. })
  142. }else if(option.manageStatus==2){
  143. uni.setNavigationBarTitle({
  144. title:'已检查'
  145. })
  146. }
  147. },
  148. onShow() {
  149. },
  150. mounted(){
  151. },
  152. methods: {
  153. //滚动事件
  154. scrollGet(){
  155. },
  156. //开展检查
  157. handleClick(row,doType){
  158. if(doType=='startInspect'){
  159. uni.navigateTo({
  160. url: '/pages_safetyExamine/examineManage/examineAdd?id='+this.id
  161. });
  162. }
  163. },
  164. //根据计划id查询附件列表
  165. async findByPlanIdAttachment(){
  166. let _this = this;
  167. const {data} = await findByPlanIdAttachment({checkPlanId:this.infoData.checkPlanId});
  168. if(data.code == 200){
  169. _this.attachmentList=data.data;
  170. }
  171. },
  172. //详情
  173. async findCheckManage(){
  174. let _this = this;
  175. const {data} = await findCheckManage({id:this.id});
  176. if(data.code == 200){
  177. data.data.checkHazardDtoList.forEach(function(item){
  178. item.switch=false;
  179. })
  180. this.infoData=data.data;
  181. if(data.data.isAttachment==1){//0没有附件 1有附件
  182. this.findByPlanIdAttachment()
  183. }
  184. }
  185. },
  186. //附件查看
  187. attachmentPreview(item){
  188. uni.showLoading({
  189. title: '下载中'
  190. });
  191. wx.downloadFile({
  192. url: config.base_url+item.fileUrl,
  193. header: {
  194. Authorization: uni.getStorageSync('token')
  195. },
  196. success: function (res) {
  197. uni.hideLoading();
  198. const filePath = res.tempFilePath
  199. wx.openDocument({
  200. filePath: filePath,
  201. success: function (res) {
  202. console.log('打开文档成功')
  203. }
  204. })
  205. },
  206. fail: function (res){
  207. uni.hideLoading();
  208. uni.showToast({
  209. title: '下载失败',
  210. icon:"none",
  211. mask:true,
  212. duration: 2000
  213. });
  214. }
  215. })
  216. },
  217. //查看图片
  218. lockImg(list){
  219. console.log(list)
  220. if(!list[0]){
  221. return
  222. }
  223. let urlList=[];
  224. for(let i=0;i<list.length;i++){
  225. urlList.push(this.baseUrl+list[i].fileUrl)
  226. }
  227. wx.previewImage({
  228. urls: urlList, //需要预览的图片http链接列表,多张的时候,url直接写在后面就行了
  229. current: '', // 当前显示图片的http链接,默认是第一个
  230. success: function(res) {},
  231. fail: function(res) {},
  232. complete: function(res) {},
  233. })
  234. },
  235. //隐患项跳转详情
  236. dangerItem(row){
  237. uni.navigateTo({
  238. url: '/pages_safetyExamine/dangerManage/dangerDetail?item='+encodeURIComponent(JSON.stringify(row))
  239. })
  240. },
  241. //隐患项收起展开
  242. inconformityFun(){
  243. this.inconformityStatus=!this.inconformityStatus;
  244. if(this.inconformityStatus){
  245. this.infoData.checkHazardDtoList.forEach(function(item){
  246. item.switch=true;
  247. })
  248. }else{
  249. this.infoData.checkHazardDtoList.forEach(function(item){
  250. item.switch=false;
  251. })
  252. }
  253. },
  254. //隐患小项收起展开
  255. switchFun(item){
  256. item.switch=!item.switch
  257. },
  258. //整改通知
  259. rectifyInform(){//rectifyNotice 整改通知(1整改告知书 2整改通知书)
  260. if(this.infoData.rectifyNotice==1){//1整改告知书
  261. this.genReport(this.infoData.id)
  262. }else if(this.infoData.rectifyNotice==2){//2整改通知书
  263. this.genNotice(this.infoData.id)
  264. }
  265. },
  266. //整改报告
  267. rectifyReport(){
  268. console.log(1111)
  269. uni.showLoading({
  270. title: '下载中'
  271. });
  272. wx.downloadFile({
  273. url: config.base_url+'/zd-security/checkRectify/genReport/' + this.infoData.id,
  274. header: {
  275. Authorization: uni.getStorageSync('token')
  276. },
  277. success: function (res) {
  278. const fileManager = wx.getFileSystemManager()
  279. const filePath = wx.env.USER_DATA_PATH + '/(整改报告).docx'
  280. fileManager.saveFile({
  281. tempFilePath: res.tempFilePath,
  282. filePath,
  283. success: () => {
  284. uni.hideLoading();
  285. wx.openDocument({
  286. filePath: filePath,
  287. showMenu: true,
  288. fileType: 'docx'
  289. })
  290. },
  291. fail: function (res){
  292. uni.hideLoading();
  293. uni.showToast({
  294. title: '下载失败',
  295. icon:"none",
  296. mask:true,
  297. duration: 2000
  298. });
  299. }
  300. })
  301. },
  302. fail: function (res){
  303. uni.hideLoading();
  304. uni.showToast({
  305. title: '下载失败',
  306. icon:"none",
  307. mask:true,
  308. duration: 2000
  309. });
  310. }
  311. })
  312. },
  313. //整改通知书
  314. genNotice(id){
  315. uni.showLoading({
  316. title: '下载中'
  317. });
  318. wx.downloadFile({
  319. url: config.base_url+'/zd-security/checkManage/getRectifyAdviceNote/' + id,
  320. header: {
  321. Authorization: uni.getStorageSync('token')
  322. },
  323. success: function (res) {
  324. const fileManager = wx.getFileSystemManager()
  325. const filePath = wx.env.USER_DATA_PATH + '/(整改通知书).docx'
  326. fileManager.saveFile({
  327. tempFilePath: res.tempFilePath,
  328. filePath,
  329. success: () => {
  330. uni.hideLoading();
  331. wx.openDocument({
  332. filePath: filePath,
  333. showMenu: true,
  334. fileType: 'docx'
  335. })
  336. },
  337. fail: function (res){
  338. uni.hideLoading();
  339. uni.showToast({
  340. title: '下载失败',
  341. icon:"none",
  342. mask:true,
  343. duration: 2000
  344. });
  345. }
  346. })
  347. },
  348. fail: function (res){
  349. uni.hideLoading();
  350. uni.showToast({
  351. title: '下载失败',
  352. icon:"none",
  353. mask:true,
  354. duration: 2000
  355. });
  356. }
  357. })
  358. },
  359. //整改告知书
  360. genReport(id){
  361. uni.showLoading({
  362. title: '下载中'
  363. });
  364. wx.downloadFile({
  365. url: config.base_url+'/zd-security/checkManage/getRectifyNotification/' + id,
  366. header: {
  367. Authorization: uni.getStorageSync('token')
  368. },
  369. success: function (res) {
  370. const fileManager = wx.getFileSystemManager()
  371. const filePath = wx.env.USER_DATA_PATH + '/整改报告.docx'
  372. fileManager.saveFile({
  373. tempFilePath: res.tempFilePath,
  374. filePath,
  375. success: () => {
  376. uni.hideLoading();
  377. wx.openDocument({
  378. filePath: filePath,
  379. showMenu: true,
  380. fileType: 'docx'
  381. })
  382. },
  383. fail: function (res){
  384. uni.hideLoading();
  385. uni.showToast({
  386. title: '下载失败',
  387. icon:"none",
  388. mask:true,
  389. duration: 2000
  390. });
  391. }
  392. })
  393. },
  394. fail: function (res){
  395. uni.hideLoading();
  396. uni.showToast({
  397. title: '下载失败',
  398. icon:"none",
  399. mask:true,
  400. duration: 2000
  401. });
  402. }
  403. })
  404. },
  405. }
  406. }
  407. </script>
  408. <style lang="stylus" scoped>
  409. .examine{
  410. height:100%;
  411. display flex;
  412. .info-max-box{
  413. flex: 1;
  414. overflow: scroll;
  415. padding-bottom: 140rpx;
  416. }
  417. .basics{
  418. width: 690rpx;
  419. background: #FFFFFF;
  420. border-radius: 20rpx;
  421. padding: 30rpx 30rpx 32rpx;
  422. box-sizing: border-box;
  423. margin: 20rpx 30rpx ;
  424. .basics_li{
  425. height: 80rpx;
  426. display: flex;
  427. justify-content: space-between;
  428. border-bottom: 1rpx solid #D8D8D8;
  429. >text:nth-of-type(1){
  430. font-size: 28rpx;
  431. font-family: PingFang SC-Medium, PingFang SC;
  432. font-weight: 400;
  433. color: #666666;
  434. line-height: 80rpx;
  435. width: 140rpx;
  436. }
  437. >text:nth-of-type(2){
  438. flex: 1;
  439. font-size: 28rpx;
  440. font-family: PingFang SC-Medium, PingFang SC;
  441. font-weight: 400;
  442. color: #333333;
  443. line-height: 80rpx;
  444. text-align: right;
  445. white-space: nowrap;
  446. overflow: hidden;
  447. text-overflow: ellipsis;
  448. }
  449. }
  450. .demand{
  451. >text{
  452. display: block;
  453. }
  454. >text:nth-of-type(1){
  455. font-size: 28rpx;
  456. font-family: PingFang SC-Medium, PingFang SC;
  457. font-weight: 400;
  458. color: #666666;
  459. line-height: 70rpx;
  460. width: 140rpx;
  461. }
  462. >text:nth-of-type(2){
  463. font-size: 28rpx;
  464. font-family: PingFang SC-Medium, PingFang SC;
  465. font-weight: 400;
  466. color: #333333;
  467. line-height: 40rpx;
  468. text-align: left;
  469. }
  470. }
  471. }
  472. .attachment{
  473. width: 690rpx;
  474. background: #FFFFFF;
  475. border-radius: 20rpx;
  476. margin: 20rpx 30rpx 0;
  477. padding-bottom: 32rpx;
  478. box-sizing: border-box;
  479. .attachment_t{
  480. border-bottom: 1rpx solid #D8D8D8;
  481. >text:nth-of-type(1){
  482. font-size: 30rpx;
  483. font-family: PingFang SC-Medium, PingFang SC;
  484. font-weight: 400;
  485. color: #333333;
  486. line-height: 110rpx;
  487. margin-left: 28rpx;
  488. }
  489. >text:nth-of-type(2){
  490. font-size: 30rpx;
  491. font-family: PingFang SC-Medium, PingFang SC;
  492. font-weight: 400;
  493. color: #999999;
  494. line-height: 110rpx;
  495. margin-left: 24rpx;
  496. }
  497. }
  498. .attachment_li{
  499. height: 40rpx;
  500. display: flex;
  501. justify-content: flex-start;
  502. align-items: center;
  503. margin-top: 32rpx;
  504. >img{
  505. width: 30rpx;
  506. height: 26rpx;
  507. margin-right: 20rpx;
  508. margin-left: 50rpx;
  509. }
  510. >text{
  511. flex: 1;
  512. font-size: 28rpx;
  513. font-family: PingFang SC-Medium, PingFang SC;
  514. font-weight: 400;
  515. color: #0183FA;
  516. line-height: 40rpx;
  517. white-space: nowrap;
  518. overflow: hidden;
  519. text-overflow: ellipsis;
  520. }
  521. .attachment_li_del{
  522. width: 30rpx;
  523. height: 30rpx;
  524. }
  525. }
  526. }
  527. .inconformity{
  528. width: 690rpx;
  529. height: 100rpx;
  530. background: #FFFFFF;
  531. border-radius: 20rpx 20rpx 20rpx 20rpx;
  532. margin: 20rpx 30rpx;
  533. font-size: 30rpx;
  534. font-family: PingFang SC-Medium, PingFang SC;
  535. font-weight: 400;
  536. color: #333333;
  537. line-height: 100rpx;
  538. text-align: center;
  539. display: flex;
  540. justify-content: center;
  541. align-items: center;
  542. >img{
  543. width: 30rpx;
  544. height: 26rpx;
  545. margin-left: 20rpx;
  546. }
  547. }
  548. .danger{
  549. width: 690rpx;
  550. background: #FFFFFF;
  551. border-radius: 20rpx;
  552. padding: 15rpx 30rpx 15rpx;
  553. box-sizing: border-box;
  554. margin: 20rpx 30rpx ;
  555. position: relative;
  556. .sort{
  557. width: 40rpx;
  558. height: 40rpx;
  559. background: #0183FA;
  560. border-radius: 20rpx 0rpx 10rpx 0rpx;
  561. font-size: 30rpx;
  562. font-family: PingFang SC-Medium, PingFang SC;
  563. font-weight: 400;
  564. color: #FFFFFF;
  565. line-height: 40rpx;
  566. text-align: center;
  567. position: absolute;
  568. left: 0;
  569. top: 0;
  570. }
  571. .danger_title{
  572. font-size: 30rpx;
  573. font-family: PingFang SC-Medium, PingFang SC;
  574. font-weight: 400;
  575. color: #333333;
  576. line-height:80rpx;
  577. border-bottom: 1rpx solid #D8D8D8;
  578. }
  579. .grade{
  580. height: 80rpx;
  581. display: flex;
  582. justify-content: space-between;
  583. border-bottom: 1rpx solid #D8D8D8;
  584. >text:nth-of-type(1){
  585. font-size: 28rpx;
  586. font-family: PingFang SC-Medium, PingFang SC;
  587. font-weight: 400;
  588. color: #666666;
  589. line-height: 80rpx;
  590. width: 140rpx;
  591. }
  592. >text:nth-of-type(2){
  593. flex: 1;
  594. font-size: 28rpx;
  595. font-family: PingFang SC-Medium, PingFang SC;
  596. font-weight: 400;
  597. color: #333333;
  598. line-height: 80rpx;
  599. text-align: right;
  600. }
  601. }
  602. .project{
  603. .project_t{
  604. font-size: 30rpx;
  605. font-family: PingFang SC-Medium, PingFang SC;
  606. font-weight: 400;
  607. color: #333333;
  608. line-height: 80rpx;
  609. }
  610. .project_b{
  611. min-height: 158rpx;
  612. font-size: 28rpx;
  613. font-family: PingFang SC-Medium, PingFang SC;
  614. font-weight: 400;
  615. color: #333333;
  616. line-height: 40rpx;
  617. padding: 20rpx 14rpx;
  618. box-sizing: border-box;
  619. background: #F5F5F5;
  620. border-radius: 20rpx 20rpx 20rpx 20rpx;
  621. }
  622. .project_b2{
  623. font-size: 26rpx;
  624. font-family: PingFang SC-Medium, PingFang SC;
  625. font-weight: 400;
  626. color: #666666;
  627. line-height: 26rpx;
  628. margin-top: 14rpx;
  629. text-align: right;
  630. }
  631. }
  632. .picture{
  633. .picture_t{
  634. font-size: 30rpx;
  635. font-family: PingFang SC-Medium, PingFang SC;
  636. font-weight: 400;
  637. color: #333333;
  638. line-height: 80rpx;
  639. }
  640. .picture_b{
  641. display: flex;
  642. justify-content: flex-start;
  643. flex-wrap: wrap;
  644. >img{
  645. width: 200rpx;
  646. height: 200rpx;
  647. border-radius: 10rpx 10rpx 10rpx 10rpx;
  648. margin-right: 14rpx;
  649. margin-bottom: 10rpx;
  650. }
  651. >img:nth-of-type(3n+3){
  652. margin-right: 0rpx;
  653. }
  654. }
  655. }
  656. }
  657. .pack_up{
  658. font-size: 30rpx;
  659. font-family: PingFang SC-Medium, PingFang SC;
  660. font-weight: 400;
  661. color: #666666;
  662. line-height: 140rpx;
  663. display: flex;
  664. justify-content: center;
  665. align-items: center;
  666. >img{
  667. width: 14rpx;
  668. height: 8rpx;
  669. margin-left: 22rpx;
  670. }
  671. }
  672. .report{
  673. width: 153rpx;
  674. height: 50rpx;
  675. background: #0183FA;
  676. border-radius: 25rpx 0rpx 0rpx 25rpx;
  677. font-size: 26rpx;
  678. font-family: Source Han Sans CN-Regular, Source Han Sans CN;
  679. font-weight: 400;
  680. color: #FFFFFF;
  681. line-height: 50rpx;
  682. position: fixed;
  683. top: 180rpx;
  684. right: 0;
  685. text-align: center;
  686. }
  687. .bottom_btn{
  688. position: fixed;
  689. bottom: 26rpx;
  690. left: 30rpx;
  691. font-size: 30rpx;
  692. font-family: PingFang SC-Medium, PingFang SC;
  693. font-weight: 400;
  694. color: #FFFFFF;
  695. line-height: 90rpx;
  696. width: 690rpx;
  697. height: 90rpx;
  698. background: #0183FA;
  699. border-radius: 20rpx;
  700. text-align: center;
  701. }
  702. }
  703. </style>