BusinessList.vue 5.45 KB
<template>
  <!-- 操作栏 -->
  <el-row justify="end">
    <el-button @click="openForm">
      <Icon class="mr-5px" icon="ep:opportunity" />
      创建商机
    </el-button>
    <el-button
      @click="openBusinessModal"
      v-hasPermi="['crm:contact:create-business']"
      v-if="queryParams.contactId"
    >
      <Icon class="mr-5px" icon="ep:circle-plus" />关联
    </el-button>
    <el-button
      @click="deleteContactBusinessList"
      v-hasPermi="['crm:contact:delete-business']"
      v-if="queryParams.contactId"
    >
      <Icon class="mr-5px" icon="ep:remove" />解除关联
    </el-button>
  </el-row>

  <!-- 列表 -->
  <ContentWrap class="mt-10px">
    <el-table
      ref="businessRef"
      v-loading="loading"
      :data="list"
      :stripe="true"
      :show-overflow-tooltip="true"
    >
      <el-table-column type="selection" width="55" v-if="queryParams.contactId" />
      <el-table-column label="商机名称" fixed="left" align="center" prop="name">
        <template #default="scope">
          <el-link type="primary" :underline="false" @click="openDetail(scope.row.id)">
            {{ scope.row.name }}
          </el-link>
        </template>
      </el-table-column>
      <el-table-column
        label="商机金额"
        align="center"
        prop="price"
        :formatter="erpPriceTableColumnFormatter"
      />
      <el-table-column label="客户名称" align="center" prop="customerName" />
      <el-table-column label="商机组" align="center" prop="statusTypeName" />
      <el-table-column label="商机阶段" align="center" prop="statusName" />
    </el-table>
    <!-- 分页 -->
    <Pagination
      :total="total"
      v-model:page="queryParams.pageNo"
      v-model:limit="queryParams.pageSize"
      @pagination="getList"
    />
  </ContentWrap>

  <!-- 表单弹窗:添加 -->
  <BusinessForm ref="formRef" @success="getList" />
  <!-- 关联商机选择弹框 -->
  <BusinessListModal
    ref="businessModalRef"
    :customer-id="props.customerId"
    @success="createContactBusinessList"
  />
</template>
<script setup lang="ts">
import * as BusinessApi from '@/api/crm/business'
import * as ContactApi from '@/api/crm/contact'
import BusinessForm from './../BusinessForm.vue'
import { BizTypeEnum } from '@/api/crm/permission'
import BusinessListModal from './BusinessListModal.vue'
import { erpPriceTableColumnFormatter } from '@/utils'

const message = useMessage() // 消息

defineOptions({ name: 'CrmBusinessList' })
const props = defineProps<{
  bizType: number // 业务类型
  bizId: number // 业务编号
  customerId?: number // 关联联系人与商机时,需要传入 customerId 进行筛选
  contactId?: number // 特殊:联系人编号;在【联系人】详情中,可以传递联系人编号,默认新建的商机关联到该联系人
}>()

const loading = ref(true) // 列表的加载中
const total = ref(0) // 列表的总页数
const list = ref([]) // 列表的数据
const queryParams = reactive({
  pageNo: 1,
  pageSize: 10,
  customerId: undefined as unknown, // 允许 undefined + number
  contactId: undefined as unknown // 允许 undefined + number
})

/** 查询列表 */
const getList = async () => {
  loading.value = true
  try {
    // 置空参数
    queryParams.customerId = undefined
    queryParams.contactId = undefined
    // 执行查询
    let data = { list: [], total: 0 }
    switch (props.bizType) {
      case BizTypeEnum.CRM_CUSTOMER:
        queryParams.customerId = props.bizId
        data = await BusinessApi.getBusinessPageByCustomer(queryParams)
        break
      case BizTypeEnum.CRM_CONTACT:
        queryParams.contactId = props.bizId
        data = await BusinessApi.getBusinessPageByContact(queryParams)
        break
      default:
        return
    }
    list.value = data.list
    total.value = data.total
  } finally {
    loading.value = false
  }
}

/** 搜索按钮操作 */
const handleQuery = () => {
  queryParams.pageNo = 1
  getList()
}

/** 添加操作 */
const formRef = ref()
const openForm = () => {
  formRef.value.open('create', null, props.customerId, props.contactId)
}

/** 打开联系人详情 */
const { push } = useRouter()
const openDetail = (id: number) => {
  push({ name: 'CrmBusinessDetail', params: { id } })
}

/** 打开联系人与商机的关联弹窗 */
const businessModalRef = ref()
const openBusinessModal = () => {
  businessModalRef.value.open()
}
const createContactBusinessList = async (businessIds: number[]) => {
  const data = {
    contactId: props.bizId,
    businessIds: businessIds
  } as ContactApi.ContactBusinessReqVO
  businessRef.value.getSelectionRows().forEach((row: BusinessApi.BusinessVO) => {
    data.businessIds.push(row.id)
  })
  await ContactApi.createContactBusinessList(data)
  // 刷新列表
  message.success('关联商机成功')
  handleQuery()
}

/** 解除联系人与商机的关联 */
const businessRef = ref()
const deleteContactBusinessList = async () => {
  const data = {
    contactId: props.bizId,
    businessIds: businessRef.value.getSelectionRows().map((row: BusinessApi.BusinessVO) => row.id)
  } as ContactApi.ContactBusinessReqVO
  if (data.businessIds.length === 0) {
    return message.error('未选择商机')
  }
  await ContactApi.deleteContactBusinessList(data)
  // 刷新列表
  message.success('取关商机成功')
  handleQuery()
}

/** 监听打开的 bizId + bizType,从而加载最新的列表 */
watch(
  () => [props.bizId, props.bizType],
  () => {
    handleQuery()
  },
  { immediate: true, deep: true }
)
</script>