| <template> | 
|   <div class="edit-selClient-box"> | 
|     <el-dialog | 
|       :title="'联系人'" | 
|       :visible.sync="editConfig.editVisible" | 
|       :width="dialogWidth" | 
|       :before-close="handleClose" | 
|       :append-to-body="true" | 
|       :close-on-click-modal="false" | 
|     > | 
|       <div class="bg-view"> | 
|         <div class="query-bg"> | 
|           <!-- <el-input placeholder="请输入内容" v-model="queryInput" size="mini" class="input-with-select"> | 
|             <el-select v-model="select" slot="prepend" placeholder="请选择" disabled> | 
|               <el-option label="全部字段" value="1"></el-option> | 
|               <el-option label="联系人姓名" value="2"></el-option> | 
|               <el-option label="联系人编号" value="3"></el-option> | 
|               <el-option label="客户名称" value="4"></el-option> | 
|               <el-option label="手机" value="5"></el-option> | 
|             </el-select> | 
|           </el-input> | 
|           <div class="btn"> | 
|             <el-button type="primary" size="mini" disabled>设置字段</el-button> | 
|             <el-button type="primary" size="mini" disabled>快速创建</el-button> | 
|           </div> | 
|         </div> | 
|         <el-table | 
|           :data="tableData" | 
|           border | 
|           size="mini" | 
|           v-loading="loading" | 
|           :header-cell-style="{ background: '#f7f7f7' }" | 
|         > | 
|           <el-table-column label="联系人姓名" prop="name" show-overflow-tooltip> | 
|             <template slot-scope="scope"> | 
|               <span class="sel-name" @click="selNameClick(scope.row)">{{ scope.row.name }}</span> | 
|             </template> | 
|           </el-table-column> | 
|           <el-table-column label="联系人编号" prop="number"></el-table-column> | 
|           <el-table-column label="客户名称" prop="client_name"></el-table-column> | 
|           <el-table-column label="手机" prop="phone"></el-table-column> | 
|           <div slot="empty"> | 
|             <el-empty :image-size="100"></el-empty> | 
|           </div> | 
|         </el-table> --> | 
|           <SearchCommonView | 
|             ref="searchCommonView" | 
|             :search-options="searchOptions" | 
|             @searchClick="searchClick" | 
|             @resetClick="resetClick" | 
|           /> | 
|           <div class="btn"> | 
|             <!-- <el-button type="primary" size="mini" disabled>设置字段</el-button> | 
|             <el-button type="primary" size="mini" disabled>快速创建</el-button> --> | 
|           </div> | 
|         </div> | 
|         <TableCommonView | 
|           ref="tableListRef" | 
|           v-loading="loading" | 
|           :table-list="tableList" | 
|           :select-box="false" | 
|           @selContactsClick="selNameClick" | 
|         > | 
|         </TableCommonView> | 
|         <div slot="footer" class="dialog-footer"> | 
|           <div class="remark">说明:支持多字段模糊查询,仅显示符合条件的前5条数据</div> | 
|         </div> | 
|       </div> | 
|     </el-dialog> | 
|   </div> | 
| </template> | 
|   | 
| <script> | 
| import { getContactList } from "@/api/client/contacts" | 
| export default { | 
|   name: "EditSelClientDialog", | 
|   props: { | 
|     editCommonConfig: { | 
|       type: Object, | 
|       default: () => { | 
|         return { | 
|           editVisible: false, | 
|           title: "", | 
|           infomation: {} | 
|         } | 
|       } | 
|     } | 
|   }, | 
|   components: {}, | 
|   computed: {}, | 
|   data() { | 
|     return { | 
|       dialogWidth: "50%", | 
|       editConfig: this.editCommonConfig, | 
|       queryInput: "", | 
|       select: "1", | 
|       tableList: [], | 
|       searchSelOptions: [], | 
|       loading: false, | 
|       search_map: {} | 
|     } | 
|   }, | 
|   created() { | 
|     this.setTable() | 
|     this.getData() | 
|   }, | 
|   methods: { | 
|     setTable() { | 
|       this.tableList = { | 
|         tableInfomation: [], | 
|         tableColumn: [ | 
|           { label: "联系人姓名", prop: "name", isContactClick: true }, // 联系人姓名 | 
|           { label: "联系人编号", prop: "number" }, // 联系人编号 | 
|           { label: "客户名称", prop: "client_name" }, // 客户名称 | 
|           { label: "手机", prop: "phone" } // 手机号码 | 
|         ] | 
|       } | 
|       this.searchOptions = [] | 
|       for (let i = 0; i < this.tableList.tableColumn.length; i++) { | 
|         const label = this.tableList.tableColumn[i].label | 
|         const value = this.tableList.tableColumn[i].prop | 
|         this.searchOptions.push({ value: value, label: label }) | 
|       } | 
|     }, | 
|     handleClose() { | 
|       this.editConfig.editVisible = false | 
|     }, | 
|     // 请求数据 | 
|     async getData() { | 
|       this.loading = true | 
|       await getContactList({ | 
|         search_map: this.search_map, | 
|         page: 0, | 
|         pageSize: 0 | 
|       }) | 
|         .then((res) => { | 
|           console.log(res) | 
|           if (res.code === 200) { | 
|             if (res.data.list && res.data.list.length > 0) { | 
|               const list = res.data.list.map((item) => { | 
|                 return { | 
|                   ...item, | 
|                   client_name: item.Client.name | 
|                 } | 
|               }) | 
|               this.tableList.tableInfomation = list.slice(0, 5) || [] | 
|             } else { | 
|               this.tableList.tableInfomation = [] | 
|             } | 
|           } else { | 
|             this.tableList.tableInfomation = [] | 
|           } | 
|           this.loading = false | 
|         }) | 
|         .catch((err) => { | 
|           console.log(err) | 
|           this.tableList.tableInfomation = [] | 
|           this.loading = false | 
|         }) | 
|     }, | 
|     selNameClick(row) { | 
|       this.editConfig.editVisible = false | 
|       this.$emit("selClient", row, "contact") | 
|     }, | 
|     // 搜索 | 
|     searchClick(val, content) { | 
|       console.log(val, content) | 
|       this.search_map = { | 
|         [val.value]: content | 
|       } | 
|       this.getData() | 
|     }, | 
|     resetClick() { | 
|       this.search_map = {} | 
|       this.getData() | 
|     } | 
|   } | 
| } | 
| </script> | 
|   | 
| <!-- Add "scoped" attribute to limit CSS to this component only --> | 
| <style lang="scss" scoped> | 
| .bg-view { | 
|   margin: 10px; | 
|   .query-bg { | 
|     margin-left: -20px; | 
|     margin-bottom: 10px; | 
|     display: flex; | 
|     justify-content: space-between; | 
|     .el-input { | 
|       width: 310px; | 
|       .el-select { | 
|         width: 100px; | 
|       } | 
|     } | 
|     .btn { | 
|       float: right; | 
|     } | 
|   } | 
| } | 
| .sel-name { | 
|   color: $color-primary; | 
|   cursor: pointer; | 
| } | 
| .dialog-footer { | 
|   height: 40px; | 
|   line-height: 40px; | 
|   color: red; | 
| } | 
| ::v-deep { | 
|   .input-with-select .el-input-group__prepend { | 
|     background-color: #fff; | 
|   } | 
| } | 
| </style> |