| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <view> | 
					
						
							|  |  |  |     <uni-popup ref="popup" type="bottom"> | 
					
						
							|  |  |  |       <view class="popupContent"> | 
					
						
							|  |  |  |         <view class="header"> | 
					
						
							|  |  |  |           <text class="cancel" @click="cancel">取消</text> | 
					
						
							|  |  |  |           <text class="title">选择维修项目</text> | 
					
						
							|  |  |  |           <text class="submit" @click="confirm">确定</text> | 
					
						
							|  |  |  |         </view> | 
					
						
							|  |  |  |         <view class="chooseProj"> | 
					
						
							|  |  |  |           <view class="desc"> | 
					
						
							|  |  |  |             已经选择{{ selectedProj.length }}项维修项目 | 
					
						
							|  |  |  |           </view> | 
					
						
							|  |  |  |           <view class="selectedProj"> | 
					
						
							|  |  |  |             <view v-for="(item, index) in selectedProj" :key="index" class="selectedProjItem"> | 
					
						
							|  |  |  |               <text>{{ item.name }}</text> | 
					
						
							|  |  |  |               <image class="itemIcon" mode="aspectFit" src="/static/icons/x.png" @click="removeProj(index)"></image> | 
					
						
							|  |  |  |             </view> | 
					
						
							|  |  |  |           </view> | 
					
						
							|  |  |  |         </view> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |         <view v-if="typeList && typeList.length > 0" class="projPicker" style="display: flex"> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |           <view class="type"> | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |             <view v-for="item in typeList" :key="item.id" :class="{'active': typeId === item.id}" class="typeItem" | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |                   @click="chooseType(item)"> | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |               {{ item.name }} | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |             </view> | 
					
						
							|  |  |  |           </view> | 
					
						
							|  |  |  |           <view class="container"> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |             <view class="groupList"> | 
					
						
							|  |  |  | <!--              <view class="groupHeader">--> | 
					
						
							|  |  |  | <!--                <view class="line"></view>--> | 
					
						
							|  |  |  | <!--                <text>{{ item.name }}</text>--> | 
					
						
							|  |  |  | <!--                <view class="line"></view>--> | 
					
						
							|  |  |  | <!--              </view>--> | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |               <view class="projList"> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  | <!--                <view v-for="(proj, index) in item.projList" :key="proj.id" class="projItem" @click="chooseProj(proj)">--> | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |                 <view class="addProj" @click="addProject()" v-if="show"> | 
					
						
							|  |  |  |                   <!--                  <text class="projName">新增维修项目</text>--> | 
					
						
							|  |  |  |                   <button type="primary" size="mini" class="addBtn" >新增</button> | 
					
						
							|  |  |  |                 </view> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |                 <view v-for="item in groupList" :key="item.id" class="projItem" @click="chooseProj(item)"> | 
					
						
							|  |  |  |                   <text class="projName">{{ item.name }}</text> | 
					
						
							|  |  |  |                   <image v-if="selectedProj && selectedProj.find(f => f.id === item.id)" class="projChooseIcon" | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |                          mode="aspectFit" src="/static/icons/duihao.png"></image> | 
					
						
							|  |  |  |                 </view> | 
					
						
							|  |  |  |               </view> | 
					
						
							|  |  |  |             </view> | 
					
						
							|  |  |  |           </view> | 
					
						
							|  |  |  |         </view> | 
					
						
							|  |  |  |       </view> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     </uni-popup> | 
					
						
							|  |  |  |   </view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  | import request from "@/utils/request"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  | export default { | 
					
						
							|  |  |  |   name: "projectPicker", | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       selectedProj: [ | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |       ], | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       typeList: [], | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |       typeId: 1, | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |       groupList: [], | 
					
						
							|  |  |  |       show: false | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |   onLoad() { | 
					
						
							|  |  |  |     // 注册事件监听器
 | 
					
						
							|  |  |  |     uni.$on('projectCreated', this.handleProjectCreated); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   onUnload() { | 
					
						
							|  |  |  |     // 移除事件监听器
 | 
					
						
							|  |  |  |     uni.$off('projectCreated'); | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |   methods: { | 
					
						
							|  |  |  |     open(selectedProj = []) { | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |       if (selectedProj) { | 
					
						
							|  |  |  |         this.selectedProj = JSON.parse(JSON.stringify(selectedProj)) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |       this.$refs.popup.open() | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       this.getProjeectList() | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |       setTimeout(() => { | 
					
						
							|  |  |  |         if (this.typeList && this.typeList.length > 0) { | 
					
						
							|  |  |  |           this.typeId = this.typeList[0].id | 
					
						
							|  |  |  |           this.getProject() | 
					
						
							|  |  |  |           this.show = true | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       },500) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // 监听事件
 | 
					
						
							|  |  |  |       uni.$on('projectCreated', (data) => { | 
					
						
							|  |  |  |         // 在这里处理接收到的数据
 | 
					
						
							|  |  |  |         this.selectedProj.push(data) | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |         this.getProject() | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       // this.selectedProj = JSON.parse(JSON.stringify(selectedProj))
 | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     removeProj(index) { | 
					
						
							|  |  |  |       this.selectedProj.splice(index, 1) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     chooseProj(proj) { | 
					
						
							|  |  |  |       const findIndex = this.selectedProj.findIndex(f => f.id === proj.id) | 
					
						
							|  |  |  |       if (findIndex > -1) { | 
					
						
							|  |  |  |         this.selectedProj.splice(findIndex, 1) | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.selectedProj.push(proj) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     chooseType(type) { | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |       this.typeId = type.id | 
					
						
							|  |  |  |       this.getProject() | 
					
						
							|  |  |  |       // this.typeId = type.typeId
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     addProject() { | 
					
						
							|  |  |  |       uni.navigateTo({ | 
					
						
							|  |  |  |         url: `/pages/project/project?typeId=${this.typeId}` | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     getProjeectList() { | 
					
						
							|  |  |  |       const params = { | 
					
						
							|  |  |  |         pageNo: 1, | 
					
						
							| 
									
										
										
										
											2024-10-22 11:54:28 +08:00
										 |  |  |         pageSize: 100000, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |         type: '03' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       request({ | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |         // url: '/admin-api/repair/project/getRepairProjectAndCateGory',
 | 
					
						
							|  |  |  |         url: '/admin-api/conf/baseType/list', | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |         method: 'GET', | 
					
						
							|  |  |  |         params: params | 
					
						
							|  |  |  |       }).then(res => { | 
					
						
							|  |  |  |         this.typeList = res.data | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     getProject() { | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       request({ | 
					
						
							|  |  |  |         url: '/admin-api/repair/project/page', | 
					
						
							|  |  |  |         method: 'GET', | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |         params: { | 
					
						
							|  |  |  |           pageNo: 1, | 
					
						
							|  |  |  |           pageSize: 10000, | 
					
						
							|  |  |  |           type: this.typeId | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       }).then(res => { | 
					
						
							| 
									
										
										
										
											2024-10-21 18:11:30 +08:00
										 |  |  |         this.groupList = res.data.records | 
					
						
							| 
									
										
										
										
											2024-10-18 17:15:20 +08:00
										 |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     confirm() { | 
					
						
							|  |  |  |       this.$emit('confirm', this.selectedProj) | 
					
						
							|  |  |  |       this.cancel() | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     cancel() { | 
					
						
							|  |  |  |       this.selectedProj = [] | 
					
						
							|  |  |  |       this.groupList = this.typeList[0].groupList | 
					
						
							|  |  |  |       this.$refs.popup.close() | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | .popupContent { | 
					
						
							|  |  |  |   height: 86vh; | 
					
						
							|  |  |  |   background-color: #fff; | 
					
						
							|  |  |  |   border-radius: 32rpx 32rpx 0rpx 0rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .header { | 
					
						
							|  |  |  |   padding: 40rpx; | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   font-size: 32rpx; | 
					
						
							|  |  |  |   border-bottom: 1rpx solid #EEEEEE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .title { | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |     width: 0; | 
					
						
							|  |  |  |     text-align: center; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     font-weight: bold; | 
					
						
							|  |  |  |     color: #333333; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .cancel { | 
					
						
							|  |  |  |     font-weight: 500; | 
					
						
							|  |  |  |     color: #999999; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .submit { | 
					
						
							|  |  |  |     font-weight: 500; | 
					
						
							|  |  |  |     color: #0174F6; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .chooseProj { | 
					
						
							|  |  |  |   padding: 30rpx 32rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .desc { | 
					
						
							|  |  |  |     font-weight: 500; | 
					
						
							|  |  |  |     font-size: 24rpx; | 
					
						
							|  |  |  |     color: #999999; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .selectedProj { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     gap: 20rpx; | 
					
						
							|  |  |  |     flex-wrap: wrap; | 
					
						
							|  |  |  |     padding: 30rpx 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .selectedProjItem { | 
					
						
							|  |  |  |       display: flex; | 
					
						
							|  |  |  |       align-items: center; | 
					
						
							|  |  |  |       column-gap: 10rpx; | 
					
						
							|  |  |  |       padding: 10rpx 16rpx; | 
					
						
							|  |  |  |       border-radius: 4rpx 4rpx 4rpx 4rpx; | 
					
						
							|  |  |  |       border: 2rpx solid #0174F6; | 
					
						
							|  |  |  |       font-weight: 500; | 
					
						
							|  |  |  |       font-size: 24rpx; | 
					
						
							|  |  |  |       color: #0174F6; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .itemIcon { | 
					
						
							|  |  |  |         width: 16rpx; | 
					
						
							|  |  |  |         height: 16rpx; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .projPicker { | 
					
						
							|  |  |  |   flex: 1; | 
					
						
							|  |  |  |   height: 0; | 
					
						
							|  |  |  |   overflow: auto; | 
					
						
							|  |  |  |   border-top: 1rpx solid #EEEEEE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .type { | 
					
						
							|  |  |  |     width: 200rpx; | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |     overflow-y: scroll; | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |     background: #FFFFFF; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .typeItem { | 
					
						
							|  |  |  |       width: 100%; | 
					
						
							|  |  |  |       background: #F2F2F7; | 
					
						
							|  |  |  |       padding: 40rpx 32rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       &.active { | 
					
						
							|  |  |  |         background-color: #fff; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .container { | 
					
						
							|  |  |  |     flex: 1; | 
					
						
							|  |  |  |     width: 0; | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |     overflow-y: scroll; | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |     padding: 30rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     .groupList { | 
					
						
							|  |  |  |       .groupHeader { | 
					
						
							|  |  |  |         display: flex; | 
					
						
							|  |  |  |         align-items: center; | 
					
						
							|  |  |  |         column-gap: 4rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         font-weight: 500; | 
					
						
							|  |  |  |         font-size: 24rpx; | 
					
						
							|  |  |  |         color: #999999; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         .line { | 
					
						
							|  |  |  |           flex: 1; | 
					
						
							|  |  |  |           width: 0; | 
					
						
							|  |  |  |           height: 2rpx; | 
					
						
							|  |  |  |           background-color: #DDDDDD; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       .projList { | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |         padding-bottom: 40rpx; | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |         display: flex; | 
					
						
							|  |  |  |         flex-direction: column; | 
					
						
							|  |  |  |         row-gap: 40rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 15:37:56 +08:00
										 |  |  |         .addProj{ | 
					
						
							|  |  |  |           text-align: right; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-13 23:24:23 +08:00
										 |  |  |         .projItem { | 
					
						
							|  |  |  |           display: flex; | 
					
						
							|  |  |  |           align-items: center; | 
					
						
							|  |  |  |           justify-content: space-between; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           .projName { | 
					
						
							|  |  |  |             flex: 1; | 
					
						
							|  |  |  |             width: 0; | 
					
						
							|  |  |  |             font-weight: 500; | 
					
						
							|  |  |  |             font-size: 28rpx; | 
					
						
							|  |  |  |             color: #333333; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           .projChooseIcon { | 
					
						
							|  |  |  |             width: 36rpx; | 
					
						
							|  |  |  |             height: 36rpx; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |