index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566
  1. <template>
  2. <view class="app-content">
  3. <!-- <img src="../../static/beijing.png" alt="" class="tuku"> -->
  4. <Navs :navname.sync="navname" @fall="fall"></Navs>
  5. <view class="content">
  6. <view class="content_top">
  7. <view class="craid" v-if="cap.name">
  8. <view class="craid_data">
  9. <p>{{cap.name}}</p>
  10. <span>{{cap.time}}</span>
  11. </view>
  12. <view class="craid_data">
  13. <p>{{cap.ct}}</p>
  14. <span>{{cap.time2}}</span>
  15. </view>
  16. <view class="aircraft"></view>
  17. <view class="craid_data">
  18. <p>{{cap.cs}}</p>
  19. <span>{{cap.time3}}</span>
  20. </view>
  21. </view>
  22. <view class="craids" v-if="!cap.name">
  23. <p>暂无航班信息</p>
  24. </view>
  25. <view class="scanning">
  26. <view :class="getFooterClass">
  27. <input class="input" v-model.trim="stratvalue" type="text" value="" placeholder-style="font-size:.8125rem;color:rgb(189, 214, 231);display:flex;justify-content: start;" placeholder="请输入机票信息"/>
  28. <view class="log_l"></view>
  29. <view class="log"></view>
  30. </view>
  31. </view>
  32. </view>
  33. <view class="content_top">
  34. <view class="craid" v-if="caps.name">
  35. <view class="craid_data">
  36. <p>{{caps.name}}</p>
  37. <span>{{caps.time}}</span>
  38. </view>
  39. <view class="craid_data">
  40. <p>{{caps.ct}}</p>
  41. <span>{{caps.time2}}</span>
  42. </view>
  43. <view class="aircraft"></view>
  44. <view class="craid_data">
  45. <p>{{caps.cs}}</p>
  46. <span>{{caps.time3}}</span>
  47. </view>
  48. </view>
  49. <view class="craids" v-if="!caps.name">
  50. <p>暂无航班信息</p>
  51. </view>
  52. <view class="scanning">
  53. <view :class="getlooterClasser">
  54. <input class="input" v-model.trim="endvalue" type="text" value="" placeholder-style="font-size:.8125rem;color:rgb(189, 214, 231);display:flex;justify-content: start;" placeholder="请输入行李牌号"/>
  55. <view class="log_l"></view>
  56. <view class="log"></view>
  57. </view>
  58. <view class="gao">*行李信息不一致,请上报处理</view>
  59. </view>
  60. </view>
  61. <view class="footer">
  62. <button form-type="submit" class="switchBtndel" >异常处理</button>
  63. <button form-type="submit" class="btnyes" >确认提取</button>
  64. </view>
  65. </view>
  66. </view>
  67. </template>
  68. <script>
  69. import Navs from '../../components/header/navs.vue'
  70. import maskModel from '../../components/mask-model/mask-model.vue'
  71. export default {
  72. data() {
  73. return {
  74. isShow: true,
  75. dataheight: '20.75rem',
  76. scrollTop: 0,
  77. old: {
  78. scrollTop: 0
  79. },
  80. input: '',
  81. main: null,
  82. poll: null,
  83. filter:null,
  84. pusher:null,
  85. intentServer:null,
  86. arr: [],
  87. navname: '提取',
  88. startcode: '扫码',
  89. stopcode: '扫码',
  90. action: true,
  91. listdate: [{
  92. name: '3880491101',
  93. types: false
  94. },
  95. {
  96. name: '3880491101',
  97. types: false
  98. },
  99. {
  100. name: '3880491101',
  101. types: false
  102. },
  103. {
  104. name: '3880491101',
  105. types: false
  106. },
  107. {
  108. name: '3880491101',
  109. types: false
  110. },
  111. {
  112. name: '3880491101',
  113. types: false
  114. },
  115. {
  116. name: '3880491101',
  117. types: false
  118. },
  119. {
  120. name: '3880491101',
  121. types: false
  122. },
  123. {
  124. name: '3880491101',
  125. types: false
  126. },
  127. {
  128. name: '3880491101',
  129. types: false
  130. },
  131. {
  132. name: '3880491101',
  133. types: false
  134. },
  135. {
  136. name: '3880491101',
  137. types: false
  138. },
  139. {
  140. name: '3880491101',
  141. types: false
  142. }],
  143. arr: [],//触发判断
  144. startData: {
  145. clientX: 0,
  146. clientY: 0
  147. },
  148. stratvalue: '',//航班
  149. endvalue: '',//行李
  150. cap:{
  151. name:'HU7412',
  152. time:'2023-02-17',
  153. ct: 'CTU',
  154. time2: '12:00:00',
  155. cs:'CSX',
  156. time3: '14:23:00'
  157. },
  158. caps:{
  159. name:'HU7412',
  160. time:'2023-02-17',
  161. ct: 'CTU',
  162. time2: '12:00:00',
  163. cs:'CSX',
  164. time3: '14:23:00'
  165. },
  166. }
  167. },
  168. created(option) {
  169. },
  170. onLoad(option){
  171. // this.navname = JSON.parse(decodeURIComponent(option.item))
  172. // if (this.navname == '分拣') {
  173. // this.tabname = '航班'
  174. // }
  175. },
  176. onUnload() {
  177. // this.$refs.showMask.show();
  178. },
  179. onShow() {
  180. },
  181. mounted() {
  182. // this.$refs.showMask.show();
  183. // console.log(this.stratvalue.length)
  184. },
  185. computed: {
  186. getFooterClass () {
  187. return this.stratvalue ? 'scanning_cds' : 'scanning_cd'
  188. },
  189. getlooterClasser () {
  190. return this.endvalue ? 'scanning_cds' : 'scanning_cd'
  191. }
  192. },
  193. components: {
  194. Navs,
  195. maskModel:maskModel,
  196. },
  197. methods: {
  198. //下拉
  199. up () {
  200. this.typeShow = false
  201. this.maskTitle = '是否确定要拉下该件行李?'
  202. this.headername = '下拉提示'
  203. this.$refs.showMask.show();
  204. },
  205. confirm:function(e){//确定按钮
  206. console.log('您点击了确定按钮');
  207. },
  208. cancel:function(){//取消按钮
  209. console.log('您点击了取消按钮');
  210. },
  211. clickOrder () {
  212. uni.redirectTo({
  213. url: "/pages/baggagecheck/index"
  214. })
  215. },
  216. fall () {
  217. uni.switchTab({
  218. url: "/pages/index/index"
  219. })
  220. },
  221. clicker () {
  222. this.action = !this.action
  223. },
  224. movetran (e) {
  225. let arr = uni.getSystemInfoSync().windowHeight;
  226. this.dataheight = (e.changedTouches[0].clientY/16) + 'rem'
  227. if (e.changedTouches[0].clientY/16 > 20.75) {
  228. this.dataheight = 20.75 + 'rem'
  229. } else if (e.changedTouches[0].clientY/16 < 7.3125) {
  230. this.dataheight = 6.3125 + 'rem'
  231. }
  232. },
  233. start(e) {
  234. this.startData.clientX = e.changedTouches[0].clientX;
  235. },
  236. end (e,item) {
  237. const subX = e.changedTouches[0].clientX - this.startData.clientX;
  238. if (subX > 50) {
  239. // console.log('右滑')
  240. item.types = false
  241. } else if (subX < -50) {
  242. item.types = true
  243. // console.log('左滑')
  244. }
  245. },
  246. checkMore (item) {
  247. console.log(item)
  248. }
  249. },
  250. }
  251. </script>
  252. <style lang="scss" scoped>
  253. .app-content{
  254. position: relative;
  255. background: rgb(49, 85, 99);
  256. >.content{
  257. width: 100%;
  258. height: calc(100vh - 4.625rem);
  259. position: relative;
  260. // overflow: hidden;
  261. // background: rgb(49, 85, 99);
  262. >.content_top{
  263. width: 100%;
  264. // background: rgb(49, 85, 99);
  265. padding-bottom: 1.3125rem;
  266. >.craid{
  267. // width: 100%;
  268. height: 5.625rem;
  269. padding: 0 2.5625rem 0 2.5625rem;
  270. display: flex;
  271. justify-content: space-between;
  272. flex-wrap: wrap;
  273. align-items: center;
  274. >.craid_data{
  275. display: flex;
  276. flex-direction: column;
  277. justify-content: center;
  278. align-items: start;
  279. >p{
  280. color: rgb(255, 255, 255);
  281. font-family: Noto Sans SC;
  282. font-size: 18px;
  283. font-weight: 700;
  284. }
  285. >span{
  286. color: rgb(255, 255, 255);
  287. font-family: Noto Sans SC;
  288. font-size: 13px;
  289. font-weight: 500;
  290. }
  291. }
  292. >.aircraft{
  293. width: 1.75rem;
  294. height: 1.75rem;
  295. background: url('../../static/hang.png') no-repeat;
  296. background-size: 100% 100%;
  297. }
  298. }
  299. >.craids{
  300. height: 5.625rem;
  301. padding: 0 2.5625rem 0 2.5625rem;
  302. display: flex;
  303. justify-content: center;
  304. align-items: center;
  305. >p{
  306. color: rgb(189, 214, 231);
  307. font-family: Noto Sans SC;
  308. font-size: 13px;
  309. font-weight: 500;
  310. }
  311. }
  312. >.scanning{
  313. // height: 12rem;
  314. padding: 0 1.5rem 0 1.5rem;
  315. opacity: 1;
  316. transition: all 3s;
  317. >.gao{
  318. color: yellow;
  319. }
  320. .scanning_cd{
  321. width: 100%;
  322. height: 3rem;
  323. opacity: 1;
  324. transition: all 3s;
  325. background: rgb(59, 103, 123);
  326. margin-top: 1rem;
  327. margin-bottom: .5rem;
  328. border-radius: 4px;
  329. display: flex;
  330. justify-content: center;
  331. align-items: center;
  332. color: rgb(255, 255, 255);
  333. font-family: Noto Sans SC;
  334. font-size: 16px;
  335. >.log{
  336. width: .875rem;
  337. height: .875rem;
  338. background: url('../../static/saoma.png') no-repeat;
  339. background-size: 100% 100%;
  340. margin-left: 1rem;
  341. }
  342. >.log_l{
  343. width: .125rem;
  344. height: 1.3125rem;
  345. margin-left: 4rem;
  346. background: rgb(255, 255, 255);
  347. }
  348. }
  349. .scanning_cds{
  350. width: 100%;
  351. height: 3rem;
  352. opacity: 1;
  353. transition: all 3s;
  354. background: rgb(51, 161, 165);
  355. margin-top: 1rem;
  356. margin-bottom: .5rem;
  357. border-radius: 4px;
  358. display: flex;
  359. justify-content: center;
  360. align-items: center;
  361. color: rgb(255, 255, 255);
  362. font-family: Noto Sans SC;
  363. font-size: 16px;
  364. >.log{
  365. width: .875rem;
  366. height: .875rem;
  367. background: url('../../static/saoma.png') no-repeat;
  368. background-size: 100% 100%;
  369. margin-left: 1rem;
  370. }
  371. >.log_l{
  372. width: .125rem;
  373. height: 1.3125rem;
  374. margin-left: 4rem;
  375. background: rgb(255, 255, 255);
  376. }
  377. }
  378. }
  379. }
  380. >.content_bootom{
  381. width: 100%;
  382. // height: calc(100vh - 20.9375rem - 4.375rem);
  383. padding-bottom: 0;
  384. position: absolute;
  385. bottom: 0;
  386. top: 20.75rem;
  387. border-radius: 6px 6px 0px 0px;
  388. overflow: hidden;
  389. background: rgb(255, 255, 255);
  390. >.choice{
  391. width: 100%;
  392. height: 2.5rem;
  393. display: flex;
  394. background: rgb(240, 241, 243);
  395. >.handle{
  396. width: 50%;
  397. display: flex;
  398. align-items: center;
  399. justify-content: center;
  400. color: rgb(0, 0, 0);
  401. font-family: Noto Sans SC;
  402. font-size: 15px;
  403. font-weight: 700;
  404. border-radius: 6px 6px 0px 0px;
  405. background: rgb(255, 255, 255);
  406. }
  407. >.handles{
  408. width: 50%;
  409. display: flex;
  410. align-items: center;
  411. justify-content: center;
  412. color: rgb(0, 0, 0);
  413. font-family: Noto Sans SC;
  414. font-size: 15px;
  415. font-weight: 700;
  416. }
  417. }
  418. .up{
  419. width: 100%;
  420. display: flex;
  421. align-items: center;
  422. margin-left: 1rem;
  423. border-bottom: 1px solid rgb(238, 238, 238);
  424. // transform: all 3s;
  425. >.down_up{
  426. width: .875rem;
  427. height: .875rem;
  428. background: url('../../static/xia.png') no-repeat;
  429. background-size: 100% 100%;
  430. }
  431. >.list{
  432. width: 97%;
  433. position: relative;
  434. height: 3.75rem;
  435. display: flex;
  436. align-items: center;
  437. transform: all 3s;
  438. right: 0;
  439. color: rgb(0, 0, 0);
  440. font-family: Noto Sans SC;
  441. font-size: 13px;
  442. font-weight: 500;
  443. }
  444. >.delete{
  445. width: 3.75rem;
  446. height: 3.75rem;
  447. background: rgb(237, 101, 101);
  448. display: flex;
  449. align-items: center;
  450. justify-content: center;
  451. position: relative;
  452. right: -3.75rem;
  453. transform: all 3s;
  454. >.log{
  455. width: .875rem;
  456. height: .875rem;
  457. background: url('../../static/vector@1x.png') no-repeat;
  458. background-size: 100% 100%;
  459. }
  460. }
  461. }
  462. .ups{
  463. width: 100%;
  464. display: flex;
  465. align-items: center;
  466. margin-left: 1rem;
  467. border-bottom: 1px solid rgb(238, 238, 238);
  468. // transform: all 3s;
  469. >.down_up{
  470. width: .875rem;
  471. height: .875rem;
  472. position: relative;
  473. right: 1.875rem;
  474. background: url('../../static/xia.png') no-repeat;
  475. background-size: 100% 100%;
  476. }
  477. >.list{
  478. width: 97%;
  479. position: relative;
  480. height: 3.75rem;
  481. display: flex;
  482. align-items: center;
  483. right: 3.75rem;
  484. // right: 0;
  485. color: rgb(0, 0, 0);
  486. font-family: Noto Sans SC;
  487. font-size: 13px;
  488. font-weight: 500;
  489. transform: all 3s;
  490. }
  491. >.delete{
  492. width: 3.75rem;
  493. height: 3.75rem;
  494. background: rgb(237, 101, 101);
  495. display: flex;
  496. align-items: center;
  497. justify-content: center;
  498. position: relative;
  499. right: 1rem;
  500. transform: all 3s;
  501. // right: -3.75rem;
  502. >.log{
  503. width: .875rem;
  504. height: .875rem;
  505. background: url('../../static/vector@1x.png') no-repeat;
  506. background-size: 100% 100%;
  507. }
  508. }
  509. }
  510. .scroll-Y {
  511. height: calc(100% - 2.5rem - 2.75rem - 2.25rem - 2.25rem);
  512. }
  513. .but{
  514. width: 20.5625rem;
  515. height: 2.75rem;
  516. 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%);
  517. border-radius: .25rem;
  518. color: rgb(255, 255, 255);
  519. font-family: Noto Sans SC;
  520. font-size: 1rem;
  521. margin: 0 auto;
  522. display: flex;
  523. align-items: center;
  524. justify-content: center;
  525. margin-top: 2.25rem;
  526. margin-bottom: 2.25rem;
  527. }
  528. }
  529. >.footer{
  530. width: 100%;
  531. height: 7.4375rem;
  532. position: absolute;
  533. bottom: 0;
  534. display: flex;
  535. align-items: center;
  536. justify-content: center;
  537. >.switchBtndel{
  538. width: 9.4375rem;
  539. height: 2.75rem;
  540. box-sizing: border-box;
  541. background: rgb(243, 253, 255);
  542. border: 1px solid rgb(172, 218, 230);
  543. border-radius:
  544. 4px;
  545. color: rgb(59, 150, 159);
  546. font-family: Noto Sans SC;
  547. font-size: 16px;
  548. font-weight: 700;
  549. }
  550. >.btnyes{
  551. width: 9.4375rem;
  552. height: 2.75rem;
  553. background: rgb(126, 138, 143);
  554. border-radius:
  555. 4px;
  556. color: rgb(255, 255, 255);
  557. font-family: Noto Sans SC;
  558. font-size: 16px;
  559. font-weight: 700;
  560. }
  561. }
  562. }
  563. }
  564. </style>