Skip to content

Commit 7c0c651

Browse files
committed
feat: backlog 分配给我的线索、客户
1 parent 24e8bd4 commit 7c0c651

File tree

2 files changed

+274
-15
lines changed

2 files changed

+274
-15
lines changed
Lines changed: 154 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,162 @@
11
<!-- 分配给我的客户 -->
2-
<!-- TODO: 后续再统一改名字 -->
32
<template>
4-
<div>
5-
TODO: 分配给我的客户
6-
</div>
3+
<ContentWrap>
4+
<div class="pb-5 text-xl">分配给我的客户</div>
5+
<!-- 搜索工作栏 -->
6+
<el-form
7+
ref="queryFormRef"
8+
:inline="true"
9+
:model="queryParams"
10+
class="-mb-15px"
11+
label-width="68px"
12+
>
13+
<el-form-item label="状态" prop="followUpStatus">
14+
<el-select
15+
v-model="queryParams.followUpStatus"
16+
class="!w-240px"
17+
placeholder="状态"
18+
@change="handleQuery"
19+
>
20+
<el-option
21+
v-for="(option, index) in FOLLOWUP_STATUS"
22+
:label="option.label"
23+
:value="option.value"
24+
:key="index"
25+
/>
26+
</el-select>
27+
</el-form-item>
28+
</el-form>
29+
</ContentWrap>
30+
<!-- 列表 -->
31+
<ContentWrap>
32+
<el-table v-loading="loading" :data="list" :show-overflow-tooltip="true" :stripe="true">
33+
<el-table-column align="center" label="编号" prop="id" />
34+
<el-table-column align="center" label="客户名称" prop="name" width="160">
35+
<template #default="scope">
36+
<el-link :underline="false" type="primary" @click="openDetail(scope.row.id)">
37+
{{ scope.row.name }}
38+
</el-link>
39+
</template>
40+
</el-table-column>
41+
<el-table-column align="center" label="手机" prop="mobile" width="120" />
42+
<el-table-column align="center" label="电话" prop="telephone" width="120" />
43+
<el-table-column align="center" label="客户来源" prop="source" width="100">
44+
<template #default="scope">
45+
<dict-tag :type="DICT_TYPE.CRM_CUSTOMER_SOURCE" :value="scope.row.source" />
46+
</template>
47+
</el-table-column>
48+
<el-table-column align="center" label="所属行业" prop="industryId" width="120">
49+
<template #default="scope">
50+
<dict-tag :type="DICT_TYPE.CRM_CUSTOMER_INDUSTRY" :value="scope.row.industryId" />
51+
</template>
52+
</el-table-column>
53+
<el-table-column align="center" label="客户等级" prop="level" width="120">
54+
<template #default="scope">
55+
<dict-tag :type="DICT_TYPE.CRM_CUSTOMER_LEVEL" :value="scope.row.level" />
56+
</template>
57+
</el-table-column>
58+
<el-table-column align="center" label="网址" prop="website" width="200" />
59+
<el-table-column
60+
:formatter="dateFormatter"
61+
align="center"
62+
label="下次联系时间"
63+
prop="contactNextTime"
64+
width="180px"
65+
/>
66+
<el-table-column align="center" label="备注" prop="remark" width="200" />
67+
<el-table-column align="center" label="成交状态" prop="dealStatus">
68+
<template #default="scope">
69+
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="scope.row.dealStatus" />
70+
</template>
71+
</el-table-column>
72+
<el-table-column align="center" label="距离进入公海" prop="poolDay">
73+
<template #default="scope"> {{ scope.row.poolDay }} 天</template>
74+
</el-table-column>
75+
<el-table-column
76+
:formatter="dateFormatter"
77+
align="center"
78+
label="最后跟进时间"
79+
prop="contactLastTime"
80+
width="180px"
81+
/>
82+
<el-table-column
83+
:formatter="dateFormatter"
84+
align="center"
85+
label="创建时间"
86+
prop="updateTime"
87+
width="180px"
88+
/>
89+
<el-table-column
90+
:formatter="dateFormatter"
91+
align="center"
92+
label="创建时间"
93+
prop="createTime"
94+
width="180px"
95+
/>
96+
<el-table-column align="center" label="负责人" prop="ownerUserName" width="100px" />
97+
<el-table-column align="center" label="所属部门" prop="ownerUserDeptName" width="100px" />
98+
<el-table-column align="center" label="创建人" prop="creatorName" width="100px" />
99+
</el-table>
100+
<!-- 分页 -->
101+
<Pagination
102+
v-model:limit="queryParams.pageSize"
103+
v-model:page="queryParams.pageNo"
104+
:total="total"
105+
@pagination="getList"
106+
/>
107+
</ContentWrap>
7108
</template>
8109

