scanning_Result.vue 43 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220
  1. <template>
  2. <view class="Scanning_Result">
  3. <view class="Scanning_top" v-if="res.status == 200">
  4. <view class="Scanning_top_icon">
  5. <view v-if="type == 'specimenPlan' || type == 'specimen'">
  6. <view class="red fweight speNum"> {{ speNum }} </view>
  7. </view>
  8. <text v-else class="cubeic-ok newicon newicon-duigou"></text>
  9. </view>
  10. <view class="Scanning_top_text">
  11. <view class="text1"> 操作成功 </view>
  12. <view class="success_tips" v-if="type == 'inspect' || type == 'patientTransport'">
  13. (请您评估患者的意识状况、生命体征、配合程度,如有异常请及时联系护士!)
  14. </view>
  15. </view>
  16. </view>
  17. <view class="Scanning_top" v-if="res.status == 11111">
  18. <view class="Scanning_top_icon">
  19. <text class="cubeic-close newicon newicon-shibai"></text>
  20. </view>
  21. <view class="Scanning_top_text">
  22. <view class="text1" style="color: red;">操作失败</view>
  23. </view>
  24. </view>
  25. <view class="Scanning_top" v-if="(res.status != 200 && res.status != 11111)">
  26. <view class="Scanning_top_icon">
  27. <text class="cubeic-close newicon newicon-shibai"></text>
  28. </view>
  29. <view class="Scanning_top_text">
  30. <view class="text1"> 操作失败 </view>
  31. <view class="text1 f30" v-if="queryObj.qrcode !== undefined"> 扫描内容:{{queryObj.qrcode}} </view>
  32. </view>
  33. </view>
  34. <view class="Scanning_cont" v-if="
  35. (res.status == 200 && type == 'specimenPlan') ||
  36. (res.status == 200 && type == 'specimen')
  37. ">
  38. <view>{{ infoDATA.stype.name }}({{infoDATA.scode}})</view>
  39. <view>检验项目 : {{ infoDATA.specimenDesc || "-" }}</view>
  40. <view>
  41. {{ infoDATA.sickRoom ? infoDATA.sickRoom.dept : "" }}
  42. <text style="width: 4em;text-align: center;margin-left: 1em;margin-right: 1em;" class="newicon newicon-arrow-right-full"></text>
  43. <text :class="{ red: isEndDeptRedShow }">{{ infoDATA.checkDept ? infoDATA.checkDept.dept : "" }}</text>
  44. </view>
  45. <view>患者姓名 : {{ infoDATA.patientName}}({{infoDATA.bedNum}})</view>
  46. <view>住院号 : {{ infoDATA.residenceNo || '-' }}</view>
  47. </view>
  48. <view class="Scanning_cont" v-if="
  49. (res.status == 11111 && type == 'specimenPlan') ||
  50. (res.status == 11111 && type == 'specimen')
  51. ">
  52. <view>{{ infoDATA.stype.name }}({{infoDATA.scode}})</view>
  53. <view>检验项目 : {{ infoDATA.specimenDesc || "-" }}</view>
  54. <view>标本状态 : <text style="color: red">{{ infoDATA.speState ? infoDATA.speState.name : '' }}</text></view>
  55. <view>
  56. {{ infoDATA.sickRoom ? infoDATA.sickRoom.dept : "" }}
  57. <text style="width: 4em;text-align: center;margin-left: 1em;margin-right: 1em;" class="newicon newicon-arrow-right-full"></text>
  58. <text :class="{ red: isEndDeptRedShow }">{{ infoDATA.checkDept ? infoDATA.checkDept.dept : "" }}</text>
  59. </view>
  60. <view>患者姓名 : {{ infoDATA.patientName}}({{infoDATA.bedNum}})</view>
  61. <view>住院号 : {{ infoDATA.residenceNo || '-' }}</view>
  62. </view>
  63. <view class="Scanning_cont" v-if="
  64. (res.status == 200 && type == 'inspect') || type == 'patientTransport'
  65. ">
  66. <view v-if="res.patient"> 患者姓名 : {{ res.patient || "-" }} </view>
  67. <view v-if="res.residenceNo">
  68. 住院号 : {{ res.residenceNo || "-" }}
  69. </view>
  70. <view v-if="res.deptName">
  71. 住院科室 : {{ res.deptName !== "undefined" ? res.deptName : "-" }}
  72. </view>
  73. <view v-if="res.bedNum">
  74. 床号 : {{ res.bedNum !== "undefined" ? res.bedNum : "-" }}
  75. </view>
  76. <view v-if="res.data">
  77. 检查项目 :
  78. <text v-for="(data, i) in res.data" :key="i">{{
  79. data.inspectName
  80. }}</text>
  81. </view>
  82. <view v-if="
  83. res.status == 200 &&
  84. infoType != 'ins-zxz-1' &&
  85. infoType != 'ins-dsd-1' &&
  86. infoType != 'ins-ddd-1' &&
  87. infoType != 'trans-ddd-1' &&
  88. infoType != 'trans-dsd-1'
  89. ">
  90. {{ res.msg || "" }}
  91. </view>
  92. <view v-if="infoType == 'trans-dsd-1' && res.status == 200">
  93. 工单已完成
  94. </view>
  95. <view v-if="infoType == 'ins-dsd-1' && res.status == 200">
  96. 工单已完成。
  97. </view>
  98. <!-- 半程陪检 -->
  99. <view v-if="infoDATA.type == 'ins-half-ok' && res.status == 200">
  100. 已到达检查科室,工单已完成。
  101. </view>
  102. </view>
  103. <view class="Scanning_cont" v-if="res.status == 200 && (type == 'drugsBag' || type == 'jPBag')">
  104. <view> 药包类型 : {{(infoDATA.packType && infoDATA.packType !== 0) ? DRUGSBAG_TYPE[infoDATA.packType] : "-"}} </view>
  105. <view v-if="type == 'drugsBag'"> 药包编码 : #{{ infoDATA.packid }} </view>
  106. <view
  107. v-if="type == 'drugsBag' && accountObj && (queryObj.type1 === 'drug-ddd-2' || queryObj.type1 === 'drug-dsd-2')">
  108. 交接人工号 : {{ accountObj.account }} </view>
  109. <view
  110. v-if="type == 'drugsBag' && accountObj && (queryObj.type1 === 'drug-ddd-2' || queryObj.type1 === 'drug-dsd-2')">
  111. 交接人姓名 : {{ accountObj.accountName }} </view>
  112. <view v-if="type == 'jPBag'">
  113. 静配药包编码 : #{{ infoDATA.packid }}
  114. </view>
  115. <view> 所属科室 : {{ infoDATA.target.dept || "-" }} </view>
  116. <view v-if="infoType === 'drug-dsd-2' || infoType === 'jp-dsd-2'">
  117. 工单已完成。
  118. </view>
  119. <view class="red"> 如果您当前科室还有药包需要扫描,请点击“继续扫描”! </view>
  120. </view>
  121. <view class="Scanning_cont" v-if="res.status != 200">
  122. <view class="Scanning_cont_center" v-if="res.status != 11111">
  123. {{ res.msg === "undefined" || !res.msg ? "" : res.msg }}
  124. </view>
  125. </view>
  126. <view class="foot_btn_spe" v-if="
  127. (type == 'specimen' && isKs != '1') ||
  128. (type == 'specimenPlan' && isKs != '1')
  129. ">
  130. <view class="btn1" @click="Scanning_again()"> 继续扫描 </view>
  131. <view class="btn3" @click="hand_again()">手动录入</view>
  132. <view class="btn3" @click="getNoScanSpecimen(false)">未扫描标本</view>
  133. <view class="btn3" @click="getNoScanSpecimen(true)">已扫描标本</view>
  134. <view class="btn2" @click="Scanning_complete(dataId)"> 完成扫描 </view>
  135. </view>
  136. <view class="foot_btn" v-if="
  137. (type != 'specimenPlan' &&
  138. type != 'specimen' &&
  139. type != 'drugsBag' &&
  140. type != 'jPBag' &&
  141. (type != 'inspect') & (type != 'patientTransport')) ||
  142. (queryObj.status == 200 &&
  143. type == 'drugsBag' &&
  144. infoType == 'drug-ddd-2') ||
  145. (queryObj.status == 200 &&
  146. type == 'drugsBag' &&
  147. infoType == 'drug-dsd-2') ||
  148. (queryObj.status == 200 && type == 'jPBag' && infoType == 'jp-ddd-2') ||
  149. (queryObj.status == 200 && type == 'jPBag' && infoType == 'jp-dsd-2') ||
  150. (queryObj.status == 200 && type == 'inspect') ||
  151. (queryObj.status == 200 && type == 'patientTransport')
  152. ">
  153. <view class="btn3" @click="Scanning_again()" v-if="type == 'drugsBag'||type == 'jPBag'"> 继续扫描 </view>
  154. <view class="btn3" @click="showAlert(dataId)"> 知道了 </view>
  155. </view>
  156. <view class="foot_btn" v-if="
  157. (isKs != '1' &&
  158. queryObj.status != 200 &&
  159. type == 'drugsBag' &&
  160. infoType == 'drug-ddd-2') ||
  161. (isKs != '1' &&
  162. queryObj.status != 200 &&
  163. type == 'drugsBag' &&
  164. infoType == 'drug-dsd-2') ||
  165. (isKs != '1' &&
  166. queryObj.status != 200 &&
  167. type == 'jPBag' &&
  168. infoType == 'jp-ddd-2') ||
  169. (isKs != '1' &&
  170. queryObj.status != 200 &&
  171. type == 'jPBag' &&
  172. infoType == 'jp-dsd-2') ||
  173. (isKs != '1' && queryObj.status != 200 && type == 'inspect') ||
  174. (isKs != '1' && queryObj.status != 200 && type == 'patientTransport')
  175. ">
  176. <view class="btn3" @click="Scanning_again()"> 继续扫描 </view>
  177. <view class="btn3" @click="showAlert()" v-if="type == 'drugsBag'"> 知道了 </view>
  178. <view class="btn3" @click="photograph(queryObj, { DEPTCode, DEPT, infoType })" v-if="
  179. (isKs != '1' && queryObj.status != 200 && type == 'inspect') ||
  180. (isKs != '1' && queryObj.status != 200 && type == 'patientTransport')
  181. ">
  182. 拍照
  183. </view>
  184. </view>
  185. <view class="foot_btn" v-if="
  186. infoType == 'spe-ddd-1' ||
  187. (isKs == '1' && queryObj.status != 200 && infoType == 'spe-dsd-2') ||
  188. (isKs == '1' && queryObj.status != 200 && infoType == 'spe-dsd-1') ||
  189. (isKs == '1' && queryObj.status != 200 && infoType == 'spe-ddd-2') ||
  190. (isKs == '1' && queryObj.status != 200 && infoType == 'spe-dsd-3') ||
  191. (isKs == '1' &&
  192. queryObj.status != 200 &&
  193. infoType == 'plan-spe-ddd-1') ||
  194. (isKs == '1' &&
  195. queryObj.status != 200 &&
  196. infoType == 'plan-spe-ddd-2') ||
  197. (isKs == '1' &&
  198. queryObj.status != 200 &&
  199. infoType == 'plan-spe-dsd-1') ||
  200. (isKs == '1' &&
  201. queryObj.status != 200 &&
  202. infoType == 'plan-spe-dsd-2') ||
  203. (isKs == '1' && queryObj.status != 200 && infoType == 'drug-ddd-2') ||
  204. (isKs == '1' && queryObj.status != 200 && infoType == 'drug-dsd-2') ||
  205. (isKs == '1' && queryObj.status != 200 && infoType == 'jp-ddd-2') ||
  206. (isKs == '1' && queryObj.status != 200 && infoType == 'jp-dsd-2') ||
  207. (isKs == '1' && queryObj.status != 200 && infoType == 'drug-ddd-1') ||
  208. (isKs == '1' && queryObj.status != 200 && infoType == 'drug-dsd-1') ||
  209. (isKs == '1' && queryObj.status != 200 && infoType == 'jp-ddd-1') ||
  210. (isKs == '1' && queryObj.status != 200 && infoType == 'jp-dsd-1') ||
  211. (isKs == '1' &&
  212. queryObj.status != 200 &&
  213. infoType == 'plan-spe-dsd-3') ||
  214. (isKs == '1' &&
  215. queryObj.status != 200 &&
  216. type == 'inspect' &&
  217. queryObj.type1 === 'undefined') ||
  218. (isKs == '1' &&
  219. queryObj.status != 200 &&
  220. type == 'patientTransport' &&
  221. queryObj.type1 === 'undefined')
  222. ">
  223. <view class="btn3" @click="showAlert(dataId)"> 知道了 </view>
  224. </view>
  225. <view class="foot_btn" v-if="
  226. (isKs == '1' &&
  227. queryObj.status != 200 &&
  228. type == 'inspect' &&
  229. queryObj.type1 === 'ins-zxz-1') ||
  230. (isKs == '1' &&
  231. queryObj.status != 200 &&
  232. type == 'inspect' &&
  233. queryObj.type1 === 'ins-dsd-1') ||
  234. (isKs == '1' &&
  235. queryObj.status != 200 &&
  236. type == 'patientTransport' &&
  237. queryObj.type1 === 'trans-dsd-1')
  238. ">
  239. <view class="btn1" @click="showAlert(dataId)"> 知道了 </view>
  240. <view class="btn2" @click="goToRight(dataId)"> 继续执行工单 </view>
  241. </view>
  242. <!-- 弹窗 -->
  243. <showModel :title="models.title" :icon="models.icon" :disjunctor="models.disjunctor" :content="models.content"
  244. @ok="ok" @cancel="cancel" :operate="models.operate"></showModel>
  245. <!-- 弹窗 -->
  246. <showModel :title="models1.title" :icon="models1.icon" :disjunctor="models1.disjunctor"
  247. :radioItem="models1.radioItem" @ok="ok1" @radioChange="radioChange1" @cancel="cancel1" :operate="models1.operate">
  248. </showModel>
  249. <!-- 弹窗 -->
  250. <showModel :title="models2.title" :icon="models2.icon" :disjunctor="models2.disjunctor" :content="models2.content"
  251. @ok="ok2" @know="know2" @cancel="cancel2" :operate="models2.operate">
  252. </showModel>
  253. <!-- 手动查询标本弹窗 -->
  254. <handViewSpecimen v-if="speModels.disjunctor" :title="speModels.title" :disjunctor="speModels.disjunctor"
  255. @ok="speOk" @cancel="speCancel">
  256. </handViewSpecimen>
  257. <!-- 调查问卷二维码 -->
  258. <questionCode v-if="isQuestionModel" :orderId="dataId" @know="isQuestionModel = false"></questionCode>
  259. <!-- PDA扫描 -->
  260. <scanner></scanner>
  261. </view>
  262. </template>
  263. <script>
  264. import scanner from "../../components/scanner/scanner.vue";
  265. import showModel from "../../components/showModel/showModel.vue";
  266. import questionCode from "../../components/questionCode/questionCode.vue";
  267. import {
  268. get,
  269. post,
  270. SM,
  271. webHandle
  272. } from "../../http/http.js";
  273. import {
  274. photographTool
  275. } from "../../tools/photograph.js";
  276. import {
  277. DRUGSBAG_TYPE
  278. } from '../../tools/enum.drugsbagType.js';
  279. export default {
  280. components:{
  281. questionCode,
  282. scanner
  283. },
  284. data() {
  285. return {
  286. // 终点科室标红
  287. isEndDeptRedShow: false,
  288. isEndDeptRed: false,
  289. // 调研二维码
  290. isQuestionModel:false,
  291. DRUGSBAG_TYPE,
  292. currentCode: '', //当前小扫描的科室二维码
  293. // 手动查询标本弹窗model
  294. speModels: {
  295. disjunctor: false,
  296. },
  297. deptId: undefined,
  298. handover: undefined,
  299. SMFlag: true,
  300. // 交接人信息
  301. accountObj: undefined,
  302. // 完成扫描的id
  303. wcId: "",
  304. wcFlag: false,
  305. // 弹窗model
  306. models: {
  307. disjunctor: false,
  308. },
  309. // 单选框弹窗model1
  310. models1: {
  311. disjunctor: false,
  312. },
  313. // 完成扫描弹窗model1
  314. models2: {
  315. disjunctor: false,
  316. },
  317. isKs: "", //是否科室签到 1
  318. infoDATA: {},
  319. res: {},
  320. infoType: "",
  321. DEPTCode: "",
  322. RESData: {},
  323. DEPT: "",
  324. dataId: "",
  325. type: "",
  326. model: {},
  327. speNum: 0,
  328. queryObj: {}, //路由传递过来的数据
  329. selectRadio: [], //单选框选中的数据,第一项是qrcode,第二项是名称
  330. gotoFlag: true,
  331. content: "",
  332. taskTypeId:"",
  333. };
  334. },
  335. methods: {
  336. // 手动查询标本-确认
  337. speOk(data) {
  338. console.log(data);
  339. if (!data.id) {
  340. //没有查询到标本
  341. uni.showModal({
  342. title: '提示',
  343. content: "没有查询到标本!",
  344. showCancel: false,
  345. success: function(res) {
  346. if (res.confirm) {
  347. console.log('用户点击确定');
  348. } else if (res.cancel) {
  349. console.log('用户点击取消');
  350. }
  351. }
  352. });
  353. return;
  354. }
  355. this.speModels.disjunctor = false;
  356. this.hand_scanning_common(data.scode, 'hand');
  357. },
  358. // 手动查询标本-取消
  359. speCancel() {
  360. this.speModels.disjunctor = false;
  361. },
  362. // 手动查询标本弹窗
  363. showHandViewSpecimen() {
  364. this.speModels = {
  365. title: '填写标本编码',
  366. disjunctor: true,
  367. }
  368. },
  369. // 手动录入标本
  370. hand_again() {
  371. this.showHandViewSpecimen();
  372. },
  373. // 手动输入标本和扫码公共方法
  374. hand_scanning_common(ress1, type) {
  375. // ----------------
  376. uni.showLoading({
  377. title: "加载中",
  378. mask: true,
  379. });
  380. //检验二维码的有效性
  381. post("/dept/scanning", {
  382. content: ress1,
  383. }).then((result) => {
  384. this.SMFlag = true;
  385. this.currentCode = result.code;
  386. if (result.state == 200 || result.state == 201) {
  387. let codes = result.code;
  388. if (codes) {
  389. let speCode = codes;
  390. let data = {
  391. code: speCode,
  392. type: this.queryObj.type1,
  393. deptCode: this.DEPTCode,
  394. ids: [],
  395. };
  396. data.ids.push(this.dataId);
  397. let postType = "";
  398. if (this.type == "jPBag" || this.type == "drugsBag") {
  399. postType = "handleDrugsAndJp";
  400. if(this.type == "drugsBag"){
  401. delete data.ids;
  402. }
  403. data.deptId = this.deptId;
  404. data.handover = this.handover;
  405. }
  406. if (this.type == "specimen") {
  407. data["speCode"] = data.code;
  408. delete data.code;
  409. postType = "handleSpes";
  410. }
  411. if (this.type == "specimenPlan") {
  412. data["speCode"] = data.code;
  413. delete data.code;
  414. postType = "handlePlanSpes";
  415. }
  416. if (this.type == "inspect") {
  417. postType = "handleIns";
  418. }
  419. if (this.type == "patientTransport") {
  420. postType = "handleTrans";
  421. }
  422. post("/workerOrder/" + postType, data).then((ress) => {
  423. uni.hideLoading();
  424. if (ress.status == 200 || ress.status == 11111) {
  425. //标本和标本轮巡工单,扫描标本后会自动调用摄像头,继续扫描,直到status不是200
  426. if ((this.type == "specimenPlan" || this.type == "specimen") && ress.status != 11111) {
  427. this.getPageConfigSpecimen((flag, type, ress) => {
  428. if(flag){
  429. setTimeout(()=>{
  430. if (type === 'scan') {
  431. // #ifdef H5
  432. this.Scanning_again();
  433. // #endif
  434. }
  435. },500)
  436. }
  437. if(ress){
  438. this.infoDATA = ress.data;
  439. this.speNum = ress.specimenCount;
  440. uni.redirectTo({
  441. url: `../scanning_Result/scanning_Result?type=${
  442. this.queryObj.type
  443. }&type1=${
  444. this.queryObj.type1
  445. }&infoData=${encodeURIComponent(
  446. JSON.stringify(ress.data)
  447. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  448. this.queryObj.deptCode
  449. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(JSON.stringify(ress))}&speNum=${this.speNum}&scanOrHand=${type}&isEndDeptRed=${this.isEndDeptRed}`,
  450. });
  451. }
  452. }, type, ress.data, ress);
  453. return;
  454. }
  455. if (this.type == "specimenPlan" || this.type == "specimen") {
  456. this.infoDATA = ress.data;
  457. this.speNum = ress.specimenCount;
  458. uni.redirectTo({
  459. url: `../scanning_Result/scanning_Result?type=${
  460. this.queryObj.type
  461. }&type1=${
  462. this.queryObj.type1
  463. }&infoData=${encodeURIComponent(
  464. JSON.stringify(ress.data)
  465. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  466. this.queryObj.deptCode
  467. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(JSON.stringify(ress))}&speNum=${this.speNum}&scanOrHand=${type}`,
  468. });
  469. } else if (
  470. this.type == "inspect" ||
  471. this.type == "patientTransport"
  472. ) {
  473. if(this.type == "patientTransport" && this.queryObj.type1 == 'trans-ddd-1'){
  474. // 门诊服务点,有orderList
  475. if(ress.orderList){
  476. uni.navigateTo({
  477. url: `/pages/outpatient/outpatientStartSignIn/outpatientStartSignIn?model=${encodeURIComponent(JSON.stringify(ress))}`,
  478. });
  479. }else{
  480. uni.redirectTo({
  481. url: `../scanning_Result/scanning_Result?type=${
  482. this.queryObj.type
  483. }&type1=${
  484. this.queryObj.type1
  485. }&infoData=${encodeURIComponent(
  486. JSON.stringify(ress.data)
  487. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  488. this.queryObj.deptCode
  489. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(
  490. JSON.stringify(ress)
  491. )}&patient=${ress.patient}&patientCode=${
  492. ress.patientCode
  493. }&deptName=${ress.deptName}&bedNum=${ress.bedNum}`,
  494. });
  495. }
  496. }else if(this.type == "patientTransport" && this.queryObj.type1 == 'trans-dsd-1'){
  497. // 门诊服务点,有orderList
  498. if(ress.orderList){
  499. uni.navigateTo({
  500. url: `/pages/outpatient/outpatientEndSignIn/outpatientEndSignIn?model=${encodeURIComponent(JSON.stringify(ress))}`,
  501. });
  502. }else{
  503. uni.redirectTo({
  504. url: `../scanning_Result/scanning_Result?type=${
  505. this.queryObj.type
  506. }&type1=${
  507. this.queryObj.type1
  508. }&infoData=${encodeURIComponent(
  509. JSON.stringify(ress.data)
  510. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  511. this.queryObj.deptCode
  512. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(
  513. JSON.stringify(ress)
  514. )}&patient=${ress.patient}&patientCode=${
  515. ress.patientCode
  516. }&deptName=${ress.deptName}&bedNum=${ress.bedNum}`,
  517. });
  518. }
  519. }else{
  520. uni.redirectTo({
  521. url: `../scanning_Result/scanning_Result?type=${
  522. this.queryObj.type
  523. }&type1=${
  524. this.queryObj.type1
  525. }&infoData=${encodeURIComponent(
  526. JSON.stringify(ress.data)
  527. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  528. this.queryObj.deptCode
  529. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(
  530. JSON.stringify(ress)
  531. )}&patient=${ress.patient}&patientCode=${
  532. ress.patientCode
  533. }&deptName=${ress.deptName}&bedNum=${ress.bedNum}`,
  534. });
  535. }
  536. } else {
  537. uni.redirectTo({
  538. url: `../scanning_Result/scanning_Result?type=${
  539. this.queryObj.type
  540. }&type1=${
  541. this.queryObj.type1
  542. }&infoData=${encodeURIComponent(
  543. JSON.stringify(ress.data)
  544. )}&status=${ress.status}&msg=${ress.msg}&deptCode=${
  545. this.queryObj.deptCode
  546. }&dept=${this.queryObj.dept}&id=${this.dataId}&model=${encodeURIComponent(JSON.stringify(ress))}&accountObj=${encodeURIComponent(JSON.stringify(this.accountObj))}&deptId=${this.deptId}&handover=${this.handover}`,
  547. });
  548. }
  549. } else {
  550. uni.redirectTo({
  551. url: `../scanning_Result/scanning_Result?type=${
  552. this.queryObj.type
  553. }&type1=${this.queryObj.type1}&status=${ress.status}&msg=${
  554. ress.msg
  555. }&deptCode=${this.queryObj.deptCode}&dept=${
  556. this.queryObj.dept
  557. }&id=${this.dataId}&model=${encodeURIComponent(
  558. JSON.stringify(this.infoDATA)
  559. )}&accountObj=${encodeURIComponent(JSON.stringify(this.accountObj))}&deptId=${this.deptId}&handover=${this.handover}&scanOrHand=${type}&qrcode=${this.currentCode}`,
  560. });
  561. }
  562. });
  563. } else {
  564. uni.hideLoading();
  565. }
  566. } else {
  567. uni.hideLoading();
  568. uni.showToast({
  569. icon: "none",
  570. title: result.info || "接口获取数据失败!",
  571. });
  572. }
  573. });
  574. // ------------------------------
  575. },
  576. // 查看未扫描标本
  577. // isScan true已扫描标本,false未扫描标本
  578. getNoScanSpecimen(isScan) {
  579. if (!this.gotoFlag) {
  580. return;
  581. }
  582. this.gotoFlag = false;
  583. if(isScan){
  584. uni.navigateTo({
  585. url: `../noScanSpecimen/noScanSpecimen?deptName=${this.queryObj.dept}&workOrderId=${encodeURIComponent(JSON.stringify([this.queryObj.id]))}&deptCode=${this.queryObj.deptCode}&isScan=1`,
  586. });
  587. }else{
  588. uni.navigateTo({
  589. url: `../noScanSpecimen/noScanSpecimen?deptName=${this.queryObj.dept}&workOrderId=${encodeURIComponent(JSON.stringify([this.queryObj.id]))}&deptCode=${this.queryObj.deptCode}`,
  590. });
  591. }
  592. },
  593. // 拍照
  594. photograph(data, obj) {
  595. photographTool(data, obj);
  596. },
  597. // 继续扫描
  598. Scanning_again() {
  599. if (!this.SMFlag) {
  600. return;
  601. }
  602. this.SMFlag = false;
  603. SM().then((ress1) => {
  604. this.hand_scanning_common(ress1, 'scan');
  605. }).catch(err => {
  606. this.SMFlag = true;
  607. });
  608. },
  609. // pda扫描
  610. pdaChange(content){
  611. content = content.replace('\n','')
  612. this.hand_scanning_common(content, 'scan');
  613. },
  614. // 正常完成扫描
  615. overFinish() {
  616. let data = {
  617. type: this.queryObj.type1,
  618. ids: [this.wcId],
  619. };
  620. //只要是标本轮巡1对多或者多对多
  621. // plan-spe-dsd-2 1对多
  622. // plan-spe-dsd-3 多对多
  623. if (
  624. this.queryObj.type1 === "plan-spe-ddd-2" ||
  625. this.queryObj.type1 === "plan-spe-dsd-2" ||
  626. this.queryObj.type1 === "plan-spe-dsd-3"
  627. ) {
  628. post("/workerOrder/finishPlanSpes", data).then((res) => {
  629. // uni.hideLoading()
  630. if (res.status == 200) {
  631. this.models2 = {
  632. disjunctor: true,
  633. title: "提示",
  634. content: `完成扫描成功`,
  635. icon: "success",
  636. operate: {
  637. know: "知道了",
  638. },
  639. };
  640. } else {
  641. uni.showToast({
  642. icon: "none",
  643. title: res.msg || "接口获取数据失败!",
  644. });
  645. }
  646. });
  647. } else {
  648. post("/workerOrder/finishSpes", data).then((res) => {
  649. // uni.hideLoading()
  650. if (res.status == 200) {
  651. uni.navigateTo({
  652. url: "../receiptpage/receiptpage",
  653. });
  654. } else {
  655. uni.showToast({
  656. icon: "none",
  657. title: res.msg || "接口获取数据失败!",
  658. });
  659. }
  660. });
  661. }
  662. },
  663. // 确定
  664. ok() {
  665. this.models.disjunctor = false;
  666. let postData = {
  667. ids: [this.queryObj.id],
  668. sign: true,
  669. deptQrCode: this.queryObj.deptCode
  670. };
  671. uni.showLoading({
  672. title: '加载中',
  673. mask: true
  674. });
  675. post("/workerOrder/expectedAndActual", postData).then((ress) => {
  676. uni.hideLoading();
  677. if (ress.status == 200) {
  678. if (this.wcFlag) {
  679. //正常完成扫描
  680. this.overFinish()
  681. } else {
  682. this.gotoOver();
  683. }
  684. } else if (ress.status == 1000035) {
  685. let content = '';
  686. if (this.queryObj.type1 === 'spe-ddd-2' || this.queryObj.type1 === 'plan-spe-ddd-2') {
  687. //待到达
  688. content =
  689. `系统内预计标本<strong class="red">${ress.expectReceiveNum}</strong>只,您扫描收取标本<strong class="red">${ress.actualReceiveNum}</strong>只,其中<strong class="red">${ress.notReceiveNum}</strong>只未扫描;`;
  690. } else {
  691. //待送达
  692. this.content =
  693. `本工单已签到<strong class="red">${ress.scanSet?ress.scanSet.join('、'):''}</strong>,剩余需签到科室<strong class="red">${ress.notScanSet?ress.notScanSet.join('、'):''}</strong>,总签收<strong class="red">${ress.totalAcceptance}</strong>只,剩余<strong class="red">${ress.notAcceptance}</strong>只未签收,您确定完成工单吗?`;
  694. content =
  695. `您在<strong class="red">${ress.deptName}</strong>检验科扫描了<strong class="red">${ress.deptScanNum}</strong>个标本,还需扫描<strong class="red">${ress.deptNotScanNum}</strong>标本。`;
  696. }
  697. // 取消弹窗 2022年10月10日
  698. this.ok2();
  699. // this.models2 = {
  700. // disjunctor: true,
  701. // title: "提示",
  702. // content,
  703. // icon: "warn",
  704. // operate: {
  705. // ok: "确定",
  706. // cancel: "取消",
  707. // },
  708. // };
  709. } else {
  710. uni.showToast({
  711. icon: "none",
  712. title: ress.msg || "接口获取数据失败!",
  713. });
  714. }
  715. })
  716. },
  717. // 取消
  718. cancel() {
  719. this.models.disjunctor = false;
  720. },
  721. // 确定
  722. ok2() {
  723. this.models2.disjunctor = false;
  724. let postData = {
  725. ids: [this.queryObj.id],
  726. deptQrCode: this.queryObj.deptCode
  727. };
  728. uni.showLoading({
  729. title: '加载中',
  730. mask: true
  731. });
  732. post("/workerOrder/expectedAndActual", postData).then((ress) => {
  733. uni.hideLoading();
  734. if (ress.status == 200) {
  735. if (this.wcFlag) {
  736. this.overFinish()
  737. } else {
  738. this.gotoOver();
  739. }
  740. } else {
  741. uni.showToast({
  742. icon: "none",
  743. title: ress.msg || "接口获取数据失败!",
  744. });
  745. }
  746. })
  747. },
  748. // 取消
  749. cancel2() {
  750. this.models2.disjunctor = false;
  751. },
  752. know2() {
  753. this.models2.disjunctor = false;
  754. uni.navigateTo({
  755. url: "../receiptpage/receiptpage",
  756. });
  757. },
  758. // 完成扫描
  759. Scanning_complete(id) {
  760. // 如果是标本配送和标本轮巡,则进入标本核对页面
  761. if((this.type === 'specimen' || this.type === 'specimenPlan') && this.queryObj.type1.includes('ddd')){
  762. uni.navigateTo({
  763. url: `../checkAfterScanning/checkAfterScanning?id=${id}&type=${this.queryObj.type}&type1=${this.queryObj.type1}&dept=${this.queryObj.dept}&deptId=${this.queryObj.deptId}&deptCode=${this.queryObj.deptCode}&speNum=${this.speNum}&content=${this.content}`,
  764. });
  765. return;
  766. }
  767. this.wcId = id;
  768. if (
  769. this.queryObj.type1 == "plan-spe-ddd-2" ||
  770. this.queryObj.type1 == "spe-ddd-2"
  771. ) {
  772. this.wcFlag = true;
  773. this.models = {
  774. disjunctor: true,
  775. title: "提示",
  776. content: "是否确定标本已扫描完成?",
  777. icon: "warn",
  778. operate: {
  779. ok: "确定",
  780. cancel: "取消",
  781. },
  782. };
  783. } else if (
  784. this.queryObj.type1 == "plan-spe-dsd-2" ||
  785. this.queryObj.type1 == "plan-spe-dsd-3" ||
  786. this.queryObj.type1 == "spe-dsd-2" ||
  787. this.queryObj.type1 == "spe-dsd-3"
  788. ) {
  789. this.wcFlag = false;
  790. this.models = {
  791. disjunctor: true,
  792. title: "提示",
  793. content: "是否确定标本已扫描完成?",
  794. icon: "warn",
  795. operate: {
  796. ok: "确定",
  797. cancel: "取消",
  798. },
  799. };
  800. } else {
  801. this.gotoOver();
  802. }
  803. },
  804. // 跳转完成工单页面
  805. gotoOver() {
  806. if(this.queryObj.type === 'specimenPlan'){
  807. uni.navigateTo({
  808. url: `../specimenCheckingEnd/specimenCheckingEnd?type=${this.queryObj.type}&type1=${
  809. this.queryObj.type1
  810. }&id=${encodeURIComponent(JSON.stringify([this.wcId]))}&deptCode=${
  811. this.queryObj.deptCode
  812. }&dept=${this.queryObj.dept}&speNum=${this.speNum}&content=${this.content}`,
  813. });
  814. }else{
  815. uni.navigateTo({
  816. url: `../scanning/scanning?type=${this.queryObj.type}&type1=${
  817. this.queryObj.type1
  818. }&id=${encodeURIComponent(JSON.stringify([this.wcId]))}&deptCode=${
  819. this.queryObj.deptCode
  820. }&dept=${this.queryObj.dept}&speNum=${this.speNum}&content=${this.content}`,
  821. });
  822. }
  823. },
  824. // 继续执行工单,当扫错科室码的时候,直接跳过,默默执行正确的科室码
  825. goToRight(id) {
  826. // flag 为1时查检查科室,flag为2时查终点科室
  827. let flag;
  828. // 患者转科,患者陪检
  829. if (
  830. this.queryObj.type1 == "trans-dsd-1" ||
  831. this.queryObj.type1 == "ins-dsd-1"
  832. ) {
  833. flag = 2;
  834. }
  835. if (this.queryObj.type1 == "ins-zxz-1") {
  836. flag = 1;
  837. }
  838. let postData = {
  839. workOrderId: id,
  840. flag: flag,
  841. };
  842. uni.showLoading({
  843. title: "加载中",
  844. mask: true,
  845. });
  846. post("/workerOrder/continueWorkOrder", postData).then((res) => {
  847. uni.hideLoading();
  848. console.log(res);
  849. if (res.state == 200) {
  850. let radioItem = [];
  851. res.data.forEach((item) => {
  852. let flag = radioItem.every(
  853. (item1) => item1.qrcode !== item.qrcode + "__" + item.deptName
  854. ); //如果radioItem里的所有项都与之不重复
  855. if (flag) {
  856. radioItem.push({
  857. qrcode: item.qrcode + "__" + item.deptName,
  858. deptName: item.deptName,
  859. });
  860. }
  861. });
  862. this.models1 = {
  863. disjunctor: true,
  864. title: "请选择正确的科室",
  865. radioItem,
  866. icon: "",
  867. operate: {
  868. ok: "确定",
  869. cancel: "取消",
  870. },
  871. };
  872. } else {
  873. uni.showToast({
  874. icon: "none",
  875. title: res.msg || "接口获取数据失败!",
  876. });
  877. }
  878. });
  879. },
  880. // 选中单选框
  881. radioChange1(item) {
  882. console.log(item);
  883. this.selectRadio = item.split("__");
  884. },
  885. // 确定
  886. ok1() {
  887. this.models1.disjunctor = false;
  888. if (!this.selectRadio.length) {
  889. //默认选中第一项,选中则是选中项
  890. this.selectRadio = [
  891. this.models1.radioItem[0].qrcode.split("__")[0],
  892. this.models1.radioItem[0].deptName,
  893. ];
  894. }
  895. uni.navigateTo({
  896. url: `../scanning_code/scanning_code?type=${this.queryObj.type}&type1=${this.queryObj.type1}&id=${this.queryObj.id}&deptCode=${this.selectRadio[0]}&dept=${this.selectRadio[1]}`,
  897. });
  898. },
  899. // 取消
  900. cancel1() {
  901. this.models1.disjunctor = false;
  902. },
  903. // 知道了
  904. showAlert(id) {
  905. uni.navigateTo({
  906. url: "../receiptpage/receiptpage"
  907. });
  908. },
  909. // 获取问卷配置
  910. getQuestionnaireSet(){
  911. uni.showLoading({
  912. title: "加载中",
  913. mask: true,
  914. });
  915. const userData = uni.getStorageSync("userData");
  916. post("/simple/data/fetchDataList/questionnaireConfig",{
  917. questionnaireConfig:{
  918. hosId:userData.user.currentHospital.id
  919. },
  920. idx:0,
  921. sum:10
  922. }).then((res) => {
  923. uni.hideLoading();
  924. if (res.status == 200) {
  925. let data = res.list[0];
  926. if(data.taskTypeDTOS.length>0 && data.questionnaireDTOS.length>0){
  927. let isQuestion = data.taskTypeDTOS.find(i=> i.id == this.taskTypeId)
  928. if(isQuestion){
  929. this.isQuestionModel = true
  930. }
  931. }
  932. } else {
  933. uni.showToast({
  934. icon: "none",
  935. title: res.msg || "接口获取数据失败!",
  936. });
  937. }
  938. });
  939. },
  940. // 页面控制-标本
  941. getPageConfigSpecimen(fn, type, specimenDTO, ress){
  942. const userData = uni.getStorageSync("userData");
  943. console.log('userData', userData);
  944. console.log('specimenDTO', specimenDTO);
  945. uni.showLoading({
  946. title: "加载中",
  947. mask: true,
  948. });
  949. // 查询标本配送业务
  950. post("/simple/data/fetchDataList/taskType",{
  951. "idx": 0,
  952. "sum": 10,
  953. "taskType": {
  954. "simpleQuery": true,
  955. "hosId": {
  956. "id": userData.user.currentHospital.id
  957. },
  958. "associationType": {
  959. "key": "association_types",
  960. "value": "specimen"
  961. }
  962. }
  963. }).then((res) => {
  964. if (res.status == 200) {
  965. let taskTypeDTO = res.list[0];
  966. if(taskTypeDTO){
  967. // 查询业务页面控制-标本
  968. post("/simple/data/fetchDataList/taskTypeConfig",{
  969. "idx": 0,
  970. "sum": 10,
  971. "taskTypeConfig": {
  972. taskTypeDTO,
  973. }
  974. }).then((res) => {
  975. uni.hideLoading();
  976. if (res.status == 200) {
  977. let data = res.list[0];
  978. if(data){
  979. let deptNotAlertList = data.deptNotAlertList || [];
  980. deptNotAlertList = deptNotAlertList.map(v => v.id);
  981. if(deptNotAlertList.includes(specimenDTO.checkDept.id)){
  982. this.isEndDeptRed = true;
  983. console.log('红色')
  984. fn(false, type, ress);
  985. }else{
  986. this.isEndDeptRed = false;
  987. fn(true, type, ress);
  988. }
  989. console.log('this.isEndDeptRed', this.isEndDeptRed);
  990. }else{
  991. this.isEndDeptRed = false;
  992. fn(true, type, ress);
  993. }
  994. } else {
  995. uni.showToast({
  996. icon: "none",
  997. title: res.msg || "接口获取数据失败!",
  998. });
  999. }
  1000. });
  1001. }else{
  1002. uni.hideLoading();
  1003. uni.showToast({
  1004. icon: "none",
  1005. title: "未查询到标本配送业务!",
  1006. });
  1007. }
  1008. } else {
  1009. uni.hideLoading();
  1010. uni.showToast({
  1011. icon: "none",
  1012. title: res.msg || "接口获取数据失败!",
  1013. });
  1014. }
  1015. });
  1016. },
  1017. },
  1018. onShow() {
  1019. this.SMFlag = true;
  1020. this.gotoFlag = true;
  1021. let that = this
  1022. // #ifdef APP-PLUS
  1023. uni.$off('scan') // 每次进来先 移除全局自定义事件监听器
  1024. uni.$on('scan', function(data) {
  1025. that.pdaChange(data)
  1026. })
  1027. // #endif
  1028. },
  1029. onLoad(options) {
  1030. this.isEndDeptRedShow = options.isEndDeptRed === 'true';
  1031. if (options.status == 200&&options.scanOrHand === 'hand'&&(options.type === "specimen"||options.type === "specimenPlan")) {
  1032. this.getPageConfigSpecimen((flag) => {
  1033. if(flag){
  1034. this.hand_again();
  1035. }
  1036. });
  1037. }
  1038. console.log(options , "options");
  1039. this.queryObj = options;
  1040. this.isKs = this.queryObj.isKs;
  1041. if (options.infoData && options.infoData != "undefined") {
  1042. this.infoDATA = JSON.parse(options.infoData);
  1043. } else if (options.model) {
  1044. this.infoDATA = JSON.parse(options.model);
  1045. }
  1046. console.log(this.infoDATA , "infoDATA");
  1047. if (options.accountObj && options.accountObj != "undefined") {
  1048. this.accountObj = JSON.parse(options.accountObj);
  1049. }
  1050. if (options.deptId && options.deptId != "undefined") {
  1051. this.deptId = options.deptId;
  1052. }
  1053. if (options.handover && options.handover != "undefined") {
  1054. this.handover = options.handover;
  1055. }
  1056. this.dataId = options.id;
  1057. if(options.taskTypeId){
  1058. this.taskTypeId = options.taskTypeId
  1059. }else if(this.infoDATA.workOrderList && this.infoDATA.workOrderList.length>0){
  1060. this.taskTypeId = this.infoDATA.workOrderList[0].taskType.id
  1061. }
  1062. this.RESData = options.resData;
  1063. this.res["status"] = options.status;
  1064. this.res["msg"] = options.msg;
  1065. console.log(options.patient);
  1066. this.res["patient"] = options.patient;
  1067. this.res["patientCode"] = options.patientCode;
  1068. this.res["deptName"] = options.deptName;
  1069. this.res["bedNum"] = options.bedNum;
  1070. this.infoType = options.type1;
  1071. if((this.infoType == 'trans-dsd-1' || this.infoType == 'ins-dsd-1'
  1072. || this.infoType == 'ins-half-ok' || this.infoDATA.type == 'ins-half-ok')
  1073. && this.res.status == 200){
  1074. this.getQuestionnaireSet()
  1075. }
  1076. if(
  1077. this.res.status == 200 &&
  1078. this.infoType != 'ins-zxz-1' &&
  1079. this.infoType != 'ins-dsd-1' &&
  1080. this.infoType != 'ins-ddd-1' &&
  1081. this.infoType != 'trans-ddd-1' &&
  1082. this.infoType != 'trans-dsd-1'){
  1083. this.getQuestionnaireSet()
  1084. }
  1085. if (options.dept) {
  1086. this.DEPT = options.dept;
  1087. }
  1088. if (options.speNum) {
  1089. this.speNum = options.speNum;
  1090. }
  1091. this.DEPTCode = options.deptCode;
  1092. this.type = options.type;
  1093. // #ifdef APP-PLUS
  1094. webHandle("no", "app");
  1095. // #endif
  1096. // #ifdef H5
  1097. webHandle("no", "wx");
  1098. // #endif
  1099. },
  1100. };
  1101. </script>
  1102. <style lang="less">
  1103. .Scanning_Result {
  1104. padding: 0 20rpx;
  1105. .Scanning_top {
  1106. .Scanning_top_icon {
  1107. width: 140rpx;
  1108. height: 140rpx;
  1109. margin: 0 auto;
  1110. margin-top: 116rpx;
  1111. border-radius: 50%;
  1112. line-height: 140rpx;
  1113. .speNum{
  1114. text-align: center;
  1115. font-size: 140rpx;
  1116. }
  1117. .cubeic-ok {
  1118. font-size: 140rpx;
  1119. color: #35b34a;
  1120. }
  1121. .cubeic-close {
  1122. font-size: 140rpx;
  1123. color: #ff3b53;
  1124. }
  1125. }
  1126. .Scanning_top_text {
  1127. .text1 {
  1128. font-size: 48rpx;
  1129. text-align: center;
  1130. }
  1131. .success_tips {
  1132. color: red;
  1133. font-size: 30rpx;
  1134. }
  1135. }
  1136. }
  1137. .Scanning_cont {
  1138. font-size: 32rpx;
  1139. text-align: center;
  1140. view {
  1141. margin-bottom: 16rpx;
  1142. }
  1143. .Scanning_cont_center {
  1144. text-align: center;
  1145. }
  1146. .text {
  1147. margin-top: 24rpx;
  1148. color: #35b34a;
  1149. }
  1150. .text1 {
  1151. margin-top: 24rpx;
  1152. color: #ff3b53;
  1153. }
  1154. }
  1155. .foot_btn {
  1156. line-height: 88rpx;
  1157. height: 100rpx;
  1158. margin-top: 40rpx;
  1159. display: flex;
  1160. justify-content: center;
  1161. .btn1,
  1162. .btn2,
  1163. .btn3 {
  1164. height: 88rpx;
  1165. flex: 1;
  1166. margin: 0 1%;
  1167. background-image: linear-gradient(to right, #72c172, #3bb197);
  1168. color: #fff;
  1169. border-radius: 8rpx;
  1170. font-size: 32rpx;
  1171. margin-top: 16rpx;
  1172. text-align: center;
  1173. }
  1174. }
  1175. .foot_btn_spe {
  1176. line-height: 88rpx;
  1177. height: 100rpx;
  1178. margin-top: 40rpx;
  1179. text-align: center;
  1180. display: flex;
  1181. justify-content: space-between;
  1182. flex-wrap: wrap;
  1183. &::after {
  1184. content: '';
  1185. flex: 1;
  1186. }
  1187. view {
  1188. height: 88rpx;
  1189. width: 48%;
  1190. margin: 0 1%;
  1191. background-image: linear-gradient(to right, #72c172, #3bb197);
  1192. color: #fff;
  1193. border-radius: 8rpx;
  1194. font-size: 32rpx;
  1195. margin-top: 16rpx;
  1196. }
  1197. }
  1198. }
  1199. </style>