scanning.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. <template>
  2. <view class="Scanning">
  3. <view class="Scanning_top footerOtherMargin">
  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 class="text2" v-if="queryObj.content && queryObj.type !== 'specimenPlan'" v-html="queryObj.content"></view>
  10. <view class="text2" v-if="!queryObj.content">
  11. 您已在
  12. <text style="font-weight: 600; color: rgb(73, 184, 86)" v-if="
  13. infoType == 'plan-spe-ddd-1' ||
  14. infoType == 'plan-spe-ddd-2' ||
  15. infoType == 'spe-ddd-1' ||
  16. infoType == 'spe-ddd-2' ||
  17. infoType == 'drug-ddd-2' ||
  18. infoType == 'jp-ddd-2'
  19. ">{{ infoDATA.startDept.dept }}</text>
  20. <text style="font-weight: 600; color: rgb(73, 184, 86)"
  21. v-if="infoType == 'drug-dsd-2' || infoType == 'jp-dsd-2'">{{ infoDATA.endDepts[0].dept }}</text>
  22. <text style="font-weight: 600; color: rgb(73, 184, 86)" v-if="
  23. infoType == 'plan-spe-dsd-2' ||
  24. infoType == 'plan-spe-dsd-3' ||
  25. infoType == 'plan-spe-dsd-1' ||
  26. infoType == 'spe-dsd-2' ||
  27. infoType == 'spe-dsd-3' ||
  28. infoType == 'spe-dsd-1' ||
  29. infoType == 'ins-zxz-1' ||
  30. infoType == 'ins-dsd-1' ||
  31. infoType == 'trans-dsd-1' ||
  32. (infoType == 'qt-ddd-1' && infoDATA.gdState.value == '5') ||
  33. infoDATA.gdState.value == '6' ||
  34. infoDATA.gdState.value == '8'
  35. ">{{ DEPT }}</text>
  36. <text>扫描<text style="color: #ff3b53">{{ speNum }}</text> 个标本,
  37. 确认是否继续配送或是完成工单。</text>
  38. </view>
  39. <template v-if="queryObj.type === 'specimenPlan'">
  40. <table class="speTable">
  41. <tr>
  42. <td>科室名称</td>
  43. <td>数量</td>
  44. <td>状态</td>
  45. </tr>
  46. <tr v-for="spe in infoList" :key="spe.deptId">
  47. <td class="maxWidth">{{spe.deptName}}</td>
  48. <td>{{spe.speNum}}</td>
  49. <td>
  50. <text v-if="spe.deptState=== 'ysd'" class="green">已到达</text>
  51. <text v-if="spe.deptState=== 'wsd'" class="red">未到达</text>
  52. </td>
  53. </tr>
  54. </table>
  55. </template>
  56. </view>
  57. </view>
  58. <view class="foot_btn1 footerPadding">
  59. <view class="btn1" @click="Scanning_again()"> 继续配送 </view>
  60. <view class="btn2" @click="Scanning_complete(dataId)" v-if="
  61. infoType == 'plan-spe-ddd-1' ||
  62. infoType == 'plan-spe-dsd-1' ||
  63. infoType == 'spe-ddd-1' ||
  64. infoType == 'spe-dsd-1'
  65. ">
  66. 完成工单
  67. </view>
  68. <view class="btn2" @click="Scanning_complete1(dataId)" v-if="
  69. infoType == 'plan-spe-ddd-2' ||
  70. infoType == 'plan-spe-dsd-2' ||
  71. infoType == 'plan-spe-dsd-3' ||
  72. infoType == 'spe-ddd-2' ||
  73. infoType == 'spe-dsd-2' ||
  74. infoType == 'spe-dsd-3'
  75. ">
  76. 完成工单
  77. </view>
  78. </view>
  79. <!-- 弹窗 -->
  80. <showModel :title="models.title" :icon="models.icon" :disjunctor="models.disjunctor" :content="models.content"
  81. @ok="ok" @cancel="cancel" :operate="models.operate"></showModel>
  82. </view>
  83. </template>
  84. <script>
  85. import showModel from "../../components/showModel/showModel.vue";
  86. import {
  87. get,
  88. post,
  89. SM,
  90. webHandle
  91. } from "../../http/http.js";
  92. export default {
  93. data() {
  94. return {
  95. infoList:[],
  96. // 弹窗model
  97. models: {
  98. disjunctor: false,
  99. },
  100. wcId: [], //完成工单id
  101. modelFlag: "", //弹窗标识
  102. infoDATA: [],
  103. infoType: "",
  104. DEPTCode: "",
  105. DEPT: "",
  106. dataId: "",
  107. speNum: 0,
  108. queryObj: {}, //路由传递过来的参数
  109. };
  110. },
  111. methods: {
  112. // 获取标本轮巡核对信息
  113. getInfo() {
  114. uni.showLoading({
  115. title: "加载中",
  116. mask: true,
  117. });
  118. let postData = {
  119. uuid: this.dataId[0]
  120. };
  121. post(`/api/getDeptSpecimensNum`, postData).then((res) => {
  122. uni.hideLoading();
  123. if (res.status == 200) {
  124. this.infoList = res.data;
  125. } else {
  126. uni.showToast({
  127. icon: "none",
  128. title: "请求失败!",
  129. });
  130. }
  131. });
  132. },
  133. // 继续配送
  134. Scanning_again(id) {
  135. uni.navigateTo({
  136. url: "../receiptpage/receiptpage",
  137. });
  138. },
  139. // 确定
  140. ok() {
  141. this.models.disjunctor = false;
  142. uni.showLoading({
  143. title: "加载中",
  144. mask: true,
  145. });
  146. if (this.modelFlag == "complete1") {
  147. //一对多、多对多完成工单
  148. let data = {
  149. type: this.infoType,
  150. ids: this.wcId,
  151. };
  152. let id = this.wcId;
  153. if (this.queryObj.type === "specimenPlan") {
  154. //标本轮巡
  155. post("/workerOrder/finishPlanSpes", data).then((res) => {
  156. uni.hideLoading();
  157. if (res.status == 200) {
  158. uni.navigateTo({
  159. url: `../scanning_orderSign/scanning_orderSign?type=${
  160. this.queryObj.type
  161. }&type1=${this.queryObj.type1}&deptCode=${
  162. this.queryObj.code
  163. }&id=${encodeURIComponent(JSON.stringify(id))}`,
  164. });
  165. } else {
  166. uni.showToast({
  167. icon: "none",
  168. title: "请求失败!",
  169. });
  170. }
  171. });
  172. } else {
  173. post("/workerOrder/finishSpes", data).then((res) => {
  174. uni.hideLoading();
  175. if (res.status == 200) {
  176. uni.navigateTo({
  177. url: `../scanning_orderSign/scanning_orderSign?type=${
  178. this.queryObj.type
  179. }&type1=${this.queryObj.type1}&deptCode=${
  180. this.queryObj.code
  181. }&id=${encodeURIComponent(JSON.stringify(id))}`,
  182. });
  183. } else {
  184. uni.showToast({
  185. icon: "none",
  186. title: "请求失败!",
  187. });
  188. }
  189. });
  190. }
  191. } else if (this.modelFlag == "complete") {
  192. //一对一完成工单
  193. let id = this.wcId;
  194. post("/workerOrder/finishSpeOrder", id).then((res) => {
  195. uni.hideLoading();
  196. if (res.status == 200) {
  197. uni.navigateTo({
  198. url: `../scanning_orderSign/scanning_orderSign?type=${
  199. this.queryObj.type
  200. }&type1=${this.queryObj.type1}&deptCode=${
  201. this.queryObj.code
  202. }&id=${encodeURIComponent(JSON.stringify(id))}`,
  203. });
  204. } else {
  205. uni.showToast({
  206. icon: "none",
  207. title: "请求失败!",
  208. });
  209. }
  210. });
  211. }
  212. },
  213. // 取消
  214. cancel() {
  215. this.models.disjunctor = false;
  216. },
  217. //一对多、多对多完成工单
  218. Scanning_complete1(id) {
  219. this.wcId = id;
  220. this.modelFlag = "complete1"; //弹窗标识
  221. this.models = {
  222. disjunctor: true,
  223. title: "提示",
  224. content: "是否确定标本配送完成?",
  225. icon: "warn",
  226. operate: {
  227. ok: "确定",
  228. cancel: "取消",
  229. },
  230. };
  231. },
  232. //一对一完成工单
  233. Scanning_complete(id) {
  234. this.wcId = id;
  235. this.modelFlag = "complete"; //弹窗标识
  236. this.models = {
  237. disjunctor: true,
  238. title: "提示",
  239. content: "是否确定标本配送完成?",
  240. icon: "warn",
  241. operate: {
  242. ok: "确定",
  243. cancel: "取消",
  244. },
  245. };
  246. },
  247. },
  248. onLoad(options) {
  249. console.log(options, 'options')
  250. this.queryObj = options;
  251. let id = JSON.parse(options.id);
  252. this.dataId = id;
  253. this.infoType = options.type1;
  254. this.DEPTCode = options.deptCode;
  255. this.DEPT = options.dept;
  256. if (options.speNum) {
  257. this.speNum = options.speNum;
  258. }
  259. if(this.queryObj.type === 'specimenPlan'){
  260. this.getInfo();
  261. }
  262. // #ifdef APP-PLUS
  263. webHandle("no", "app");
  264. // #endif
  265. // #ifdef H5
  266. webHandle("no", "wx");
  267. // #endif
  268. },
  269. };
  270. </script>
  271. <style lang="less" scoped>
  272. .Scanning {
  273. padding: 0 20rpx;
  274. // 标本轮巡核对 start
  275. .speTable {
  276. margin: 32rpx 0;
  277. width: 100%;
  278. border-collapse: collapse;
  279. .green{
  280. color: green;
  281. }
  282. .red{
  283. color: red;
  284. }
  285. .maxWidth{
  286. width: 60%;
  287. }
  288. td{
  289. border: 2rpx solid #666;
  290. }
  291. }
  292. // 标本轮巡核对 end
  293. .Scanning_top {
  294. height: 340rpx;
  295. .Scanning_top_icon {
  296. width: 140rpx;
  297. height: 140rpx;
  298. margin: 0 auto;
  299. margin-top: 36rpx;
  300. border-radius: 50%;
  301. line-height: 140rpx;
  302. .cubeic-ok {
  303. font-size: 140rpx;
  304. color: #35b34a;
  305. }
  306. }
  307. .Scanning_top_text {
  308. text-align: center;
  309. .text1 {
  310. margin-top: 40rpx;
  311. font-size: 48rpx;
  312. }
  313. .text2 {
  314. margin-top: 16rpx;
  315. font-size: 36rpx;
  316. }
  317. }
  318. }
  319. .page_item {
  320. margin-top: 16rpx;
  321. margin-bottom: 124rpx;
  322. min-height: 356rpx;
  323. background: #fff;
  324. border-radius: 8rpx;
  325. overflow: hidden;
  326. padding: 0 16rpx;
  327. border: 2rpx solid #e5e9ed;
  328. .L {
  329. width: 40rpx;
  330. height: 40rpx;
  331. border-radius: 50%;
  332. background: #f9fafb;
  333. position: relative;
  334. left: -50rpx;
  335. top: 66rpx;
  336. }
  337. .R {
  338. width: 40rpx;
  339. height: 40rpx;
  340. border-radius: 50%;
  341. background: #f9fafb;
  342. position: relative;
  343. float: right;
  344. right: -50rpx;
  345. top: 26rpx;
  346. }
  347. .starting {
  348. width: 50rpx;
  349. height: 50rpx;
  350. color: #fff;
  351. background: #49b856;
  352. display: inline-block;
  353. border-radius: 50%;
  354. text-align: center;
  355. line-height: 46rpx;
  356. font-size: 32rpx;
  357. margin-right: 6rpx;
  358. }
  359. .End {
  360. width: 50rpx;
  361. height: 50rpx;
  362. color: #fff;
  363. background: #39b199;
  364. display: inline-block;
  365. border-radius: 50%;
  366. text-align: center;
  367. line-height: 46rpx;
  368. font-size: 32rpx;
  369. margin-right: 6rpx;
  370. }
  371. .page_item_top {
  372. height: 86rpx;
  373. border-bottom: 2rpx dashed #e5e9ed;
  374. padding: 0 16rpx;
  375. .page_item_top_L {
  376. height: 100%;
  377. float: left;
  378. line-height: 88rpx;
  379. .emergencys {
  380. background: #ff3b53 !important;
  381. width: 124rpx !important;
  382. }
  383. .emergency {
  384. background: #ff3b53 !important;
  385. }
  386. .emergency1 {
  387. background: #49b856 !important;
  388. }
  389. .page_item_cont_start {
  390. text-align: center;
  391. height: 44rpx;
  392. width: 104rpx;
  393. line-height: 44rpx;
  394. border-radius: 8rpx;
  395. background: #49b856;
  396. color: #fff;
  397. display: inline-block;
  398. }
  399. .L_time {
  400. color: #6cc076;
  401. font-size: 32rpx;
  402. }
  403. .L_text {
  404. font-size: 32rpx;
  405. display: inline-block;
  406. font-weight: 700;
  407. }
  408. }
  409. .page_item_top_R {
  410. height: 60rpx;
  411. float: right;
  412. padding-top: 20rpx;
  413. font-size: 32rpx;
  414. position: absolute;
  415. right: 50rpx;
  416. .L_iocn {
  417. display: inline-block;
  418. height: 52rpx;
  419. line-height: 48rpx;
  420. color: rgb(7, 134, 60);
  421. font-size: 36rpx;
  422. font-weight: 700;
  423. }
  424. }
  425. }
  426. .page_item_cont {
  427. min-height: 180rpx;
  428. max-height: 424rpx;
  429. padding: 0 16rpx;
  430. text-align: left;
  431. position: relative;
  432. .text_big {
  433. font-size: 32rpx;
  434. position: absolute;
  435. right: 16rpx;
  436. font-weight: 700;
  437. margin-top: 10rpx;
  438. }
  439. .text_big2 {
  440. font-size: 32rpx;
  441. position: absolute;
  442. right: 16rpx;
  443. font-weight: 700;
  444. }
  445. .line {
  446. height: 20rpx;
  447. width: 2rpx;
  448. border-left: 2rpx solid #e5e9ed;
  449. position: absolute;
  450. top: 82rpx;
  451. left: 40rpx;
  452. }
  453. .lines {
  454. height: 40%;
  455. width: 2rpx;
  456. border-left: 2rpx solid #e5e9ed;
  457. position: absolute;
  458. top: 23%;
  459. left: 36rpx;
  460. }
  461. .page_item_cont_T {
  462. padding-top: 28rpx;
  463. font-size: 28rpx;
  464. .page_item_cont_title {
  465. height: 100%;
  466. font-size: 32rpx;
  467. }
  468. }
  469. .page_item_cont_B {
  470. padding-top: 28rpx;
  471. margin-bottom: 28rpx;
  472. .page_item_cont_title {
  473. height: 60rpx;
  474. font-size: 32rpx;
  475. }
  476. .page_item_cont_title1 {
  477. height: 60rpx;
  478. line-height: 60rpx;
  479. font-size: 32rpx;
  480. padding-left: 64rpx;
  481. }
  482. }
  483. }
  484. .page_item_foot {
  485. border-top: 2rpx dashed #e5e9ed;
  486. border-bottom: 2rpx dashed #e5e9ed;
  487. padding: 28rpx 16rpx;
  488. text-align: left;
  489. .page_item_foot_text {
  490. font-size: 32rpx;
  491. margin-bottom: 20rpx;
  492. .text1 {
  493. color: rgb(102, 102, 102);
  494. }
  495. .text2 {
  496. float: right;
  497. font-weight: 700;
  498. }
  499. }
  500. .text_padd {
  501. padding: 0 10% 0 10%;
  502. }
  503. }
  504. #infos {
  505. display: none;
  506. }
  507. .page_item_infos {
  508. padding-bottom: 20rpx;
  509. border-bottom: 2rpx dashed #e5e9ed;
  510. .page_item_info2 {
  511. text-align: left;
  512. line-height: 60rpx;
  513. font-size: 32rpx;
  514. padding-left: 16rpx;
  515. .page_item_foot_text {
  516. font-size: 32rpx;
  517. margin-bottom: 20rpx;
  518. .text1 {
  519. color: rgb(102, 102, 102);
  520. }
  521. .text2 {
  522. float: right;
  523. font-weight: 700;
  524. }
  525. }
  526. }
  527. }
  528. }
  529. .foot_btn1 {
  530. position: fixed;
  531. bottom: 0;
  532. right: 20rpx;
  533. left: 20rpx;
  534. line-height: 66rpx;
  535. height: 100rpx;
  536. border-top: 2rpx solid #e5e9ed;
  537. background: #f9fafb;
  538. text-align: center;
  539. view {
  540. height: 66rpx;
  541. width: 45%;
  542. background-image: linear-gradient(to right, #72c172, #3bb197);
  543. color: #fff;
  544. border-radius: 8rpx;
  545. font-size: 32rpx;
  546. margin-top: 16rpx;
  547. }
  548. .btn1 {
  549. float: left;
  550. }
  551. .btn2 {
  552. float: right;
  553. }
  554. }
  555. }
  556. </style>