index.vue 26 KB

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