Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
jiedao-app-operator-master
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lanbaoming
jiedao-app-operator-master
Commits
1dec6dce
Commit
1dec6dce
authored
Sep 10, 2024
by
余金瑶
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
客户列表操作设置按钮
parent
65c81e67
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
287 additions
and
7 deletions
+287
-7
customer.js
src/api/ecw/customer.js
+8
-0
customerFollow.vue
src/views/ecw/customer/components/customerFollow.vue
+19
-3
customerFollowSelectOffer.vue
...ews/ecw/customer/components/customerFollowSelectOffer.vue
+1
-1
customerSetting.vue
src/views/ecw/customer/components/customerSetting.vue
+236
-0
index.vue
src/views/ecw/customer/index.vue
+21
-2
query.vue
src/views/ecw/customer/query.vue
+2
-1
No files found.
src/api/ecw/customer.js
View file @
1dec6dce
...
@@ -528,6 +528,14 @@ export function changeCustomerDefaultBilling(data){
...
@@ -528,6 +528,14 @@ export function changeCustomerDefaultBilling(data){
})
})
}
}
export
function
customerSettingButton
(
data
){
return
request
({
url
:
'
ecw/customer/change-customer-arrival-confirm
'
,
method
:
'
put
'
,
data
})
}
export
function
addCompetitor
(
data
){
export
function
addCompetitor
(
data
){
return
request
({
return
request
({
url
:
'
customer/competitor/create
'
,
url
:
'
customer/competitor/create
'
,
...
...
src/views/ecw/customer/components/customerFollow.vue
View file @
1dec6dce
...
@@ -41,8 +41,8 @@
...
@@ -41,8 +41,8 @@
</el-col>
</el-col>
<el-col
:span=
"12"
>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('联系人')"
required
>
<el-form-item
:label=
"$t('联系人')"
required
>
<el-select
v-model=
"form.contact
Name"
clearable
:placeholder=
"$t('请选择')"
:disabled=
"isView
"
>
<el-select
v-model=
"form.contact
Id"
clearable
:placeholder=
"$t('请选择')"
:disabled=
"isView"
@
change=
"changeContactUser
"
>
<el-option
v-for=
"(item, index) in customerContactsList"
:key=
"index"
:label=
"item.name"
:value=
"item.
name
"
>
<el-option
v-for=
"(item, index) in customerContactsList"
:key=
"index"
:label=
"item.name"
:value=
"item.
id
"
>
</el-option>
</el-option>
</el-select>
</el-select>
</el-form-item>
</el-form-item>
...
@@ -281,7 +281,9 @@ export default {
...
@@ -281,7 +281,9 @@ export default {
reset
()
{
reset
()
{
this
.
form
=
{
this
.
form
=
{
attatchment
:
undefined
,
attatchment
:
undefined
,
contactId
:
undefined
,
contactName
:
undefined
,
contactName
:
undefined
,
contactPhone
:
undefined
,
customerId
:
this
.
customerId
,
customerId
:
this
.
customerId
,
feedback
:
undefined
,
feedback
:
undefined
,
followMethod
:
undefined
,
followMethod
:
undefined
,
...
@@ -313,6 +315,20 @@ export default {
...
@@ -313,6 +315,20 @@ export default {
}
}
}
}
},
},
changeContactUser
(
val
)
{
if
(
val
)
{
for
(
const
item
of
this
.
customerContactsList
)
{
if
(
item
.
id
==
val
)
{
this
.
form
.
contactName
=
item
.
name
// this.form.contactPhone = `+${item.areaCode}${item.phoneNew}`
break
}
}
}
else
{
this
.
form
.
contactName
=
null
this
.
form
.
contactPhone
=
null
}
},
customerFollowSubmit
(
status
)
{
customerFollowSubmit
(
status
)
{
console
.
log
(
this
.
form
)
console
.
log
(
this
.
form
)
this
.
$refs
[
"
customerFollowForm
"
].
validate
(
valid
=>
{
this
.
$refs
[
"
customerFollowForm
"
].
validate
(
valid
=>
{
...
...
src/views/ecw/customer/components/customerFollowSelectOffer.vue
View file @
1dec6dce
...
@@ -130,7 +130,7 @@ export default {
...
@@ -130,7 +130,7 @@ export default {
/** 搜索按钮操作 */
/** 搜索按钮操作 */
handleQuery
()
{
handleQuery
()
{
this
.
queryParams
.
pageNo
=
1
;
this
.
queryParams
.
pageNo
=
1
;
this
.
get
List
();
this
.
get
OfferList
()
},
},
/** 重置按钮操作 */
/** 重置按钮操作 */
resetQuery
()
{
resetQuery
()
{
...
...
src/views/ecw/customer/components/customerSetting.vue
0 → 100644
View file @
1dec6dce
<
template
>
<el-dialog
append-to-body
:title=
"$t('设置')"
:visible.sync=
"dialogVisible"
width=
"900px"
>
<el-form
ref=
"form"
:model=
"form"
label-width=
"150px"
>
<el-row
:gutter=
"10"
>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('是否显示提单价格')"
prop=
"isShowTidanPrice"
>
<el-switch
v-model=
"form.isShowTidanPrice"
></el-switch>
</el-form-item>
</el-col>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('到仓确认')"
prop=
"arrivalConfirm"
>
<el-switch
v-model=
"form.arrivalConfirm"
:active-value=
"1"
:inactive-value=
"0"
/>
</el-form-item>
</el-col>
<el-col
:span=
"13"
>
<el-form-item
:label=
"$t('重货标准')"
prop=
"weightUnit"
>
<el-switch
v-model=
"showZhong"
/>
<el-input
v-model=
"form.weightUnit"
:placeholder=
"$t('请输入重货标准')"
v-show=
"showZhong"
>
<template
slot=
"append"
>
kg/cbm
</
template
>
</el-input>
</el-form-item>
</el-col>
<el-col
:span=
"24"
v-show=
"showZhong"
>
<el-form-item
:label=
"$t('指定线路')"
prop=
"line"
>
<el-switch
v-model=
"showZhong1"
></el-switch>
<customer-line-table
v-if=
"showZhong1"
:warehouse-list=
"warehouseList"
:import-city-list=
"importCityList"
v-model=
"zhongLines"
:zhong-pao-type=
"1"
></customer-line-table>
</el-form-item>
</el-col>
<el-col
:span=
"13"
>
<el-form-item
:label=
"$t('泡货标准')"
prop=
"lightUnit"
>
<el-switch
v-model=
"showPao"
/>
<el-input
v-model=
"form.lightUnit"
:placeholder=
"$t('请输入泡货标准')"
v-show=
"showPao"
>
<
template
slot=
"append"
>
kg/cbm
</
template
>
</el-input>
</el-form-item>
</el-col>
<el-col
:span=
"24"
v-show=
"showPao"
>
<el-form-item
:label=
"$t('指定线路')"
prop=
"line"
>
<el-switch
v-model=
"showPao1"
></el-switch>
<customer-line-table
v-if=
"showPao1"
:warehouse-list=
"warehouseList"
:import-city-list=
"importCityList"
v-model=
"paoLines"
:zhong-pao-type=
"2"
></customer-line-table>
</el-form-item>
</el-col>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('控货无收货人')"
>
<el-switch
v-model=
"form.noConsignee"
/>
</el-form-item>
</el-col>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('默认付款')"
>
<el-switch
v-model=
"form.defaultPay"
/>
</el-form-item>
</el-col>
<el-col
:span=
"12"
>
<el-form-item
:label=
"$t('默认开票')"
>
<el-switch
v-model=
"form.defaultBilling"
/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div
slot=
"footer"
class=
"dialog-footer"
>
<el-button
type=
"warning"
@
click=
"handleClose"
>
{{$t('关 闭')}}
</el-button>
<el-button
type=
"primary"
@
click=
"handerSubmit"
>
{{$t('保 存')}}
</el-button>
</div>
</el-dialog>
</template>
<
script
>
import
CustomerLineTable
from
"
@/components/CustomerLineTable
"
;
import
{
getWarehouseList
}
from
"
@/api/ecw/warehouse
"
;
import
{
getTradeCityList
}
from
"
@/api/ecw/region
"
;
import
{
getZhongPaoBest
,
getZhongPaoPage
}
from
"
@/api/ecw/zhongPao
"
;
import
{
getCustomer
,
getCustomerLines
,
customerSettingButton
}
from
"
@/api/ecw/customer
"
;
export
default
{
name
:
"
CustomerSetting
"
,
components
:
{
CustomerLineTable
},
data
()
{
return
{
dialogVisible
:
false
,
form
:
{
isShowTidanPrice
:
false
,
arrivalConfirm
:
0
,
weightUnit
:
null
,
lightUnit
:
null
,
customerLines
:
[],
noConsignee
:
false
,
defaultPay
:
false
,
defaultBilling
:
false
},
showZhong
:
false
,
showZhong1
:
false
,
showPao
:
false
,
showPao1
:
false
,
warehouseList
:
[],
zhongLines
:
[],
warehouseList
:
[],
// 仓库列表
importCityList
:
[],
// 进口地址
zhongLines
:
[],
paoLines
:
[],
}
},
created
()
{
getWarehouseList
().
then
((
r
)
=>
{
this
.
warehouseList
=
r
.
data
;
});
getTradeCityList
({
type
:
1
}).
then
((
r
)
=>
{
this
.
importCityList
=
r
.
data
.
filter
((
item
)
=>
item
.
type
===
"
1
"
);
});
},
methods
:
{
getZhongPao
()
{
getZhongPaoBest
({
customerId
:
this
.
customerId
,
// departureId: this.departureId,
// objectiveId: this.objectiveId
}).
then
((
r
)
=>
{
if
(
!
this
.
form
.
weightUnit
)
this
.
form
.
weightUnit
=
r
.
data
.
zhongEdge
;
if
(
!
this
.
form
.
lightUnit
)
this
.
form
.
lightUnit
=
r
.
data
.
paoEdge
;
});
},
init
(
id
)
{
this
.
customerId
=
id
getCustomer
(
this
.
customerId
).
then
((
response
)
=>
{
const
row
=
response
.
data
this
.
form
=
{
customerId
:
row
.
id
,
isShowTidanPrice
:
row
.
isShowTidanPrice
,
arrivalConfirm
:
row
.
arrivalConfirm
,
weightUnit
:
row
.
weightUnit
,
lightUnit
:
row
.
lightUnit
,
customerLines
:
[],
noConsignee
:
row
.
noConsignee
,
defaultPay
:
row
.
defaultPay
,
defaultBilling
:
row
.
defaultBilling
}
// 打开重泡货开关
if
(
this
.
form
.
weightUnit
)
{
this
.
showZhong
=
true
;
}
if
(
this
.
form
.
lightUnit
)
{
this
.
showPao
=
true
;
}
getCustomerLines
(
this
.
customerId
).
then
((
res
)
=>
{
this
.
zhongLines
=
res
.
data
.
filter
((
item
)
=>
item
.
zhongPaoType
==
1
);
this
.
paoLines
=
res
.
data
.
filter
((
item
)
=>
item
.
zhongPaoType
==
2
);
if
(
this
.
zhongLines
.
length
)
this
.
showZhong1
=
true
;
if
(
this
.
paoLines
.
length
)
this
.
showPao1
=
true
;
});
this
.
getZhongPao
()
})
},
handleClose
()
{
this
.
resetForm
(
"
form
"
)
this
.
dialogVisible
=
false
},
handerSubmit
()
{
this
.
$refs
[
"
form
"
].
validate
((
valid
,
err
)
=>
{
// 重货标准和泡货标准,未打开就不传,提交前清空一下
if
(
!
this
.
showZhong
)
{
this
.
form
.
weightUnit
=
null
;
this
.
zhongLines
=
[];
}
if
(
!
this
.
showZhong1
)
{
this
.
zhongLines
=
[];
}
if
(
!
this
.
showPao
)
{
this
.
form
.
lightUnit
=
null
;
this
.
paoLines
=
[];
}
if
(
!
this
.
showPao1
)
{
this
.
paoLines
=
[];
}
this
.
updateCustomerLines
();
// 检查路线是否启用了但是没选择目的仓
let
errors
=
0
;
this
.
form
.
customerLines
.
forEach
((
line
)
=>
{
if
(
!
line
.
objectiveIds
||
line
.
objectiveIds
==
""
)
{
errors
++
;
}
});
if
(
errors
)
{
return
this
.
$message
.
error
(
"
有两条路线未选择目的地
"
);
}
customerSettingButton
(
this
.
form
).
then
((
response
)
=>
{
this
.
$modal
.
msgSuccess
(
this
.
$t
(
"
操作成功
"
));
this
.
dialogVisible
=
false
;
const
obj
=
{
path
:
"
/customer/customer
"
};
this
.
$emit
(
'
refresh
'
)
});
});
},
updateCustomerLines
()
{
let
zhongLines
=
[],
paoLines
=
[];
if
(
this
.
zhongLines
.
length
>
0
)
{
zhongLines
=
this
.
zhongLines
;
}
if
(
this
.
paoLines
.
length
>
0
)
{
paoLines
=
this
.
paoLines
;
}
this
.
form
.
customerLines
=
[...
zhongLines
,
...
paoLines
];
},
}
}
</
script
>
src/views/ecw/customer/index.vue
View file @
1dec6dce
...
@@ -888,6 +888,14 @@
...
@@ -888,6 +888,14 @@
@
click=
"quote(scope.row)"
@
click=
"quote(scope.row)"
>
{{
$t
(
"
报价
"
)
}}
</el-button
>
{{
$t
(
"
报价
"
)
}}
</el-button
>
>
<el-button
v-has-permi=
"[selectAuthorityFn('ecw:customer:treat-quoted-price')]"
size=
"mini"
type=
"text"
icon=
"el-icon-user"
@
click=
"handleSetting(scope.row)"
>
{{
$t
(
"
设置
"
)
}}
</el-button
>
</
template
>
</
template
>
</el-table-column>
</el-table-column>
</el-table>
</el-table>
...
@@ -1390,6 +1398,10 @@
...
@@ -1390,6 +1398,10 @@
ref=
"potentialCustom"
ref=
"potentialCustom"
@
change=
"getList"
@
change=
"getList"
></add-potential-custom>
></add-potential-custom>
<customer-setting
ref=
"customerSetting"
@
refresh=
"getList"
/>
<!--业绩类型 -->
<!--业绩类型 -->
<el-dialog
title=
"业绩类型"
:visible.sync=
"dialogVisible"
width=
"30%"
>
<el-dialog
title=
"业绩类型"
:visible.sync=
"dialogVisible"
width=
"30%"
>
<div>
<div>
...
@@ -1451,7 +1463,7 @@ import transferCustomer from "@/views/ecw/customer/transferCustomer";
...
@@ -1451,7 +1463,7 @@ import transferCustomer from "@/views/ecw/customer/transferCustomer";
import
Template
from
"
@/views/cms/template/index.vue
"
;
import
Template
from
"
@/views/cms/template/index.vue
"
;
import
AddPotentialCustom
from
"
@/views/ecw/customer/addPotentialCustom.vue
"
;
import
AddPotentialCustom
from
"
@/views/ecw/customer/addPotentialCustom.vue
"
;
import
Contacts
from
"
@/views/ecw/customer/components/contacts.vue
"
;
import
Contacts
from
"
@/views/ecw/customer/components/contacts.vue
"
;
import
CustomerSetting
from
"
./components/customerSetting.vue
"
;
import
AreaCodeSelector
from
"
@/components/AreaCodeSelector/index.vue
"
;
import
AreaCodeSelector
from
"
@/components/AreaCodeSelector/index.vue
"
;
import
{
getCustomerSelect
}
from
"
@/api/ecw/customer
"
;
import
{
getCustomerSelect
}
from
"
@/api/ecw/customer
"
;
import
{
getProductTypeList
}
from
"
@/api/ecw/productType
"
;
import
{
getProductTypeList
}
from
"
@/api/ecw/productType
"
;
...
@@ -1467,7 +1479,8 @@ export default {
...
@@ -1467,7 +1479,8 @@ export default {
CustomerFollowList
,
CustomerFollowList
,
customerComplaints
,
customerComplaints
,
transferCustomer
,
transferCustomer
,
AreaCodeSelector
AreaCodeSelector
,
CustomerSetting
},
},
data
()
{
data
()
{
return
{
return
{
...
@@ -2120,6 +2133,12 @@ export default {
...
@@ -2120,6 +2133,12 @@ export default {
return
null
return
null
}
}
},
},
handleSetting
(
row
)
{
this
.
$refs
[
'
customerSetting
'
].
dialogVisible
=
true
this
.
$nextTick
(
_
=>
{
this
.
$refs
[
'
customerSetting
'
].
init
(
row
.
id
)
})
},
getBusiCountryNames
(
ids
)
{
getBusiCountryNames
(
ids
)
{
if
(
ids
)
{
if
(
ids
)
{
const
idsArr
=
ids
.
split
(
'
,
'
)
const
idsArr
=
ids
.
split
(
'
,
'
)
...
...
src/views/ecw/customer/query.vue
View file @
1dec6dce
...
@@ -480,6 +480,7 @@
...
@@ -480,6 +480,7 @@
<
el
-
table
-
column
prop
=
"
followTime
"
:
label
=
"
$t('跟进时间')
"
:
formatter
=
"
(row, column, cellValue) => parseTime(cellValue)
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
followTime
"
:
label
=
"
$t('跟进时间')
"
:
formatter
=
"
(row, column, cellValue) => parseTime(cellValue)
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
customerNumber
"
:
label
=
"
$t('客户编号')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
customerNumber
"
:
label
=
"
$t('客户编号')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
contactName
"
:
label
=
"
$t('联系人')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
contactName
"
:
label
=
"
$t('联系人')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
contactPhone
"
:
label
=
"
$t('联系方式')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
followUserName
"
:
label
=
"
$t('客户经理')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
followUserName
"
:
label
=
"
$t('客户经理')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
followMethod
"
:
label
=
"
$t('跟进方式')
"
:
formatter
=
"
(row, column, cellValue) => getDictDataLabel(DICT_TYPE.CUSTOMER_FOLLOWUP_METHOD, cellValue)
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
followMethod
"
:
label
=
"
$t('跟进方式')
"
:
formatter
=
"
(row, column, cellValue) => getDictDataLabel(DICT_TYPE.CUSTOMER_FOLLOWUP_METHOD, cellValue)
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
purpose
"
:
label
=
"
$t('目的')
"
><
/el-table-column
>
<
el
-
table
-
column
prop
=
"
purpose
"
:
label
=
"
$t('目的')
"
><
/el-table-column
>
...
...
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