| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  | <template> | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |   <el-select :loading="selectLoading" v-model="staffSelected" clearable filterable :filter-method="changeQuery" | 
					
						
							|  |  |  |              @blur="$emit('input-blur', $event)"> | 
					
						
							| 
									
										
										
										
											2024-09-29 18:13:07 +08:00
										 |  |  |     <el-option v-for="staff in staffList" :key="staff.id" :label="staff.name + ' ' + staff.tel" :value="staff.id"/> | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |   </el-select> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import {getStaffList} from "@/api/company/staff"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: "StaffChoose", | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |   props: { | 
					
						
							| 
									
										
										
										
											2024-09-14 18:27:01 +08:00
										 |  |  |     value: { | 
					
						
							|  |  |  |       type: Object, | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     isGet: { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |       type: String, | 
					
						
							|  |  |  |       default: '', | 
					
						
							|  |  |  |       required: false | 
					
						
							| 
									
										
										
										
											2024-09-14 18:27:01 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       staffList: [], | 
					
						
							|  |  |  |       staffSelected: undefined, | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       hasRequest: false, | 
					
						
							|  |  |  |       query: null, | 
					
						
							|  |  |  |       selectLoading: false, | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |   watch: { | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |     staffSelected(val) { | 
					
						
							|  |  |  |       const staff = this.staffList.find(item => item.id === val); | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |       if (staff) { | 
					
						
							|  |  |  |         this.$emit("input", staff); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-14 18:27:01 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |     value(newVal) { | 
					
						
							|  |  |  |       if (newVal) { | 
					
						
							| 
									
										
										
										
											2024-09-14 18:27:01 +08:00
										 |  |  |         this.staffSelected = newVal.id | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2024-09-14 18:27:01 +08:00
										 |  |  |         this.staffSelected = null | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-09-20 21:21:39 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   mounted() { | 
					
						
							|  |  |  |     this.listStaff() | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     async listStaff() { | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       this.selectLoading = true | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |       try { | 
					
						
							| 
									
										
										
										
											2024-09-25 15:42:23 +08:00
										 |  |  |         if (!this.isGet) return; | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |         const res = await getStaffList(this.query) | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |         this.staffList = res.data | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       } finally { | 
					
						
							|  |  |  |         this.selectLoading = false | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-14 17:25:49 +08:00
										 |  |  |     changeQuery(val) { | 
					
						
							| 
									
										
										
										
											2024-10-08 18:28:36 +08:00
										 |  |  |       this.query = val | 
					
						
							|  |  |  |       this.listStaff() | 
					
						
							| 
									
										
										
										
											2024-09-11 18:49:43 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style scoped lang="scss"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | </style> |