bigScreen.vue 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664
  1. <template>
  2. <view class="toolbar" :class="!isNumberKey?'fixed-class':''" @click="Scanning()" hover-class="seimin-btn-hover">
  3. <text class="toolbar-icon newicon newicon-saoma"></text>
  4. <text class="toolbar-sao">扫一扫</text>
  5. <!-- 填写交接人工号弹窗 -->
  6. <selectAccount @click.stop.native v-if="hosModels.disjunctor" :disjunctor="hosModels.disjunctor" @ok="hosOk"
  7. @cancel="hosCancel">
  8. </selectAccount>
  9. </view>
  10. </template>
  11. <script>
  12. import {
  13. post,
  14. SM
  15. } from "../../http/http.js";
  16. export default {
  17. data() {
  18. return {
  19. hosId: uni.getStorageSync('userData').user.currentHospital.id,
  20. // 填写交接人工号弹窗model
  21. hosModels: {
  22. disjunctor: false,
  23. },
  24. userId: {
  25. ids: [],
  26. },
  27. workData: [],
  28. infoDATA: {},
  29. tabType: "", //当前选中项
  30. selectArr: [], //选中项
  31. code: "",
  32. currentCode: '', //当前小扫描的科室二维码
  33. SMFlag: true,
  34. }
  35. },
  36. props:{
  37. isNumberKey:Boolean
  38. },
  39. methods: {
  40. // 填写交接人工号-确认
  41. hosOk(data) {
  42. console.log(data);
  43. const {
  44. accountName,
  45. account,
  46. accountId
  47. } = data;
  48. if (!accountName && !account) {
  49. //没有填写交接人
  50. uni.showModal({
  51. title: "提示",
  52. content: "请填写交接人工号!",
  53. showCancel: false,
  54. success: function(res) {
  55. if (res.confirm) {
  56. console.log("用户点击确定");
  57. } else if (res.cancel) {
  58. console.log("用户点击取消");
  59. }
  60. },
  61. });
  62. return;
  63. } else if ((!accountName && account) || (accountName && !account)) {
  64. //没有填写交接人
  65. uni.showModal({
  66. title: "提示",
  67. content: "请填写正确的交接人工号!",
  68. showCancel: false,
  69. success: function(res) {
  70. if (res.confirm) {
  71. console.log("用户点击确定");
  72. } else if (res.cancel) {
  73. console.log("用户点击取消");
  74. }
  75. },
  76. });
  77. return;
  78. }
  79. this.hosModels.disjunctor = false;
  80. this.orderDeptHandler(false, data);
  81. },
  82. // 填写交接人工号-取消
  83. hosCancel() {
  84. this.hosModels.disjunctor = false;
  85. this.flag = true;
  86. },
  87. // 填写交接人工号弹窗
  88. showSelectAccount() {
  89. this.hosModels = {
  90. disjunctor: true,
  91. };
  92. },
  93. // 标本配送-待送达-运输过程-标本数字交接,则,科室签到不需要填写交接人
  94. validateHandoverSpecimen(){
  95. return post("/simple/data/fetchDataList/taskType", {
  96. "idx": 0,
  97. "sum": 1,
  98. "taskType": {
  99. "hosId": {
  100. "id": this.hosId
  101. },
  102. "associationType": {
  103. "key": "association_types",
  104. "value": "specimen"
  105. }
  106. }
  107. });
  108. },
  109. //科室签到
  110. //trueBigScanner----判断是否大扫描
  111. //bigScanner----判断是否需要交接人
  112. //accountObj----弹窗填写的交接人信息
  113. async orderDeptHandler(bigScanner, accountObj) {
  114. console.log(this.infoDATA);
  115. uni.showLoading({
  116. title: "加载中",
  117. mask: true,
  118. });
  119. if(this.tabType === 'specimen' && this.infoDATA.specimen && this.infoDATA.specimen[0].gdState.value == 5){
  120. let result = await this.validateHandoverSpecimen();
  121. if (result.status == 200) {
  122. if(result.list.length){
  123. // 标本-运送过程-终点科室-标本数字交接
  124. if(result.list[0].carryingCourses[1].checkoutMethod.value == 3){
  125. bigScanner = false;
  126. }
  127. }else{
  128. uni.showToast({
  129. icon: "none",
  130. title: "请配置标本配送任务类型!",
  131. });
  132. uni.hideLoading();
  133. return;
  134. }
  135. }
  136. }
  137. let type = "orderSign/" + this.code;
  138. let list = {
  139. ids: this.userId.ids,
  140. trueBigScanner: ['666']
  141. };
  142. bigScanner && (list.bigScanner = ['666']);
  143. if (accountObj) {
  144. list.handover = [accountObj.accountId];
  145. }
  146. post("/workerOrder/" + type, list).then((res) => {
  147. console.log(this.tabType)
  148. uni.hideLoading();
  149. if (res.status == 200) {
  150. if (this.tabType == 'specimenPlan') {
  151. // -----------------------------
  152. console.log(this.selectArr, '选中工单')
  153. let gd = this.infoDATA.specimenPlan.find(v => v.id == this.selectArr[0]);
  154. let startDeptId = gd.startDept.id; //起点科室id
  155. let isDigitalHandover = gd.taskType.isDigitalHandover; //是否数字交接开关
  156. let signDeptId = res.deptId; //签到的科室id
  157. let gdId = gd.id;
  158. let gdState = gd.gdState.value;
  159. let endDepts = gd.endDepts.map(v => v.id).toString();
  160. uni.navigateTo({
  161. url: `../scanning_djEnd/scanning_djEnd?type=${
  162. this.tabType
  163. }&type1=${res.type}&code=${this.code}&dept=${
  164. res.dept
  165. }&ids=${encodeURIComponent(
  166. JSON.stringify(this.userId.ids)
  167. )}&model=${encodeURIComponent(JSON.stringify(res))}&accountObj=${encodeURIComponent(JSON.stringify(accountObj))}&deptId=${res.deptId}&startDeptId=${startDeptId}&isDigitalHandover=${isDigitalHandover}&signDeptId=${signDeptId}&gdId=${gdId}&gdState=${gdState}&endDepts=${endDepts}`,
  168. });
  169. } else if (this.tabType == 'specimen') {
  170. // 同济是false
  171. if (res.deptType && res.deptType.value === 'middleRoom') {
  172. // if (false) {
  173. // 如果是中转科室
  174. uni.navigateTo({
  175. url: `../checkAfterBigScreen/checkAfterBigScreen?type=${
  176. this.tabType
  177. }&type1=${res.type}&code=${this.code}&dept=${
  178. res.dept
  179. }&ids=${encodeURIComponent(
  180. JSON.stringify(this.userId.ids)
  181. )}&model=${encodeURIComponent(JSON.stringify(res))}&accountObj=${encodeURIComponent(JSON.stringify(accountObj))}&deptId=${res.deptId}`,
  182. });
  183. } else if(res.type === 'spe-dsd-4'){
  184. // 检验方式是标本数字交接
  185. uni.navigateTo({
  186. url: `/pages/specimenHandoverNew/specimenHandoverNew?type=${
  187. this.tabType
  188. }&type1=${res.type}&code=${this.code}&dept=${
  189. res.dept
  190. }&ids=${encodeURIComponent(
  191. JSON.stringify(this.userId.ids)
  192. )}&model=${encodeURIComponent(JSON.stringify(res))}&accountObj=${encodeURIComponent(JSON.stringify(accountObj))}&deptId=${res.deptId}`,
  193. });
  194. } else{
  195. uni.navigateTo({
  196. url: `../scanning_djEnd/scanning_djEnd?type=${
  197. this.tabType
  198. }&type1=${res.type}&code=${this.code}&dept=${
  199. res.dept
  200. }&ids=${encodeURIComponent(
  201. JSON.stringify(this.userId.ids)
  202. )}&model=${encodeURIComponent(JSON.stringify(res))}&accountObj=${encodeURIComponent(JSON.stringify(accountObj))}&deptId=${res.deptId}`,
  203. });
  204. }
  205. }
  206. } else if (res.status == "0000") {
  207. this.showSelectAccount();
  208. } else {
  209. this.flag = true;
  210. uni.navigateTo({
  211. url: `../scanning_djEnd/scanning_djEnd?type=${this.tabType}&type1=${
  212. res.type
  213. }&code=${this.code}&dept=${res.dept}&ids=${encodeURIComponent(
  214. JSON.stringify(this.userId.ids)
  215. )}&model=${encodeURIComponent(JSON.stringify(res))}&deptId=${res.deptId}`,
  216. });
  217. }
  218. });
  219. },
  220. //获取药包信息
  221. getInfo(responeseData, code){
  222. console.log(responeseData);
  223. uni.showLoading({
  224. title: "加载中",
  225. mask: true,
  226. });
  227. post(`/transflow/scanInfo`, {type: responeseData.drugsBagType, id: responeseData.drugsBagId, orderStateValue: responeseData.orderStateValue}).then(res => {
  228. uni.hideLoading();
  229. if(res.state == 200){
  230. if(res.data){
  231. let drugsBag = res.data.dto || {};
  232. let orderId = responeseData.orderId;
  233. let config = res.data.taskTypeConfig || {};
  234. console.log(res);
  235. if(responeseData.orderStateValue == 2 || responeseData.orderStateValue == 3 || (responeseData.orderStateValue == 4 && responeseData.workerId == uni.getStorageSync('userData').user.id)){
  236. // 待抢单、待接单、待到达(本人),进入起点科室流程
  237. uni.navigateTo({
  238. url: `/pages/newDrug/createOrder/createOrder?drugsBagType=${responeseData.drugsBagType}&drugsBagId=${responeseData.drugsBagId}&orderId=${responeseData.orderId || ''}&type=receive`,
  239. });
  240. }else if(responeseData.orderStateValue == 5 && responeseData.workerId == uni.getStorageSync('userData').user.id){
  241. // 待送达(本人),进入终点科室流程
  242. this.pageNavigateByConfig(config, responeseData, responeseData, code)
  243. }else{
  244. // 查看药包信息
  245. uni.navigateTo({
  246. url: `/pages/newDrug/createOrder/createOrder?drugsBagType=${responeseData.drugsBagType}&drugsBagId=${responeseData.drugsBagId}&type=view`,
  247. });
  248. }
  249. }
  250. }else{
  251. uni.showToast({
  252. icon: "none",
  253. title: res.msg || "接口获取数据失败!",
  254. });
  255. }
  256. })
  257. },
  258. // 工单完成
  259. completeOrder(responseData, queryObj){
  260. console.log(responseData, queryObj)
  261. uni.showLoading({
  262. title: "加载中",
  263. mask: true,
  264. });
  265. let postData = {
  266. "type": queryObj.drugsBagType,
  267. "orderId": responseData.orderId,
  268. };
  269. post('/transflow/checkComplete', postData).then(res => {
  270. uni.hideLoading();
  271. if(res.state == 200){
  272. uni.showToast({
  273. icon: "none",
  274. title: responseData.orderStateValue == 4 ? "交接成功,请尽快送达科室!" : (responseData.orderStateValue == 5 ? "交接成功,完成配送!" : ""),
  275. duration: 60000,
  276. mask: true,
  277. complete(){
  278. setTimeout(() => {
  279. uni.hideToast();
  280. uni.redirectTo({
  281. url: `/pages/receiptpage/receiptpage`,
  282. });
  283. }, 2000)
  284. }
  285. });
  286. }else{
  287. uni.showToast({
  288. icon: "none",
  289. title: res.msg || "接口获取数据失败!",
  290. });
  291. }
  292. })
  293. },
  294. // 根据配置跳转页面
  295. pageNavigateByConfig(config, responseData, queryObj, code){
  296. let drugsBagType = queryObj.drugsBagType;
  297. let orderId = responseData.orderId;
  298. let drugsBagId = responseData.drugsBagId;
  299. let orderStateValue = responseData.orderStateValue;
  300. if(config.drugsModel === 1){
  301. // 一单一码
  302. if(responseData.orderStateValue == 4){
  303. // 待到达
  304. if(config.drugsStartCheck === 1){
  305. // 起点科室支持核对
  306. uni.navigateTo({
  307. url: `/pages/newDrug/checkPage/checkPage?drugsBagType=${drugsBagType}&orderId=${orderId}`,
  308. });
  309. }else{
  310. // 起点科室不支持核对
  311. if(config.drugsStartPhoto === 1){
  312. // 起点科室支持拍照留存
  313. uni.navigateTo({
  314. url: `/pages/newDrug/photoRetention/photoRetention?drugsBagType=${drugsBagType}&orderId=${orderId}`,
  315. });
  316. }else{
  317. // 起点科室不支持拍照留存
  318. this.completeOrder(responseData, queryObj);
  319. }
  320. }
  321. }else if(responseData.orderStateValue == 5){
  322. // 待送达
  323. if(config.drugsEndCheck === 1){
  324. // 起点科室支持核对
  325. uni.navigateTo({
  326. url: `/pages/newDrug/checkPage/checkPage?drugsBagType=${drugsBagType}&orderId=${orderId}`,
  327. });
  328. }else{
  329. // 起点科室不支持核对
  330. if(config.drugsEndPhoto === 1){
  331. // 起点科室支持拍照留存
  332. uni.navigateTo({
  333. url: `/pages/newDrug/photoRetention/photoRetention?drugsBagType=${drugsBagType}&orderId=${orderId}`,
  334. });
  335. }else{
  336. // 终点科室不支持拍照留存
  337. this.completeOrder(responseData, queryObj);
  338. }
  339. }
  340. }
  341. }else if(config.drugsModel === 2){
  342. // 一单多码
  343. uni.showLoading({
  344. title: "加载中",
  345. mask: true,
  346. });
  347. post("/transflow/scanBind", { type: drugsBagType, orderId, code }).then((ress) => {
  348. uni.hideLoading();
  349. if (ress.state == 200) {
  350. if(ress.data.msg){
  351. uni.showToast({
  352. icon: "none",
  353. title: ress.data.msg || "接口获取数据失败!",
  354. });
  355. }else{
  356. uni.navigateTo({
  357. url: `/pages/newDrug/continueScanning/continueScanning?drugsBagType=${drugsBagType}&orderId=${orderId}&drugsBagId=${drugsBagId}&orderStateValue=${orderStateValue}`,
  358. });
  359. }
  360. } else {
  361. uni.showToast({
  362. icon: "none",
  363. title: ress.msg || "接口获取数据失败!",
  364. });
  365. }
  366. });
  367. }
  368. },
  369. // 底部扫描
  370. Scanning(qrcodePrefix = '') {
  371. if (!this.SMFlag) {
  372. return;
  373. }
  374. this.SMFlag = false;
  375. SM().then((content) => {
  376. uni.showLoading({
  377. title: "加载中",
  378. mask: true,
  379. });
  380. //检验二维码的有效性(扫码前必须验证)
  381. post("/dept/scanning", {
  382. content,
  383. })
  384. .then((result) => {
  385. this.currentCode = result.code;
  386. this.SMFlag = true;
  387. // 200检测通过,201没有有效期也通过。
  388. if (result.state == 200 || result.state == 201) {
  389. let data = {
  390. code: result.code, //二维码
  391. };
  392. //微信—大扫描(科室码,患者码,标本码,快捷建单码,药包码)
  393. let code = result.code.includes(qrcodePrefix) ? result.code : qrcodePrefix + result.code;
  394. post("/workerOrder/scanCode", { code, hosId: this.hosId })
  395. .then((res) => {
  396. uni.hideLoading();
  397. if (res.status == 200) {
  398. // 扫描标本码
  399. if (res.type == "specimen") {
  400. let infoDATA = {
  401. stype: res.data.stype,
  402. scode: res.data.scode,
  403. patientName: res.data.patientName,
  404. sickRoom: res.data.sickRoom ?
  405. res.data.sickRoom.dept : "-",
  406. checkDept: res.data.checkDept ?
  407. res.data.checkDept.dept : "-",
  408. bedNum: res.data.bedNum,
  409. };
  410. uni.navigateTo({
  411. url: `../scanning_B/scanning_B?res=${encodeURIComponent(
  412. JSON.stringify(res)
  413. )}&infoDATA=${encodeURIComponent(
  414. JSON.stringify(infoDATA)
  415. )}`,
  416. });
  417. } else if (res.type == "patient") {
  418. //如果是患者腕带码
  419. // code: data.code //二维码
  420. res.workOrder = res.workOrder ? res.workOrder : []; //liao
  421. uni.navigateTo({
  422. url: `../scanning_ins/scanning_ins?code=${
  423. data.code
  424. }&infoDATA=${encodeURIComponent(
  425. JSON.stringify(res.data)
  426. )}&workData=${encodeURIComponent(
  427. JSON.stringify(res.workOrder)
  428. )}&patientOrders=${encodeURIComponent(
  429. JSON.stringify(res.patientOrders)
  430. )}`,
  431. });
  432. } else if (res.type == "quickOrder") {
  433. //快捷建单
  434. if(res.data.isDigitalHandover == 1){
  435. uni.navigateTo({
  436. url: `../specimenChecking/specimenChecking?infoDATA=${encodeURIComponent(
  437. JSON.stringify(res.data)
  438. )}`,
  439. });
  440. }else{
  441. uni.navigateTo({
  442. url: `../shortcutbuildOrders/shortcutbuildOrders?infoDATA=${encodeURIComponent(
  443. JSON.stringify(res.data)
  444. )}`,
  445. });
  446. }
  447. } else if (res.type == "dept") {
  448. // 扫描科室码
  449. // code: data.code //二维码
  450. let infoDATA = res.data;
  451. console.log(infoDATA)
  452. // 判断是否是标本配送,并且仅仅只有这一种业务类型,默认全选,并跳转到下一步;
  453. // 判断是否是标本轮巡 ,并且仅仅只有这一种业务类型,并且只有一个工单,默认选中,并跳转到下一步;
  454. if(Object.keys(infoDATA).length === 1 && (infoDATA.specimen || (infoDATA.specimenPlan && infoDATA.specimenPlan.length === 1))){
  455. this.infoDATA = infoDATA;
  456. this.workData = infoDATA.specimen || infoDATA.specimenPlan;
  457. this.tabType = infoDATA.specimen ? 'specimen' : 'specimenPlan';
  458. this.code = data.code;
  459. this.selectArr = [];
  460. for (var i = 0; i < this.workData.length; i++) {
  461. this.selectArr.push(this.workData[i].id);
  462. }
  463. this.userId.ids = this.selectArr;
  464. this.orderDeptHandler(true);
  465. }else if(res.deptHandoverType && res.deptHandoverType.value == 'clinicalWaste'){
  466. // 医废
  467. uni.navigateTo({
  468. url: `/pages/medicalWaste/medicalWasteSignIn/medicalWasteSignIn?code=${data.code}&deptName=${res.deptName}&deptId=${res.deptId}`,
  469. });
  470. }else{
  471. uni.navigateTo({
  472. url: `../scanning_all/scanning_all?infoDATA=${encodeURIComponent(
  473. JSON.stringify(infoDATA)
  474. )}&code=${data.code}&deptName=${res.deptName}&deptId=${res.deptId}`,
  475. });
  476. }
  477. } else if (res.type == 'drugsBag') {
  478. if (res.drugsBagType == 'drugsJpbag' || res.drugsBagType == 'drugsWestern' || res.drugsBagType == 'drugsReturn' || res.drugsBagType == 'drugsPoison' || res.drugsBagType == 'drugsHerbal') {
  479. //新药品-扫静配|西药|退药|毒麻|中草药
  480. if(res.orderId){
  481. // 有工单
  482. this.getInfo(res, code);
  483. }else{
  484. // 没有工单,进入起点科室流程
  485. uni.navigateTo({
  486. url: `/pages/newDrug/createOrder/createOrder?drugsBagType=${res.drugsBagType}&drugsBagId=${res.drugsBagId}&type=build`,
  487. });
  488. }
  489. }else{
  490. //扫药包码
  491. uni.navigateTo({
  492. url: `/pages/scanning_drug/scanning_drug?drugsBagId=${res.drugsBagId}&drugsBagBatchNo=${res.drugsBagBatchNo}`,
  493. });
  494. }
  495. } else if (res.type == 'nucleicAcid') {
  496. //扫核酸码
  497. uni.navigateTo({
  498. url: `/pages/scanning_nucleicAcid/scanning_nucleicAcid?qrcode=${data.code}`,
  499. });
  500. } else if (res.type == 'blood') {
  501. //扫血制品
  502. // 判断size,多个则进入新页面选择
  503. if(res.size > 1){
  504. uni.navigateTo({
  505. url: `/pages/bloodSelect/bloodSelect?qrcode=${data.code}&navigateTo=scanning_blood`,
  506. });
  507. } else {
  508. uni.navigateTo({
  509. url: `/pages/scanning_blood/scanning_blood?qrcode=${data.code}`,
  510. });
  511. }
  512. } else if (res.type == 'receiveOrder') {
  513. //扫快捷接单
  514. uni.showModal({
  515. title: "提示",
  516. content: `您本次接单包括${res.names.join('、')},一共含有${res.data.length}个工单,是否确认接单?`,
  517. success: function(result) {
  518. if (result.confirm) {
  519. uni.showLoading({
  520. title: "加载中",
  521. mask: true,
  522. });
  523. post("/workerOrder/receiveOrders", {ids: res.data.toString()}).then((result) => {
  524. uni.hideLoading();
  525. if (result.status == 200) {
  526. uni.showModal({
  527. title: "提示",
  528. content: `本次接单包括${res.names.join('、')},${res.data.length}个工单已接单完成`,
  529. showCancel: false,
  530. success: function(res) {
  531. if (res.confirm) {
  532. console.log("用户点击确定");
  533. uni.redirectTo({
  534. url: "../receiptpage/receiptpage",
  535. });
  536. } else if (res.cancel) {
  537. console.log("用户点击取消");
  538. }
  539. },
  540. });
  541. } else {
  542. uni.showToast({
  543. icon: "none",
  544. title: result.msg || "接口获取数据失败!",
  545. });
  546. }
  547. });
  548. } else if (result.cancel) {
  549. console.log("用户点击取消");
  550. }
  551. },
  552. });
  553. } else if (res.type == 'bloodTake') {
  554. if(res.data){
  555. //新血制品-扫科室
  556. uni.navigateTo({
  557. url: `/pages/newBlood/startOrderSignBlood/startOrderSignBlood?deptId=${res.deptId}&deptName=${res.deptName}&taskTypeId=${res.taskTypeId}`,
  558. });
  559. }else{
  560. // 走type是dept的流程
  561. // 扫描科室码
  562. // code: data.code //二维码
  563. let infoDATA = res.data;
  564. console.log(infoDATA)
  565. // 判断是否是标本配送,并且仅仅只有这一种业务类型,默认全选,并跳转到下一步;
  566. // 判断是否是标本轮巡 ,并且仅仅只有这一种业务类型,并且只有一个工单,默认选中,并跳转到下一步;
  567. if(Object.keys(infoDATA).length === 1 && (infoDATA.specimen || (infoDATA.specimenPlan && infoDATA.specimenPlan.length === 1))){
  568. this.infoDATA = infoDATA;
  569. this.workData = infoDATA.specimen || infoDATA.specimenPlan;
  570. this.tabType = infoDATA.specimen ? 'specimen' : 'specimenPlan';
  571. this.code = data.code;
  572. this.selectArr = [];
  573. for (var i = 0; i < this.workData.length; i++) {
  574. this.selectArr.push(this.workData[i].id);
  575. }
  576. this.userId.ids = this.selectArr;
  577. this.orderDeptHandler(true);
  578. }else{
  579. uni.navigateTo({
  580. url: `../scanning_all/scanning_all?infoDATA=${encodeURIComponent(
  581. JSON.stringify(infoDATA)
  582. )}&code=${data.code}&deptName=${res.deptName}&deptId=${res.deptId}`,
  583. });
  584. }
  585. }
  586. } else if(res.type == 'clinicalWaste'){
  587. // 医废
  588. if(res.wasteDetails){
  589. uni.navigateTo({
  590. url: `/pages/medicalWaste/medicalWasteDetail/medicalWasteDetail?qrcode=${res.code}`,
  591. });
  592. }else{
  593. uni.navigateTo({
  594. url: `/pages/medicalWaste/medicalWasteBind/medicalWasteBind?qrcode=${res.code}`,
  595. });
  596. }
  597. }
  598. } else {
  599. if(res.bigScanSpecialMsg){
  600. uni.navigateTo({
  601. url: `../scanning_big_Result/scanning_big_Result?msg=${res.msg || ''}&qrcode=${this.currentCode}&bigScanSpecialMsg=${encodeURIComponent(JSON.stringify(res.bigScanSpecialMsg))}`,
  602. });
  603. }else{
  604. uni.navigateTo({
  605. url: `../scanning_Result/scanning_Result?status=${res.status}&msg=${res.msg}&qrcode=${this.currentCode}`,
  606. });
  607. }
  608. }
  609. });
  610. } else {
  611. uni.hideLoading();
  612. uni.showToast({
  613. icon: "none",
  614. title: result.info || "接口获取数据失败!",
  615. });
  616. }
  617. })
  618. }).catch(err => {
  619. this.SMFlag = true;
  620. });
  621. },
  622. },
  623. onShow() {
  624. this.SMFlag = true;
  625. }
  626. };
  627. </script>
  628. <style lang="less">
  629. // 底部扫一扫
  630. .fixed-class{
  631. position: fixed;
  632. }
  633. .toolbar {
  634. // position: fixed;
  635. left: 0;
  636. right: 0;
  637. bottom: 30rpx;
  638. z-index: 999;
  639. height: 88rpx;
  640. display: flex;
  641. justify-content: center;
  642. align-items: center;
  643. box-sizing: border-box;
  644. border-radius: 4rpx;
  645. // box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.24);
  646. // background-color: #e5e9ed;
  647. .toolbar-icon {
  648. font-size: 52rpx;
  649. margin-right: 16rpx;
  650. color: #07863c;
  651. }
  652. .toolbar-sao {
  653. font-size: 36rpx;
  654. color: #333;
  655. }
  656. }
  657. </style>