scanning.vue 13 KB

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