| <template>  | 
|     <view class="main_app">  | 
|         <div class="main_head">  | 
|             <view class="head_wrap">  | 
|                 <view class="search_wrap">  | 
|                     <image class="mr12 search" src="@/static/home/ic_search@2x.png" mode="widthFix"></image>  | 
|                     <input v-model="param.roomName" @confirm="handleQuery" type="text" placeholder="搜索楼宇/房间名称"  | 
|                         placeholder-class="placeholder9" />  | 
|                 </view>  | 
|             </view>  | 
|             <!--  -->  | 
|             <view class="tabs">  | 
|                 <view class="tab" :class="{active: activeTab == '0,1'}" @click="tabsClick('0,1')">  | 
|                     <text>待处理</text>  | 
|                     <text class="border"></text>  | 
|                 </view>  | 
|                 <view class="tab" :class="{active: activeTab == 2}" @click="tabsClick(2)">  | 
|                     <text>已处理</text>  | 
|                     <text class="border"></text>  | 
|                 </view>  | 
|                 <view class="tab" @click="allClick">  | 
|                     <view class="name">  | 
|                         <image v-if="selectAll" class="icon" src="@/static/checked.png" mode=""></image>  | 
|                         <image v-else class="icon" src="@/static/check.png" mode=""></image>  | 
|                         <text>查看全部</text>  | 
|                     </view>  | 
|                     <text class="border"></text>  | 
|                 </view>  | 
|             </view>  | 
|         </div>  | 
|         <!--  -->  | 
|         <scroll-view scroll-y="true" class="scroll_Y" @scrolltolower="scrolltolower">  | 
|             <view class="list">  | 
|                 <view class="item" v-for="item in list" @click="itemClick(item)">  | 
|                     <image v-if="item.dealStatus == 0" src="@/static/side/workordered.png" class="icon"></image>  | 
|                     <image v-else src="@/static/side/workorder.png" class="icon"></image>  | 
|                     <view class="content">  | 
|                         <view class="name_wrap line">  | 
|                             <view class="name">{{item.buildingName}}/{{item.roomNum || item.floorName}}</view>  | 
|                             <view class="status gray" v-if="item.dealStatus == 2">已处理</view>  | 
|                             <view class="status" v-if="item.dealStatus == 0">待处理</view>  | 
|                             <view class="status" v-if="item.dealStatus == 1">待处理</view>  | 
|                         </view>  | 
|                         <view class="line">位置类型:{{item.areaType == '0' ? '室内装修' : '公共区域'}}</view>  | 
|                         <view class="line">工单分类:{{item.categoryName}}</view>  | 
|                         <view class="line">上报时间:{{item.createDate}}</view>  | 
|                         <view class="line" v-if="item.getDate">上门时间:{{item.getDate}}</view>  | 
|                     </view>  | 
|                 </view>  | 
|                 <view v-if="list.length == 0" class="empty_wrap">  | 
|                     <image src="@/static/empty.png" mode=""></image>  | 
|                     <view class="">暂无数据</view>  | 
|                 </view>  | 
|             </view>  | 
|         </scroll-view>  | 
|         <!--  -->  | 
|     </view>  | 
| </template>  | 
|   | 
| <script>  | 
|     import {  | 
|         ywWorkorder  | 
|     } from '@/api'  | 
|     export default {  | 
|         data() {  | 
|             return {  | 
|                 param: {},  | 
|                 activeTab: '0,1',  | 
|                 selectAll: false,  | 
|   | 
|                 list: [],  | 
|                 total: 0,  | 
|                 page: 1,  | 
|             };  | 
|         },  | 
|         onShow() {  | 
|             this.getList()  | 
|         },  | 
|         methods: { | 
|             scrolltolower() { | 
|                 const { | 
|                     total, | 
|                     list | 
|                 } = this | 
|                 if (list.length < total) { | 
|                     this.page = this.page + 1 | 
|                     this.getList() | 
|                 } else { | 
|                     this.showToast('暂无更多数据') | 
|                 } | 
|             },  | 
|             tabsClick(val) {  | 
|                 this.activeTab = val  | 
|                 this.list = []  | 
|                 this.page = 1  | 
|                 this.getList()  | 
|             },  | 
|             allClick() {  | 
|                 this.selectAll = !this.selectAll  | 
|                 this.list = []  | 
|                 this.page = 1  | 
|                 this.getList()  | 
|             },  | 
|             itemClick(item) {  | 
|                 uni.navigateTo({  | 
|                     url: `/pages/workOrder/detail?id=${item.id}`  | 
|                 })  | 
|             },  | 
|             handleQuery() {  | 
|                 this.list = []  | 
|                 this.page = 1  | 
|                 this.getList()  | 
|             },  | 
|             getList() {  | 
|                 const {  | 
|                     page,  | 
|                     total,  | 
|                     list,  | 
|                     activeTab,  | 
|                     param,  | 
|                     selectAll  | 
|                 } = this  | 
|                 ywWorkorder({  | 
|                     page,  | 
|                     capacity: 10,  | 
|                     model: {  | 
|                         ...param,  | 
|                         queryStatus: activeTab,  | 
|                         dealUserId: selectAll ? '' : uni.getStorageSync('userInfo').id,  | 
|                     }  | 
|                 }).then(res => {  | 
|                     this.list = [...this.list, ...res.data.records]  | 
|                     this.total = res.data.total  | 
|                 })  | 
|             }  | 
|         }  | 
|     }  | 
| </script>  | 
|   | 
| <style lang="scss" scoped>  | 
|     .main_app {  | 
|         padding: 0 30rpx;  | 
|     }  | 
|   | 
|     .tabs {  | 
|         display: flex;  | 
|         width: 750rpx;  | 
|         margin: 12rpx -30rpx 0;  | 
|         border-bottom: 1rpx solid #E5E5E5;  | 
|   | 
|         .tab {  | 
|             font-size: 30rpx;  | 
|             color: #666666;  | 
|             flex: 1;  | 
|             display: flex;  | 
|             flex-direction: column;  | 
|             align-items: center;  | 
|             justify-content: flex-end;  | 
|             height: 88rpx;  | 
|   | 
|             .name {  | 
|                 display: flex;  | 
|                 align-items: center;  | 
|             }  | 
|   | 
|             .icon {  | 
|                 width: 28rpx;  | 
|                 height: 28rpx;  | 
|                 margin-right: 10rpx;  | 
|             }  | 
|   | 
|             .border {  | 
|                 width: 54rpx;  | 
|                 height: 6rpx;  | 
|                 background-color: #fff;  | 
|                 border-radius: 3rpx;  | 
|                 margin-top: 24rpx;  | 
|             }  | 
|         }  | 
|   | 
|         .active {  | 
|             font-weight: 600;  | 
|             font-size: 32rpx;  | 
|             color: #222222;  | 
|   | 
|             .border {  | 
|                 background-color: $primaryColor;  | 
|             }  | 
|   | 
|         }  | 
|   | 
|     }  | 
|   | 
|     .head_wrap {  | 
|         display: flex;  | 
|         align-items: center;  | 
|   | 
|         .search_wrap {  | 
|             display: flex;  | 
|             align-items: center;  | 
|             width: 100%;  | 
|             height: 76rpx;  | 
|             background: #F7F7F7;  | 
|             border-radius: 38rpx;  | 
|             padding-left: 30rpx;  | 
|   | 
|             input {  | 
|                 flex: 1;  | 
|             }  | 
|   | 
|             .search {  | 
|                 width: 28rpx;  | 
|                 height: 28rpx;  | 
|             }  | 
|         }  | 
|   | 
|     }  | 
|     .scroll_Y{ | 
|         height: calc(100vh - 320rpx); | 
|     }  | 
|     .list {  | 
|         .item {  | 
|             display: flex;  | 
|             // height: 290rpx;  | 
|             padding: 30rpx 0;  | 
|             border-bottom: 2rpx solid #E5E5E5;  | 
|   | 
|             .icon {  | 
|                 width: 80rpx;  | 
|                 height: 80rpx;  | 
|                 margin-right: 24rpx;  | 
|             }  | 
|   | 
|             .content {  | 
|                 flex: 1;  | 
|                 color: #666666;  | 
|                 display: flex;  | 
|                 flex-direction: column;  | 
|                 justify-content: space-between;  | 
|   | 
|                 .line {  | 
|                     margin-bottom: 20rpx;  | 
|   | 
|                     &:nth-last-child(1) {  | 
|                         margin-bottom: 0;  | 
|                     }  | 
|                 }  | 
|   | 
|                 .name_wrap {  | 
|                     display: flex;  | 
|                     justify-content: space-between;  | 
|                     align-items: center;  | 
|   | 
|                     .name {  | 
|                         display: flex;  | 
|                         align-items: flex-end;  | 
|                         font-weight: 600;  | 
|                         font-size: 34rpx;  | 
|                         color: #222222;  | 
|                     }  | 
|   | 
|                     .status {  | 
|                         color: $primaryColor;  | 
|                     }  | 
|   | 
|                     .gray {  | 
|                         color: #999999;  | 
|                     }  | 
|                 }  | 
|             }  | 
|         }  | 
|     }  | 
| </style> |