Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
marketing
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
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
marketing-web
marketing
Commits
b0f81c84
Commit
b0f81c84
authored
Jan 24, 2022
by
crushh
Browse files
Options
Browse Files
Download
Plain Diff
update: merging
parents
05c4abd2
026a095b
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
51 additions
and
49 deletions
+51
-49
form.js
src/views/ecm/form.js
+39
-4
form.vue
src/views/ecm/form.vue
+4
-4
index.vue
src/views/ecm/marketing-event/index.vue
+8
-41
No files found.
src/views/ecm/form.js
View file @
b0f81c84
...
...
@@ -110,6 +110,22 @@ export default {
return
time
.
getTime
()
<
Date
.
now
()
-
8.64e7
;
}
},
endDatePickerOptions2
:
{
//编辑 消费触发-累计订单实付金额-结束时间
disabledDate
:
time
=>
{
return
time
.
getTime
()
<
Date
.
now
()
-
8.64e7
||
time
.
getTime
()
>
this
.
endDate
;
}
},
endDatePickerOptions3
:
{
//新增 消费触发-累计订单实付金额-结束时间
disabledDate
:
time
=>
{
if
(
this
.
form
.
beginDate
)
{
return
time
.
getTime
()
<
Date
.
now
()
-
8.64e7
||
time
.
getTime
()
>
new
Date
(
this
.
form
.
beginDate
).
getTime
()
+
31
*
24
*
60
*
60
*
1000
;
}
else
{
return
time
.
getTime
()
<
Date
.
now
()
-
8.64e7
;
}
}
},
pickerOptions
:
{
disabledDate
(
val
)
{
return
Date
.
now
()
>=
val
.
getTime
()
+
24
*
60
*
60
*
1000
;
...
...
@@ -176,7 +192,8 @@ export default {
checkList
:
[],
paymentFlag
:
1
,
// 是否选择了非实时分组 true:是 false:否
hasRealTime
:
false
hasRealTime
:
false
,
endDate
:
''
//编辑 消费触发-累计订单实付金额-结束时间修改时用到
};
},
components
:
{
...
...
@@ -468,6 +485,7 @@ export default {
if
(
this
.
form
.
expireType
)
{
this
.
form
.
beginDate
=
result
.
beginDate
||
''
;
this
.
form
.
endDate
=
result
.
endDate
||
''
;
this
.
endDate
=
this
.
form
.
endDate
;
}
if
(
res
.
result
.
searchId
)
{
this
.
useId
=
res
.
result
.
searchId
||
''
;
...
...
@@ -950,6 +968,7 @@ export default {
conditionList
:
this
.
isEdit
?
this
.
xxSysp
.
conditionList_copy
:
this
.
xxSysp
.
conditionList
,
// 编辑保存备份数据
filterAbbrInfo
:
this
.
xxSysp
.
filterAbbrInfo
});
consumeObj
.
gift_flag
=
this
.
form
.
gift_flag
;
}
if
(
this
.
form
.
consum_type
==
1
)
{
consumeObj
.
consum_type
=
1
;
...
...
@@ -987,9 +1006,6 @@ export default {
}
else
{
consumeObj
.
consum_type
=
2
;
consumeObj
[
'lowest_cost'
]
=
this
.
form
.
lowest_cost
;
if
(
this
.
consumeChecked
.
good
&&
this
.
xxSysp
.
goodsFilterId
)
{
consumeObj
.
gift_flag
=
this
.
form
.
gift_flag
;
}
}
params
=
Object
.
assign
(
params
,
consumeObj
);
// 合并消费触发数据
}
...
...
@@ -1128,6 +1144,9 @@ export default {
// console.log(this.gradeList )
});
}
if
(
isInit
!==
true
)
{
this
.
resetConsumType
();
}
},
// 消费触发
handleLowestCost
()
{
...
...
@@ -1171,6 +1190,8 @@ export default {
this
.
form
.
expireType
=
1
;
this
.
consumeChecked
.
cost
=
true
;
}
this
.
form
.
beginDate
=
''
;
this
.
form
.
endDate
=
''
;
// this.form.lowest_cost = '';
},
// 对比开始时间结束时间
...
...
@@ -1182,6 +1203,11 @@ export default {
// this.form.beginDate = this.form.endDate;
this
.
showMessage
=
true
;
return
true
;
}
else
if
(
this
.
form
.
expireType
&&
this
.
form
.
consum_type
==
2
&&
beginDate
&&
endDate
&&
endDate
.
getTime
()
-
beginDate
.
getTime
()
>
31
*
24
*
60
*
60
*
1000
)
{
this
.
$tips
({
type
:
'warning'
,
message
:
'最长时间跨度为31天'
});
this
.
showMessage
=
true
;
return
true
;
}
else
{
this
.
showMessage
=
false
;
return
false
;
...
...
@@ -1317,6 +1343,15 @@ export default {
this
.
analyseConfig
.
crowd_send
=
4
;
this
.
analyseConfig
.
crowd_no_send
=
1
;
}
this
.
resetConsumType
();
},
resetConsumType
()
{
//切换时效或触发行为 重置 累计消费的配置
if
(
this
.
form
.
consum_type
==
2
)
{
this
.
form
.
consum_type
=
1
;
this
.
form
.
beginDate
=
''
;
this
.
form
.
endDate
=
''
;
}
}
},
filters
:
{
...
...
src/views/ecm/form.vue
View file @
b0f81c84
...
...
@@ -177,7 +177,7 @@
<el-button
type=
"primary"
@
click=
"handleXxSyspClick"
class=
"fl mt5"
size=
"mini"
>
{{ !isAdd ? '查看' : '编辑' }}
</el-button>
<el-button
v-show=
"xxSysp.filterAbbrInfo.length && isAdd"
@
click=
"handleXxSyspReset"
class=
"fl mt5"
size=
"mini"
>
清空
</el-button>
</div>
<div
v-show=
"consumeChecked.good
&& form.consum_type == 2
"
>
<div
v-show=
"consumeChecked.good"
>
<span
style=
"margin-left: 38px;"
>
赠品是否支持触发
</span>
<el-radio-group
:disabled=
"!isAdd"
v-model=
"form.gift_flag"
>
<el-radio
:label=
"1"
style=
"width: auto;"
>
支持
</el-radio>
...
...
@@ -360,8 +360,8 @@
<el-date-picker
v-if=
"form.expireType"
v-model=
"form.endDate"
:disabled=
"isEdit && onlineStatus == 2"
type=
"datetime"
:picker-options=
"endDatePickerOptions"
placeholder=
"结束时间"
@
change=
"checkBeginEndTime"
>
</el-date-picker>
</el-form-item>
<el-form-item
label=
"固定期限"
prop=
"endDate"
:show-message=
"showMessage"
v-else
>
<el-date-picker
class=
"ml10"
v-model=
"form.beginDate"
:disabled=
"isEdit && onlineStatus != 0"
type=
"datetime"
placeholder=
"开始时间"
@
change=
"checkBeginEndTime"
>
</el-date-picker>
<el-date-picker
v-model=
"form.endDate"
:disabled=
"isEdit && onlineStatus == 2"
type=
"datetime"
:picker-options=
"
endDatePickerOptions
"
placeholder=
"结束时间"
@
change=
"checkBeginEndTime"
>
</el-date-picker>
<el-date-picker
class=
"ml10"
v-model=
"form.beginDate"
:disabled=
"isEdit && onlineStatus != 0"
type=
"datetime"
placeholder=
"开始时间"
@
change=
"checkBeginEndTime"
:picker-options=
"endDatePickerOptions"
>
</el-date-picker>
<el-date-picker
v-model=
"form.endDate"
:disabled=
"isEdit && onlineStatus == 2"
type=
"datetime"
:picker-options=
"
isEdit ? endDatePickerOptions2 : endDatePickerOptions3
"
placeholder=
"结束时间"
@
change=
"checkBeginEndTime"
>
</el-date-picker>
</el-form-item>
</section>
<!-- 人群筛选器 -->
...
...
@@ -421,7 +421,7 @@
</div>
</h3>
<!-- 只有实时才是单图文 -->
<marketing-event
:effectType=
"form.effectType"
:readOnly=
"isInfo || onlineStatus == 2
"
:show-delete-tooltip=
"isEdit && analyseConfig.open_flag == 1"
show-out-coupon-icon
ref=
"marketingEvent"
@
has-card=
"hasCard"
v-if=
"ecmPlanId"
:singleFlag=
"form.effectType === 0"
:integralMultiple=
"form.effectAction === 'consume'
"
:ecmPlanId=
"ecmPlanId"
:isSupportVar=
"form.effectType === 0"
:code=
"code"
:enabledMessageState=
"enabledMessageState"
:cardLimitType=
"-1"
:use-stored=
"useStoredFlag && ['consume', 'stored'].includes(form.effectAction) && form.effectType == 0 && form.consum_type == 1"
:use-qfxx=
"form.effectType !== 0"
:consumType=
"form.consum_type"
>
</marketing-event>
<marketing-event
:effectType=
"form.effectType"
:readOnly=
"isInfo || onlineStatus == 2
|| (form.consum_type == 2 && isEdit)"
:show-delete-tooltip=
"isEdit && analyseConfig.open_flag == 1"
show-out-coupon-icon
ref=
"marketingEvent"
@
has-card=
"hasCard"
v-if=
"ecmPlanId"
:singleFlag=
"form.effectType === 0"
:integralMultiple=
"form.effectAction === 'consume' && form.consum_type != 2
"
:ecmPlanId=
"ecmPlanId"
:isSupportVar=
"form.effectType === 0"
:code=
"code"
:enabledMessageState=
"enabledMessageState"
:cardLimitType=
"-1"
:use-stored=
"useStoredFlag && ['consume', 'stored'].includes(form.effectAction) && form.effectType == 0 && form.consum_type == 1"
:use-qfxx=
"form.effectType !== 0"
:consumType=
"form.consum_type"
>
</marketing-event>
<!-- 只有非实时&&选择卡券了展示提示 -->
<div
v-if=
"currentCard.comName && form.effectType != 0 && couponAutoGetFlag"
class=
"fz13 regular-font-color line-height2"
style=
"margin-left:120px;margin-top:30px;"
>
* 用户在领取卡券后需要
<b
class=
"bold"
>
同步至ERP
</b>
,如果关闭用户
<b
class=
"bold"
>
手动领取
</b>
,卡券在
<b
class=
"bold"
>
批量投放
</b>
时会需要将卡券信息批量同步至ERP。
<br
/>
...
...
src/views/ecm/marketing-event/index.vue
View file @
b0f81c84
...
...
@@ -184,8 +184,14 @@ export default {
},
computed
:
{
showOptionList
()
{
if
(
this
.
consumType
==
2
&&
this
.
effectType
==
0
)
{
const
arr
=
[
'card'
,
'integral'
];
if
(
this
.
effectType
==
0
&&
this
.
consumType
==
2
)
{
// 消费触发-累计 只有 积分和卡券事件 且积分事件只能添加一次
let
arr
=
[
'card'
,
'integral'
];
if
(
this
.
list
&&
this
.
list
.
length
)
{
if
(
this
.
list
.
map
(
item
=>
item
.
comName
).
includes
(
'item-integral'
))
{
arr
=
[
'card'
];
}
}
this
.
options
.
forEach
(
item
=>
{
if
(
arr
.
includes
(
item
.
value
))
{
item
.
show
=
true
;
...
...
@@ -268,45 +274,6 @@ export default {
this
.
delItem
(
el
);
});
},
// useStored: {
// handler() {
// console.log('useStored');
// if (this.useStored) {
// // this.options = [ ...this.options, { name: '会员卡升级', value: 'grade', key: 9, img: require('./assets/img/grade.svg'), disabled: false }]; //eslint-disable-line
// this.options.forEach(item => {
// if (item.value == 'grade') {
// item.show = false;
// }
// });
// } else {
// // this.options = this.options.filter(item => item.value !== 'grade');
// this.options.forEach(item => {
// if (item.value == 'grade') {
// item.show = true;
// }
// });
// }
// }
// },
// useQywx: {
// handler() {
// console.log('qywx');
// if (this.useQywx) {
// this.options.forEach(item => {
// if (item.value == 'qywx') {
// item.show = false;
// }
// });
// } else {
// this.options.forEach(item => {
// if (item.value == 'qywx') {
// item.show = true;
// }
// });
// }
// },
// },
list
()
{
if
(
this
.
list
.
some
(
item
=>
item
.
comName
===
'item-grade'
))
{
this
.
options
.
forEach
(
item
=>
{
...
...
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