Skip to content
Toggle navigation
P
Projects
G
Groups
S
Snippets
Help
phsl
/
admin
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Members
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Unverified
Commit
f0c45103
authored
Nov 05, 2023
by
芋道源码
Committed by
Gitee
Nov 05, 2023
Browse files
Options
Browse Files
Download
Plain Diff
!309 完善回款管理和回款计划功能
Merge pull request !309 from souvc/master
parents
4f2f4f72
8ef5227f
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
115 additions
and
94 deletions
+115
-94
src/api/crm/receivablePlan/index.ts
+1
-1
src/views/crm/receivable/ReceivableForm.vue
+28
-18
src/views/crm/receivable/index.vue
+10
-7
src/views/crm/receivablePlan/ReceivablePlanForm.vue
+27
-18
src/views/crm/receivablePlan/index.vue
+49
-50
No files found.
src/api/crm/receivablePlan/index.ts
View file @
f0c45103
...
@@ -2,7 +2,7 @@ import request from '@/config/axios'
...
@@ -2,7 +2,7 @@ import request from '@/config/axios'
export
interface
ReceivablePlanVO
{
export
interface
ReceivablePlanVO
{
id
:
number
id
:
number
indexNo
:
number
period
:
number
receivableId
:
number
receivableId
:
number
status
:
number
status
:
number
checkStatus
:
string
checkStatus
:
string
...
...
src/views/crm/receivable/ReceivableForm.vue
View file @
f0c45103
...
@@ -10,14 +10,14 @@
...
@@ -10,14 +10,14 @@
<el-form-item
label=
"回款编号"
prop=
"no"
>
<el-form-item
label=
"回款编号"
prop=
"no"
>
<el-input
v-model=
"formData.no"
placeholder=
"请输入回款编号"
/>
<el-input
v-model=
"formData.no"
placeholder=
"请输入回款编号"
/>
</el-form-item>
</el-form-item>
<
!--
<el-form-item
label=
"回款计划ID
"
prop=
"planId"
>
<
el-form-item
label=
"回款计划
"
prop=
"planId"
>
<el-input
v-model=
"formData.planId"
placeholder=
"请输入回款计划
ID
"
/>
<el-input
v-model=
"formData.planId"
placeholder=
"请输入回款计划"
/>
</el-form-item>
-->
</el-form-item>
<el-form-item
label=
"客户
ID
"
prop=
"customerId"
>
<el-form-item
label=
"客户
名称
"
prop=
"customerId"
>
<el-input
v-model=
"formData.customerId"
placeholder=
"请输入客户
ID
"
/>
<el-input
v-model=
"formData.customerId"
placeholder=
"请输入客户
名称
"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"合同
ID
"
prop=
"contractId"
>
<el-form-item
label=
"合同
名称
"
prop=
"contractId"
>
<el-input
v-model=
"formData.contractId"
placeholder=
"请输入合同
ID
"
/>
<el-input
v-model=
"formData.contractId"
placeholder=
"请输入合同
名称
"
/>
</el-form-item>
</el-form-item>
<!--
<el-form-item
label=
"审批状态"
prop=
"checkStatus"
>
<!--
<el-form-item
label=
"审批状态"
prop=
"checkStatus"
>
<el-select
v-model=
"formData.checkStatus"
placeholder=
"请选择审批状态"
>
<el-select
v-model=
"formData.checkStatus"
placeholder=
"请选择审批状态"
>
...
@@ -54,15 +54,22 @@
...
@@ -54,15 +54,22 @@
<el-input-number
v-model=
"formData.price"
placeholder=
"请输入回款金额"
/>
<el-input-number
v-model=
"formData.price"
placeholder=
"请输入回款金额"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-input
v-model=
"formData.ownerUserId"
placeholder=
"请输入负责人"
/>
<el-select
v-model=
"formData.ownerUserId"
clearable
placeholder=
"请输入负责人"
>
<el-option
v-for=
"item in userList"
:key=
"item.id"
:label=
"item.nickname"
:value=
"item.id"
/>
</el-select>
</el-form-item>
</el-form-item>
<el-form-item
label=
"批次"
prop=
"batchId"
>
<el-form-item
label=
"批次"
prop=
"batchId"
>
<el-input
v-model=
"formData.batchId"
placeholder=
"请输入批次"
/>
<el-input
-number
v-model=
"formData.batchId"
placeholder=
"请输入批次"
/>
</el-form-item>
</el-form-item>
<
!--
<el-form-item
label=
"显示顺
序"
prop=
"sort"
>
<
el-form-item
label=
"显示排
序"
prop=
"sort"
>
<el-input
v-model=
"formData.sort"
placeholder=
"请输入显示顺序
"
/>
<el-input
-number
v-model=
"formData.sort"
:min=
"0"
controls-position=
"right
"
/>
</el-form-item>
-->
</el-form-item>
<el-form-item
label=
"状态"
prop=
"status"
>
<
!--
<
el-form-item
label=
"状态"
prop=
"status"
>
<el-select
v-model=
"formData.status"
placeholder=
"请选择状态"
>
<el-select
v-model=
"formData.status"
placeholder=
"请选择状态"
>
<el-option
<el-option
v-for=
"dict in getIntDictOptions(DICT_TYPE.COMMON_STATUS)"
v-for=
"dict in getIntDictOptions(DICT_TYPE.COMMON_STATUS)"
...
@@ -71,7 +78,7 @@
...
@@ -71,7 +78,7 @@
:value=
"dict.value"
:value=
"dict.value"
/>
/>
</el-select>
</el-select>
</el-form-item>
</el-form-item>
-->
<el-form-item
label=
"备注"
prop=
"remark"
>
<el-form-item
label=
"备注"
prop=
"remark"
>
<el-input
type=
"textarea"
:rows=
"3"
v-model=
"formData.remark"
placeholder=
"请输入备注"
/>
<el-input
type=
"textarea"
:rows=
"3"
v-model=
"formData.remark"
placeholder=
"请输入备注"
/>
</el-form-item>
</el-form-item>
...
@@ -85,10 +92,11 @@
...
@@ -85,10 +92,11 @@
<
script
setup
lang=
"ts"
>
<
script
setup
lang=
"ts"
>
import
{
DICT_TYPE
,
getIntDictOptions
,
getStrDictOptions
}
from
'@/utils/dict'
import
{
DICT_TYPE
,
getIntDictOptions
,
getStrDictOptions
}
from
'@/utils/dict'
import
*
as
ReceivableApi
from
'@/api/crm/receivable'
import
*
as
ReceivableApi
from
'@/api/crm/receivable'
import
*
as
UserApi
from
'@/api/system/user'
const
{
t
}
=
useI18n
()
// 国际化
const
{
t
}
=
useI18n
()
// 国际化
const
message
=
useMessage
()
// 消息弹窗
const
message
=
useMessage
()
// 消息弹窗
const
userList
=
ref
<
UserApi
.
UserVO
[]
>
([])
// 用户列表
const
dialogVisible
=
ref
(
false
)
// 弹窗的是否展示
const
dialogVisible
=
ref
(
false
)
// 弹窗的是否展示
const
dialogTitle
=
ref
(
''
)
// 弹窗的标题
const
dialogTitle
=
ref
(
''
)
// 弹窗的标题
const
formLoading
=
ref
(
false
)
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const
formLoading
=
ref
(
false
)
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
...
@@ -112,9 +120,9 @@ const formData = ref({
...
@@ -112,9 +120,9 @@ const formData = ref({
status
:
undefined
,
status
:
undefined
,
remark
:
undefined
remark
:
undefined
})
})
const
formRules
=
reactive
({
//
const formRules = reactive({
status
:
[{
required
:
true
,
message
:
'状态不能为空'
,
trigger
:
'change'
}]
//
status: [{ required: true, message: '状态不能为空', trigger: 'change' }]
})
//
})
const
formRef
=
ref
()
// 表单 Ref
const
formRef
=
ref
()
// 表单 Ref
/** 打开弹窗 */
/** 打开弹窗 */
...
@@ -132,6 +140,8 @@ const open = async (type: string, id?: number) => {
...
@@ -132,6 +140,8 @@ const open = async (type: string, id?: number) => {
formLoading
.
value
=
false
formLoading
.
value
=
false
}
}
}
}
// 获得用户列表
userList
.
value
=
await
UserApi
.
getSimpleUserList
()
}
}
defineExpose
({
open
})
// 提供 open 方法,用于打开弹窗
defineExpose
({
open
})
// 提供 open 方法,用于打开弹窗
...
...
src/views/crm/receivable/index.vue
View file @
f0c45103
...
@@ -26,19 +26,19 @@
...
@@ -26,19 +26,19 @@
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
-->
</el-form-item>
-->
<el-form-item
label=
"客户"
prop=
"customerId"
>
<el-form-item
label=
"客户
名称
"
prop=
"customerId"
>
<el-input
<el-input
v-model=
"queryParams.customerId"
v-model=
"queryParams.customerId"
placeholder=
"请输入客户"
placeholder=
"请输入客户
名称
"
clearable
clearable
@
keyup
.
enter=
"handleQuery"
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"合同"
prop=
"contractId"
>
<el-form-item
label=
"合同
名称
"
prop=
"contractId"
>
<el-input
<el-input
v-model=
"queryParams.contractId"
v-model=
"queryParams.contractId"
placeholder=
"请输入合同"
placeholder=
"请输入合同
名称
"
clearable
clearable
@
keyup
.
enter=
"handleQuery"
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
class=
"!w-240px"
...
@@ -103,7 +103,7 @@
...
@@ -103,7 +103,7 @@
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
-->
</el-form-item>
-->
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<
!--
<
el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-input
<el-input
v-model=
"queryParams.ownerUserId"
v-model=
"queryParams.ownerUserId"
placeholder=
"请输入负责人"
placeholder=
"请输入负责人"
...
@@ -112,7 +112,7 @@
...
@@ -112,7 +112,7 @@
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
</el-form-item>
<
!--
<
el-form-item
label=
"批次"
prop=
"batchId"
>
<el-form-item
label=
"批次"
prop=
"batchId"
>
<el-input
<el-input
v-model=
"queryParams.batchId"
v-model=
"queryParams.batchId"
placeholder=
"请输入批次"
placeholder=
"请输入批次"
...
@@ -227,8 +227,11 @@
...
@@ -227,8 +227,11 @@
:formatter=
"dateFormatter"
:formatter=
"dateFormatter"
width=
"180px"
width=
"180px"
/>
/>
<el-table-column
label=
"操作"
align=
"center"
width=
"1
3
0px"
>
<el-table-column
label=
"操作"
align=
"center"
width=
"1
8
0px"
>
<
template
#
default=
"scope"
>
<
template
#
default=
"scope"
>
<!--
<router-link
:to=
"'/crm/receivable-plan?receivableId=' + scope.row.receivableId"
>
<el-button
link
type=
"primary"
>
详情
</el-button>
</router-link>
-->
<el-button
<el-button
link
link
type=
"primary"
type=
"primary"
...
...
src/views/crm/receivablePlan/ReceivablePlanForm.vue
View file @
f0c45103
...
@@ -7,8 +7,24 @@
...
@@ -7,8 +7,24 @@
label-width=
"100px"
label-width=
"100px"
v-loading=
"formLoading"
v-loading=
"formLoading"
>
>
<el-form-item
label=
"期数"
prop=
"indexNo"
>
<el-form-item
label=
"客户名称"
prop=
"customerId"
>
<el-input-number
v-model=
"formData.indexNo"
placeholder=
"请输入期数"
/>
<el-input
v-model=
"formData.customerId"
placeholder=
"请输入客户名称"
/>
</el-form-item>
<el-form-item
label=
"合同名称"
prop=
"contractId"
>
<el-input
v-model=
"formData.contractId"
placeholder=
"请输入合同名称"
/>
</el-form-item>
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-select
v-model=
"formData.ownerUserId"
clearable
placeholder=
"请输入负责人"
>
<el-option
v-for=
"item in userList"
:key=
"item.id"
:label=
"item.nickname"
:value=
"item.id"
/>
</el-select>
</el-form-item>
<el-form-item
label=
"期数"
prop=
"period"
>
<el-input-number
v-model=
"formData.period"
placeholder=
"请输入期数"
/>
</el-form-item>
</el-form-item>
<!--
<el-form-item
label=
"回款ID"
prop=
"receivableId"
>
<!--
<el-form-item
label=
"回款ID"
prop=
"receivableId"
>
<el-input
v-model=
"formData.receivableId"
placeholder=
"请输入回款ID"
/>
<el-input
v-model=
"formData.receivableId"
placeholder=
"请输入回款ID"
/>
...
@@ -58,18 +74,9 @@
...
@@ -58,18 +74,9 @@
placeholder=
"选择提醒日期"
placeholder=
"选择提醒日期"
/>
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"
客户ID"
prop=
"customerId
"
>
<el-form-item
label=
"
显示排序"
prop=
"sort
"
>
<el-input
v-model=
"formData.customerId"
placeholder=
"请输入客户ID
"
/>
<el-input
-number
v-model=
"formData.sort"
:min=
"0"
controls-position=
"right
"
/>
</el-form-item>
</el-form-item>
<el-form-item
label=
"合同ID"
prop=
"contractId"
>
<el-input
v-model=
"formData.contractId"
placeholder=
"请输入合同ID"
/>
</el-form-item>
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-input
v-model=
"formData.ownerUserId"
placeholder=
"请输入负责人"
/>
</el-form-item>
<!--
<el-form-item
label=
"显示顺序"
prop=
"sort"
>
<el-input
v-model=
"formData.sort"
placeholder=
"请输入显示顺序"
/>
</el-form-item>
-->
<el-form-item
label=
"备注"
prop=
"remark"
>
<el-form-item
label=
"备注"
prop=
"remark"
>
<el-input
type=
"textarea"
:rows=
"3"
v-model=
"formData.remark"
placeholder=
"请输入备注"
/>
<el-input
type=
"textarea"
:rows=
"3"
v-model=
"formData.remark"
placeholder=
"请输入备注"
/>
</el-form-item>
</el-form-item>
...
@@ -81,19 +88,18 @@
...
@@ -81,19 +88,18 @@
</Dialog>
</Dialog>
</template>
</template>
<
script
setup
lang=
"ts"
>
<
script
setup
lang=
"ts"
>
import
{
DICT_TYPE
,
getIntDictOptions
,
getStrDictOptions
}
from
'@/utils/dict'
import
*
as
ReceivablePlanApi
from
'@/api/crm/receivablePlan'
import
*
as
ReceivablePlanApi
from
'@/api/crm/receivablePlan'
import
*
as
UserApi
from
'@/api/system/user'
const
{
t
}
=
useI18n
()
// 国际化
const
{
t
}
=
useI18n
()
// 国际化
const
message
=
useMessage
()
// 消息弹窗
const
message
=
useMessage
()
// 消息弹窗
const
userList
=
ref
<
UserApi
.
UserVO
[]
>
([])
// 用户列表
const
dialogVisible
=
ref
(
false
)
// 弹窗的是否展示
const
dialogVisible
=
ref
(
false
)
// 弹窗的是否展示
const
dialogTitle
=
ref
(
''
)
// 弹窗的标题
const
dialogTitle
=
ref
(
''
)
// 弹窗的标题
const
formLoading
=
ref
(
false
)
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const
formLoading
=
ref
(
false
)
// 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
const
formType
=
ref
(
''
)
// 表单的类型:create - 新增;update - 修改
const
formType
=
ref
(
''
)
// 表单的类型:create - 新增;update - 修改
const
formData
=
ref
({
const
formData
=
ref
({
id
:
undefined
,
id
:
undefined
,
indexNo
:
undefined
,
period
:
undefined
,
receivableId
:
undefined
,
receivableId
:
undefined
,
status
:
undefined
,
status
:
undefined
,
checkStatus
:
undefined
,
checkStatus
:
undefined
,
...
@@ -128,6 +134,9 @@ const open = async (type: string, id?: number) => {
...
@@ -128,6 +134,9 @@ const open = async (type: string, id?: number) => {
formLoading
.
value
=
false
formLoading
.
value
=
false
}
}
}
}
// 获得用户列表
userList
.
value
=
await
UserApi
.
getSimpleUserList
()
}
}
defineExpose
({
open
})
// 提供 open 方法,用于打开弹窗
defineExpose
({
open
})
// 提供 open 方法,用于打开弹窗
...
@@ -161,7 +170,7 @@ const submitForm = async () => {
...
@@ -161,7 +170,7 @@ const submitForm = async () => {
const
resetForm
=
()
=>
{
const
resetForm
=
()
=>
{
formData
.
value
=
{
formData
.
value
=
{
id
:
undefined
,
id
:
undefined
,
indexNo
:
undefined
,
period
:
undefined
,
receivableId
:
undefined
,
receivableId
:
undefined
,
status
:
undefined
,
status
:
undefined
,
checkStatus
:
undefined
,
checkStatus
:
undefined
,
...
...
src/views/crm/receivablePlan/index.vue
View file @
f0c45103
...
@@ -8,10 +8,19 @@
...
@@ -8,10 +8,19 @@
:inline=
"true"
:inline=
"true"
label-width=
"68px"
label-width=
"68px"
>
>
<el-form-item
label=
"期数"
prop=
"indexNo"
>
<el-form-item
label=
"客户"
prop=
"customerId"
>
<el-input
v-model=
"queryParams.customerId"
placeholder=
"请输入客户"
clearable
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
/>
</el-form-item>
<el-form-item
label=
"合同"
prop=
"contractId"
>
<el-input
<el-input
v-model=
"queryParams.
indexNo
"
v-model=
"queryParams.
contractId
"
placeholder=
"请输入
期数
"
placeholder=
"请输入
合同
"
clearable
clearable
@
keyup
.
enter=
"handleQuery"
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
class=
"!w-240px"
...
@@ -67,7 +76,7 @@
...
@@ -67,7 +76,7 @@
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
-->
</el-form-item>
-->
<el-form-item
label=
"提醒日期"
prop=
"remindTime"
>
<
!--
<
el-form-item
label=
"提醒日期"
prop=
"remindTime"
>
<el-date-picker
<el-date-picker
v-model=
"queryParams.remindTime"
v-model=
"queryParams.remindTime"
value-format=
"YYYY-MM-DD HH:mm:ss"
value-format=
"YYYY-MM-DD HH:mm:ss"
...
@@ -77,26 +86,8 @@
...
@@ -77,26 +86,8 @@
:default-time=
"[new Date('1 00:00:00'), new Date('1 23:59:59')]"
:default-time=
"[new Date('1 00:00:00'), new Date('1 23:59:59')]"
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
</el-form-item>
-->
<el-form-item
label=
"客户"
prop=
"customerId"
>
<!--
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-input
v-model=
"queryParams.customerId"
placeholder=
"请输入客户"
clearable
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
/>
</el-form-item>
<el-form-item
label=
"合同"
prop=
"contractId"
>
<el-input
v-model=
"queryParams.contractId"
placeholder=
"请输入合同"
clearable
@
keyup
.
enter=
"handleQuery"
class=
"!w-240px"
/>
</el-form-item>
<el-form-item
label=
"负责人"
prop=
"ownerUserId"
>
<el-input
<el-input
v-model=
"queryParams.ownerUserId"
v-model=
"queryParams.ownerUserId"
placeholder=
"请输入负责人"
placeholder=
"请输入负责人"
...
@@ -105,7 +96,7 @@
...
@@ -105,7 +96,7 @@
class=
"!w-240px"
class=
"!w-240px"
/>
/>
</el-form-item>
</el-form-item>
<
!--
<
el-form-item
label=
"备注"
prop=
"remark"
>
<el-form-item
label=
"备注"
prop=
"remark"
>
<el-input
<el-input
v-model=
"queryParams.remark"
v-model=
"queryParams.remark"
placeholder=
"请输入备注"
placeholder=
"请输入备注"
...
@@ -152,40 +143,44 @@
...
@@ -152,40 +143,44 @@
<!-- 列表 -->
<!-- 列表 -->
<ContentWrap>
<ContentWrap>
<el-table
v-loading=
"loading"
:data=
"list"
:stripe=
"true"
:show-overflow-tooltip=
"true"
>
<el-table
v-loading=
"loading"
:data=
"list"
:stripe=
"true"
:show-overflow-tooltip=
"true"
>
<el-table-column
label=
"ID"
align=
"center"
prop=
"id"
/>
<!--
<el-table-column
label=
"ID"
align=
"center"
prop=
"id"
/>
-->
<el-table-column
label=
"期数"
align=
"center"
prop=
"indexNo"
/>
<el-table-column
label=
"客户名称"
align=
"center"
prop=
"customerId"
width=
"150px"
/>
<!--
<el-table-column
label=
"回款ID"
align=
"center"
prop=
"receivableId"
/>
-->
<el-table-column
label=
"合同名称"
align=
"center"
prop=
"contractId"
width=
"150px"
/>
<el-table-column
label=
"完成状态"
align=
"center"
prop=
"status"
>
<el-table-column
label=
"期数"
align=
"center"
prop=
"period"
/>
<template
#
default=
"scope"
>
<el-table-column
label=
"计划回款"
align=
"center"
prop=
"price"
/>
<dict-tag
:type=
"DICT_TYPE.COMMON_STATUS"
:value=
"scope.row.status"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"审批状态"
align=
"center"
prop=
"checkStatus"
width=
"130px"
>
<
template
#
default=
"scope"
>
<dict-tag
:type=
"DICT_TYPE.CRM_RECEIVABLE_CHECK_STATUS"
:value=
"scope.row.checkStatus"
/>
</
template
>
</el-table-column>
<!--<el-table-column label="工作流编号" align="center" prop="processInstanceId" />-->
<el-table-column
label=
"回款金额"
align=
"center"
prop=
"price"
/>
<el-table-column
<el-table-column
label=
"回款日期"
label=
"
计划
回款日期"
align=
"center"
align=
"center"
prop=
"returnTime"
prop=
"returnTime"
:formatter=
"dateFormatter2"
:formatter=
"dateFormatter2"
width=
"180px"
width=
"180px"
/>
/>
<el-table-column
label=
"提前几天提醒"
align=
"center"
prop=
"remindDays"
/>
<el-table-column
label=
"提前几天提醒"
align=
"center"
prop=
"remindDays"
/>
<el-table-column
<
!--
<
el-table-column
label=
"提醒日期"
label=
"提醒日期"
align=
"center"
align=
"center"
prop=
"remindTime"
prop=
"remindTime"
:formatter=
"dateFormatter"
:formatter=
"dateFormatter"
width=
"180px"
width=
"180px"
/>
/>
-->
<el-table-column
label=
"客户ID"
align=
"center"
prop=
"customerId"
/>
<!--
<el-table-column
label=
"回款ID"
align=
"center"
prop=
"receivableId"
/>
-->
<el-table-column
label=
"合同ID"
align=
"center"
prop=
"contractId"
/>
<el-table-column
label=
"完成状态"
align=
"center"
prop=
"status"
>
<el-table-column
label=
"负责人"
align=
"center"
prop=
"ownerUserId"
/>
<template
#
default=
"scope"
>
<!--<el-table-column label="显示顺序" align="center" prop="sort" />-->
<dict-tag
:type=
"DICT_TYPE.COMMON_STATUS"
:value=
"scope.row.status"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"审批状态"
align=
"center"
prop=
"checkStatus"
width=
"130px"
>
<
template
#
default=
"scope"
>
<dict-tag
:type=
"DICT_TYPE.CRM_RECEIVABLE_CHECK_STATUS"
:value=
"scope.row.checkStatus"
/>
</
template
>
</el-table-column>
<!--<el-table-column label="工作流编号" align="center" prop="processInstanceId" />-->
<el-table-column
prop=
"ownerUserId"
label=
"负责人"
width=
"120"
>
<
template
#
default=
"scope"
>
{{
userList
.
find
((
user
)
=>
user
.
id
===
scope
.
row
.
ownerUserId
)?.
nickname
}}
</
template
>
</el-table-column>
<el-table-column
label=
"显示顺序"
align=
"center"
prop=
"sort"
/>
<el-table-column
label=
"备注"
align=
"center"
prop=
"remark"
/>
<el-table-column
label=
"备注"
align=
"center"
prop=
"remark"
/>
<el-table-column
<el-table-column
label=
"创建时间"
label=
"创建时间"
...
@@ -234,6 +229,7 @@ import { dateFormatter, dateFormatter2 } from '@/utils/formatTime'
...
@@ -234,6 +229,7 @@ import { dateFormatter, dateFormatter2 } from '@/utils/formatTime'
import
download
from
'@/utils/download'
import
download
from
'@/utils/download'
import
*
as
ReceivablePlanApi
from
'@/api/crm/receivablePlan'
import
*
as
ReceivablePlanApi
from
'@/api/crm/receivablePlan'
import
ReceivablePlanForm
from
'./ReceivablePlanForm.vue'
import
ReceivablePlanForm
from
'./ReceivablePlanForm.vue'
import
*
as
UserApi
from
'@/api/system/user'
defineOptions
({
name
:
'ReceivablePlan'
})
defineOptions
({
name
:
'ReceivablePlan'
})
...
@@ -243,10 +239,11 @@ const { t } = useI18n() // 国际化
...
@@ -243,10 +239,11 @@ const { t } = useI18n() // 国际化
const
loading
=
ref
(
true
)
// 列表的加载中
const
loading
=
ref
(
true
)
// 列表的加载中
const
total
=
ref
(
0
)
// 列表的总页数
const
total
=
ref
(
0
)
// 列表的总页数
const
list
=
ref
([])
// 列表的数据
const
list
=
ref
([])
// 列表的数据
const
userList
=
ref
<
UserApi
.
UserVO
[]
>
([])
// 用户列表
const
queryParams
=
reactive
({
const
queryParams
=
reactive
({
pageNo
:
1
,
pageNo
:
1
,
pageSize
:
10
,
pageSize
:
10
,
indexNo
:
null
,
period
:
null
,
status
:
null
,
status
:
null
,
checkStatus
:
null
,
checkStatus
:
null
,
returnTime
:
[],
returnTime
:
[],
...
@@ -320,7 +317,9 @@ const handleExport = async () => {
...
@@ -320,7 +317,9 @@ const handleExport = async () => {
}
}
/** 初始化 **/
/** 初始化 **/
onMounted
(()
=>
{
onMounted
(
async
()
=>
{
getList
()
await
getList
()
// 获取用户列表
userList
.
value
=
await
UserApi
.
getSimpleUserList
()
})
})
</
script
>
</
script
>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment