queryList.vue 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. <template>
  2. <view>
  3. <u-navbar
  4. :title="title"
  5. title-color="#fff"
  6. :is-back="true"
  7. :border-bottom="false"
  8. :custom-back="customBack"
  9. back-icon-color="#CCE8FF"
  10. :background="{background: 'linear-gradient(99deg, #7A4398 0%, #5A5DB9 100%)' }"></u-navbar>
  11. <!-- <u-tabs :list="tabList" :is-scroll="false" height="108" bar-width="100" :current="tabIndex" @change="tabChange"></u-tabs>
  12. <u-gap height="20" bg-color="#F6F6F6"></u-gap> -->
  13. <mescroll-uni ref="mescrollRef" @init="mescrollInit" :top="config.platform=='h5'?60:120" @down="downCallback" :up="upOption" @up="upCallback" @emptyclick="emptyClick">
  14. <view class="owelist">
  15. <view class="owelist-item" v-for="(item,index) in dataList" :key="item.id">
  16. <view class="item-header u-flex u-row-between">
  17. <view class="vehicle-no">{{item.vehicleNo}}</view>
  18. <view v-if="item.orderStatus==2"
  19. class="order-status"
  20. :class="{'order-status-0':item.orderStatus=='0','order-status-1':item.orderStatus=='1','order-status-2':item.orderStatus=='2','order-status-3':item.orderStatus=='3','order-status-4':item.orderStatus=='4'}">
  21. {{item.orderStatus|filterOrderStatus}}
  22. {{item.payStatus|filterPayStatus}}
  23. </view>
  24. <view v-else class="order-status" :class="{'order-status-0':item.orderStatus=='0','order-status-1':item.orderStatus=='1','order-status-2':item.orderStatus=='2','order-status-3':item.orderStatus=='3','order-status-4':item.orderStatus=='4'}">{{item.orderStatus|filterOrderStatus}}</view>
  25. </view>
  26. <view class="road-name u-flex">
  27. <u-icon name="map-fill" color="#3397FA" size="36"></u-icon>
  28. {{item.roadName}}
  29. </view>
  30. <view class="info-item">订单号:{{item.orderId}}</view>
  31. <view class="info-item">进场时间:{{item.inTime}}</view>
  32. <view v-if="item.orderStatus != 1" class="info-item">出场时间:{{item.ouTtime}}</view>
  33. <view v-if="item.orderStatus != 1" class="info-item">停车时长:{{item.duration}}</view>
  34. <view v-if="item.orderStatus != 1" class="info-item">免费时长:{{item.freeDuration}}</view>
  35. <view v-if="item.orderStatus != 1" class="info-item">计费时长:{{item.billinDuration}}</view>
  36. <view v-if="item.orderStatus != 1" class="info-item">应缴金额:{{item.payAmount}}</view>
  37. <view v-if="item.orderStatus != 1" class="info-item">实缴金额:<span class="amount">{{item.actualAmount||'0'}}元</span></view>
  38. </view>
  39. </view>
  40. </mescroll-uni>
  41. </view>
  42. </template>
  43. <script>
  44. import MescrollMixin from "@/uni_modules/mescroll-uni/components/mescroll-uni/mescroll-mixins.js";
  45. export default{
  46. mixins: [MescrollMixin], // 使用mixin (在main.js注册全局组件)
  47. data(){
  48. return{
  49. title:"查询结果",
  50. warningType:'环境',
  51. vehicleNo:'',
  52. selectShow:false,
  53. selectList: [
  54. {
  55. value: '1',
  56. label: '环境'
  57. },
  58. {
  59. value: '2',
  60. label: '设备/工艺'
  61. }
  62. ],
  63. tabIndex:0,
  64. tabList:[
  65. {name:'停放中'},
  66. {name:'出场中'},
  67. {name:'欠费'},
  68. {name:'完成'},
  69. ],
  70. upOption:{
  71. // page: {
  72. // size: 10 // 每页数据的数量
  73. // },
  74. // auto:false,
  75. // use:false,
  76. noMoreSize: 4, //如果列表已无数据,可设置列表的总数量要大于半页才显示无更多数据;避免列表数据过少(比如只有一条数据),显示无更多数据会不好看; 默认5
  77. empty:{
  78. tip: '~ 暂无数据 ~', // 提示
  79. // btnText: '去看看'
  80. }
  81. },
  82. dataList: [], //列表数据
  83. }
  84. },
  85. onLoad(page){
  86. this.vehicleNo = page.vehicleNo;
  87. },
  88. onShow(){
  89. setTimeout(()=>{
  90. this.mescroll.resetUpScroll();
  91. },500)
  92. },
  93. methods:{
  94. customBack(){
  95. uni.reLaunch({
  96. url: '/pages/ownersQuery/ownersQuery'
  97. });
  98. },
  99. /*上拉加载的回调: 其中page.num:当前页 从1开始, page.size:每页数据条数,默认10 */
  100. upCallback(page) {
  101. // console.log('page',page)
  102. //联网加载数据
  103. // let keyword = this.tabs[this.tabIndex]?.text;
  104. let params ={
  105. // orderStatus:this.tabIndex + 1,//预警状态 1-待处理 2-已处理 3-已解除 如需要状态就放开
  106. vehicleNo:this.vehicleNo,
  107. // queryType:this.deviceTypeId,//查询类型 0-历史预警
  108. pageNum:page.num,
  109. queryType:page.size
  110. }
  111. this.$u.api.getParkingRecord(params).then(curPageData=>{
  112. // console.log('curPageData',curPageData)
  113. //联网成功的回调,隐藏下拉刷新和上拉加载的状态;
  114. this.mescroll.endSuccess(curPageData.total);
  115. this.mescroll.endBySize(curPageData.data.rows.length, curPageData.total);
  116. //设置列表数据
  117. if(page.num == 1) this.dataList = []; //如果是第一页需手动制空列表
  118. this.dataList=this.dataList.concat(curPageData.data.rows); //追加新数据
  119. }).catch((err)=>{
  120. uni.showToast({
  121. title:'链接失败'
  122. });
  123. console.log('err',err)
  124. //联网失败, 结束加载
  125. this.mescroll.endErr();
  126. })
  127. },
  128. //点击空布局按钮的回调
  129. emptyClick(){
  130. },
  131. // 切换菜单
  132. tabChange(index) {
  133. this.dataList = [];// 先置空列表,显示加载进度
  134. this.tabIndex = index;
  135. this.mescroll.resetUpScroll(); // 再刷新列表数据
  136. },
  137. selectConfirm(e){
  138. console.log('e',e);
  139. this.warningType = e[0].label;
  140. // this.$emit('workTypeChange', e[0].label);
  141. },
  142. openDetails(item){
  143. this.$u.route({
  144. url: 'pages/warningCenter/warningDetails/warningDetails',
  145. params:{
  146. deviceId:item.deviceId,
  147. warningId:item.id
  148. }
  149. })
  150. }
  151. }
  152. }
  153. </script>
  154. <style>
  155. page{background: #f7f7f7;}
  156. </style>
  157. <style lang="scss" scoped>
  158. // @import './warningCenter.scss'
  159. .owelist{
  160. margin: 31rpx auto;
  161. padding: 24rpx;
  162. .owelist-item{
  163. background-color: #fff;
  164. padding: 25rpx 31rpx;
  165. border-radius: 10rpx;
  166. margin-bottom: 19rpx;
  167. .item-header{
  168. margin-bottom: 11rpx;
  169. .vehicle-no{
  170. font-size: 40rpx;
  171. font-weight: 500;
  172. color: #3D3D3D;
  173. line-height: 56rpx;
  174. }
  175. .order-status{
  176. font-size: 24rpx;
  177. font-weight: 500;
  178. color: #8F8F8F;
  179. line-height: 48rpx;
  180. border: 1px solid #ddd;
  181. color: #777;
  182. padding: 0 24rpx;
  183. border-radius: 8rpx;
  184. &.order-status-4{
  185. color: #777;
  186. }
  187. &.order-status-3{
  188. border-color: #FA6400;
  189. color: #FA6400;
  190. }
  191. }
  192. }
  193. .road-name{
  194. font-size: 26rpx;
  195. font-weight: 400;
  196. color: #A2A2A2;
  197. line-height: 37rpx;
  198. padding-bottom: 20rpx;
  199. border-bottom: 1px solid #D5D5D5;
  200. margin-bottom: 21rpx;
  201. }
  202. .info-item{
  203. font-size: 30rpx;
  204. color: #63717F;
  205. line-height: 42rpx;
  206. margin-bottom: 13rpx;
  207. .amount{
  208. font-weight: 500;
  209. color: #FA6400;
  210. }
  211. }
  212. }
  213. }
  214. </style>