scanning_djInfo.vue 19 KB

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