|  |  |  | 
|---|
|  |  |  | <div class="custom-manage"> | 
|---|
|  |  |  | <div class="tab-view"> | 
|---|
|  |  |  | <el-tabs v-model="activeName" @tab-click="tabsClick"> | 
|---|
|  |  |  | <el-tab-pane label="全部(含所有公海)" name="first"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="全部(含公海)" name="second"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="全部(不含公海)" name="third"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="公海已分配" name="fourth"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="公未分配" name="aaa"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="公海客户" name="first"></el-tab-pane> | 
|---|
|  |  |  | <el-tab-pane label="我的客户" name="second"></el-tab-pane> | 
|---|
|  |  |  | </el-tabs> | 
|---|
|  |  |  | <div class="sel-gonghai"> | 
|---|
|  |  |  | <el-select v-model="gonghaiValue" placeholder="请选择" class="query-class-sel" size="mini"> | 
|---|
|  |  |  | <!-- <div class="sel-gonghai"> | 
|---|
|  |  |  | <el-select v-model="gonghaiValue" placeholder="请选择" class="query-class-sel" size="mini" disabled> | 
|---|
|  |  |  | <el-option v-for="item in gonghaiOptions" :key="item.value" :label="item.label" :value="item.value"> | 
|---|
|  |  |  | </el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | <div class="query-class-btn"> | 
|---|
|  |  |  | <i class="el-icon-setting"></i> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> --> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="filter"> | 
|---|
|  |  |  | <div class="filter-card"> | 
|---|
|  |  |  | <CommonSearch | 
|---|
|  |  |  | :show-add="false" | 
|---|
|  |  |  | :show-download="false" | 
|---|
|  |  |  | :amount-view="false" | 
|---|
|  |  |  | :show-action-btn="false" | 
|---|
|  |  |  | placeholder="请输入客户名称" | 
|---|
|  |  |  | @searchClick="onFilterSearch" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot="leftButton"> | 
|---|
|  |  |  | <el-button size="small" type="primary"  @click="addBtnClick">新建</el-button> | 
|---|
|  |  |  | <!-- <el-button size="small"  @click="delClick">删除</el-button> --> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </CommonSearch> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <SearchCommonView ref="searchCommonView" :query-class-options="queryClassOptions" :search-options="searchOptions" /> | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PublicFunctionBtnView | 
|---|
|  |  |  | :duplicate-check="true" | 
|---|
|  |  |  | :list-button="true" | 
|---|
|  |  |  | :map-button="true" | 
|---|
|  |  |  | :statistics="true" | 
|---|
|  |  |  | :operates-list="operatesList" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | <PagerView class="page" /> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="body"> | 
|---|
|  |  |  | <div class="body-card"> | 
|---|
|  |  |  | <div class="list-view"> | 
|---|
|  |  |  | <TableCommonView | 
|---|
|  |  |  | ref="tableListRef" | 
|---|
|  |  |  | v-loading="loading" | 
|---|
|  |  |  | :table-list="tableList" | 
|---|
|  |  |  | @selClientClick="selClientClick" | 
|---|
|  |  |  | @selContactsClick="selContactsClick" | 
|---|
|  |  |  | @getSelectArray="getSelectArray" | 
|---|
|  |  |  | @selTableCol="selTableCol" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <template slot="tableButton"> | 
|---|
|  |  |  | <el-table-column label="操作" width="180"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-button v-if="activeName === 'first'" type="text" size="small" @click="allocationBtnClick(scope.row)" | 
|---|
|  |  |  | >分配</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="text" size="small" @click="changeHighSeasClick(scope.row)">变更公海</el-button> | 
|---|
|  |  |  | <el-button @click="handleClick(scope.row)" type="text" size="small">编辑</el-button> | 
|---|
|  |  |  | <el-button @click="followupClick(scope.row)" type="text" size="small">跟进</el-button> | 
|---|
|  |  |  | <el-button @click="delClick(scope.row.id)" type="text" size="small">删除</el-button> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </TableCommonView> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="btn-pager"> | 
|---|
|  |  |  | <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <TableCommonView ref="tableListRef" v-loading="loading" :table-list="tableList"> | 
|---|
|  |  |  | <template slot="tableButton"> | 
|---|
|  |  |  | <el-table-column label="操作" width="150" fixed="right"> | 
|---|
|  |  |  | <template slot-scope="scope"> | 
|---|
|  |  |  | <el-button type="text" size="small">变更公海</el-button> | 
|---|
|  |  |  | <el-button @click="handleClick(scope.row)" type="text" size="small">编辑</el-button> | 
|---|
|  |  |  | <el-button type="text" size="small">跟进</el-button> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </el-table-column> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  | </TableCommonView> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- 新建/编辑客户管理 --> | 
|---|
|  |  |  | <AddClientManageDialog v-if="editConfig.visible" :edit-client-manage-config="editConfig" /> | 
|---|
|  |  |  | <!-- 客户详情 --> | 
|---|
|  |  |  | <DetailClientManage v-if="clientDeail.visible" :client-manage-detail="clientDeail" /> | 
|---|
|  |  |  | <!-- 联系人详情 --> | 
|---|
|  |  |  | <DetailContacts v-if="contactsDeail.visible" :contacts-detail="contactsDeail" /> | 
|---|
|  |  |  | <!-- 新建/编辑跟进记录 --> | 
|---|
|  |  |  | <AddFollowupRecordsDialog v-if="editFollowupConfig.visible" :edit-contacts-config="editFollowupConfig" /> | 
|---|
|  |  |  | <!-- 分配 --> | 
|---|
|  |  |  | <AllocationDialog v-if="allocationConfig.visible" :edit-common-config="allocationConfig" /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script> | 
|---|
|  |  |  | import AddClientManageDialog from "@/views/client/client/AddClientManageDialog.vue" | 
|---|
|  |  |  | import { getClientList } from "@/api/client/client" | 
|---|
|  |  |  | import { dateFormat } from "@/common/config/index" | 
|---|
|  |  |  | import AddClientManageDialog from "@/views/client/client/AddClientManageDialog" | 
|---|
|  |  |  | import { getClientList, getDeleteClient } from "@/api/client/client" | 
|---|
|  |  |  | import pageMixin from "@/components/makepager/pager/mixin/pageMixin" | 
|---|
|  |  |  | import AddFollowupRecordsDialog from "@/views/client/followupRecords/AddFollowupRecordsDialog" | 
|---|
|  |  |  | import AllocationDialog from "@/views/client/client/AllocationDialog" | 
|---|
|  |  |  | import { getAssign } from "@/api/common/other" | 
|---|
|  |  |  |  | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | name: "CustomManage", | 
|---|
|  |  |  | props: {}, | 
|---|
|  |  |  | mixins: [pageMixin], | 
|---|
|  |  |  | components: { | 
|---|
|  |  |  | AddClientManageDialog | 
|---|
|  |  |  | AddClientManageDialog, | 
|---|
|  |  |  | DetailContacts: () => import("@/views/client/contacts/DetailContacts"), | 
|---|
|  |  |  | DetailClientManage: () => import("@/views/client/client/DetailClientManage"), | 
|---|
|  |  |  | AddFollowupRecordsDialog, | 
|---|
|  |  |  | AllocationDialog | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | computed: { | 
|---|
|  |  |  | searchCommonHeight() { | 
|---|
|  |  |  | return this.$refs.searchCommonView.offsetHeight | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | computed: {}, | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | tableList: {}, | 
|---|
|  |  |  | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: "新建", | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | contactsDeail: { | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | clientDeail: { | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | search_map: {}, | 
|---|
|  |  |  | selValueList: [], | 
|---|
|  |  |  | editFollowupConfig: { | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | title: "新建", | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | allocationConfig: { | 
|---|
|  |  |  | visible: false, | 
|---|
|  |  |  | infomation: {} | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | not_admin: 2, | 
|---|
|  |  |  | tableColumn:[ | 
|---|
|  |  |  | { label: "客户名称", prop: "name", min: 100, isClientClick: true, default:true}, // 客户名称 | 
|---|
|  |  |  | { label: "销售负责人", prop: "member_name" }, // 销售负责人 | 
|---|
|  |  |  | { label: "重要级别", prop: "client_level" }, // 重要级别 | 
|---|
|  |  |  | { label: "下次回访日期", prop: "next_visit_time", min: 90 }, // 下次回访日期 | 
|---|
|  |  |  | { label: "详细地址", prop: "detail_address", min: 200 }, // 详细地址 | 
|---|
|  |  |  | { label: "客户状态", prop: "client_status" }, // 客户状态 | 
|---|
|  |  |  | { label: "联系人姓名", prop: "contact_name", isContactClick: true }, // 联系人姓名 | 
|---|
|  |  |  | { label: "联系人手机号码", prop: "contact_phone" } // 手机号码 | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | showCol:['客户名称','销售负责人','重要级别','下次回访日期','详细地址','客户状态','联系人姓名','联系人手机号码'] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | this.setTable() | 
|---|
|  |  |  | this.search_map = { | 
|---|
|  |  |  | not_admin: this.not_admin | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | setTable() { | 
|---|
|  |  |  | this.tableList = { | 
|---|
|  |  |  | selectIndex: true, | 
|---|
|  |  |  | tableInfomation: [], | 
|---|
|  |  |  | tableColumn: [ | 
|---|
|  |  |  | { label: "客户名称", prop: "name", min: 100 }, // 客户名称 | 
|---|
|  |  |  | { label: "销售负责人", prop: "member_id" }, // 销售负责人 | 
|---|
|  |  |  | { label: "重要级别", prop: "client_level_id" }, // 重要级别 | 
|---|
|  |  |  | { label: "下次回访日期", prop: "next_visit_time", min: 90 }, // 下次回访日期 | 
|---|
|  |  |  | { label: "详细地址", prop: "detail_address", min: 200 }, // 详细地址 | 
|---|
|  |  |  | { label: "客户状态", prop: "client_status_id" }, // 客户状态 | 
|---|
|  |  |  | { label: "联系人姓名", prop: "contact_name" }, // 联系人姓名 | 
|---|
|  |  |  | { label: "手机号码", prop: "contact_phone" } // 手机号码 | 
|---|
|  |  |  | ] | 
|---|
|  |  |  | 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 | 
|---|
|  |  |  | this.searchOptions.push({ value: (i + 1).toString(), label: 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); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 请求数据 | 
|---|
|  |  |  | 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) { | 
|---|
|  |  |  | 
|---|
|  |  |  | const list = res.data.list.map((item) => { | 
|---|
|  |  |  | let contact_name = "" | 
|---|
|  |  |  | let contact_phone = "" | 
|---|
|  |  |  | let contact_id = 0 | 
|---|
|  |  |  | let contact_wechat = "" | 
|---|
|  |  |  | let contact_email = "" | 
|---|
|  |  |  | let position = "" | 
|---|
|  |  |  | if (item.contacts.length !== 0) { | 
|---|
|  |  |  | for (let i = 0; i < item.contacts.length; i++) { | 
|---|
|  |  |  | if (item.contacts[i].is_first) { | 
|---|
|  |  |  | contact_name = item.contacts[i].name | 
|---|
|  |  |  | contact_phone = item.contacts[i].phone | 
|---|
|  |  |  | contact_id = item.contacts[i].id | 
|---|
|  |  |  | contact_wechat = item.contacts[i].wechat | 
|---|
|  |  |  | contact_email = item.contacts[i].email | 
|---|
|  |  |  | position = item.contacts[i].position | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...item, | 
|---|
|  |  |  | next_visit_time: dateFormat("YYYY-mm-dd HH:MM:ss", item.next_visit_time), | 
|---|
|  |  |  | contact_name: contact_name, | 
|---|
|  |  |  | contact_phone: contact_phone | 
|---|
|  |  |  | contact_phone: contact_phone, | 
|---|
|  |  |  | client_level: item.client_level.name, | 
|---|
|  |  |  | client_status: item.client_status.name, | 
|---|
|  |  |  | contact_id: contact_id, | 
|---|
|  |  |  | member_name: item.member.username, | 
|---|
|  |  |  | contact_wechat: contact_wechat, | 
|---|
|  |  |  | contact_email: contact_email, | 
|---|
|  |  |  | position: position | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.tableList.tableInfomation = list || [] | 
|---|
|  |  |  | this.pagerOptions.totalCount = res.data.count | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableList.tableInfomation = [] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | this.loading = false | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | tabsClick(tab, event) { | 
|---|
|  |  |  | console.log(tab, event) | 
|---|
|  |  |  | tabsClick(tab) { | 
|---|
|  |  |  | console.log(tab.name) | 
|---|
|  |  |  | if (tab.name === "first") { | 
|---|
|  |  |  | this.not_admin = 2 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.not_admin = 1 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.search_map = { | 
|---|
|  |  |  | not_admin: this.not_admin | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.pagerOptions.currPage = 1 | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 搜索 | 
|---|
|  |  |  | onFilterSearch(searchText){ | 
|---|
|  |  |  | this.search_map = { | 
|---|
|  |  |  | not_admin: this.not_admin, | 
|---|
|  |  |  | name: searchText | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.pagerOptions.currPage = 1 | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 新建 | 
|---|
|  |  |  | addBtnClick() { | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "新建" | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | name: "", | 
|---|
|  |  |  | number: "", | 
|---|
|  |  |  | client_status_id: "", | 
|---|
|  |  |  | member_id: "", | 
|---|
|  |  |  | client_type_id: "", | 
|---|
|  |  |  | clientSource: "", | 
|---|
|  |  |  | client_level_id: "", | 
|---|
|  |  |  | service_member_id: "", | 
|---|
|  |  |  | next_visit_time: "", | 
|---|
|  |  |  | latest_service_time: "", | 
|---|
|  |  |  | contact_name: "", | 
|---|
|  |  |  | contact_phone: "", | 
|---|
|  |  |  | contact_duties: "", | 
|---|
|  |  |  | contact_wechat: "", | 
|---|
|  |  |  | contact_email: "", | 
|---|
|  |  |  | industry_id: "", | 
|---|
|  |  |  | representative: "", | 
|---|
|  |  |  | registration_time: "", | 
|---|
|  |  |  | registered_capital_id: "", | 
|---|
|  |  |  | enterprise_nature_id: "", | 
|---|
|  |  |  | enterprise_scale_id: "", | 
|---|
|  |  |  | business_scope: "", | 
|---|
|  |  |  | country: "", | 
|---|
|  |  |  | province: "", | 
|---|
|  |  |  | city: "", | 
|---|
|  |  |  | region: "", | 
|---|
|  |  |  | detail_address: "", | 
|---|
|  |  |  | remark: "" | 
|---|
|  |  |  | city_id: 0, | 
|---|
|  |  |  | client_type_id: 1, | 
|---|
|  |  |  | client_origin_id: 1, | 
|---|
|  |  |  | client_level_id: 1, | 
|---|
|  |  |  | registered_capital_id: 1, | 
|---|
|  |  |  | enterprise_nature_id: 1, | 
|---|
|  |  |  | enterprise_scale_id: 1, | 
|---|
|  |  |  | industry_id: 1, | 
|---|
|  |  |  | province_id:'' | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 编辑 | 
|---|
|  |  |  | handleClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | this.editConfig.title = "编辑" | 
|---|
|  |  |  | let contactObj = {} | 
|---|
|  |  |  | if (row.contacts.length > 0) { | 
|---|
|  |  |  | row.contacts.forEach((ele) => { | 
|---|
|  |  |  | if (ele.is_first) { | 
|---|
|  |  |  | contactObj = { ...ele } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | console.log(contactObj) | 
|---|
|  |  |  | this.editConfig.infomation = { | 
|---|
|  |  |  | id: row.id, | 
|---|
|  |  |  | name: row.name, | 
|---|
|  |  |  | number: row.number, | 
|---|
|  |  |  | client_status_id: row.client_status_id, | 
|---|
|  |  |  | member_id: row.member_id, | 
|---|
|  |  |  | client_type_id: row.client_type_id, | 
|---|
|  |  |  | clientSource: row.clientSource, | 
|---|
|  |  |  | client_level_id: row.client_level_id, | 
|---|
|  |  |  | service_member_id: row.service_member_id, | 
|---|
|  |  |  | next_visit_time: row.next_visit_time, | 
|---|
|  |  |  | latest_service_time: row.latest_service_time, | 
|---|
|  |  |  | contact_name: row.contact_name, | 
|---|
|  |  |  | contact_phone: row.contact_phone, | 
|---|
|  |  |  | contact_duties: "", | 
|---|
|  |  |  | contact_wechat: contactObj.length > 0 ? contactObj.wechat : "", | 
|---|
|  |  |  | contact_email: contactObj.length > 0 ? contactObj.email : "", | 
|---|
|  |  |  | industry_id: row.industry_id, | 
|---|
|  |  |  | representative: row.representative, | 
|---|
|  |  |  | registration_time: row.registration_time, | 
|---|
|  |  |  | registered_capital_id: row.registered_capital_id, | 
|---|
|  |  |  | enterprise_nature_id: row.enterprise_nature_id, | 
|---|
|  |  |  | enterprise_scale_id: row.enterprise_scale_id, | 
|---|
|  |  |  | business_scope: row.business_scope, | 
|---|
|  |  |  | country: row.country, | 
|---|
|  |  |  | province: row.province, | 
|---|
|  |  |  | city: row.city, | 
|---|
|  |  |  | region: row.region, | 
|---|
|  |  |  | detail_address: row.detail_address, | 
|---|
|  |  |  | remark: row.remark | 
|---|
|  |  |  | ...row | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.editConfig.visible = true | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 删除 | 
|---|
|  |  |  | delClick(id) { | 
|---|
|  |  |  | if(!id){ | 
|---|
|  |  |  | if (this.selValueList && this.selValueList.length == 0) { | 
|---|
|  |  |  | this.$message.warning("请至少选择一条记录") | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.$confirm("是否确认删除?", "警告", { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | type: "warning" | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | let params={ids: this.selValueList } | 
|---|
|  |  |  | if(id){ | 
|---|
|  |  |  | params={ids: [id]} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | getDeleteClient(params).then((response) => { | 
|---|
|  |  |  | if (response.code === 200) { | 
|---|
|  |  |  | this.$message.success("删除成功") | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.warning("删除失败") | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}) | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getSelectArray(val) { | 
|---|
|  |  |  | console.log(val) | 
|---|
|  |  |  | this.selValueList = [] | 
|---|
|  |  |  | const list = val.map((item) => { | 
|---|
|  |  |  | return item.id | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | this.selValueList = list | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 客户名称详情 | 
|---|
|  |  |  | selClientClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.clientDeail.visible = true | 
|---|
|  |  |  | this.clientDeail.infomation = { ...row, client_name: row.name } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 联系人详情 | 
|---|
|  |  |  | selContactsClick(row) { | 
|---|
|  |  |  | this.contactsDeail.visible = true | 
|---|
|  |  |  | let contact = {} | 
|---|
|  |  |  | if (row.contacts.length !== 0) { | 
|---|
|  |  |  | for (let i = 0; i < row.contacts.length; i++) { | 
|---|
|  |  |  | if (row.contacts[i].is_first) { | 
|---|
|  |  |  | contact = row.contacts[i] | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.contactsDeail.infomation = { | 
|---|
|  |  |  | ...contact, | 
|---|
|  |  |  | Client: { name: row.name, client_status_id: row.client_status_id }, | 
|---|
|  |  |  | client_name: row.name | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 跟进 | 
|---|
|  |  |  | followupClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.editFollowupConfig.title = "新建" | 
|---|
|  |  |  | this.editFollowupConfig.infomation = { | 
|---|
|  |  |  | ...row, | 
|---|
|  |  |  | client_name: row.name, | 
|---|
|  |  |  | number: "", | 
|---|
|  |  |  | codeStandID:'', | 
|---|
|  |  |  | next_follow_time: row.next_visit_time | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.editFollowupConfig.visible = true | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 分配 | 
|---|
|  |  |  | allocationBtnClick(row) { | 
|---|
|  |  |  | console.log(row) | 
|---|
|  |  |  | this.allocationConfig.visible = true | 
|---|
|  |  |  | this.allocationConfig.infomation = { member_id: row.member_id, id: row.id } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 变更公海 | 
|---|
|  |  |  | async changeHighSeasClick(row) { | 
|---|
|  |  |  | await getAssign({ | 
|---|
|  |  |  | ids: [row.id], | 
|---|
|  |  |  | member_id: 1, | 
|---|
|  |  |  | type: "client" | 
|---|
|  |  |  | }).then((res) => { | 
|---|
|  |  |  | this.editConfig.visible = false | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | this.$message.success("变更成功") | 
|---|
|  |  |  | this.getData() | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- Add "scoped" attribute to limit CSS to this component only --> | 
|---|
|  |  |  | <style lang="scss" scoped> | 
|---|
|  |  |  | .custom-manage { | 
|---|
|  |  |  | .tab-view { | 
|---|
|  |  |  | position: relative; | 
|---|
|  |  |  | .sel-gonghai { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | position: absolute; | 
|---|
|  |  |  | top: 5px; | 
|---|
|  |  |  | left: 660px; | 
|---|
|  |  |  | height: 35px; | 
|---|
|  |  |  | line-height: 35px; | 
|---|
|  |  |  | .query-class-sel { | 
|---|
|  |  |  | width: 165px; | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .query-class-btn { | 
|---|
|  |  |  | font-size: 16px; | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | color: #bebebe; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .btn-pager { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | .page { | 
|---|
|  |  |  | margin-left: auto; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ::v-deep { | 
|---|
|  |  |  | .el-tabs--top .el-tabs__item.is-top:nth-child(2) { | 
|---|
|  |  |  | padding-left: 25px; | 
|---|
|  |  |  | 
|---|
|  |  |  | height: 45px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .custom-manage{ | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  | overflow: hidden; | 
|---|
|  |  |  | .filter{ | 
|---|
|  |  |  | height: 80px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | padding: 0 20px 0 20px; | 
|---|
|  |  |  | &-card{ | 
|---|
|  |  |  | height: 80px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | box-sizing: border-box; | 
|---|
|  |  |  | padding: 10px 20px; | 
|---|
|  |  |  | flex: 1; | 
|---|
|  |  |  | border-radius: 12px; | 
|---|
|  |  |  | background-color: #fff; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .body{ | 
|---|
|  |  |  | box-sizing: border-box; | 
|---|
|  |  |  | padding: 10px 20px; | 
|---|
|  |  |  | border-radius: 12px; | 
|---|
|  |  |  | height: calc(100% - 139px); | 
|---|
|  |  |  | .body-card { | 
|---|
|  |  |  | background-color: #fff; | 
|---|
|  |  |  | border-radius: 12px; | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  | overflow: hidden; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .list-view { | 
|---|
|  |  |  | height: calc(100% - 60px); | 
|---|
|  |  |  | overflow: hidden; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .btn-pager { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | margin-top: 10px; | 
|---|
|  |  |  | .page { | 
|---|
|  |  |  | margin-left: auto; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </style> | 
|---|