| | |
| | | :custom-funnel="true" |
| | | :operates-list="operatesList" |
| | | /> |
| | | <PagerView class="page" /> |
| | | <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" /> |
| | | </div> |
| | | <TableCommonView ref="tableListRef" :table-list="tableList"> |
| | | <template slot="tableButton"> |
| | | <el-table-column label="操作" width="100"> |
| | | <el-table-column label="操作" width="120"> |
| | | <template slot-scope="scope"> |
| | | <el-button @click="handleClick(scope.row)" type="text" size="small">编辑</el-button> |
| | | <el-button type="text" size="small">跟进</el-button> |
| | | <el-button @click="delClick(scope.row.id)" type="text" size="small">删除</el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </template> |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import SearchCommonView from "@/components/makepager/SearchCommonView" |
| | | import PublicFunctionBtnView from "@/components/makepager/PublicFunctionBtnView" |
| | | import PagerView from "@/components/makepager/PagerView" |
| | | import TableCommonView from "@/components/makepager/TableCommonView" |
| | | import AddSalesOpportunityDialog from "@/views/sales/salesOpportunity/AddSalesOpportunityDialog" |
| | | import { getSaleChanceList, getDelSaleChance } from "@/api/sales/salesOpportunity" |
| | | import pageMixin from "@/components/makepager/pager/mixin/pageMixin" |
| | | |
| | | export default { |
| | | name: "SalesOpportunity", |
| | | props: {}, |
| | | mixins: [pageMixin], |
| | | components: { |
| | | SearchCommonView, |
| | | PublicFunctionBtnView, |
| | | PagerView, |
| | | TableCommonView, |
| | | AddSalesOpportunityDialog |
| | | }, |
| | | computed: { |
| | |
| | | }, |
| | | created() { |
| | | this.setTable() |
| | | this.getData() |
| | | }, |
| | | methods: { |
| | | setTable() { |
| | | this.tableList = { |
| | | tableInfomation: [ |
| | | { |
| | | opportunityName: "123123", |
| | | customName: "上海铃铛", |
| | | salesOpportunityNo: "POT205", |
| | | contactName: "刘总", |
| | | saleStage: "初期沟通", |
| | | possible: "A类客户", |
| | | expectDealDate: "50", |
| | | expectContractAmount: "2023-05-28", |
| | | budgetAbsoluteValue: "¥200,000.00", |
| | | salesHead: "系统管理员" |
| | | } |
| | | ], |
| | | tableInfomation: [], |
| | | tableColumn: [ |
| | | { label: "机会名称", prop: "opportunityName", min: 120 }, // 机会名称 |
| | | { label: "客户名称", prop: "customName", min: 90 }, // 客户名称 |
| | | { label: "销售机会编号", prop: "salesOpportunityNo" }, // 销售机会编号 |
| | | { label: "联系人姓名", prop: "contactName", min: 100 }, // 联系人姓名 |
| | | { label: "销售阶段", prop: "saleStage" }, // 销售阶段 |
| | | { label: "可能性(%)", prop: "possible" }, // 可能性 |
| | | { label: "预计成交日期", prop: "expectDealDate" }, // 预计成交日期 |
| | | { label: "预计合同金额", prop: "expectContractAmount" }, // 预计合同金额 |
| | | { label: "预算绝对值", prop: "budgetAbsoluteValue" }, // 预算绝对值 |
| | | { label: "销售负责人", prop: "salesHead" } // 销售负责人 |
| | | { label: "机会名称", prop: "name", min: 120 }, // 机会名称 |
| | | { label: "客户名称", prop: "client_name", min: 90 }, // 客户名称 |
| | | { label: "销售机会编号", prop: "number" }, // 销售机会编号 |
| | | { label: "联系人姓名", prop: "contact_name", min: 100 }, // 联系人姓名 |
| | | { label: "销售阶段", prop: "sale_stage_id" }, // 销售阶段 |
| | | { label: "可能性(%)", prop: "possibilities_id" }, // 可能性 |
| | | { label: "预计成交日期", prop: "expected_time", isTime: true, min: 130 }, // 预计成交日期 |
| | | { label: "预计合同金额", prop: "projected_amount" }, // 预计合同金额 |
| | | { label: "预算绝对值", prop: "capital_budget" }, // 预算绝对值 |
| | | { label: "销售负责人", prop: "member_id" } // 销售负责人 |
| | | ] |
| | | } |
| | | this.searchOptions = [] |
| | |
| | | this.searchOptions.push({ value: (i + 1).toString(), label: label }) |
| | | } |
| | | }, |
| | | // 请求数据 |
| | | async getData() { |
| | | this.loading = true |
| | | await getSaleChanceList({ |
| | | keyword: "", |
| | | 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) { |
| | | const list = res.data.list.map((item) => { |
| | | return { |
| | | ...item, |
| | | client_name: item.client.name, |
| | | contact_name: item.contact.name |
| | | } |
| | | }) |
| | | this.tableList.tableInfomation = list || [] |
| | | this.pagerOptions.totalCount = res.data.count |
| | | } else { |
| | | this.tableList.tableInfomation = [] |
| | | } |
| | | } else { |
| | | this.tableList.tableInfomation = [] |
| | | } |
| | | this.loading = false |
| | | }) |
| | | .catch((err) => { |
| | | console.log(err) |
| | | this.tableList.tableInfomation = [] |
| | | this.loading = false |
| | | }) |
| | | }, |
| | | // 新建 |
| | | addBtnClick() { |
| | | this.editConfig.visible = true |
| | | this.editConfig.title = "新建" |
| | | this.editConfig.infomation = { |
| | | customName: "", |
| | | salesOpportunityNo: "POT521", |
| | | opportunityName: "", |
| | | contactName: "", |
| | | businessSource: "", |
| | | businessType: "", |
| | | saleStage: "", |
| | | salesHead: "", |
| | | oldCustomerMarket: "", |
| | | competitor: "", |
| | | possible: "", |
| | | currency: "", |
| | | budgetAbsoluteValue: "", |
| | | expectDealDate: "", |
| | | expectContractAmount: "", |
| | | currentState: "", |
| | | demandPainPoint: "", |
| | | projectApproval: "", |
| | | fundBudget: "", |
| | | decisionMaker: "", |
| | | decisionFactors: "", |
| | | decisionFlow: "", |
| | | programme: "", |
| | | advantage: "", |
| | | disadvantage: "", |
| | | opportunity: "", |
| | | threaten: "", |
| | | position: "", |
| | | map: "", |
| | | country: "1", |
| | | province: "1", |
| | | city: "1", |
| | | region: "1", |
| | | notes: "" |
| | | } |
| | | this.editConfig.infomation = {} |
| | | }, |
| | | // 编辑 |
| | | handleClick(row) { |
| | | console.log(row) |
| | | this.editConfig.visible = true |
| | | this.editConfig.title = "编辑" |
| | | this.editConfig.infomation = { |
| | | customName: "", |
| | | salesOpportunityNo: "POT521", |
| | | opportunityName: "", |
| | | contactName: "", |
| | | businessSource: "", |
| | | businessType: "", |
| | | saleStage: "", |
| | | salesHead: "", |
| | | oldCustomerMarket: "", |
| | | competitor: "", |
| | | possible: "", |
| | | currency: "", |
| | | budgetAbsoluteValue: "", |
| | | expectDealDate: "", |
| | | expectContractAmount: "", |
| | | currentState: "", |
| | | demandPainPoint: "", |
| | | projectApproval: "", |
| | | fundBudget: "", |
| | | decisionMaker: "", |
| | | decisionFactors: "", |
| | | decisionFlow: "", |
| | | programme: "", |
| | | advantage: "", |
| | | disadvantage: "", |
| | | opportunity: "", |
| | | threaten: "", |
| | | position: "", |
| | | map: "", |
| | | country: "1", |
| | | province: "1", |
| | | city: "1", |
| | | region: "1", |
| | | notes: "" |
| | | } |
| | | this.editConfig.infomation = { ...row } |
| | | }, |
| | | // 删除 |
| | | delClick(id) { |
| | | this.$confirm("是否确认删除?", "警告", { |
| | | confirmButtonText: "确定", |
| | | cancelButtonText: "取消", |
| | | type: "warning" |
| | | }) |
| | | .then(function () { |
| | | return getDelSaleChance({ id: id }) |
| | | }) |
| | | .then((response) => { |
| | | if (response.code === 200) { |
| | | this.$message.success("删除成功") |
| | | this.getData() |
| | | } else { |
| | | this.$message.warning("删除失败") |
| | | } |
| | | }) |
| | | .catch(function () {}) |
| | | }, |
| | | getSelectArray(val) { |
| | | console.log(val) |
| | | } |
| | | } |
| | | } |