index.vue 29 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057
  1. <template>
  2. <view class="app-content">
  3. <!-- <img src="../../static/beijing.png" alt="" class="tuku"> -->
  4. <Navs :navname.sync="navname" @fall="fall" :index='index'></Navs>
  5. <view class="content">
  6. <view class="content_top">
  7. <view class="craid" v-if="flightDetail&&flightDetail.carrierFlights">
  8. <view class="craid_data">
  9. <p>{{flightDetail.carrierFlights}}</p>
  10. <span>{{flightDetail.carrierFlightsDate}}</span>
  11. </view>
  12. <view class="craid_data">
  13. <p>{{flightDetail.outAirport}}</p>
  14. <span>{{flightDetail.scheduleTakeOffTime?flightDetail.scheduleTakeOffTime:"-"}}</span>
  15. </view>
  16. <view class="fight_center">
  17. <view class="type">
  18. {{flightDetail.normalState}}
  19. </view>
  20. <view class="aircraft"></view>
  21. </view>
  22. <view class="craid_data">
  23. <p>{{flightDetail.landAirport}}</p>
  24. <span>{{flightDetail.scheduleLandInTime?flightDetail.scheduleLandInTime:"-"}}</span>
  25. </view>
  26. </view>
  27. <view class="craids" v-if="!flightDetail.carrierFlights">
  28. <p>暂无航班信息</p>
  29. </view>
  30. <view class="scanning">
  31. <view :class="getFooterClass">
  32. <input class="input" v-model.trim="stratvalue" type="text"
  33. placeholder-style="font-size:.8125rem;color:rgb(189, 214, 231);display:flex;justify-content: start;"
  34. placeholder="请输入操作位置" />
  35. <view class="log_l"></view>
  36. <view class="log" @tap="scan('1')"></view>
  37. </view>
  38. <view :class="getFooterClasser" v-if="navname == '装车'">
  39. <input class="input" v-model.trim="container_ID" type="text"
  40. placeholder-style="font-size:.8125rem;color:rgb(189, 214, 231);display:flex;justify-content: start;"
  41. placeholder="请输入容器编号" />
  42. <view class="log_l"></view>
  43. <view class="log" @tap="scan('2')"></view>
  44. </view>
  45. <view :class="getlooterClass">
  46. <input class="input" v-model.trim="currentLuggageNum" disabled="true" @tap="baggageEntry"
  47. type="text"
  48. placeholder-style="font-size:.8125rem;color:rgb(189, 214, 231);display:flex;justify-content: start;"
  49. placeholder="请输入行李号" />
  50. <view class="log_l"></view>
  51. <view class="log" @tap="scan('3')"></view>
  52. </view>
  53. </view>
  54. </view>
  55. <view class="content_bootom" :style="{top:dataheight}">
  56. <view class="choice" @touchmove="movetran">
  57. <view :class="action === true ?'handle':'handles'" @tap="clicker(true)">已处理({{listdate1.length}}件)
  58. </view>
  59. <view :class="action !== true ?'handle':'handles'" @tap="clicker(false)">未处理({{listdate2.length}}件)
  60. </view>
  61. </view>
  62. <scroll-view scroll-y="true" class="scroll-Y">
  63. <view v-if="action === true" :class="item.types ? 'ups':'up'" v-for="(item, index) in listdate1"
  64. :key="index" @touchstart="start" @touchend="(e)=>end(e,item)">
  65. <view class="list" @tap="toDetail(item.luggageNum)">{{ item.luggageNum }}</view>
  66. <view class="normal" @tap="toDetail(item.luggageNum)">
  67. {{item.specialType!=null?specialTypeList[item.specialType]:" "}}
  68. </view>
  69. <view :class="item.abnormalType!=null?'error':'normal'" @tap="toDetail(item.luggageNum)">
  70. {{item.abnormalType!=null?item.abnormalName:"正常"}}</view>
  71. <view class="down_up" v-if="pagename == 'LOAD' && item.abnormalType!='OFF' && item.abnormalType!='POFF'"
  72. @tap="up(item,index)"></view>
  73. <view class="delete" v-if="pagename == 'LOAD' && item.abnormalType!='OFF' && item.abnormalType!='POFF'">
  74. <view class="log" @click="()=>up(item,index)"></view>
  75. </view>
  76. </view>
  77. <view v-if="action !== true" :class="item.types ? 'ups':'up'" v-for="(item, index) in listdate2"
  78. :key="index" @tap="toDetail(item.luggageNum)">
  79. <view class="list" >{{ item.luggageNum }}</view>
  80. <view class="normal">
  81. {{item.specialType!=null?specialTypeList[item.specialType]:" "}}
  82. </view>
  83. <view :class="item.abnormalType!=null?'error':'normal'">
  84. {{item.abnormalType!=null?item.abnormalName:"正常"}}</view>
  85. <!-- <view class="down_up" @tap="up"></view> -->
  86. </view>
  87. </scroll-view>
  88. <view class="but" v-if="!action&&listdate2.length>0" @tap="clickOrder">一键处理</view>
  89. </view>
  90. </view>
  91. <!-- 提示信息和下拉弹窗 -->
  92. <mask-model :headername="headername" :typeShow="typeShow" :tabname="tabname" ref="showMask" btnType="1"
  93. @confirm="confirm" @next="next" @load="load" @cancel="cancel" titleColoe="#666666" cancelColor="#666666"
  94. confirmColor="#007AFF" :maskTitle="maskTitle"></mask-model>
  95. <!-- 一键弹窗 -->
  96. <mask-model :headername="headername" :typeShow="typeShow" ref="showMask2" btnType="1" @confirm="confirm2"
  97. @cancel="cancel" titleColoe="#666666" cancelColor="#666666" confirmColor="#007AFF"
  98. :maskTitle="maskTitle2"></mask-model>
  99. <!-- 航班开始操作弹窗 -->
  100. <mask-model :headername="headername" :typeShow="typeShow" ref="showMask3" btnType="1" @confirm="confirm3"
  101. @cancel="cancel3" titleColoe="#666666" cancelColor="#666666" confirmColor="#007AFF"
  102. :maskTitle="maskTitle3"></mask-model>
  103. </view>
  104. </template>
  105. <script>
  106. import Navs from '../../components/header/navs.vue'
  107. import maskModel from '../../components/mask-model/mask-model.vue'
  108. import {
  109. Format
  110. } from '@/components/utils/validate'
  111. export default {
  112. data() {
  113. return {
  114. isShow: true,
  115. dataheight: '20.75rem',
  116. scrollTop: 0,
  117. input: '',
  118. arr: [],
  119. navname: '',
  120. action: true,
  121. listdate: [],
  122. listdate1: [],
  123. loadNumber: 0,
  124. listdate2: [],
  125. startData: {
  126. clientX: 0,
  127. clientY: 0
  128. },
  129. stratvalue: '', //开始位置
  130. container_ID: '',
  131. endvalue: '', //结束位置
  132. maskTitle: '该行李不属于当前航班,请选择处理方式。',
  133. maskTitle2: "",
  134. maskTitle3: "",
  135. tabname: '', //航班名称
  136. typeShow: true,
  137. headername: '提示信息',
  138. flightNO: "null",
  139. flightDate: null,
  140. outAirport:null,
  141. landAirport:null,
  142. onFlightDate: null,
  143. flightDetail: {},
  144. index: 0,
  145. currentLuggageNum: null,
  146. pagename: "",
  147. currentLuggage: null,
  148. currentIndex: null,
  149. abnormalList: [{
  150. "type": null,
  151. "name": "无"
  152. },
  153. {
  154. "type": "NAL",
  155. "name": "未授权装载"
  156. },
  157. {
  158. "type": "OFF",
  159. "name": "已卸载"
  160. },
  161. {
  162. "type": "PFF",
  163. "name": "预卸载"
  164. },
  165. {
  166. "type": "UNS",
  167. "name": "未找到"
  168. },
  169. {
  170. "type": "OND",
  171. "name": "在场未装载,未授权"
  172. },
  173. {
  174. "type": "ONA",
  175. "name": "在场未装载,已授权"
  176. }
  177. ],
  178. oldRfidList: [],
  179. specialTypeList:{
  180. "AVIH":"装笼动物",
  181. "CREW":"机组行李",
  182. "RFAG":"易碎行李",
  183. "HVY":"重型行李",
  184. "PRIO":"优先行李",
  185. "RUSH":"无人行李",
  186. "SCON":"急转行李",
  187. "SPEQ":"运动装备",
  188. "VIP":"VIP行李",
  189. "WCHR":"轮椅",
  190. "WFAP":"武器枪支",
  191. "SJ05":"到港行李破损",
  192. "SJ34":"超大柜台接收",
  193. }
  194. }
  195. },
  196. created(option) {},
  197. onLoad(option) {
  198. this.pagename = option.item
  199. this.flightNO = option.flightNO
  200. this.flightDate = option.date
  201. this.outAirport = option.outAirport
  202. this.landAirport = option.landAirport
  203. this.getNode()
  204. switch (this.pagename) {
  205. case "SORT":
  206. this.navname = "分拣"
  207. break;
  208. case "LOAD":
  209. this.navname = "装车"
  210. break;
  211. case "INFL":
  212. this.navname = "装机"
  213. break;
  214. case "UNLOAD":
  215. this.navname = "卸机"
  216. break;
  217. case "ARRIVED":
  218. this.navname = "到达"
  219. break;
  220. default:
  221. break;
  222. }
  223. if (this.flightNO != "null" && this.flightNO) {
  224. this.getFlightData()
  225. }
  226. console.log("onLoad")
  227. },
  228. onUnload() {
  229. uni.$off("scancodemsg");
  230. if(this.$devapi.RFIDIntervalTime!=0){
  231. this.$devapi.RFIDStopInventory()
  232. this.$devapi.ISRFIDOPEN = false
  233. }
  234. },
  235. onShow() {
  236. uni.$on("scancodemsg", (data) => {
  237. // data.msg = '0089580761'
  238. if (data.msg.trim().length > 9) {
  239. this.currentLuggageNum = data.msg.trim()
  240. this.getluggage(this.currentLuggageNum, true)
  241. }
  242. if (data.msg.trim().length < 9) {
  243. this.container_ID = data.msg.trim()
  244. }
  245. });
  246. uni.$on("scancodeList", (data) => {
  247. // data.msg = ['0089580818','0089580819','0089580820', '0089580783', '0089580816']
  248. if (this.flightNO == "null" && data.msg.length > 0) {
  249. this.currentLuggageNum = data.msg[0].trim()
  250. this.getluggage(this.currentLuggageNum, true)
  251. this.$devapi.RFIDStopInventory()
  252. this.$devapi.ISRFIDOPEN = false
  253. } else if (this.flightNO && data.msg.length > 0) {
  254. data.msg.map(item => {
  255. if (_.findIndex(this.listdate1, function(o) {
  256. return o.luggageNum == item
  257. }) < 0) {
  258. if (item.trim().length > 9) {
  259. this.currentLuggageNum = item.trim()
  260. this.getluggage(this.currentLuggageNum, true)
  261. }
  262. }
  263. })
  264. }
  265. });
  266. if (this.$storage.getJson('airport')) {
  267. this.index = this.$storage.getJson('airport')
  268. }
  269. if (this.flightNO != "null" && this.flightNO) {
  270. this.getFlightData()
  271. }
  272. console.log("onShow")
  273. },
  274. onHide() {
  275. uni.$off("scancodemsg");
  276. },
  277. mounted() {
  278. // this.$refs.showMask.show();
  279. // console.log(this.stratvalue.length)
  280. },
  281. computed: {
  282. getFooterClass() {
  283. return this.stratvalue ? 'scanning_cds' : 'scanning_cd'
  284. },
  285. getlooterClass() {
  286. return this.currentLuggageNum ? 'scanning_cds' : 'scanning_cd'
  287. },
  288. getFooterClasser() {
  289. return this.container_ID ? 'scanning_cds' : 'scanning_cd'
  290. },
  291. },
  292. components: {
  293. Navs,
  294. maskModel: maskModel,
  295. },
  296. methods: {
  297. scan(type) {
  298. let that = this
  299. uni.scanCode({
  300. onlyFromCamera: true,
  301. success: function(res) {
  302. if (type == "1") {
  303. that.stratvalue = res.result;
  304. } else if (type == "2") {
  305. that.container_ID = res.result;
  306. } else {
  307. that.currentLuggageNum = res.result
  308. that.getluggage(that.currentLuggageNum, true)
  309. }
  310. }
  311. });
  312. },
  313. async getNode() {
  314. let data = {
  315. "serviceId": 3003,
  316. "dataContent": {},
  317. "event": "0"
  318. }
  319. await this.$http.httpPost('/openApi/query', data).then(res => {
  320. if (res.code == "0") {
  321. res.returnData.map(item => {
  322. if (item.nodeCode == this.pagename) {
  323. this.stratvalue = item.nodeDescribe;
  324. }
  325. })
  326. }
  327. })
  328. },
  329. next(data) {
  330. this.flightNO = this.currentLuggage.carrierFlights;
  331. this.flightDate = this.currentLuggage.carrierFlightsDate;
  332. this.outAirport = this.currentLuggage.outAirport;
  333. this.landAirport = this.currentLuggage.landAirport;
  334. this.loadNumber = 0;
  335. this.getFlightData()
  336. this.$refs.showMask.hide();
  337. },
  338. load() {
  339. this.currentLuggage.carrierFlights = this.flightNO
  340. this.currentLuggage.carrierFlightsDate = this.flightDate;
  341. this.currentLuggage.outAirport = this.outAirport;
  342. this.currentLuggage.landAirport = this.landAirport;
  343. let datas = this.setLuggage()
  344. this.sendData(datas)
  345. },
  346. async getFlightData() {
  347. let data = {
  348. "serviceId": 3000,
  349. "page": 1,
  350. "pageSize": 10,
  351. "dataContent": [{
  352. "carrierFlights": this.flightNO
  353. }],
  354. "event": "0"
  355. }
  356. await this.$http.httpPost('/openApi/query', data).then(res => {
  357. if (res.code == "0" && res.returnData.length > 0) {
  358. this.flightDetail = []
  359. if (this.flightDate && this.flightDate != "null") {
  360. console.log(this.outAirport)
  361. console.log(this.landAirport)
  362. res.returnData.map(item => {
  363. if (this.flightDate == item.carrierFlightsDate && this.outAirport == item.outAirport&& this.landAirport == item.landAirport) {
  364. this.flightDetail = item
  365. this.getluggageList()
  366. }
  367. })
  368. } else {
  369. this.flightDetail = res.returnData[0]
  370. this.getluggageList()
  371. }
  372. if (this.flightDetail.scheduleTakeOffTime) {
  373. this.flightDetail.scheduleTakeOffTime = this.flightDetail.scheduleTakeOffTime
  374. .split("T")[1]
  375. } else {
  376. item.scheduleTakeOffTime = "-"
  377. }
  378. if (this.flightDetail.scheduleLandInTime) {
  379. this.flightDetail.scheduleLandInTime = this.flightDetail.scheduleLandInTime.split(
  380. "T")[1]
  381. } else {
  382. item.scheduleLandInTime = "-"
  383. }
  384. } else {
  385. this.$scanAudio.src = "../../static/hqhb.mp3"
  386. this.$scanAudio.play()
  387. uni.showToast({
  388. icon: 'none',
  389. title: "未查询到" + this.flightNO + "航班信息",
  390. duration: 5000
  391. });
  392. }
  393. })
  394. },
  395. async getluggageList() {
  396. let data = {
  397. "serviceId": 3001,
  398. "page": 1,
  399. "pageSize": 999,
  400. "dataContent": {
  401. "carrierFlights": this.flightDetail.carrierFlights,
  402. "carrierFlightsDate": this.flightDetail.carrierFlightsDate,
  403. "outAirport":this.flightDetail.outAirport,
  404. "landAirport":this.flightDetail.landAirport
  405. },
  406. "event": "0"
  407. }
  408. await this.$http.httpPost('/openApi/query', data).then(res => {
  409. this.listdate1 = []
  410. this.listdate2 = []
  411. if (res.code == "0") {
  412. this.listdate = res.returnData;
  413. res.returnData.map(item => {
  414. this.abnormalList.map(item2 => {
  415. if (item.abnormalType == item2.type) {
  416. item.abnormalName = item2.name
  417. }
  418. })
  419. switch (this.pagename) {
  420. case "SORT":
  421. if (item.sorting_time != null) {
  422. this.listdate1.push(item)
  423. this.listdate1.sort(this.compareDesc("sorting_time"))
  424. } else {
  425. this.listdate2.push(item)
  426. }
  427. break;
  428. case "LOAD":
  429. if (item.loading_time != null) {
  430. this.listdate1.push(item)
  431. this.listdate1.sort(this.compareDesc("loading_time"))
  432. } else {
  433. this.listdate2.push(item)
  434. }
  435. break;
  436. case "INFL":
  437. if (item.installation_time != null) {
  438. this.listdate1.push(item)
  439. this.listdate1.sort(this.compareDesc("installation_time"))
  440. } else {
  441. this.listdate2.push(item)
  442. }
  443. break;
  444. case "UNLOAD":
  445. if (item.unloadtime != null) {
  446. this.listdate1.push(item)
  447. this.listdate1.sort(this.compareDesc("unloadtime"))
  448. } else {
  449. this.listdate2.push(item)
  450. }
  451. break;
  452. case "ARRIVED":
  453. if (item.arrivedtime != null) {
  454. this.listdate1.push(item)
  455. this.listdate1.sort(this.compareDesc("arrivedtime"))
  456. } else {
  457. this.listdate2.push(item)
  458. }
  459. break;
  460. default:
  461. break;
  462. }
  463. })
  464. if (this.loadNumber == 0 && this.currentLuggageNum != null) {
  465. this.loadNumber = this.listdate1.length;
  466. let datas = this.setLuggage()
  467. this.sendData(datas)
  468. } else {
  469. this.loadNumber = this.listdate1.length;
  470. }
  471. }
  472. })
  473. },
  474. async getluggage(num, isSend) {
  475. let data = {
  476. "serviceId": 3002,
  477. "page": 1,
  478. "pageSize": 1,
  479. "dataContent": {
  480. "luggageNum": num, //行李号
  481. },
  482. "event": "0"
  483. }
  484. await this.$http.httpPost('/openApi/query', data).then(res => {
  485. if (res.code == "0" && res.returnData.length > 0) {
  486. this.currentLuggage = res.returnData[0];
  487. if (this.flightNO != "null" && this.flightNO && this.flightNO == res.returnData[0]
  488. .carrierFlights && isSend == true) {
  489. let datas = this.setLuggage()
  490. this.sendData(datas)
  491. } else if (this.flightNO != "null" && this.flightNO && this.flightNO != res.returnData[
  492. 0].carrierFlights) {
  493. if (this.$storage.get('times') == 1 && this.$storage.get('device') == 1) {
  494. return
  495. } else {
  496. this.tabname = res.returnData[0].carrierFlights
  497. this.typeShow = true
  498. this.$refs.showMask.show();
  499. this.$scanAudio.src = "../../static/qzcz.mp3"
  500. this.$scanAudio.play()
  501. }
  502. } else if (this.flightNO == "null") {
  503. this.typeShow = false
  504. this.maskTitle3 = '是否对航班:' + res.returnData[0].carrierFlights + "行李进行" + this
  505. .navname + "操作?"
  506. this.headername = '提示'
  507. this.$refs.showMask3.show();
  508. this.$scanAudio.src = "../../static/kscz.mp3"
  509. this.$scanAudio.play()
  510. }
  511. } else {
  512. if(this.$devapi.RFIDIntervalTime!=0){
  513. this.$devapi.RFIDStopInventory()
  514. this.$devapi.ISRFIDOPEN = false
  515. }
  516. this.$scanAudio.src = "../../static/hqxl.mp3"
  517. this.$scanAudio.play()
  518. uni.showToast({
  519. icon: 'none',
  520. title: "未查询到" + this.currentLuggageNum + "行李信息",
  521. duration: 5000
  522. });
  523. }
  524. })
  525. },
  526. setLuggage(data) {
  527. let arr = []
  528. if (data) {
  529. data.map(item => {
  530. item.nodeCode = this.pagename;
  531. item.nodeName = this.navname;
  532. item.location_code = this.stratvalue;
  533. item.container_ID = this.container_ID
  534. item.loadNumber = this.loadNumber++;
  535. item.sourceAirport = this.$storage.get('airportName');
  536. item.ID = null;
  537. item.dataType = "BPM";
  538. item.agentNumber = this.$storage.getJson("users").user_name;
  539. item.device_ID = uni.getDeviceInfo().deviceId;
  540. arr.push(item)
  541. })
  542. return arr
  543. } else {
  544. this.currentLuggage.nodeCode = this.pagename;
  545. this.currentLuggage.nodeName = this.navname;
  546. this.currentLuggage.location_code = this.stratvalue;
  547. this.currentLuggage.container_ID = this.container_ID
  548. this.currentLuggage.loadNumber = this.loadNumber++;
  549. this.currentLuggage.sourceAirport = this.$storage.get('airportName');
  550. this.currentLuggage.ID = null;
  551. this.currentLuggage.dataType = "BPM";
  552. this.currentLuggage.agentNumber = this.$storage.getJson("users").user_name;
  553. this.currentLuggage.device_ID = uni.getDeviceInfo().deviceId;
  554. arr.push(this.currentLuggage)
  555. return arr
  556. }
  557. },
  558. async sendData(result) {
  559. let that = this;
  560. let data = {
  561. "serviceId": 3005,
  562. "dataContent": result,
  563. "event": "0"
  564. }
  565. await this.$http.httpPost('/openApi/query', data).then(res => {
  566. if (res.code == "0") {
  567. if (result.length > 1) {
  568. setTimeout(function() {
  569. uni.showToast({
  570. icon: 'none',
  571. title: "操作行李成功",
  572. duration: 5000
  573. });
  574. that.getluggageList()
  575. }, 3000)
  576. } else {
  577. this.getluggageList()
  578. }
  579. } else {
  580. this.$scanAudio.src = "../../static/czsb.mp3"
  581. this.$scanAudio.play()
  582. uni.showToast({
  583. icon: 'none',
  584. title: "操作失败",
  585. duration: 5000
  586. });
  587. }
  588. })
  589. },
  590. datatime() {
  591. let dataTime = Format("yyyy-MM-dd hh:mm:ss", new Date());
  592. return dataTime
  593. },
  594. //下拉
  595. up(item, index) {
  596. this.currentLuggageNum = item.luggageNum;
  597. this.getluggage(this.currentLuggageNum, false);
  598. this.currentIndex = index
  599. this.typeShow = false
  600. this.maskTitle = '是否确定要拉下该件行李?'
  601. this.headername = '拉下提示'
  602. this.$refs.showMask.show();
  603. this.$scanAudio.src = "../../static/sflx.mp3"
  604. this.$scanAudio.play()
  605. },
  606. confirm: function(e) { //确定按钮
  607. this.currentLuggage.abnormalState = "PFF"
  608. this.currentLuggage.abnormalName = "预卸载"
  609. let datas = this.setLuggage()
  610. this.sendData(datas)
  611. },
  612. confirm2(e) { //确定一键操作按钮
  613. uni.showToast({
  614. icon: 'none',
  615. title: "操作中",
  616. duration: 5000
  617. });
  618. let data = this.listdate2
  619. let datas = this.setLuggage(data)
  620. this.sendData(datas)
  621. },
  622. confirm3: function(e) { //确定按钮
  623. this.flightNO = this.currentLuggage.carrierFlights
  624. this.flightDate = this.currentLuggage.carrierFlightsDate
  625. this.landAirport = this.currentLuggage.landAirport
  626. this.outAirport = this.currentLuggage.outAirport
  627. this.getFlightData();
  628. if (this.$devapi.RFIDIntervalTime!=0) {//继续连续操作
  629. this.$devapi.RFIDStartInventory()
  630. this.$devapi.ISRFIDOPEN = true
  631. }
  632. },
  633. cancel3: function() { //取消按钮
  634. this.flightNO = "null"
  635. },
  636. cancel: function() { //取消按钮
  637. console.log('您点击了取消按钮');
  638. },
  639. toDetail(num) {
  640. uni.navigateTo({
  641. // url: "/pages/detail/index?luggageNum=" + data.msg
  642. url: "/pages/detail/index?luggageNum=" + num
  643. })
  644. },
  645. clickOrder() {
  646. this.typeShow = false
  647. this.maskTitle2 = '是否确定要一键' + this.navname + '全部行李?'
  648. this.headername = '操作提示'
  649. this.$refs.showMask2.show();
  650. this.$scanAudio.src = "../../static/yjzc.mp3"
  651. this.$scanAudio.play()
  652. },
  653. baggageEntry() {
  654. uni.navigateTo({
  655. url: "/pages/baggageEntry/index"
  656. })
  657. },
  658. locationEntry() {
  659. uni.navigateTo({
  660. url: "/pages/locationEntry/index"
  661. })
  662. },
  663. fall() {
  664. uni.navigateBack({
  665. delta: 1
  666. })
  667. },
  668. clicker(e) {
  669. this.action = !this.action
  670. if (e != this.action) {
  671. this.action = e
  672. }
  673. },
  674. compareDesc(propertyName) {
  675. return function(object1, object2) {
  676. var value1 = object1[propertyName];
  677. var value2 = object2[propertyName];
  678. if (value2 < value1) {
  679. return -1;
  680. } else if (value2 > value1) {
  681. return 1;
  682. } else {
  683. return 0;
  684. }
  685. }
  686. },
  687. movetran(e) {
  688. let arr = uni.getSystemInfoSync().windowHeight;
  689. this.dataheight = (e.changedTouches[0].clientY / 16) + 'rem'
  690. if (e.changedTouches[0].clientY / 16 > 20.75) {
  691. this.dataheight = 20.75 + 'rem'
  692. } else if (e.changedTouches[0].clientY / 16 < 7.3125) {
  693. this.dataheight = 6.3125 + 'rem'
  694. }
  695. },
  696. start(e) {
  697. this.startData.clientX = e.changedTouches[0].clientX;
  698. },
  699. end(e, item) {
  700. const subX = e.changedTouches[0].clientX - this.startData.clientX;
  701. if (subX > 50) {
  702. // console.log('右滑')
  703. item.types = false
  704. } else if (subX < -50) {
  705. item.types = true
  706. // console.log('左滑')
  707. }
  708. },
  709. checkMore(item) {
  710. console.log(item)
  711. }
  712. },
  713. }
  714. </script>
  715. <style lang="scss" scoped>
  716. .app-content {
  717. position: relative;
  718. background: rgb(49, 85, 99);
  719. >.content {
  720. width: 100%;
  721. height: calc(100vh - 5.375rem);
  722. position: relative;
  723. // overflow: hidden;
  724. // background: rgb(49, 85, 99);
  725. >.content_top {
  726. width: 100%;
  727. // background: rgb(49, 85, 99);
  728. padding-bottom: 1.3125rem;
  729. >.craid {
  730. // width: 100%;
  731. height: 5.625rem;
  732. padding: 0 2.5625rem 0 2.5625rem;
  733. display: flex;
  734. justify-content: space-between;
  735. flex-wrap: wrap;
  736. align-items: center;
  737. >.craid_data {
  738. display: flex;
  739. flex-direction: column;
  740. justify-content: center;
  741. align-items: start;
  742. >p {
  743. color: rgb(255, 255, 255);
  744. font-family: Noto Sans SC;
  745. font-size: 18px;
  746. font-weight: 700;
  747. }
  748. >span {
  749. color: rgb(255, 255, 255);
  750. font-family: Noto Sans SC;
  751. font-size: 13px;
  752. font-weight: 500;
  753. }
  754. }
  755. .fight_center {
  756. width: 3rem;
  757. display: flex;
  758. flex-direction: column;
  759. align-items: center;
  760. justify-content: center;
  761. color: rgb(255, 255, 255);
  762. font-family: Noto Sans SC;
  763. font-size: 16px;
  764. line-height: 24px;
  765. font-weight: 700;
  766. >.aircraft {
  767. width: 1.75rem;
  768. height: 1.75rem;
  769. background: url('../../static/hang.png') no-repeat;
  770. background-size: 100% 100%;
  771. }
  772. }
  773. }
  774. >.craids {
  775. height: 5.625rem;
  776. padding: 0 2.5625rem 0 2.5625rem;
  777. display: flex;
  778. justify-content: center;
  779. align-items: center;
  780. >p {
  781. color: rgb(189, 214, 231);
  782. font-family: Noto Sans SC;
  783. font-size: 13px;
  784. font-weight: 500;
  785. }
  786. }
  787. >.scanning {
  788. height: 12rem;
  789. padding: 0 1.5rem 0 1.5rem;
  790. opacity: 1;
  791. transition: all 3s;
  792. .scanning_cd {
  793. width: 100%;
  794. height: 3rem;
  795. opacity: 1;
  796. transition: all 3s;
  797. background: rgb(59, 103, 123);
  798. margin-top: 1rem;
  799. margin-bottom: .5rem;
  800. border-radius: 4px;
  801. display: flex;
  802. justify-content: center;
  803. align-items: center;
  804. color: rgb(255, 255, 255);
  805. font-family: Noto Sans SC;
  806. font-size: 16px;
  807. >.log {
  808. width: .875rem;
  809. height: .875rem;
  810. background: url('../../static/saoma.png') no-repeat;
  811. background-size: 100% 100%;
  812. margin-left: 1rem;
  813. }
  814. >.log_l {
  815. width: .125rem;
  816. height: 1.3125rem;
  817. margin-left: 4rem;
  818. background: rgb(255, 255, 255);
  819. }
  820. }
  821. .scanning_cds {
  822. width: 100%;
  823. height: 3rem;
  824. opacity: 1;
  825. transition: all 3s;
  826. background: rgb(51, 161, 165);
  827. margin-top: 1rem;
  828. margin-bottom: .5rem;
  829. border-radius: 4px;
  830. display: flex;
  831. justify-content: center;
  832. align-items: center;
  833. color: rgb(255, 255, 255);
  834. font-family: Noto Sans SC;
  835. font-size: 16px;
  836. >.log {
  837. width: .875rem;
  838. height: .875rem;
  839. background: url('../../static/saoma.png') no-repeat;
  840. background-size: 100% 100%;
  841. margin-left: 1rem;
  842. }
  843. >.log_l {
  844. width: .125rem;
  845. height: 1.3125rem;
  846. margin-left: 4rem;
  847. background: rgb(255, 255, 255);
  848. }
  849. }
  850. }
  851. }
  852. >.content_bootom {
  853. width: 100%;
  854. // height: calc(100vh - 20.9375rem - 4.375rem);
  855. padding-bottom: 0;
  856. position: absolute;
  857. bottom: 0;
  858. top: 20.75rem;
  859. border-radius: 6px 6px 0px 0px;
  860. overflow: hidden;
  861. background: rgb(255, 255, 255);
  862. >.choice {
  863. width: 100%;
  864. height: 2.5rem;
  865. display: flex;
  866. background: rgb(240, 241, 243);
  867. >.handle {
  868. width: 50%;
  869. display: flex;
  870. align-items: center;
  871. justify-content: center;
  872. color: rgb(0, 0, 0);
  873. font-family: Noto Sans SC;
  874. font-size: 15px;
  875. font-weight: 700;
  876. border-radius: 6px 6px 0px 0px;
  877. background: rgb(255, 255, 255);
  878. }
  879. >.handles {
  880. width: 50%;
  881. display: flex;
  882. align-items: center;
  883. justify-content: center;
  884. color: rgb(0, 0, 0);
  885. font-family: Noto Sans SC;
  886. font-size: 15px;
  887. font-weight: 700;
  888. }
  889. }
  890. .up {
  891. width: 100%;
  892. display: flex;
  893. align-items: center;
  894. justify-content: space-between;
  895. margin-left: 1rem;
  896. border-bottom: 1px solid rgb(238, 238, 238);
  897. // transform: all 3s;
  898. >.down_up {
  899. width: .875rem;
  900. height: .875rem;
  901. background: url('../../static/xia.png') no-repeat;
  902. background-size: 100% 100%;
  903. }
  904. >.error {
  905. width: 20%;
  906. color: red
  907. }
  908. >.normal {
  909. width: 20%;
  910. color: #4682b4
  911. }
  912. >.list {
  913. position: relative;
  914. height: 3rem;
  915. display: flex;
  916. align-items: center;
  917. transform: all 3s;
  918. right: 0;
  919. color: rgb(0, 0, 0);
  920. font-family: Noto Sans SC;
  921. font-size: 16px;
  922. font-weight: 500;
  923. }
  924. >.delete {
  925. width: 3.75rem;
  926. height: 3.75rem;
  927. background: rgb(237, 101, 101);
  928. display: flex;
  929. align-items: center;
  930. justify-content: center;
  931. position: relative;
  932. right: -3.75rem;
  933. transform: all 3s;
  934. >.log {
  935. width: .875rem;
  936. height: .875rem;
  937. background: url('../../static/vector@1x.png') no-repeat;
  938. background-size: 100% 100%;
  939. }
  940. }
  941. }
  942. .ups {
  943. width: 100%;
  944. display: flex;
  945. align-items: center;
  946. justify-content: space-between;
  947. margin-left: 1rem;
  948. border-bottom: 1px solid rgb(238, 238, 238);
  949. // transform: all 3s;
  950. >.down_up {
  951. width: .875rem;
  952. height: .875rem;
  953. position: relative;
  954. right: 1.875rem;
  955. background: url('../../static/xia.png') no-repeat;
  956. background-size: 100% 100%;
  957. }
  958. >.list {
  959. position: relative;
  960. height: 3rem;
  961. display: flex;
  962. align-items: center;
  963. transform: all 3s;
  964. right: 0;
  965. color: rgb(0, 0, 0);
  966. font-family: Noto Sans SC;
  967. font-size: 16px;
  968. font-weight: 500;
  969. }
  970. >.delete {
  971. width: 3.75rem;
  972. height: 3.75rem;
  973. background: rgb(237, 101, 101);
  974. display: flex;
  975. align-items: center;
  976. justify-content: center;
  977. position: relative;
  978. right: 1rem;
  979. transform: all 3s;
  980. // right: -3.75rem;
  981. >.log {
  982. width: .875rem;
  983. height: .875rem;
  984. background: url('../../static/vector@1x.png') no-repeat;
  985. background-size: 100% 100%;
  986. }
  987. }
  988. }
  989. .scroll-Y {
  990. // height: calc(100% - 2.5rem - 2.75rem - 2.25rem - 2.25rem);
  991. height: calc(100% - 2.5rem - 2.75rem);
  992. }
  993. .but {
  994. width: 20.5625rem;
  995. height: 2.5rem;
  996. background: linear-gradient(179.10deg, rgba(51, 161, 165, 1.00) 11.326%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%);
  997. border-radius: .25rem;
  998. color: rgb(255, 255, 255);
  999. font-family: Noto Sans SC;
  1000. font-size: 1rem;
  1001. margin: 0 auto;
  1002. display: flex;
  1003. align-items: center;
  1004. justify-content: center;
  1005. margin-top: 0.25rem;
  1006. margin-bottom: 2.25rem;
  1007. }
  1008. }
  1009. }
  1010. }
  1011. </style>