Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
J
jinfa-platform
Project
Project
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
黄庭坚
jinfa-platform
Commits
14b70f40
Commit
14b70f40
authored
Jul 02, 2021
by
XieZhiXiong
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat: 对接 待提交商家优惠劵
parent
a33add65
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
84 additions
and
41 deletions
+84
-41
index.tsx
...gAbility/merchantCoupon/merchantCouponToConfirm/index.tsx
+65
-24
index.tsx
...y/merchantCoupon/merchantCouponToConfirm/verify/index.tsx
+19
-17
No files found.
src/pages/transaction/marketingAbility/merchantCoupon/merchantCouponToConfirm/index.tsx
View file @
14b70f40
...
...
@@ -2,7 +2,7 @@
* @Author: XieZhiXiong
* @Date: 2021-06-22 11:10:04
* @LastEditors: XieZhiXiong
* @LastEditTime: 2021-0
6-28 16:58:45
* @LastEditTime: 2021-0
7-01 17:22:41
* @Description: 待提交商家优惠劵
*/
import
React
,
{
useState
,
useRef
}
from
'react'
;
...
...
@@ -11,11 +11,15 @@ import {
Card
,
Space
,
Button
,
message
,
Modal
,
}
from
'antd'
;
import
{
QuestionCircleOutlined
}
from
'@ant-design/icons'
;
import
{
StandardTable
}
from
'god'
;
import
{
ColumnType
}
from
'antd/lib/table/interface'
;
import
{
createFormActions
}
from
'@formily/antd'
;
import
{
DatePicker
}
from
'@formily/antd-components'
;
import
moment
from
'moment'
;
import
{
useStateFilterSearchLinkageEffect
}
from
'@/formSchema/effects/useFilterSearch'
;
import
{
useAsyncInitSelect
}
from
'@/formSchema/effects/useAsyncInitSelect'
;
import
{
FORM_FILTER_PATH
}
from
'@/formSchema/const'
;
...
...
@@ -25,14 +29,33 @@ import useSpliceArray from '@/hooks/useSpliceArray';
import
verifySchema
from
'../common/schemas/verify'
;
import
commonColumn
from
'../common/columns/coupon'
;
const
{
confirm
}
=
Modal
;
const
formActions
=
createFormActions
();
type
fetchParams
=
{
name
:
string
,
id
:
number
,
effectiveTimeStart
:
string
|
number
,
effectiveTimeEnd
:
string
|
number
,
type
:
number
,
}
const
MerchantCouponToConfirm
:
React
.
FC
=
()
=>
{
const
ref
=
useRef
<
any
>
({});
const
[
selectedRowKeys
,
setSelectedRowKeys
]
=
useState
<
number
[]
>
([]);
const
fetchData
=
async
(
params
:
any
)
=>
{
let
res
=
await
PublicApi
.
getMemberAbilityMaintenancePage
(
params
);
const
fetchData
=
async
(
params
:
fetchParams
)
=>
{
const
{
effectiveTimeStart
=
null
,
effectiveTimeEnd
=
null
}
=
params
;
const
newParams
:
fetchParams
=
{
...
params
};
if
(
effectiveTimeStart
)
{
newParams
.
effectiveTimeStart
=
moment
(
effectiveTimeStart
).
valueOf
();
}
if
(
effectiveTimeEnd
)
{
newParams
.
effectiveTimeEnd
=
moment
(
effectiveTimeEnd
).
valueOf
();
}
let
res
=
await
PublicApi
.
getMarketingCouponWaitSubmitPage
(
newParams
as
any
);
return
res
.
data
;
};
...
...
@@ -45,7 +68,7 @@ const MerchantCouponToConfirm: React.FC = () => {
<>
<
Button
type=
"link"
onClick=
{
()
=>
history
.
push
(
`/memberCenter/marketingAbility/merchantCoupon/toConfirm/verify?id=${record.
validateI
d}`
)
}
onClick=
{
()
=>
history
.
push
(
`/memberCenter/marketingAbility/merchantCoupon/toConfirm/verify?id=${record.
i
d}`
)
}
>
提交
</
Button
>
...
...
@@ -64,35 +87,53 @@ const MerchantCouponToConfirm: React.FC = () => {
};
// 初始化高级筛选选项
const
fetch
SelectOption
s
=
async
()
=>
{
const
res
=
await
PublicApi
.
getM
emberAbilityInfoPageitems
();
const
fetch
TypeEnum
s
=
async
()
=>
{
const
res
=
await
PublicApi
.
getM
arketingCouponTypeList
();
if
(
res
.
code
===
1000
)
{
const
{
data
=
{}
}:
any
=
res
;
const
{
outerStatus
=
[],
}
=
data
;
const
outerIndex
=
columns
.
findIndex
((
item
)
=>
item
.
dataIndex
===
'memberTypeName'
);
if
(
outerIndex
)
{
columnsHandle
.
replace
(
outerIndex
,
{
...
columns
[
outerIndex
],
filters
:
outerStatus
.
map
(
item
=>
({
text
:
item
.
text
,
value
:
item
.
id
})).
filter
(
item
=>
item
.
value
!==
0
),
});
}
const
{
data
=
[]
}
=
res
;
return
{
innerStatus
:
outerStatus
.
map
(
item
=>
({
label
:
item
.
text
,
value
:
item
.
id
})),
type
:
data
.
map
(
item
=>
({
label
:
item
.
name
,
value
:
item
.
value
})),
};
}
return
{};
};
const
handleBatchVerify
=
()
=>
{
if
(
!
selectedRowKeys
.
length
)
{
message
.
warning
(
'未选择任何优惠券'
);
return
;
}
confirm
({
title
:
'提示'
,
icon
:
<
QuestionCircleOutlined
/>,
content
:
'确定要通过选中的优惠券吗?'
,
onOk
()
{
return
new
Promise
<
void
>
((
resolve
,
reject
)
=>
{
PublicApi
.
postMarketingCouponWaitSubmitSubmitBatch
({
ids
:
selectedRowKeys
,
})
.
then
(
res
=>
{
if
(
res
.
code
===
1000
)
{
ref
.
current
.
reload
();
setSelectedRowKeys
([]);
resolve
();
}
reject
();
})
.
catch
(()
=>
{
reject
();
});
});
},
});
};
const
ControllerBtns
=
()
=>
(
<
Space
size=
{
16
}
>
<
Button
onClick=
{
()
=>
{}
}
onClick=
{
handleBatchVerify
}
>
批量审核通过
</
Button
>
...
...
@@ -103,7 +144,7 @@ const MerchantCouponToConfirm: React.FC = () => {
<
Card
>
<
StandardTable
tableProps=
{
{
rowKey
:
'
validateI
d'
,
rowKey
:
'
i
d'
,
}
}
columns=
{
columns
}
currentRef=
{
ref
}
...
...
@@ -125,8 +166,8 @@ const MerchantCouponToConfirm: React.FC = () => {
FORM_FILTER_PATH
,
);
useAsyncInitSelect
(
[
'
outerStatus
'
],
fetch
SelectOption
s
,
[
'
type
'
],
fetch
TypeEnum
s
,
);
}
}
schema=
{
verifySchema
}
...
...
src/pages/transaction/marketingAbility/merchantCoupon/merchantCouponToConfirm/verify/index.tsx
View file @
14b70f40
...
...
@@ -6,17 +6,16 @@
* @Description:
*/
import
React
,
{
useState
}
from
'react'
;
import
{
history
}
from
'umi'
;
import
{
Button
}
from
'antd'
;
import
{
CheckCircleOutlined
}
from
'@ant-design/icons'
;
import
{
usePageStatus
}
from
'@/hooks/usePageStatus'
;
import
{
PublicApi
}
from
'@/services/api'
;
import
fetchDetailHoc
from
'../../common/hoc/fetchDetailHoc'
;
import
CouponDetail
from
'../../components/CouponDetail'
;
import
VerifyModal
,
{
ValueType
as
VerifyData
}
from
'../../components/VerifyModal'
;
const
MerchantCouponConfirm
:
React
.
FC
=
()
=>
{
const
{
id
}
=
usePageStatus
();
const
[
visibleVerifyModal
,
setVisibleVerifyModal
]
=
useState
(
false
);
const
[
submitLoading
,
setSubmitLoading
]
=
useState
(
false
);
const
CouponDetailPro
=
fetchDetailHoc
({
...
...
@@ -25,13 +24,22 @@ const MerchantCouponConfirm: React.FC = () => {
}),
},
CouponDetail
);
const
handleVisibleVerifyModal
=
(
flag
?)
=>
{
setVisibleVerifyModal
(
!!
flag
);
};
const
handleSubmit
=
(
value
:
VerifyData
)
=>
{
const
handleSubmit
=
()
=>
{
setSubmitLoading
(
true
);
console
.
log
(
'提交审核'
,
value
)
PublicApi
.
postMarketingCouponWaitSubmitSubmitBatch
({
ids
:
[
+
id
],
},
{
timeout
:
0
,
}).
then
(
res
=>
{
if
(
res
.
code
!==
1000
)
{
return
;
}
setTimeout
(()
=>
{
history
.
goBack
();
},
800
);
}).
finally
(()
=>
{
setSubmitLoading
(
false
);
});
};
return
(
...
...
@@ -41,19 +49,13 @@ const MerchantCouponConfirm: React.FC = () => {
<
Button
type=
"primary"
icon=
{
<
CheckCircleOutlined
/>
}
onClick=
{
()
=>
handleVisibleVerifyModal
(
true
)
}
loading=
{
submitLoading
}
onClick=
{
handleSubmit
}
>
单据审核
提交
</
Button
>
)
}
/>
<
VerifyModal
visible=
{
visibleVerifyModal
}
onClose=
{
()
=>
handleVisibleVerifyModal
(
false
)
}
submitLoading=
{
submitLoading
}
onSubmit=
{
handleSubmit
}
/>
</
div
>
);
};
...
...
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