|  |  |  | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <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="请选择"> | 
|---|
|  |  |  | <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-option label="注册时间" value="6"></el-option> | 
|---|
|  |  |  | <el-option label="经营范围" value="7"></el-option> | 
|---|
|  |  |  | <el-option label="详细地址" value="8"></el-option> | 
|---|
|  |  |  | <el-option label="备注" value="9"></el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | <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> | 
|---|
|  |  |  | <!-- <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" | 
|---|
|  |  |  | <TableCommonView | 
|---|
|  |  |  | ref="tableListRef" | 
|---|
|  |  |  | v-loading="loading" | 
|---|
|  |  |  | :header-cell-style="{ background: '#f7f7f7' }" | 
|---|
|  |  |  | :table-list="tableList" | 
|---|
|  |  |  | :select-box="false" | 
|---|
|  |  |  | @selClientClick="selNameClick" | 
|---|
|  |  |  | @selTableCol="selTableCol" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-table-column label="客户名称" prop="name" show-overflow-tooltip> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <!-- <div style="margin-right: 10px"> --> | 
|---|
|  |  |  | <span class="sel-name" @click="selNameClick(scope.row)">{{ scope.row.name }}</span> | 
|---|
|  |  |  | <!-- </div> --> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="客户编号" prop="number"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="客户状态" prop="client_status"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="销售负责人" prop="member_id"></el-table-column> | 
|---|
|  |  |  | <!-- <el-table-column label="线索升级状态" prop="setDefault"></el-table-column> --> | 
|---|
|  |  |  | <el-table-column label="法定代表人" prop="representative"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="注册时间" prop="registration_time" show-overflow-tooltip> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <span>{{ | 
|---|
|  |  |  | dateFormat("YYYY-mm-dd HH:MM:SS", scope.row.registration_time) === "1900-01-01 08:00:00" | 
|---|
|  |  |  | ? "--" | 
|---|
|  |  |  | : dateFormat("YYYY-mm-dd HH:MM:SS", scope.row.registration_time) | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | <el-table-column label="经营范围" prop="business_scope"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="详细地址" prop="detail_address"></el-table-column> | 
|---|
|  |  |  | <el-table-column label="备注" prop="remark"></el-table-column> | 
|---|
|  |  |  | <div slot="empty"> | 
|---|
|  |  |  | <el-empty :image-size="100"></el-empty> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-table> | 
|---|
|  |  |  | </TableCommonView> | 
|---|
|  |  |  | <div slot="footer" class="dialog-footer"> | 
|---|
|  |  |  | <div class="remark">说明:支持多字段模糊查询,仅显示符合条件的前5条数据</div> | 
|---|
|  |  |  | <!-- <div class="remark">说明:支持多字段模糊查询,仅显示符合条件的前5条数据</div> --> | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script> | 
|---|
|  |  |  | import { getClientList } from "@/api/client/client" | 
|---|
|  |  |  | import pageMixin from "@/components/makepager/pager/mixin/pageMixin" | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | name: "EditSelClientDialog", | 
|---|
|  |  |  | mixins: [pageMixin], | 
|---|
|  |  |  | props: { | 
|---|
|  |  |  | editCommonConfig: { | 
|---|
|  |  |  | type: Object, | 
|---|
|  |  |  | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | editVisible: false, | 
|---|
|  |  |  | title: "", | 
|---|
|  |  |  | infomation: { | 
|---|
|  |  |  | name: "", | 
|---|
|  |  |  | color: "", | 
|---|
|  |  |  | setDefault: "" | 
|---|
|  |  |  | } | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | select: "1", | 
|---|
|  |  |  | tableData: [], | 
|---|
|  |  |  | searchSelOptions: [], | 
|---|
|  |  |  | loading: false | 
|---|
|  |  |  | loading: false, | 
|---|
|  |  |  | searchOptions: [], | 
|---|
|  |  |  | tableList: {}, | 
|---|
|  |  |  | search_map: {}, | 
|---|
|  |  |  | tableColumn: [ | 
|---|
|  |  |  | { label: "客户名称", prop: "name", min: 100, isClientClick: true, default: true }, | 
|---|
|  |  |  | { label: "客户编号", prop: "number" }, | 
|---|
|  |  |  | { label: "客户状态", prop: "client_status" }, | 
|---|
|  |  |  | { label: "销售负责人", prop: "member_name", min: 100 }, | 
|---|
|  |  |  | { label: "法定代表人", prop: "representative", min: 100 }, | 
|---|
|  |  |  | { label: "注册时间", prop: "registration_time" }, | 
|---|
|  |  |  | { label: "经营范围", prop: "business_scope" }, | 
|---|
|  |  |  | { label: "详细地址", prop: "detail_address" }, | 
|---|
|  |  |  | { label: "备注", prop: "remark" } | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | showCol: [ | 
|---|
|  |  |  | "客户名称", | 
|---|
|  |  |  | "客户编号", | 
|---|
|  |  |  | "客户状态", | 
|---|
|  |  |  | "销售负责人", | 
|---|
|  |  |  | "法定代表人", | 
|---|
|  |  |  | "注册时间", | 
|---|
|  |  |  | "经营范围", | 
|---|
|  |  |  | "详细地址", | 
|---|
|  |  |  | "备注" | 
|---|
|  |  |  | ] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | this.setTable() | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | setTable() { | 
|---|
|  |  |  | this.tableList = { | 
|---|
|  |  |  | selectIndex: true, | 
|---|
|  |  |  | tableInfomation: [], | 
|---|
|  |  |  | allcol: [], | 
|---|
|  |  |  | showcol: this.showCol, | 
|---|
|  |  |  | tableColumn: this.setColumnVisible(this.showCol) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.tableList.allcol = this.tableList.tableColumn.filter((ele) => !ele.default).map((ele) => ele.label) | 
|---|
|  |  |  | 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 }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | setColumnVisible(showCol) { | 
|---|
|  |  |  | return this.tableColumn.map((ele) => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...ele, | 
|---|
|  |  |  | isShowColumn: showCol.includes(ele.label) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | selTableCol(val) { | 
|---|
|  |  |  | this.showcol = val | 
|---|
|  |  |  | this.tableList.tableColumn = this.setColumnVisible(val) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleClose() { | 
|---|
|  |  |  | this.editConfig.editVisible = false | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 请求数据 | 
|---|
|  |  |  | async getData() { | 
|---|
|  |  |  | this.loading = true | 
|---|
|  |  |  | await getClientList() | 
|---|
|  |  |  | await getClientList({ | 
|---|
|  |  |  | search_map: this.search_map, | 
|---|
|  |  |  | page: this.pagerOptions.currPage, | 
|---|
|  |  |  | pageSize: this.pagerOptions.pageSize | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then((res) => { | 
|---|
|  |  |  | console.log(res) | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | if (res.data.list && res.data.list.length > 0) { | 
|---|
|  |  |  | console.log("ssss") | 
|---|
|  |  |  | const list = res.data.list.map((item) => { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...item, | 
|---|
|  |  |  | client_status: item.client_status.name | 
|---|
|  |  |  | client_status: item.client_status.name, | 
|---|
|  |  |  | member_name: item.member.username | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.tableData = list.slice(0, 5) || [] | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableData = [] | 
|---|
|  |  |  | this.tableList.tableInfomation = list || [] | 
|---|
|  |  |  | this.pagerOptions.totalCount = res.data.count | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableData = [] | 
|---|
|  |  |  | this.tableList.tableInfomation = [] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.loading = false | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch((err) => { | 
|---|
|  |  |  | console.log(err) | 
|---|
|  |  |  | this.tableData = [] | 
|---|
|  |  |  | this.this.tableList.tableInfomation = [] | 
|---|
|  |  |  | this.loading = false | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | selNameClick(row) { | 
|---|
|  |  |  | this.editConfig.editVisible = false | 
|---|
|  |  |  | this.$emit("selClient", row) | 
|---|
|  |  |  | this.$emit("selClient", row, "client") | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 时间显示 | 
|---|
|  |  |  | dateFormat(fmt, date) { | 
|---|
|  |  |  | let ret = "" | 
|---|
|  |  |  | date = new Date(date) | 
|---|
|  |  |  | const opt = { | 
|---|
|  |  |  | "Y+": date.getFullYear().toString(), // 年 | 
|---|
|  |  |  | "m+": (date.getMonth() + 1).toString(), // 月 | 
|---|
|  |  |  | "d+": date.getDate().toString(), // 日 | 
|---|
|  |  |  | "H+": date.getHours().toString(), // 时 | 
|---|
|  |  |  | "M+": date.getMinutes().toString(), // 分 | 
|---|
|  |  |  | "S+": date.getSeconds().toString() // 秒 | 
|---|
|  |  |  | // 有其他格式化字符需求可以继续添加,必须转化成字符串 | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | searchClick(val, content) { | 
|---|
|  |  |  | console.log(val, content) | 
|---|
|  |  |  | this.search_map = { | 
|---|
|  |  |  | [val.value]: content | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (let k in opt) { | 
|---|
|  |  |  | ret = new RegExp("(" + k + ")").exec(fmt) | 
|---|
|  |  |  | if (ret) { | 
|---|
|  |  |  | fmt = fmt.replace(ret[1], ret[1].length == 1 ? opt[k] : opt[k].padStart(ret[1].length, "0")) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return fmt | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | resetClick() { | 
|---|
|  |  |  | this.search_map = {} | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | .bg-view { | 
|---|
|  |  |  | margin: 10px; | 
|---|
|  |  |  | .query-bg { | 
|---|
|  |  |  | margin-left: -20px; | 
|---|
|  |  |  | margin-bottom: 10px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | justify-content: space-between; | 
|---|
|  |  |  | 
|---|
|  |  |  | float: right; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .list-view { | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  | background: #c22f2f; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .sel-name { | 
|---|
|  |  |  | color: $color-primary; | 
|---|
|  |  |  | cursor: pointer; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .dialog-footer { | 
|---|
|  |  |  | height: 40px; | 
|---|
|  |  |  | line-height: 40px; | 
|---|
|  |  |  | height: 50px; | 
|---|
|  |  |  | line-height: 50px; | 
|---|
|  |  |  | color: red; | 
|---|
|  |  |  | .btn-pager { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | margin-top: 0px; | 
|---|
|  |  |  | .page { | 
|---|
|  |  |  | margin-left: auto; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ::v-deep { | 
|---|
|  |  |  | .input-with-select .el-input-group__prepend { | 
|---|