scanning_djEnd.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714
  1. <template>
  2. <view class="Scanning_djEnd">
  3. <view class="Scanning_top" v-if="infoDATA.status == 200">
  4. <view class="Scanning_top_icon">
  5. <text class="cubeic-ok icon_transport transport-duigou"></text>
  6. </view>
  7. <view class="Scanning_top_text">
  8. <view class="text1">操作成功</view>
  9. </view>
  10. </view>
  11. <view
  12. class="Scanning_top"
  13. v-if="
  14. infoDATA.status == 10005 ||
  15. infoDATA.status == 100018 ||
  16. infoDATA.status == 10004 ||
  17. infoDATA.status == 100021 ||
  18. infoDATA.status == 500 ||
  19. infoDATA.status == 100031
  20. "
  21. >
  22. <view class="Scanning_top_icon">
  23. <text class="cubeic-close icon_transport transport-shibai"></text>
  24. </view>
  25. <view class="Scanning_top_text">
  26. <view class="text1">操作失败</view>
  27. </view>
  28. </view>
  29. <view
  30. class="Scanning_cont"
  31. v-if="
  32. (infoDATA.status == 200 && type == 'specimenPlan') ||
  33. (infoDATA.status == 200 && type == 'specimen')
  34. "
  35. ></view>
  36. <view
  37. class="Scanning_cont"
  38. v-if="
  39. (infoDATA.status == 200 && type == 'patientTransport') ||
  40. (infoDATA.status == 200 && type == 'inspect')
  41. "
  42. >扫描患者腕带并将患者送往目标科室.</view
  43. >
  44. <view
  45. class="Scanning_cont"
  46. v-if="
  47. (infoDATA.status == 200 &&
  48. type == 'drugsBag' &&
  49. (type1 == 'drug-ddd-2' || type1 == 'drug-dsd-2')) ||
  50. (infoDATA.status == 200 &&
  51. type == 'jPBag' &&
  52. (type1 == 'jp-ddd-2' || type1 == 'jp-dsd-2'))
  53. "
  54. >已到达目标科室,请扫描药包或静配包.</view
  55. >
  56. <view
  57. class="Scanning_cont"
  58. v-if="
  59. (infoDATA.status == 200 &&
  60. type == 'drugsBag' &&
  61. (type1 == 'drug-ddd-1' || type1 == 'drug-dsd-1')) ||
  62. (infoDATA.status == 200 &&
  63. type == 'jPBag' &&
  64. (type1 == 'jp-ddd-1' || type1 == 'jp-dsd-1'))
  65. "
  66. >已到达目标科室,请取药包或静配包后送达目标科室.</view
  67. >
  68. <view
  69. class="Scanning_cont"
  70. v-if="
  71. infoDATA.status == 200 && type == 'other' && infoDATA.type == 'qt-ddd-1'
  72. "
  73. >已到达目标科室,请执行该工单.</view
  74. >
  75. <view
  76. class="Scanning_cont"
  77. v-if="
  78. (infoDATA.state == 'finish' &&
  79. infoDATA.status == 200 &&
  80. type == 'specimenPlan' &&
  81. infoDATA.type == 'plan-spe-dsd-1') ||
  82. (infoDATA.status == 200 &&
  83. type == 'other' &&
  84. infoDATA.type == 'qt-dsd-1')
  85. "
  86. >已到达目标科室,工单已完成.</view
  87. >
  88. <view
  89. class="Scanning_cont"
  90. v-if="
  91. (infoDATA.status == 200 &&
  92. type == 'specimenPlan' &&
  93. infoDATA.type != 'plan-spe-ddd-1' &&
  94. infoDATA.type != 'plan-spe-dsd-1') ||
  95. (infoDATA.status == 200 &&
  96. type == 'specimen' &&
  97. infoDATA.type != 'spe-ddd-1' &&
  98. infoDATA.type != 'spe-dsd-1')
  99. "
  100. >已到达目标科室,请扫描标本.</view
  101. >
  102. <view
  103. class="Scanning_cont"
  104. v-if="
  105. (infoDATA.status == 200 &&
  106. type == 'specimenPlan' &&
  107. infoDATA.type == 'plan-spe-ddd-1') ||
  108. (infoDATA.status == 200 &&
  109. type == 'specimen' &&
  110. infoDATA.type == 'spe-ddd-1')
  111. "
  112. >已到达目标科室,请取标本后送达目标科室.</view
  113. >
  114. <view
  115. class="Scanning_cont"
  116. v-if="
  117. (infoDATA.state != 'finish' &&
  118. infoDATA.status == 200 &&
  119. type == 'specimenPlan' &&
  120. infoDATA.type == 'plan-spe-dsd-1') ||
  121. (infoDATA.status == 200 &&
  122. type == 'specimen' &&
  123. infoDATA.type == 'spe-dsd-1')
  124. "
  125. >已到达目标科室,请放置标本完成该工单.</view
  126. >
  127. <view class="Scanning_cont" v-if="infoDATA.status != 200">
  128. <view>{{ infoDATA.msg }}</view>
  129. </view>
  130. <view
  131. class="foot_btn"
  132. v-if="type == 'inspect' || type == 'patientTransport'"
  133. >
  134. <view class="btn3" @click="Scanning_again()">继续扫描</view>
  135. </view>
  136. <view class="foot_btn" v-if="type == 'drugsBag' || type == 'jPBag'">
  137. <view
  138. class="btn3"
  139. @click="Scanning_again()"
  140. v-if="
  141. type1 === 'drug-ddd-2' ||
  142. type1 === 'drug-dsd-2' ||
  143. type1 === 'jp-ddd-2' ||
  144. type1 === 'jp-dsd-2'
  145. "
  146. >继续扫描</view
  147. >
  148. <view
  149. class="btn3"
  150. @click="showAlert()"
  151. v-if="
  152. type1 === 'drug-ddd-1' ||
  153. type1 === 'drug-dsd-1' ||
  154. type1 === 'jp-ddd-1' ||
  155. type1 === 'jp-dsd-1'
  156. "
  157. >知道了</view
  158. >
  159. </view>
  160. <view
  161. class="foot_btn"
  162. v-if="
  163. (type == 'specimenPlan' &&
  164. type1 != 'plan-spe-dsd-1' &&
  165. (type1 != 'plan-spe-ddd-1') & (type1 != 'plan-spe-ddd-2')) ||
  166. (type == 'specimen' &&
  167. type1 != 'spe-dsd-1' &&
  168. (type1 != 'spe-ddd-1') & (type1 != 'spe-ddd-2'))
  169. "
  170. >
  171. <view class="btn1" @click="Scanning_again()">扫描标本</view>
  172. <view class="btn3" @click="getNoScanSpecimen()" v-show="this.queryObj.speNum">查看未扫描标本</view>
  173. <view class="btn2" @click="Scanning_complete(ids)" v-show="this.queryObj.speNum">完成扫描</view>
  174. </view>
  175. <view
  176. class="foot_btn"
  177. v-if="
  178. (type == 'specimenPlan' && type1 == 'plan-spe-ddd-2') ||
  179. (type == 'specimen' && type1 == 'spe-ddd-2')
  180. "
  181. >
  182. <view class="btn1" @click="Scanning_again()">扫描标本</view>
  183. <view class="btn3" @click="getNoScanSpecimen()" v-show="this.queryObj.speNum">查看未扫描标本</view>
  184. <view class="btn2" @click="Scanning_complete(ids)" v-show="this.queryObj.speNum">完成扫描</view>
  185. </view>
  186. <view
  187. class="foot_btn"
  188. v-if="
  189. (infoDATA.state != 'finish' &&
  190. type == 'specimenPlan' &&
  191. type1 == 'plan-spe-dsd-1') ||
  192. (type == 'specimen' && type1 == 'spe-dsd-1')
  193. "
  194. >
  195. <view class="btn1" @click="Scanning_complete1(ids)">完成工单</view>
  196. <view class="btn2" @click="showAlert()">继续配送</view>
  197. </view>
  198. <view
  199. class="foot_btn"
  200. v-if="
  201. infoDATA.status != 200 &&
  202. type != 'specimenPlan' &&
  203. type != 'specimen' &&
  204. type !== 'jPBag' &&
  205. type !== 'inspect' &&
  206. type !== 'drugsBag' &&
  207. type !== 'patientTransport'
  208. "
  209. >
  210. <view class="btn3" @click="showAlert()">知道了</view>
  211. </view>
  212. <view
  213. class="foot_btn"
  214. v-if="
  215. (infoDATA.status == 200 && type1 == 'spe-ddd-1') ||
  216. (infoDATA.status == 200 && type1 == 'plan-spe-ddd-1')
  217. "
  218. >
  219. <view class="btn3" @click="showAlert()">知道了</view>
  220. </view>
  221. <view
  222. class="foot_btn"
  223. v-if="
  224. (infoDATA.state == 'finish' &&
  225. infoDATA.status == 200 &&
  226. type == 'specimenPlan' &&
  227. type1 == 'plan-spe-dsd-1') ||
  228. (infoDATA.status == 200 && type == 'other')
  229. "
  230. >
  231. <view class="btn3" @click="showAlert()">知道了</view>
  232. </view>
  233. <!-- 弹窗 -->
  234. <showModel
  235. :title="models.title"
  236. :icon="models.icon"
  237. :disjunctor="models.disjunctor"
  238. :content="models.content"
  239. @ok="ok"
  240. @cancel="cancel"
  241. :operate="models.operate"
  242. ></showModel>
  243. <!-- 弹窗 -->
  244. <showModel
  245. :title="models2.title"
  246. :icon="models2.icon"
  247. :disjunctor="models2.disjunctor"
  248. :content="models2.content"
  249. @ok="ok2"
  250. @know="know2"
  251. @cancel="cancel2"
  252. :operate="models2.operate"
  253. >
  254. </showModel>
  255. </view>
  256. </template>
  257. <script>
  258. import showModel from "../../components/showModel/showModel.vue";
  259. import { get, post, SM, webHandle } from "../../http/http.js";
  260. export default {
  261. data() {
  262. return {
  263. SMFlag:true,
  264. // 弹窗model
  265. models: {
  266. disjunctor: false,
  267. },
  268. // 完成扫描弹窗model1
  269. models2: {
  270. disjunctor: false,
  271. },
  272. wcId: "", //工单完成ID
  273. wcFlag:false,
  274. modelFlag: "", //工单完成类型
  275. infoDATA: [],
  276. ids: [],
  277. type: "",
  278. type1: "",
  279. queryObj: {}, //路由传递过来的参数
  280. gotoFlag: true,
  281. speNum:0
  282. };
  283. },
  284. methods: {
  285. // 查看未扫描标本
  286. getNoScanSpecimen() {
  287. if (!this.gotoFlag) {
  288. return;
  289. }
  290. this.gotoFlag = false;
  291. let id = JSON.parse(this.queryObj.ids)[0];
  292. uni.navigateTo({
  293. url: `../noScanSpecimen/noScanSpecimen?workOrderId=${id}&deptCode=${this.queryObj.deptCode}`,
  294. });
  295. },
  296. // 正常完成扫描
  297. overFinish() {
  298. //完成扫描
  299. let postType = "";
  300. if (
  301. this.queryObj.type1 === "plan-spe-ddd-2" ||
  302. this.queryObj.type1 === "plan-spe-dsd-2" ||
  303. this.queryObj.type1 === "plan-spe-dsd-3"
  304. ) {
  305. postType = "finishPlanSpes";
  306. } else if (this.queryObj.type1 == "spe-ddd-2") {
  307. postType = "finishSpes";
  308. }
  309. let data = {
  310. type: this.queryObj.type1,
  311. ids: this.wcId,
  312. };
  313. uni.showLoading({
  314. title: "加载中",
  315. mask: true,
  316. });
  317. post("/workerOrder/" + postType, data).then((res) => {
  318. if (res.status == 200) {
  319. this.models2 = {
  320. disjunctor: true,
  321. title: "提示",
  322. content: `完成扫描成功`,
  323. icon: "success",
  324. operate: {
  325. know: "知道了",
  326. },
  327. };
  328. } else {
  329. uni.hideLoading();
  330. uni.showToast({
  331. icon: "none",
  332. title: "请求失败!",
  333. });
  334. }
  335. });
  336. },
  337. // 确定
  338. ok() {
  339. this.models.disjunctor = false;
  340. if (this.modelFlag === "complete") {
  341. uni.showLoading({
  342. title: "加载中",
  343. mask: true,
  344. });
  345. let id = JSON.parse(this.queryObj.ids)[0];
  346. let postData = {
  347. ids: [id],
  348. sign: true,
  349. deptQrCode:this.queryObj.deptCode
  350. };
  351. post("/workerOrder/expectedAndActual", postData).then((ress) => {
  352. uni.hideLoading();
  353. if (ress.status == 200) {
  354. if (ress.actualReceiveNum === undefined) {
  355. if(this.wcFlag){
  356. //正常完成扫描
  357. this.overFinish()
  358. }else{
  359. this.gotoOver();
  360. }
  361. } else {
  362. let content = '';
  363. if(this.queryObj.type1 === 'spe-ddd-2'||this.queryObj.type1 === 'plan-spe-ddd-2'){
  364. //待到达
  365. content = `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
  366. }else{
  367. //待送达
  368. content = `本工单已签到${ress.scanSet?ress.scanSet.join('、'):''},剩余需签到科室${ress.notScanSet?ress.notScanSet.join('、'):''},总签收${ress.totalAcceptance}只,剩余${ress.notAcceptance}只未签收,您确定完成工单吗?`;
  369. }
  370. this.models2 = {
  371. disjunctor: true,
  372. title: "提示",
  373. content,
  374. icon: "warn",
  375. operate: {
  376. ok: "确定",
  377. cancel: "取消",
  378. },
  379. };
  380. }
  381. } else {
  382. uni.showToast({
  383. icon: "none",
  384. title: "请求失败!",
  385. });
  386. }
  387. });
  388. } else if (this.modelFlag === "complete1") {
  389. //1对1标本完成工单
  390. let ids = this.wcId;
  391. uni.showLoading({
  392. title: "加载中",
  393. mask: true,
  394. });
  395. post("/workerOrder/finishSpeOrder", ids).then((res) => {
  396. if (res.status == 200) {
  397. uni.reLaunch({
  398. url: "../receiptpage/receiptpage",
  399. });
  400. } else {
  401. uni.hideLoading();
  402. uni.showToast({
  403. icon: "none",
  404. title: "请求失败!",
  405. });
  406. }
  407. });
  408. }
  409. },
  410. // 取消
  411. cancel() {
  412. this.models.disjunctor = false;
  413. },
  414. // 确定
  415. ok2() {
  416. this.models2.disjunctor = false;
  417. let id = JSON.parse(this.queryObj.ids)[0];
  418. let postData = {
  419. ids: [id],
  420. deptQrCode:this.queryObj.deptCode
  421. };
  422. uni.showLoading({
  423. title: "加载中",
  424. mask: true,
  425. });
  426. post("/workerOrder/expectedAndActual", postData).then((ress) => {
  427. uni.hideLoading();
  428. if (ress.status == 200) {
  429. if(this.wcFlag){
  430. this.overFinish()
  431. }else{
  432. this.gotoOver();
  433. }
  434. } else {
  435. uni.showToast({
  436. icon: "none",
  437. title: "请求失败!",
  438. });
  439. }
  440. });
  441. },
  442. // 取消
  443. cancel2() {
  444. this.models2.disjunctor = false;
  445. },
  446. know2(){
  447. this.models2.disjunctor = false;
  448. uni.reLaunch({
  449. url: "../receiptpage/receiptpage",
  450. });
  451. },
  452. //完成扫描
  453. Scanning_complete(id) {
  454. this.modelFlag = "complete";
  455. this.wcId = id;
  456. if (
  457. this.queryObj.type1 == "plan-spe-ddd-2" ||
  458. this.queryObj.type1 == "spe-ddd-2"
  459. ) {
  460. this.wcFlag = true;
  461. this.models = {
  462. disjunctor: true,
  463. title: "提示",
  464. content: "是否确定标本已扫描完成?",
  465. icon: "warn",
  466. operate: {
  467. ok: "确定",
  468. cancel: "取消",
  469. },
  470. };
  471. }else if (
  472. this.queryObj.type1 == "plan-spe-dsd-2" ||
  473. this.queryObj.type1 == "plan-spe-dsd-3" ||
  474. this.queryObj.type1 == "spe-dsd-2" ||
  475. this.queryObj.type1 == "spe-dsd-3"
  476. ) {
  477. this.wcFlag = false;
  478. this.models = {
  479. disjunctor: true,
  480. title: "提示",
  481. content: "是否确定标本已扫描完成?",
  482. icon: "warn",
  483. operate: {
  484. ok: "确定",
  485. cancel: "取消",
  486. },
  487. };
  488. } else {
  489. this.gotoOver();
  490. }
  491. },
  492. // 跳转完成工单页面
  493. gotoOver(){
  494. uni.navigateTo({
  495. url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
  496. this.queryObj.type1
  497. }&deptCode=${this.queryObj.code}&dept=${
  498. this.queryObj.dept
  499. }&id=${encodeURIComponent(JSON.stringify(this.wcId))}`,
  500. });
  501. },
  502. //一对一完成工单
  503. Scanning_complete1(id) {
  504. this.modelFlag = "complete1";
  505. this.wcId = id;
  506. this.models = {
  507. disjunctor: true,
  508. title: "提示",
  509. content: "是否确定标本配送完成?",
  510. icon: "warn",
  511. operate: {
  512. ok: "确定",
  513. cancel: "取消",
  514. },
  515. };
  516. },
  517. //继续扫描
  518. Scanning_again() {
  519. if (!this.SMFlag) {
  520. return;
  521. }
  522. this.SMFlag = false;
  523. SM().then((ress1) => {
  524. // ----------------
  525. //检验二维码的有效性
  526. post("/dept/scanning", {
  527. content: ress1,
  528. }).then((result) => {
  529. this.SMFlag = true;
  530. if (result.state == 200 || result.state == 201) {
  531. let ress = result.code;
  532. let speCode = ress;
  533. let data = {
  534. code: speCode,
  535. type: this.queryObj.type1,
  536. deptCode: this.code,
  537. ids: this.ids,
  538. };
  539. let postType = "";
  540. if (this.type == "jPBag" || this.type == "drugsBag") {
  541. postType = "handleDrugsAndJp";
  542. }
  543. if (this.type == "specimen") {
  544. postType = "handleSpes";
  545. data["speCode"] = data.code;
  546. delete data.code;
  547. }
  548. if (this.type == "specimenPlan") {
  549. postType = "handlePlanSpes";
  550. data["speCode"] = data.code;
  551. delete data.code;
  552. }
  553. if (this.type == "inspect") {
  554. postType = "handleIns";
  555. }
  556. if (this.type == "patientTransport") {
  557. postType = "handleTrans";
  558. }
  559. post("/workerOrder/" + postType, data).then((ress) => {
  560. if (ress.status == 200) {
  561. this.speNum = ress.specimenCount;
  562. uni.navigateTo({
  563. url: `../scanning_djInfo/scanning_djInfo?type=${
  564. this.queryObj.type
  565. }&type1=${this.queryObj.type1}&infoData=${encodeURIComponent(
  566. JSON.stringify(ress.data)
  567. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  568. this.queryObj.code
  569. }&dept=${this.queryObj.dept}&ids=${encodeURIComponent(
  570. JSON.stringify(this.ids)
  571. )}&model=${encodeURIComponent(JSON.stringify(ress))}&speNum=${this.speNum}`,
  572. });
  573. } else {
  574. uni.navigateTo({
  575. url: `../scanning_djInfo/scanning_djInfo?type=${
  576. this.queryObj.type
  577. }&type1=${this.queryObj.type1}&status=${ress.status}&msg=${
  578. ress.msg
  579. }&deptCode=${this.queryObj.code}&dept=${
  580. this.queryObj.dept
  581. }&ids=${encodeURIComponent(
  582. JSON.stringify(this.ids)
  583. )}&infoData=${encodeURIComponent(
  584. JSON.stringify(ress.data)
  585. )}&model=${encodeURIComponent(JSON.stringify(ress))}`,
  586. });
  587. }
  588. });
  589. } else {
  590. uni.showToast({
  591. icon: "none",
  592. title: "请求失败!",
  593. });
  594. }
  595. });
  596. // ------------------------------
  597. }).catch(err=>{
  598. this.SMFlag = true;
  599. });
  600. },
  601. // 知道了
  602. showAlert() {
  603. uni.navigateTo({
  604. url: "../receiptpage/receiptpage",
  605. });
  606. },
  607. },
  608. onShow() {
  609. this.SMFlag = true;
  610. this.gotoFlag = true;
  611. },
  612. onLoad(options) {
  613. console.log(options, "djEnd");
  614. if(options.speNum){
  615. this.speNum = options.speNum;
  616. }
  617. this.queryObj = options;
  618. let list = JSON.parse(options.model); //签到返回的信息
  619. this.code = options.code; //二维码code
  620. this.ids = options.ids && JSON.parse(options.ids); //科室ID数组
  621. this.infoDATA = list;
  622. if (options.type) {
  623. //关联类型
  624. this.type = options.type;
  625. } else {
  626. this.type = list.type;
  627. }
  628. this.type1 = options.type1;
  629. // #ifdef APP-PLUS
  630. webHandle("no", "app");
  631. // #endif
  632. // #ifdef H5
  633. webHandle("no", "wx");
  634. // #endif
  635. },
  636. };
  637. </script>
  638. <style lang="less">
  639. .Scanning_djEnd {
  640. padding: 0px 20rpx;
  641. .Scanning_top {
  642. height: 270rpx;
  643. .Scanning_top_icon {
  644. width: 140rpx;
  645. height: 140rpx;
  646. margin: 0 auto;
  647. // margin-top: 116rpx;
  648. border-radius: 50%;
  649. line-height: 140rpx;
  650. .cubeic-ok {
  651. font-size: 140rpx;
  652. color: #35b34a;
  653. }
  654. .cubeic-close {
  655. font-size: 140rpx;
  656. color: #ff3b53;
  657. }
  658. }
  659. .Scanning_top_text {
  660. .text1 {
  661. margin-top: 40rpx;
  662. font-size: 48rpx;
  663. text-align: center;
  664. }
  665. }
  666. }
  667. .Scanning_cont {
  668. font-size: 32rpx;
  669. text-align: center;
  670. view {
  671. margin-bottom: 16rpx;
  672. }
  673. .text {
  674. margin-top: 24rpx;
  675. color: #35b34a;
  676. }
  677. .text1 {
  678. margin-top: 24rpx;
  679. color: #ff3b53;
  680. }
  681. }
  682. .foot_btn {
  683. line-height: 88rpx;
  684. height: 100rpx;
  685. margin-top: 40rpx;
  686. text-align: center;
  687. display: flex;
  688. view {
  689. height: 88rpx;
  690. flex: 1;
  691. margin: 0 1%;
  692. background-image: linear-gradient(to right, #72c172, #3bb197);
  693. color: #fff;
  694. border-radius: 8rpx;
  695. font-size: 32rpx;
  696. margin-top: 16rpx;
  697. }
  698. }
  699. }
  700. </style>