index.vue 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. <template>
  2. <view class="app-content">
  3. <img src="static/beijing.png" alt="" class="tuku">
  4. <!-- <Nav :navname.sync="navname" :navtype="false" :navtypes="true" :index="index"></Nav> -->
  5. <view class="cont" style="margin-top: 3rem;">
  6. <view class="photograph" @tap="upindiv">
  7. <img src="static/shuai.png" alt="">
  8. </view>
  9. <view class="details">
  10. <p>{{$storage.getJson("users").user_name}}</p>
  11. <span>工号:{{$storage.getJson("users").user_id}}</span>
  12. </view>
  13. <view class="detail_list">
  14. <view class="list_child">
  15. <p>分拣</p>
  16. <span>200</span>
  17. </view>
  18. <view class="list_child">
  19. <p>装车</p>
  20. <span>200</span>
  21. </view>
  22. <view class="list_child">
  23. <p>上机</p>
  24. <span>200</span>
  25. </view>
  26. <view class="list_child">
  27. <p>卸机</p>
  28. <span>200</span>
  29. </view>
  30. <view class="list_child">
  31. <p>卸车</p>
  32. <span>200</span>
  33. </view>
  34. </view>
  35. <view class="detail_type">
  36. <view class="list_child" @tap="recup">
  37. <view class="log bg1"></view>
  38. <p>我的记录</p>
  39. </view>
  40. <view class="list_child" @tap="uppop">
  41. <view class="log bg2"></view>
  42. <p>扫码开关</p>
  43. </view>
  44. <view class="list_child" @tap="uppops">
  45. <view class="log bg3"></view>
  46. <p>工作方式</p>
  47. </view>
  48. <view class="list_child" @tap="uphelp">
  49. <view class="log bg4"></view>
  50. <p>帮助</p>
  51. </view>
  52. </view>
  53. </view>
  54. <z-popup v-model="all">
  55. <view class="popup_title">
  56. <p>请选择扫码开关</p>
  57. </view>
  58. <view class="popup_content">
  59. <ul>
  60. <li v-for="(item, index) in list" :key="index" @tap="()=>selectup(index)">
  61. <p>{{item.name}}</p>
  62. <view class="start" v-if="action === index ? true: false">
  63. <img src="static/gou.png" alt="">
  64. </view>
  65. </li>
  66. </ul>
  67. <view class="top"></view>
  68. <view class="cancel" @tap="()=>topup()">取消</view>
  69. </view>
  70. </z-popup>
  71. <z-popup v-model="allshow">
  72. <view class="popup_title">
  73. <p>请选择工作方式</p>
  74. </view>
  75. <view class="popup_content">
  76. <ul>
  77. <li v-for="(item, index) in lists" :key="index" @tap="()=>selectup(index)">
  78. <p>{{item.name}}</p>
  79. <view class="start" v-if="action === index ? true: false">
  80. <img src="static/gou.png" alt="">
  81. </view>
  82. </li>
  83. </ul>
  84. <view class="top"></view>
  85. <view class="cancel" @tap="()=>topup()">取消</view>
  86. </view>
  87. </z-popup>
  88. </view>
  89. </template>
  90. <script>
  91. import Nav from '../../components/header/nav.vue'
  92. // import Popup from '../../uni_modules/z-popup/components/z-popup'
  93. export default {
  94. data() {
  95. return {
  96. main: null,
  97. poll: null,
  98. filter:null,
  99. pusher:null,
  100. intentServer:null,
  101. navname: '我的',
  102. all: false,
  103. allshow: false,
  104. action: '',
  105. index:0,
  106. list: [{
  107. name: '相机'
  108. },
  109. {
  110. name: '激光扫描枪'
  111. },
  112. {
  113. name: 'RFID读取器'
  114. }],
  115. lists: [
  116. {
  117. name: '单次扫描'
  118. },
  119. {
  120. name: '连续扫描'
  121. }
  122. ]
  123. }
  124. },
  125. created(option) {
  126. },
  127. onLoad(){
  128. },
  129. onUnload() {
  130. uni.$off("scancodemsg");
  131. },
  132. onShow() {
  133. // uni.hideTabBar()//关闭导航栏
  134. // uni.showTabBar()//显示导航栏
  135. uni.$on("scancodemsg", (data) => {
  136. if(data.msg.length > 9){
  137. uni.navigateTo({
  138. url: "/pages/detail/index?luggageNum=" + data.msg
  139. // url: "/pages/detail/index?luggageNum=3999483183"
  140. })
  141. }
  142. });
  143. if(this.$storage.get('airport')){
  144. this.index = this.$storage.get('airport')
  145. }
  146. },
  147. onHide() {
  148. uni.$off("scancodemsg");
  149. },
  150. mounted() {
  151. },
  152. components: {
  153. Nav
  154. },
  155. watch: {
  156. allshow () {
  157. if (this.allshow) {
  158. uni.hideTabBar({})
  159. } else{
  160. uni.showTabBar()
  161. }
  162. },
  163. all () {
  164. if (this.all) {
  165. uni.hideTabBar({})
  166. } else{
  167. uni.showTabBar()
  168. }
  169. }
  170. },
  171. methods: {
  172. recup () {
  173. uni.redirectTo({
  174. url: "/pages/myrecords/index"
  175. })
  176. },
  177. fall () {
  178. uni.redirectTo({
  179. url: "/pages/index/index"
  180. })
  181. },
  182. upindiv () {
  183. uni.redirectTo({
  184. url: "/pages/individual/index"
  185. })
  186. },
  187. uphelp () {
  188. uni.redirectTo({
  189. url: "/pages/help/index"
  190. })
  191. },
  192. uppop () {
  193. uni.hideTabBar({})
  194. this.all = true
  195. },
  196. uppops () {
  197. uni.hideTabBar({})
  198. this.allshow = true
  199. },
  200. selectup (index) {
  201. this.action = index
  202. },
  203. topup () {
  204. this.all = false
  205. this.allshow = false
  206. uni.showTabBar()//显示导航栏
  207. }
  208. },
  209. }
  210. </script>
  211. <style lang="scss" scoped>
  212. .app-content{
  213. // position: relative;
  214. >.tuku{
  215. position: absolute;
  216. z-index: -1;
  217. width: 100%;
  218. top: 0;
  219. }
  220. >.cont{
  221. z-index: 999;
  222. >.photograph{
  223. width: 6rem;
  224. height: 6rem;
  225. // background: red;
  226. border-radius: 50%;
  227. margin: 0 auto;
  228. margin-top: .625rem;
  229. }
  230. >.details{
  231. width: 100%;
  232. height: 3.125rem;
  233. display: flex;
  234. flex-direction: column;
  235. align-items: center;
  236. justify-content: center;
  237. // background: red;
  238. margin-top: .625rem;
  239. >p{
  240. color: rgb(255, 255, 255);
  241. font-family: Noto Sans SC;
  242. font-size: 1rem;
  243. font-weight: 500;
  244. }
  245. >span{
  246. color: rgb(255, 255, 255);
  247. font-family: Noto Sans SC;
  248. font-size: .8125rem;
  249. font-weight: 500;
  250. }
  251. }
  252. >.detail_list{
  253. width: 100%;
  254. // background: red;
  255. display: flex;
  256. flex-wrap: wrap;
  257. margin-top: 1rem;
  258. >.list_child{
  259. width: 33%;
  260. display: flex;
  261. flex-direction: column;
  262. justify-items: center;
  263. align-items: center;
  264. margin-bottom: 1rem;
  265. >p{
  266. color: rgb(255, 255, 255);
  267. font-family: Noto Sans SC;
  268. font-size: .8125rem;
  269. font-weight: 500;
  270. }
  271. >span{
  272. color: rgb(255, 255, 255);
  273. font-family: Helvetica;
  274. font-size: 1rem;
  275. font-weight: 700;
  276. }
  277. }
  278. }
  279. >.detail_type{
  280. height: calc(100vh - 35.875rem);
  281. padding: 0 3.125rem 0 3.125rem;
  282. display: flex;
  283. justify-content: space-around;
  284. flex-wrap: wrap;
  285. flex: 1;
  286. >.list_child{
  287. width: 7.5rem;
  288. height: 7.5rem;
  289. background: linear-gradient(188.06deg, rgba(65.49,109.04,128.64,1.00) 3.551%,rgba(38,68.32,81.96,1.00) 110.878%);
  290. box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  291. border-radius: 4px;
  292. margin-bottom: 4%;
  293. display: flex;
  294. flex-direction: column;
  295. justify-content: center;
  296. align-items: center;
  297. >.log{
  298. width: 2.25rem;
  299. height: 2.25rem;
  300. // background: rgb(196, 196, 196);
  301. margin-bottom: .5rem;
  302. }
  303. .bg1{
  304. background: url('../../static/jilu.png') no-repeat;
  305. background-size: 100% 100%;
  306. }
  307. .bg2{
  308. background: url('../../static/kaiguan.png') no-repeat;
  309. background-size: 100% 100%;
  310. }
  311. .bg3{
  312. background: url('../../static/gongzuo.png') no-repeat;
  313. background-size: 100% 100%;
  314. }
  315. .bg4{
  316. background: url('../../static/bagzu.png') no-repeat;
  317. background-size: 100% 100%;
  318. }
  319. >p{
  320. color: rgb(255, 255, 255);
  321. font-family: Noto Sans SC;
  322. font-size: .9375rem;
  323. font-weight: 500;
  324. }
  325. }
  326. }
  327. }
  328. .popup_title{
  329. width: 100%;
  330. height: 4.5rem;
  331. background: rgb(255, 255, 255);
  332. border-radius: 10px 10px 0px 0px;
  333. display: flex;
  334. align-items: center;
  335. color: rgb(16, 17, 22);
  336. font-family: Noto Sans SC;
  337. font-size: 1rem;
  338. font-weight: 700;
  339. >p{
  340. margin-left: 1.5rem;
  341. color: rgb(16, 17, 22);
  342. font-family: Noto Sans SC;
  343. font-size: 1rem;
  344. font-weight: 700;
  345. }
  346. }
  347. .popup_content{
  348. width: 100%;
  349. background: rgb(255, 255, 255);
  350. >ul{
  351. width: 100%;
  352. >li{
  353. width: 82%;
  354. height: 2.6875rem;
  355. display: flex;
  356. align-items: center;
  357. justify-content: space-between;
  358. >p{
  359. color: rgb(0, 0, 0);
  360. font-family: Noto Sans SC;
  361. font-size: .8125rem;
  362. font-weight: 400;
  363. }
  364. >.start{
  365. width: 1rem;
  366. height: 1rem;
  367. background: rgb(37, 121, 160);
  368. display: flex;
  369. align-items: center;
  370. justify-content: center;
  371. border-radius: 50%;
  372. }
  373. }
  374. }
  375. >.top{
  376. width: 100%;
  377. height: .875rem;
  378. background: rgb(249, 249, 249);
  379. }
  380. >.cancel{
  381. width: 100%;
  382. height: 3.3125rem;
  383. display: flex;
  384. align-items: center;
  385. justify-content: center;
  386. color: rgb(0, 0, 0);
  387. font-family: Noto Sans SC;
  388. font-size: .9375rem;
  389. font-weight: 500;
  390. }
  391. }
  392. }
  393. </style>