9110
<script setup lang="ts" name="FollowCustomer">
111+
import { DICT_TYPE } from '@/utils/dict'
112+
import { dateFormatter } from '@/utils/formatTime'
113+
import * as CustomerApi from '@/api/crm/customer'
10114
11-
</script>
115+
const { push } = useRouter()
116+
117+
const FOLLOWUP_STATUS = [
118+
{ label: '已跟进', value: true },
119+
{ label: '待跟进', value: false }
120+
]
121+
122+
const loading = ref(true) // 列表的加载中
123+
const total = ref(0) // 列表的总页数
124+
const list = ref([]) // 列表的数据
125+
const queryParams = ref({
126+
pageNo: 1,
127+
pageSize: 10,
128+
followUpStatus: false,
129+
sceneType: 1
130+
})
131+
const queryFormRef = ref() // 搜索的表单
132+
133+
/** 查询列表 */
134+
const getList = async () => {
135+
loading.value = true
136+
try {
137+
const data = await CustomerApi.getCustomerPage(queryParams.value)
138+
list.value = data.list
139+
total.value = data.total
140+
} finally {
141+
loading.value = false
142+
}
143+
}
12144
13-
<style scoped>
145+
/** 搜索按钮操作 */
146+
const handleQuery = () => {
147+
queryParams.value.pageNo = 1
148+
getList()
149+
}
150+
151+
/** 打开客户详情 */
152+
const openDetail = (id: number) => {
153+
push({ name: 'CrmCustomerDetail', params: { id } })
154+
}
155+
156+
/** 初始化 **/
157+
onMounted(() => {
158+
getList()
159+
})
160+
</script>
14161

15-
</style>
162+
<style scoped></style>
Lines changed: 120 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,127 @@
1-
<!-- 分配给我的线索 -->
2-
<!-- TODO: 后续再统一改名字 -->
1+
<!-- TODO: dhb52 待Clue页面更新后同步更新 -->
32
<template>
4-
<div>
5-
TODO: 分配给我的线索
6-
</div>
3+
<ContentWrap>
4+
<div class="pb-5 text-xl">分配给我的线索</div>
5+
<!-- 搜索工作栏 -->
6+
<el-form
7+
ref="queryFormRef"
8+
:inline="true"
9+
:model="queryParams"
10+
class="-mb-15px"
11+
label-width="68px"
12+
>
13+
<el-form-item label="状态" prop="followUpStatus">
14+
<el-select
15+
v-model="queryParams.followUpStatus"
16+
class="!w-240px"
17+
placeholder="状态"
18+
@change="handleQuery"
19+
>
20+
<el-option
21+
v-for="(option, index) in FOLLOWUP_STATUS"
22+
:label="option.label"
23+
:value="option.value"
24+
:key="index"
25+
/>
26+
</el-select>
27+
</el-form-item>
28+
</el-form>
29+
</ContentWrap>
30+
<!-- 列表 -->
31+
<ContentWrap>
32+
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
33+
<el-table-column label="编号" align="center" prop="id" />
34+
<el-table-column label="转化状态" align="center" prop="transformStatus">
35+
<template #default="scope">
36+
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="scope.row.transformStatus" />
37+
</template>
38+
</el-table-column>
39+
<el-table-column label="跟进状态" align="center" prop="followUpStatus">
40+
<template #default="scope">
41+
<dict-tag :type="DICT_TYPE.INFRA_BOOLEAN_STRING" :value="scope.row.followUpStatus" />
42+
</template>
43+
</el-table-column>
44+
<el-table-column label="线索名称" align="center" prop="name" />
45+
<el-table-column label="客户id" align="center" prop="customerId" />
46+
<el-table-column
47+
label="下次联系时间"
48+
align="center"
49+
prop="contactNextTime"
50+
:formatter="dateFormatter"
51+
width="180px"
52+
/>
53+
<el-table-column label="电话" align="center" prop="telephone" />
54+
<el-table-column label="手机号" align="center" prop="mobile" />
55+
<el-table-column label="地址" align="center" prop="address" />
56+
<el-table-column label="负责人" align="center" prop="ownerUserId" />
57+
<el-table-column
58+
label="最后跟进时间"
59+
align="center"
60+
prop="contactLastTime"
61+
:formatter="dateFormatter"
62+
width="180px"
63+
/>
64+
<el-table-column label="备注" align="center" prop="remark" />
65+
<el-table-column
66+
label="创建时间"
67+
align="center"
68+
prop="createTime"
69+
:formatter="dateFormatter"
70+
width="180px"
71+
/>
72+
</el-table>
73+
<!-- 分页 -->
74+
<Pagination
75+
:total="total"
76+
v-model:page="queryParams.pageNo"
77+
v-model:limit="queryParams.pageSize"
78+
@pagination="getList"
79+
/>
80+
</ContentWrap>
781
</template>
882

983
<script setup lang="ts" name="FollowLeads">
84+
import { DICT_TYPE } from '@/utils/dict'
85+
import { dateFormatter } from '@/utils/formatTime'
86+
import * as ClueApi from '@/api/crm/clue'
1087
11-
</script>
88+
const FOLLOWUP_STATUS = [
89+
{ label: '已跟进', value: true },
90+
{ label: '待跟进', value: false }
91+
]
92+
93+
const loading = ref(true) // 列表的加载中
94+
const total = ref(0) // 列表的总页数
95+
const list = ref([]) // 列表的数据
96+
const queryParams = reactive({
97+
pageNo: 1,
98+
pageSize: 10,
99+
followUpStatus: false
100+
})
101+
const queryFormRef = ref() // 搜索的表单
102+
103+
/** 查询列表 */
104+
const getList = async () => {
105+
loading.value = true
106+
try {
107+
const data = await ClueApi.getCluePage(queryParams)
108+
list.value = data.list
109+
total.value = data.total
110+
} finally {
111+
loading.value = false
112+
}
113+
}
12114
13-
<style scoped>
115+
/** 搜索按钮操作 */
116+
const handleQuery = () => {
117+
queryParams.pageNo = 1
118+
getList()
119+
}
120+
121+
/** 初始化 **/
122+
onMounted(() => {
123+
getList()
124+
})
125+
</script>
14126

15-
</style>
127+
<style scoped></style>

0 commit comments

Comments
 (0)