index.vue 25 KB

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