scanning_all.vue 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221
  1. <template>
  2. <view class="Scanning_all">
  3. <view class="Scanning">
  4. <view class="Scanning_top" id="Scanning_tops" :animation="animationData">
  5. <view class="Scanning_top_icon">
  6. <text class="cubeic-ok icon_transport transport-duigou"></text>
  7. </view>
  8. <view class="Scanning_top_text">
  9. <view class="text1">签到成功</view>
  10. </view>
  11. <view class="Scanning_cont">
  12. 当前科室关联多个工单,请查看工单信息,
  13. <view>可选择多个工单后,点击 一键送达 完成配送.</view>
  14. </view>
  15. </view>
  16. <view class="title" v-if="workData && workData.length > 0">
  17. <text class="span1">工单信息</text>
  18. <text class="span2" @click="all()">全选</text>
  19. <text class="span3" @click="Dall()">全不选</text>
  20. </view>
  21. <view class="tabs" v-if="workData && workData.length > 0">
  22. <view class="tab">
  23. <view @click="act('drugsBag')" v-if="infoDATA['drugsBag']">
  24. <view id="10" :class="{ acts: tabType == 'drugsBag' }"
  25. >药品({{ infoDATA.drugsBag.length }})</view
  26. >
  27. </view>
  28. <view @click="act('specimen')" v-if="infoDATA['specimen']">
  29. <view id="40" :class="{ acts: tabType == 'specimen' }"
  30. >标本({{ infoDATA.specimen.length }})</view
  31. >
  32. </view>
  33. <view @click="act('specimenPlan')" v-if="infoDATA['specimenPlan']">
  34. <view id="40" :class="{ acts: tabType == 'specimenPlan' }"
  35. >标本轮巡({{ infoDATA.specimenPlan.length }})</view
  36. >
  37. </view>
  38. <view
  39. @click="act('patientTransport')"
  40. v-if="infoDATA['patientTransport']"
  41. >
  42. <view id="20" :class="{ acts: tabType == 'patientTransport' }"
  43. >患者转运({{ infoDATA.patientTransport.length }})</view
  44. >
  45. </view>
  46. <view @click="act('inspect')" v-if="infoDATA['inspect']">
  47. <view id="30" :class="{ acts: tabType == 'inspect' }"
  48. >患者陪检({{ infoDATA.inspect.length }})</view
  49. >
  50. </view>
  51. <view @click="act('jPBag')" v-if="infoDATA['jPBag']">
  52. <view id="40" :class="{ acts: tabType == 'jPBag' }"
  53. >静配({{ infoDATA.jPBag.length }})</view
  54. >
  55. </view>
  56. <view @click="act('other')" v-if="infoDATA['other']">
  57. <view id="40" :class="{ acts: tabType == 'other' }"
  58. >其他({{ infoDATA.other.length }})</view
  59. >
  60. </view>
  61. </view>
  62. </view>
  63. <view
  64. class="page_items"
  65. v-if="!workData"
  66. style="font-size: 18px; margin-top: 15%"
  67. >
  68. <view class="zwsj">
  69. <image
  70. class="zwsj_img"
  71. mode="widthFix"
  72. src="../../static/img/zanwushuju.png"
  73. ></image>
  74. <view class="zwsj_txt">暂无工单</view>
  75. </view>
  76. </view>
  77. <view
  78. class="page_items footerOtherMargin"
  79. v-if="workData && workData.length > 0"
  80. >
  81. <view class="page_item" v-for="(infoDATA, i) of workData" :key="i">
  82. <view class="page_item_top">
  83. <view class="page_item_top_L">
  84. <text
  85. v-show="hasSelect(infoDATA.id)"
  86. class="ac"
  87. @click="ac(infoDATA, i)"
  88. :id="infoDATA.id"
  89. >
  90. <text class="ac-span"></text>
  91. </text>
  92. <text
  93. v-show="!hasSelect(infoDATA.id)"
  94. class="ac1"
  95. @click="ac1(infoDATA, i)"
  96. :id="infoDATA.id + '0'"
  97. ></text>
  98. <text class="L_text">单号:{{ infoDATA.gdcode }}</text>
  99. <view
  100. class="page_item_cont_start emergency1"
  101. v-if="infoDATA.emergencyType.value == 1"
  102. >
  103. <text class="page_item_cont_start_txt">
  104. <text
  105. class="cubeic-star icon_transport transport-shiwujiaoxing"
  106. ></text>
  107. {{ infoDATA.emergencyType.name }}
  108. </text>
  109. </view>
  110. <view
  111. class="page_item_cont_start emergency"
  112. v-if="infoDATA.emergencyType.value == 2"
  113. >
  114. <text class="page_item_cont_start_txt">
  115. <text
  116. class="cubeic-star icon_transport transport-shiwujiaoxing"
  117. ></text>
  118. {{ infoDATA.emergencyType.name }}
  119. </text>
  120. </view>
  121. <view
  122. class="page_item_cont_start emergencys"
  123. v-if="infoDATA.emergencyType.value == 3"
  124. >
  125. <text class="page_item_cont_start_txt">
  126. <text
  127. class="cubeic-star icon_transport transport-shiwujiaoxing"
  128. ></text>
  129. {{ infoDATA.emergencyType.name }}
  130. </text>
  131. </view>
  132. </view>
  133. <view class="page_item_top_R">
  134. <text
  135. class="L_iocn"
  136. v-if="infoDATA.taskType.associationType.value == 'specimen'"
  137. >标本</text
  138. >
  139. <text
  140. class="L_iocn"
  141. v-if="infoDATA.taskType.associationType.value == 'specimenPlan'"
  142. >标本</text
  143. >
  144. <text
  145. class="L_iocn"
  146. v-if="infoDATA.taskType.associationType.value == 'drugsBag'"
  147. >药品</text
  148. >
  149. <text
  150. class="L_iocn"
  151. v-if="infoDATA.taskType.associationType.value == 'jPBag'"
  152. >静配</text
  153. >
  154. <text
  155. class="L_iocn"
  156. v-if="infoDATA.taskType.associationType.value == 'inspect'"
  157. >患者陪检</text
  158. >
  159. <text
  160. class="L_iocn"
  161. v-if="
  162. infoDATA.taskType.associationType.value == 'patientTransport'
  163. "
  164. >患者转运</text
  165. >
  166. <text
  167. class="L_iocn"
  168. v-if="infoDATA.taskType.associationType.value == 'other'"
  169. >其他</text
  170. >
  171. </view>
  172. <view class="L"></view>
  173. <view class="R"></view>
  174. </view>
  175. <view class="page_item_cont">
  176. <view class="page_item_cont_T">
  177. <view class="page_item_cont_title">
  178. <text> <text class="starting">起</text> 点科室 </text>
  179. <text class="text_big">{{ infoDATA.startDept.dept }}</text>
  180. </view>
  181. </view>
  182. <view class="line"></view>
  183. <view class="page_item_cont_B">
  184. <template
  185. v-if="infoDATA.taskType.associationType.value == 'inspect'"
  186. >
  187. <view
  188. class="page_item_cont_title"
  189. v-for="(dept, i) of infoDATA.middleDept"
  190. :key="i"
  191. >
  192. <text> <text class="End">检</text> 查科室 </text>
  193. <text class="text_big">{{ dept.dept }}</text>
  194. <view></view>
  195. </view>
  196. </template>
  197. <template
  198. v-if="infoDATA.taskType.associationType.value != 'inspect'"
  199. >
  200. <view
  201. class="page_item_cont_title"
  202. v-for="(dept, i) of infoDATA.endDepts"
  203. :key="i"
  204. >
  205. <text> <text class="End">终</text> 点科室 </text>
  206. <text class="text_big">{{ dept.dept }}</text>
  207. </view>
  208. </template>
  209. </view>
  210. </view>
  211. <view class="page_item_foot">
  212. <view class="page_item_foot_text">
  213. <text class="text1">状态</text>
  214. <text
  215. class="text2"
  216. v-if="
  217. !(
  218. infoDATA.gdState.value == '5' &&
  219. infoDATA.taskType.associationType.value == 'inspect'
  220. )
  221. "
  222. >{{ infoDATA.gdState.name }}</text
  223. >
  224. <text
  225. class="text2"
  226. v-if="
  227. infoDATA.gdState.value == '5' &&
  228. infoDATA.taskType.associationType.value == 'inspect'
  229. "
  230. >待送回</text
  231. >
  232. </view>
  233. <view
  234. class="page_item_foot_text"
  235. v-if="infoDATA.gdState.value == '2'"
  236. >
  237. <text class="text1">预计响应时间</text>
  238. <text class="text2">{{ infoDATA.estimeResponseTime || 0 }}</text>
  239. </view>
  240. <view
  241. class="page_item_foot_text"
  242. v-if="infoDATA.gdState.value == '5'"
  243. >
  244. <text
  245. class="text1"
  246. v-if="!(infoDATA.taskType.associationType.value == 'inspect')"
  247. >预计送达时间</text
  248. >
  249. <text
  250. class="text1"
  251. v-if="infoDATA.taskType.associationType.value == 'inspect'"
  252. >预计送回时间</text
  253. >
  254. <text class="text2">{{ infoDATA.estimeCompleteTime || 0 }}</text>
  255. </view>
  256. <view
  257. class="page_item_foot_text"
  258. v-if="infoDATA.gdState.value == '4'"
  259. >
  260. <text class="text1">预计到达时间</text>
  261. <text class="text2">{{ infoDATA.estimateArriveTime || 0 }}</text>
  262. </view>
  263. <view class="page_item_foot_text">
  264. <text class="text1">创建时间</text>
  265. <text class="text2">{{ infoDATA.startTime }}</text>
  266. </view>
  267. </view>
  268. </view>
  269. </view>
  270. <view
  271. class="foot_btn2 footerPadding"
  272. v-if="workData && workData.length > 0"
  273. >
  274. <view class="btn1" @click="allStart()" v-if="flag">一键操作</view>
  275. <view class="btn1" v-if="!flag">一键操作</view>
  276. <view class="btn2" @click="showAlert">知道了</view>
  277. </view>
  278. <view class="foot_btn1 footerPadding" v-if="!workData">
  279. <view class="btn3" @click="showAlert">知道了</view>
  280. </view>
  281. </view>
  282. <!-- 弹窗 -->
  283. <showModel
  284. :title="models.title"
  285. :icon="models.icon"
  286. :disjunctor="models.disjunctor"
  287. :content="models.content"
  288. @know="know"
  289. :operate="models.operate"
  290. ></showModel>
  291. <!-- 填写交接人账号弹窗 -->
  292. <selectAccount
  293. v-if="hosModels.disjunctor"
  294. :title="hosModels.title"
  295. :disjunctor="hosModels.disjunctor"
  296. @ok="hosOk"
  297. @cancel="hosCancel"
  298. >
  299. </selectAccount>
  300. </view>
  301. </template>
  302. <script>
  303. import showModel from "../../components/showModel/showModel.vue";
  304. import { post, SM, webHandle } from "../../http/http.js";
  305. export default {
  306. data() {
  307. return {
  308. SMFlag: true,
  309. // 填写交接人账号弹窗model
  310. hosModels: {
  311. disjunctor: false,
  312. },
  313. // 弹窗model
  314. models: {
  315. disjunctor: false,
  316. },
  317. infoDATA: {},
  318. workData: [],
  319. tabType: "", //当前选中项
  320. userId: {
  321. ids: [],
  322. },
  323. typeData: [],
  324. types: false,
  325. code: "",
  326. flag: true, //一键操作,禁止多次
  327. flagTimer: null,
  328. selectArr: [], //选中项
  329. animationData: {}, //动画
  330. };
  331. },
  332. methods: {
  333. // 填写交接人账号-确认
  334. hosOk(data) {
  335. console.log(data);
  336. const { accountName, account, accountId } = data;
  337. if (!accountName && !account) {
  338. //没有填写交接人
  339. uni.showModal({
  340. title: "提示",
  341. content: "请填写交接人账号!",
  342. showCancel: false,
  343. success: function (res) {
  344. if (res.confirm) {
  345. console.log("用户点击确定");
  346. } else if (res.cancel) {
  347. console.log("用户点击取消");
  348. }
  349. },
  350. });
  351. return;
  352. } else if ((!accountName && account) || (accountName && !account)) {
  353. //没有填写交接人
  354. uni.showModal({
  355. title: "提示",
  356. content: "请填写正确的交接人账号!",
  357. showCancel: false,
  358. success: function (res) {
  359. if (res.confirm) {
  360. console.log("用户点击确定");
  361. } else if (res.cancel) {
  362. console.log("用户点击取消");
  363. }
  364. },
  365. });
  366. return;
  367. }
  368. this.hosModels.disjunctor = false;
  369. this.orderDeptHandler(false,data);
  370. },
  371. // 填写交接人账号-取消
  372. hosCancel() {
  373. this.hosModels.disjunctor = false;
  374. },
  375. // 填写交接人账号弹窗
  376. showSelectAccount() {
  377. this.hosModels = {
  378. title: "填写交接人账号",
  379. disjunctor: true,
  380. };
  381. },
  382. // 知道了
  383. showAlert() {
  384. uni.navigateTo({
  385. url: "../receiptpage/receiptpage",
  386. });
  387. },
  388. //科室签到
  389. //bigScanner----判断是否需要交接人
  390. //accountObj----弹窗填写的交接人信息
  391. orderDeptHandler(bigScanner,accountObj) {
  392. let type = "orderSign/" + this.code;
  393. let list = { ids: this.userId.ids };
  394. bigScanner && (list.bigScanner = ['666']);
  395. if (accountObj) {
  396. list.handover = [accountObj.accountId];
  397. }
  398. uni.showLoading({
  399. title: "加载中",
  400. mask: true,
  401. });
  402. post("/workerOrder/" + type, list).then((res) => {
  403. uni.hideLoading();
  404. if (res.status == 200) {
  405. if (this.tabType == "inspect" || this.tabType == "patientTransport") {
  406. if (res.ids) {
  407. for (var i = 0; i < this.userId.ids.length; i++) {
  408. if (this.userId.ids[i] == res.ids[0]) {
  409. this.userId.ids.splice(i, 1);
  410. }
  411. }
  412. }
  413. uni.navigateTo({
  414. url: `../scanning_djInfo/scanning_djInfo?type=${
  415. this.tabType
  416. }&type1=${res.type}&infoData=${res.data}&status=${
  417. res.status
  418. }&msg=${res.msg}&deptCode=${this.code}&dept=${
  419. res.dept
  420. }&ids=${encodeURIComponent(
  421. JSON.stringify(this.userId.ids)
  422. )}&model=${encodeURIComponent(JSON.stringify(res))}`,
  423. });
  424. } else {
  425. uni.navigateTo({
  426. url: `../scanning_djEnd/scanning_djEnd?type=${
  427. this.tabType
  428. }&type1=${res.type}&code=${this.code}&dept=${
  429. res.dept
  430. }&ids=${encodeURIComponent(
  431. JSON.stringify(this.userId.ids)
  432. )}&model=${encodeURIComponent(JSON.stringify(res))}&accountObj=${encodeURIComponent(JSON.stringify(accountObj))}&deptId=${res.deptId}`,
  433. });
  434. }
  435. } else if (res.status == "0000") {
  436. this.showSelectAccount(); //yeye
  437. } else {
  438. this.flag = true;
  439. uni.navigateTo({
  440. url: `../scanning_djEnd/scanning_djEnd?type=${this.tabType}&type1=${
  441. res.type
  442. }&code=${this.code}&dept=${res.dept}&ids=${encodeURIComponent(
  443. JSON.stringify(this.userId.ids)
  444. )}&model=${encodeURIComponent(JSON.stringify(res))}&deptId=${res.deptId}`,
  445. });
  446. }
  447. });
  448. },
  449. //一键操作
  450. allStart() {
  451. clearTimeout(this.flagTimer);
  452. this.flagTimer = setTimeout(() => {
  453. this.flag = false;
  454. let list = {};
  455. let type = "";
  456. if (this.userId.ids.length > 0) {
  457. if (
  458. this.tabType == "drugsBag" ||
  459. this.tabType == "jPBag" ||
  460. this.tabType == "other" ||
  461. this.tabType == "specimen" ||
  462. this.tabType == "specimenPlan"
  463. ) {
  464. this.orderDeptHandler(true);
  465. } else {
  466. if (!this.SMFlag) {
  467. return;
  468. }
  469. this.SMFlag = false;
  470. SM()
  471. .then((ress1) => {
  472. uni.showLoading({
  473. title: "加载中",
  474. mask: true,
  475. });
  476. //检验二维码的有效性
  477. post("/dept/scanning", {
  478. content: ress1,
  479. }).then((result) => {
  480. this.SMFlag = true;
  481. if (result.state == 200 || result.state == 201) {
  482. let ress = result.code;
  483. if (ress) {
  484. if (this.tabType == "patientTransport") {
  485. type = "handleTrans";
  486. let data = {
  487. ids: this.userId.ids,
  488. deptCode: this.code,
  489. code: ress,
  490. };
  491. list = data;
  492. }
  493. if (this.tabType == "inspect") {
  494. type = "handleIns";
  495. let data = {
  496. ids: this.userId.ids,
  497. deptCode: this.code,
  498. code: ress,
  499. };
  500. list = data;
  501. }
  502. post("/workerOrder/" + type, list).then((res) => {
  503. uni.hideLoading();
  504. if (res.status == 200) {
  505. if (
  506. this.tabType == "inspect" ||
  507. this.tabType == "patientTransport"
  508. ) {
  509. if (res.ids) {
  510. for (var i = 0; i < this.userId.ids.length; i++) {
  511. if (this.userId.ids[i] == res.ids[0]) {
  512. this.userId.ids.splice(i, 1);
  513. }
  514. }
  515. }
  516. uni.navigateTo({
  517. url: `../scanning_djInfo/scanning_djInfo?type=${
  518. this.tabType
  519. }&type1=${res.type}&infoData=${res.data}&status=${
  520. res.status
  521. }&msg=${res.msg}&deptCode=${this.code}&dept=${
  522. res.dept
  523. }&ids=${encodeURIComponent(
  524. JSON.stringify(this.userId.ids)
  525. )}&model=${encodeURIComponent(
  526. JSON.stringify(res)
  527. )}`,
  528. });
  529. } else {
  530. uni.navigateTo({
  531. url: `../scanning_djEnd/scanning_djEnd?type=${
  532. this.tabType
  533. }&type1=${res.type}&dept=${
  534. res.dept
  535. }&ids=${encodeURIComponent(
  536. JSON.stringify(this.userId.ids)
  537. )}&model=${encodeURIComponent(
  538. JSON.stringify(res)
  539. )}&code=${this.code}`,
  540. });
  541. }
  542. } else {
  543. uni.navigateTo({
  544. url: `../scanning_djEnd/scanning_djEnd?type=${
  545. this.tabType
  546. }&type1=${res.type}&dept=${
  547. res.dept
  548. }&ids=${encodeURIComponent(
  549. JSON.stringify(this.userId.ids)
  550. )}&model=${encodeURIComponent(
  551. JSON.stringify(res)
  552. )}&code=${this.code}`,
  553. });
  554. }
  555. });
  556. }
  557. } else {
  558. this.flag = true;
  559. uni.hideLoading();
  560. uni.showToast({
  561. icon: "none",
  562. title: "请求失败!",
  563. });
  564. }
  565. });
  566. })
  567. .catch((err) => {
  568. this.SMFlag = true;
  569. });
  570. }
  571. } else {
  572. this.flag = true;
  573. this.models = {
  574. disjunctor: true,
  575. title: "提示",
  576. content: "请选择工单!",
  577. icon: "warn",
  578. operate: {
  579. know: "知道了",
  580. },
  581. };
  582. }
  583. }, 500);
  584. },
  585. typePD(data, list) {
  586. if (list) {
  587. if (data.length >= 2) {
  588. for (var i = 0; i < data.length; i++) {
  589. if (data[i].gdState.value != list.gdState.value) {
  590. this.typeData.splice(i, 1);
  591. this.types = true;
  592. }
  593. }
  594. } else {
  595. this.types = false;
  596. }
  597. } else if (data.length == 1) {
  598. this.types = false;
  599. } else {
  600. this.types = false;
  601. for (var i = 0; i < data.length; i++) {
  602. if (data[0].gdState.value != data[i].gdState.value) {
  603. this.typeData.splice(i, 1);
  604. this.types = true;
  605. }
  606. }
  607. }
  608. },
  609. act(type) {
  610. this.Dall();
  611. this.tabType = type;
  612. this.workData = this.infoDATA[type];
  613. },
  614. // 已选择的项中是否包含该id
  615. hasSelect(id) {
  616. return this.selectArr.includes(id);
  617. },
  618. //选中
  619. ac(data, i) {
  620. // id放入数组
  621. this.selectArr = this.selectArr.filter((item) => item != data.id);
  622. for (var i = 0; i < this.userId.ids.length; i++) {
  623. if (this.userId.ids[i] == data.id) {
  624. this.typeData.splice(i, 1);
  625. this.userId.ids.splice(i, 1);
  626. }
  627. }
  628. },
  629. //未选中
  630. ac1(data, i) {
  631. this.typeData.push(data);
  632. this.types = false;
  633. for (var i = 0; i < this.typeData.length; i++) {
  634. if (this.typeData[0].gdState.value != this.typeData[i].gdState.value) {
  635. this.models = {
  636. disjunctor: true,
  637. title: "提示",
  638. content: "请选择不同状态的工单!",
  639. icon: "warn",
  640. operate: {
  641. know: "知道了",
  642. },
  643. };
  644. this.typeData.splice(i, 1);
  645. this.types = true;
  646. }
  647. }
  648. if (this.types) {
  649. } else {
  650. this.userId.ids.push(data.id);
  651. this.selectArr.push(data.id);
  652. }
  653. },
  654. //全选
  655. all() {
  656. let id = [];
  657. this.typeData = JSON.parse(JSON.stringify(this.workData));
  658. this.typePD(this.workData);
  659. if (this.types) {
  660. this.models = {
  661. disjunctor: true,
  662. title: "提示",
  663. content: "请选择不同状态的工单!",
  664. icon: "warn",
  665. operate: {
  666. know: "知道了",
  667. },
  668. };
  669. this.typeData = [];
  670. } else {
  671. for (var i = 0; i < this.workData.length; i++) {
  672. id.push(this.workData[i].id);
  673. this.selectArr.push(this.workData[i].id);
  674. }
  675. this.userId.ids = id;
  676. }
  677. },
  678. //全不选
  679. Dall() {
  680. this.selectArr = [];
  681. this.typeData = [];
  682. this.userId.ids = [];
  683. },
  684. texiao() {
  685. setTimeout(() => {
  686. this.animation.height(0).opacity(0).step();
  687. this.animationData = this.animation.export();
  688. }, 15000);
  689. },
  690. // 知道了
  691. know() {
  692. this.models.disjunctor = false;
  693. },
  694. },
  695. onLoad(options) {
  696. this.infoDATA = JSON.parse(options.infoDATA); //扫描科室码返回的信息
  697. this.code = options.code; //扫描科室码返回的二维码信息
  698. let arr = [];
  699. for (var key in this.infoDATA) {
  700. arr.push(key);
  701. }
  702. this.workData = this.infoDATA[arr[0]];
  703. this.tabType = arr[0];
  704. // #ifdef APP-PLUS
  705. webHandle("no", "app");
  706. // #endif
  707. // #ifdef H5
  708. webHandle("no", "wx");
  709. // #endif
  710. },
  711. onShow() {
  712. this.SMFlag = true;
  713. this.flag = true;
  714. // 创建动画
  715. this.animation = uni.createAnimation({
  716. duration: 500,
  717. timingFunction: "ease",
  718. delay: 2000,
  719. });
  720. setTimeout(() => {
  721. this.texiao();
  722. }, 500);
  723. },
  724. onHide() {
  725. this.animationData = {};
  726. },
  727. onUnload() {
  728. // 页面关闭后清空数据
  729. this.animationData = {};
  730. },
  731. };
  732. </script>
  733. <style lang="less">
  734. ::-webkit-scrollbar {
  735. width: 0;
  736. }
  737. ::-webkit-scrollbar-track {
  738. background-color: none;
  739. }
  740. ::-webkit-scrollbar-thumb {
  741. background-color: none;
  742. }
  743. ::-webkit-scrollbar-thumb:hover {
  744. background-color: none;
  745. }
  746. ::-webkit-scrollbar-thumb:active {
  747. background-color: none;
  748. }
  749. .Scanning_all {
  750. .title {
  751. font-size: 36rpx;
  752. margin-top: 20rpx;
  753. margin-bottom: 20rpx;
  754. font-weight: 700;
  755. position: relative;
  756. height: 40rpx;
  757. .span1 {
  758. position: absolute;
  759. left: 0;
  760. font-weight: 700;
  761. }
  762. .span2 {
  763. position: absolute;
  764. right: 20%;
  765. color: rgb(73, 184, 86);
  766. }
  767. .span3 {
  768. position: absolute;
  769. right: 0;
  770. color: rgb(73, 184, 86);
  771. }
  772. }
  773. .tabs {
  774. height: 90rpx;
  775. width: 100%;
  776. overflow-x: auto;
  777. overflow-y: hidden;
  778. position: relative;
  779. background: #fff;
  780. .acts {
  781. background: #ccc;
  782. height: 50rpx !important;
  783. width: 80% !important;
  784. border-radius: 20rpx;
  785. }
  786. .tab {
  787. display: flex;
  788. align-items: center;
  789. flex-wrap: nowrap;
  790. height: 90rpx;
  791. position: absolute;
  792. width: auto;
  793. padding-top: 6rpx;
  794. view {
  795. display: inline-block;
  796. width: 260rpx;
  797. line-height: 48rpx;
  798. font-size: 32rpx;
  799. height: 100%;
  800. text-align: center;
  801. }
  802. }
  803. }
  804. .Scanning {
  805. padding: 0 20rpx;
  806. height: calc(100% - 100rpx);
  807. // seimin
  808. .Scanning_top {
  809. height: 400rpx;
  810. opacity: 1;
  811. .Scanning_top_icon {
  812. width: 140rpx;
  813. height: 140rpx;
  814. margin: 0 auto;
  815. margin-top: 36rpx;
  816. border-radius: 50%;
  817. line-height: 140rpx;
  818. .cubeic-ok {
  819. font-size: 140rpx;
  820. color: #35b34a;
  821. }
  822. }
  823. .Scanning_top_text {
  824. .text1 {
  825. margin-top: 40rpx;
  826. font-size: 48rpx;
  827. text-align: center;
  828. }
  829. }
  830. .Scanning_cont {
  831. font-size: 32rpx;
  832. margin-top: 30rpx;
  833. text-align: center;
  834. .text1 {
  835. margin-top: 24rpx;
  836. color: #ff3b53;
  837. }
  838. }
  839. }
  840. .page_items {
  841. margin-bottom: 110rpx;
  842. .zwsj {
  843. margin-top: 180rpx;
  844. text-align: center;
  845. .zwsj-img {
  846. width: 560rpx;
  847. }
  848. .zwsj_txt {
  849. font-size: 36rpx;
  850. font-weight: 700;
  851. margin-top: 20rpx;
  852. text-align: center;
  853. }
  854. }
  855. .page_item {
  856. margin-top: 16rpx;
  857. min-height: 356rpx;
  858. background: #fff;
  859. border-radius: 8rpx;
  860. overflow: hidden;
  861. padding: 0 16rpx;
  862. border: 2rpx solid #e5e9ed;
  863. .L {
  864. width: 40rpx;
  865. height: 40rpx;
  866. border-radius: 50%;
  867. background: #f9fafb;
  868. position: relative;
  869. left: -50rpx;
  870. top: 66rpx;
  871. }
  872. .R {
  873. width: 40rpx;
  874. height: 40rpx;
  875. border-radius: 50%;
  876. background: #f9fafb;
  877. position: relative;
  878. float: right;
  879. right: -50rpx;
  880. top: 26rpx;
  881. }
  882. .starting {
  883. width: 50rpx;
  884. height: 50rpx;
  885. color: #fff;
  886. background: #49b856;
  887. display: inline-block;
  888. border-radius: 50%;
  889. text-align: center;
  890. line-height: 46rpx;
  891. font-size: 32rpx;
  892. margin-right: 6rpx;
  893. }
  894. .End {
  895. width: 50rpx;
  896. height: 50rpx;
  897. color: #fff;
  898. background: #39b199;
  899. display: inline-block;
  900. border-radius: 50%;
  901. text-align: center;
  902. line-height: 46rpx;
  903. font-size: 32rpx;
  904. margin-right: 6rpx;
  905. }
  906. .page_item_top {
  907. height: 86rpx;
  908. border-bottom: 2rpx dashed #e5e9ed;
  909. padding: 0 16rpx;
  910. .page_item_top_L {
  911. height: 100%;
  912. float: left;
  913. line-height: 88rpx;
  914. display: flex;
  915. align-items: center;
  916. .ac {
  917. width: 32rpx;
  918. height: 32rpx;
  919. border: 2rpx solid #ccc;
  920. display: inline-block;
  921. position: relative;
  922. .ac-span {
  923. position: absolute;
  924. left: 50%;
  925. top: 50%;
  926. width: 24rpx;
  927. height: 24rpx;
  928. background: #39b199;
  929. transform: translate(-50%, -50%);
  930. }
  931. }
  932. .ac1 {
  933. width: 32rpx;
  934. height: 32rpx;
  935. border: 2rpx solid #ccc;
  936. display: inline-block;
  937. position: relative;
  938. }
  939. .emergencys {
  940. background: #ff3b53 !important;
  941. width: 124rpx !important;
  942. }
  943. .emergency {
  944. background: #ff3b53 !important;
  945. }
  946. .emergency1 {
  947. background: #49b856 !important;
  948. }
  949. .page_item_cont_start {
  950. text-align: center;
  951. height: 44rpx;
  952. width: 104rpx;
  953. line-height: 44rpx;
  954. border-radius: 8rpx;
  955. background: #49b856;
  956. color: #fff;
  957. display: inline-block;
  958. .page_item_cont_start_txt {
  959. font-size: 28rpx;
  960. display: flex;
  961. align-items: center;
  962. justify-content: center;
  963. .cubeic-star {
  964. font-size: 28rpx;
  965. }
  966. }
  967. }
  968. .L_time {
  969. color: #6cc076;
  970. font-size: 32rpx;
  971. }
  972. .L_text {
  973. font-size: 32rpx;
  974. display: inline-block;
  975. font-weight: 700;
  976. margin-right: 8rpx;
  977. }
  978. }
  979. .page_item_top_R {
  980. height: 60rpx;
  981. float: right;
  982. padding-top: 20rpx;
  983. font-size: 32rpx;
  984. position: absolute;
  985. right: 50rpx;
  986. .L_iocn {
  987. display: inline-block;
  988. height: 52rpx;
  989. line-height: 48rpx;
  990. color: rgb(7, 134, 60);
  991. font-size: 36rpx;
  992. font-weight: 700;
  993. }
  994. }
  995. }
  996. .page_item_cont {
  997. min-height: 180rpx;
  998. padding: 0 16rpx;
  999. text-align: left;
  1000. position: relative;
  1001. .text_big {
  1002. font-size: 32rpx;
  1003. position: absolute;
  1004. right: 16rpx;
  1005. font-weight: 700;
  1006. margin-top: 10rpx;
  1007. }
  1008. .text_big2 {
  1009. font-size: 32rpx;
  1010. position: absolute;
  1011. right: 16rpx;
  1012. font-weight: 700;
  1013. }
  1014. .line {
  1015. height: 20rpx;
  1016. width: 2rpx;
  1017. border-left: 2rpx solid #e5e9ed;
  1018. position: absolute;
  1019. top: 82rpx;
  1020. left: 40rpx;
  1021. }
  1022. .lines {
  1023. height: 40%;
  1024. width: 2rpx;
  1025. border-left: 2rpx solid #e5e9ed;
  1026. position: absolute;
  1027. top: 23%;
  1028. left: 36rpx;
  1029. }
  1030. .page_item_cont_T {
  1031. padding-top: 28rpx;
  1032. font-size: 28rpx;
  1033. .page_item_cont_title {
  1034. height: 100%;
  1035. font-size: 32rpx;
  1036. }
  1037. }
  1038. .page_item_cont_B {
  1039. padding-top: 28rpx;
  1040. margin-bottom: 28rpx;
  1041. .page_item_cont_title {
  1042. height: 60rpx;
  1043. font-size: 32rpx;
  1044. }
  1045. .page_item_cont_title1 {
  1046. height: 60rpx;
  1047. line-height: 60rpx;
  1048. font-size: 32rpx;
  1049. padding-left: 64rpx;
  1050. }
  1051. }
  1052. }
  1053. .page_item_foot {
  1054. border-top: 2rpx dashed #e5e9ed;
  1055. border-bottom: 2rpx dashed #e5e9ed;
  1056. padding: 28rpx 16rpx;
  1057. text-align: left;
  1058. .page_item_foot_text {
  1059. height: 48rpx;
  1060. font-size: 32rpx;
  1061. line-height: 48rpx;
  1062. margin-bottom: 20rpx;
  1063. .text1 {
  1064. color: rgb(102, 102, 102);
  1065. }
  1066. .text2 {
  1067. float: right;
  1068. font-weight: 700;
  1069. }
  1070. }
  1071. }
  1072. #infos {
  1073. display: none;
  1074. }
  1075. .page_item_infos {
  1076. padding-bottom: 20rpx;
  1077. border-bottom: 2rpx dashed #e5e9ed;
  1078. .page_item_info2 {
  1079. text-align: left;
  1080. line-height: 60rpx;
  1081. font-size: 32rpx;
  1082. padding-left: 16rpx;
  1083. .page_item_foot_text {
  1084. height: 48rpx;
  1085. font-size: 32rpx;
  1086. line-height: 48rpx;
  1087. margin-bottom: 20rpx;
  1088. .text1 {
  1089. color: rgb(102, 102, 102);
  1090. }
  1091. .text2 {
  1092. float: right;
  1093. font-weight: 700;
  1094. }
  1095. }
  1096. }
  1097. }
  1098. }
  1099. }
  1100. .foot_btn2 {
  1101. position: fixed;
  1102. bottom: 0;
  1103. right: 20rpx;
  1104. left: 20rpx;
  1105. line-height: 66rpx;
  1106. height: 100rpx;
  1107. border-top: 2rpx solid #e5e9ed;
  1108. background: #f9fafb;
  1109. .btn1,
  1110. .btn2 {
  1111. height: 66rpx;
  1112. width: 45%;
  1113. background-image: linear-gradient(to right, #72c172, #3bb197);
  1114. color: #fff;
  1115. border-radius: 8rpx;
  1116. font-size: 32rpx;
  1117. margin-top: 16rpx;
  1118. text-align: center;
  1119. }
  1120. .btn1 {
  1121. float: left;
  1122. }
  1123. .btn2 {
  1124. float: right;
  1125. }
  1126. }
  1127. .foot_btn1 {
  1128. position: fixed;
  1129. bottom: 0;
  1130. right: 20rpx;
  1131. left: 20rpx;
  1132. line-height: 66rpx;
  1133. height: 100rpx;
  1134. border-top: 2rpx solid #e5e9ed;
  1135. background: #f9fafb;
  1136. text-align: center;
  1137. .btn3 {
  1138. height: 66rpx;
  1139. width: 100%;
  1140. background-image: linear-gradient(to right, #72c172, #3bb197);
  1141. color: #fff;
  1142. border-radius: 8rpx;
  1143. font-size: 32rpx;
  1144. margin-top: 16rpx;
  1145. }
  1146. }
  1147. }
  1148. }
  1149. </style>