Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
mr-julyedu
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
baiguangyao
mr-julyedu
Commits
29ff89a7
Commit
29ff89a7
authored
Sep 20, 2019
by
xuzhenghua
Browse files
Options
Browse Files
Download
Plain Diff
pull
parents
51b9a8eb
d9389d99
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
89 additions
and
73 deletions
+89
-73
src/App.js
+17
-9
src/components/detail/redPacket/index.js
+71
-63
src/components/passport/login/index.js
+1
-1
No files found.
src/App.js
View file @
29ff89a7
import
React
,
{
Component
}
from
'react'
import
React
,
{
Component
}
from
'react'
import
Routes
from
'./router'
import
cookie
from
'js-cookie'
import
{
connect
}
from
"react-redux"
;
import
{
setCurrentUser
,
startFetchUser
}
from
"@/store/userAction"
;
import
{
withRouter
}
from
'react-router-dom'
import
{
compose
}
from
'redux'
import
{
getParam
,
http
,
browser
}
from
"@/utils"
;
import
{
Toast
}
from
"antd-mobile"
;
import
{
addDays
}
from
'date-fns'
import
{
connect
}
from
"react-redux"
;
import
{
setCurrentUser
,
startFetchUser
}
from
"@/store/userAction"
;
import
{
withRouter
}
from
'react-router-dom'
import
{
compose
}
from
'redux'
import
{
getParam
,
http
,
browser
}
from
"@/utils"
;
import
{
Toast
}
from
"antd-mobile"
;
import
{
addDays
}
from
'date-fns'
//拦截ajax请求,返回mock数据
...
...
@@ -69,12 +69,18 @@ class App extends Component {
return
}
location
.
state
=
{
from
:
this
.
previousLocation
};
}
else
{
this
.
removeShareCodeCookie
()
}
})
}
removeShareCodeCookie
=
()
=>
{
cookie
.
remove
(
'share_code'
,
{
path
:
'/'
,
domain
:
'.julyedu.com'
})
}
setNavigationRecord
=
(
location
)
=>
{
let
{
location
:
_location
}
=
this
.
props
let
{
state
:
_state
=
{}}
=
_location
...
...
@@ -165,7 +171,7 @@ class App extends Component {
let
payload
if
(
res
.
data
.
code
===
200
)
{
//移除红包统计cookie
cookie
.
remove
(
'share_code'
,
{
path
:
'/'
,
domain
:
'.julyedu.com'
}
)
this
.
removeShareCodeCookie
(
)
const
{
msg
,
data
:
{
avatar_file
:
avatar
,
...
...
@@ -201,6 +207,8 @@ class App extends Component {
transformWxUser
=
res
=>
{
let
data
=
res
.
data
if
(
data
.
errno
==
200
)
{
//移除红包统计cookie
this
.
removeShareCodeCookie
()
let
{
uid
,
token
,
avatar_file
:
avatar
,
uname
:
username
,}
=
data
.
data
return
{
...
...
src/components/detail/redPacket/index.js
View file @
29ff89a7
...
...
@@ -40,7 +40,7 @@ class RedPacket extends PureComponent {
endTime
:
10
,
// 手机绑定时限
countdownTimer
:
null
,
countdown
:
'00分00秒'
,
// 绑定时间
accountInfo
:
{},
accountInfo
:
{},
bindInfo
:
{},
country
:
{
num
:
'86'
...
...
@@ -55,12 +55,16 @@ class RedPacket extends PureComponent {
// 分享链接进入
this
.
judgePopupType
();
window
.
addEventListener
(
'beforeunload'
,
this
.
removeStatisticsCookie
)
// 微信进入
const
isWechat
=
getParam
(
'wechat'
);
const
{
userInfo
}
=
this
.
props
;
if
(
!
userInfo
||
!
userInfo
.
uid
)
{
this
.
setRelativeCookie
()
}
if
(
isWechat
===
'1'
&&
!
browser
.
isWeixin
)
{
if
(
userInfo
&&
userInfo
.
uid
)
{
const
type
=
window
.
localStorage
.
getItem
(
'redpacket-click'
);
...
...
@@ -114,13 +118,11 @@ class RedPacket extends PureComponent {
componentWillUnmount
()
{
window
.
removeEventListener
(
'beforeunload'
,
this
.
removeStatisticsCookie
)
this
.
removeStatisticsCookie
()
}
// 获取分享信息
fetchShareInfo
=
()
=>
{
const
share_code
=
getParam
(
'share_code'
);
http
.
get
(
`
${
API
.
home
}
/sys/redPacket/shareUrl/
${
getParam
(
'id'
)}
`
).
then
(
res
=>
{
const
{
code
,
data
}
=
res
.
data
;
...
...
@@ -161,7 +163,7 @@ class RedPacket extends PureComponent {
});
}
else
{
// is_receive 是否领取过 0-否 1-是
// is_receive 是否领取过 0-否 1-是
if
(
data
.
is_receive
)
{
this
.
judgeReceiveStatus
(
data
);
}
else
{
...
...
@@ -204,7 +206,7 @@ class RedPacket extends PureComponent {
const
{
code
,
data
}
=
res
.
data
;
if
(
code
===
200
)
{
// is_receive 是否领取过 0-否 1-是
// is_receive 是否领取过 0-否 1-是
if
(
data
.
is_receive
)
{
this
.
judgeReceiveStatus
(
data
,
8
);
}
else
{
...
...
@@ -305,8 +307,15 @@ class RedPacket extends PureComponent {
history
.
push
(
`/detail?id=
${
getParam
(
'id'
)}
&wechat=1`
);
}
else
{
if
(
userInfo
&&
userInfo
.
uid
)
{
this
.
setState
({
type
:
1
// 领取好友的后,再领取自己的 share_code 未更新
http
.
get
(
`
${
API
.
home
}
/sys/redPacket/shareUrl/
${
getParam
(
'id'
)}
`
).
then
(
res
=>
{
const
{
code
,
data
}
=
res
.
data
;
if
(
code
===
200
)
{
this
.
setState
({
shareInfo
:
data
,
type
:
1
});
}
});
}
else
{
history
.
push
(
'/passport/login'
);
...
...
@@ -561,7 +570,7 @@ class RedPacket extends PureComponent {
const
{
accountInfo
:
{
tel
,
code
},
country
:
{
num
=
'0086'
}
}
=
this
.
state
;
// is_valid 是否验证 1:验证(默认),0不验证
http
.
post
(
`
${
API
[
'passport-api'
]}
/m/personal/bindPhone`
,
`
${
API
[
'passport-api'
]}
/m/personal/bindPhone`
,
{
area_code
:
num
.
padStart
(
4
,
'0'
),
phone_num
:
tel
,
...
...
@@ -594,24 +603,23 @@ class RedPacket extends PureComponent {
//设置统计信息
setRelativeCookie
=
()
=>
{
const
config
=
{
path
:
'/'
,
domain
:
'.julyedu.com'
}
const
{
shareInfo
}
=
this
.
state
cookie
.
set
(
'share_code'
,
shareInfo
&&
shareInfo
.
share_code
?
shareInfo
.
share_code
:
'share_code:share_code'
,
config
)
cookie
.
set
(
'share_code'
,
getParam
(
'share_code'
)
?
getParam
(
'share_code'
)
:
'share_code'
,
config
)
}
render
()
{
// console.log(this.props);
const
{
history
,
userInfo
}
=
this
.
props
;
const
{
type
,
isCopy
,
validate
,
isTimer
,
seconds
,
const
{
type
,
isCopy
,
validate
,
isTimer
,
seconds
,
shareInfo
:
{
command
=
''
,
share_code
=
''
},
money
,
},
money
,
doneInfo
,
countdown
,
endTime
,
...
...
@@ -636,7 +644,7 @@ class RedPacket extends PureComponent {
{
/* wechat */
}
{
type
==
2
&&
type
==
2
&&
<
div
className
=
"pupup-wechat"
>
<
h4
className
=
"popup-wechat__title"
>
当前环境不支持领红包活动
<
/h4
>
<
p
className
=
"popup-wechat__desc"
>
请点击右上角“
···
”,选择在浏览器中打开
然后参与活动!
<
/p
>
...
...
@@ -657,7 +665,7 @@ class RedPacket extends PureComponent {
{
!
isCopy
?
userInfo
&&
userInfo
.
uid
?
(
<
CopyToClipboard
<
CopyToClipboard
text
=
{
command
}
onCopy
=
{()
=>
this
.
setState
({
isCopy
:
true
...
...
@@ -667,8 +675,8 @@ class RedPacket extends PureComponent {
<
/CopyToClipboard
>
)
:
(
<
button
className
=
"popup-password__button--copy"
<
button
className
=
"popup-password__button--copy"
onClick
=
{()
=>
{
window
.
localStorage
.
setItem
(
'redpacket-click'
,
'copy'
);
history
.
push
(
'/passport/login'
);
...
...
@@ -683,8 +691,8 @@ class RedPacket extends PureComponent {
自己也可以领取哦
~
<
/p
>
<
/div
>
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
onClick
=
{()
=>
{
if
(
getParam
(
'wechat'
)
===
'1'
)
{
if
(
userInfo
&&
userInfo
.
uid
)
{
...
...
@@ -707,14 +715,14 @@ class RedPacket extends PureComponent {
<
/div
>
}
{
/* red-packet--close */
}
{
/* red-packet--close */
}
{
type
===
3
&&
<
Packet
<
Packet
type
=
{
3
}
packetInfo
=
{{
title
:
'七月在线给你发了个红包~'
}}
handleToClose
=
{()
=>
this
.
handleToClose
(
false
)}
handleToOpen
=
{
this
.
handleToOpen
}
...
...
@@ -724,7 +732,7 @@ class RedPacket extends PureComponent {
{
/* red-packet--open */
}
{
type
===
4
&&
<
Packet
<
Packet
type
=
{
4
}
packetInfo
=
{{
money
,
...
...
@@ -745,7 +753,7 @@ class RedPacket extends PureComponent {
{
/* red-packet--money success */
}
{
type
===
5
&&
<
Packet
<
Packet
type
=
{
5
}
packetInfo
=
{{
money
,
...
...
@@ -768,7 +776,7 @@ class RedPacket extends PureComponent {
{
/* red-packet--fragment success */
}
{
type
===
6
&&
<
Packet
<
Packet
type
=
{
6
}
packetInfo
=
{{
money
,
...
...
@@ -791,7 +799,7 @@ class RedPacket extends PureComponent {
{
/* red-packet--late 来完了 */
}
{
type
===
7
&&
<
Packet
<
Packet
type
=
{
7
}
packetInfo
=
{{
btn
:
{
...
...
@@ -819,7 +827,7 @@ class RedPacket extends PureComponent {
}}
validate
=
{({
tel
,
code
})
=>
{
const
errors
=
{};
// if (!validateTel(tel)) {
if
(
!
/^
\d
+$/
.
test
(
tel
))
{
errors
.
tel
=
'请填写正确格式的手机号'
;
...
...
@@ -827,7 +835,7 @@ class RedPacket extends PureComponent {
if
(
!
/
[
0-9
]{6}
/
.
test
(
code
))
{
errors
.
code
=
'请输入验证码'
;
}
return
errors
;
}}
onSubmit
=
{(
values
,
{
setStatus
,
setSubmitting
})
=>
{
...
...
@@ -842,8 +850,8 @@ class RedPacket extends PureComponent {
<
Form
className
=
"popup-form__content"
>
<
h4
className
=
"popup-form__title"
>
绑定手机号
<
/h4
>
<
div
className
=
"popup-form__item"
>
<
a
className
=
"popup-form__button--num"
<
a
className
=
"popup-form__button--num"
href
=
{
`/country?id=
${
getParam
(
'id'
)}
&share_code=
${
share_code
}
`
}
>
+
{
country
.
num
}
<
i
className
=
"iconfont iconiconfront-69"
><
/i
>
...
...
@@ -852,9 +860,9 @@ class RedPacket extends PureComponent {
name
=
"tel"
render
=
{({
field
})
=>
{
return
(
<
input
<
input
{...
field
}
className
=
"popup-form__ipt"
className
=
"popup-form__ipt"
data
-
bdrs
=
"0 6px 6px 0"
data
-
type
=
"tel"
type
=
"text"
...
...
@@ -864,7 +872,7 @@ class RedPacket extends PureComponent {
}}
/
>
<
/div
>
<
Captcha
<
Captcha
mrBtm
=
{
15
}
getInstance
=
{
this
.
getCaptchaInstance
}
onVerify
=
{
this
.
onVerify
}
...
...
@@ -878,8 +886,8 @@ class RedPacket extends PureComponent {
绑定超时,红包已失效
!
<
/p
>
<
/div
>
<
button
className
=
"popup-packet__button--bundle"
<
button
className
=
"popup-packet__button--bundle"
data
-
status
=
"do"
type
=
"button"
onClick
=
{()
=>
{
...
...
@@ -894,7 +902,7 @@ class RedPacket extends PureComponent {
name
=
"code"
render
=
{({
field
})
=>
{
return
(
<
input
<
input
{...
field
}
className
=
"popup-form__ipt popup-form__ipt--left"
type
=
"text"
...
...
@@ -903,7 +911,7 @@ class RedPacket extends PureComponent {
);
}}
/
>
<
button
<
button
className
=
"popup-form__button--code"
data
-
status
=
{(
validate
&&
!
isTimer
)?
'do'
:
''
}
type
=
"button"
...
...
@@ -914,8 +922,8 @@ class RedPacket extends PureComponent {
}
<
/button
>
<
/div
>
<
button
className
=
"popup-packet__button--bundle"
<
button
className
=
"popup-packet__button--bundle"
data
-
status
=
{(
tel
&&
code
&&
isEmpty
(
errors
))?
'do'
:
'done'
}
type
=
"submit"
>
...
...
@@ -927,8 +935,8 @@ class RedPacket extends PureComponent {
<
/Form
>
)}
/
>
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
onClick
=
{()
=>
this
.
handleToClose
(
false
)}
/
>
<
/div
>
...
...
@@ -947,8 +955,8 @@ class RedPacket extends PureComponent {
{
doneInfo
.
txt
}
<
/h4
>
<
p
className
=
"popup-done__desc"
>
{
doneInfo
.
desc
}
<
/p
>
<
button
className
=
"popup-packet__button--bundle"
<
button
className
=
"popup-packet__button--bundle"
data
-
status
=
"do"
type
=
"submit"
onClick
=
{()
=>
{
...
...
@@ -956,8 +964,8 @@ class RedPacket extends PureComponent {
}}
>
获取更多奖励
<
/button
>
<
/div
>
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
onClick
=
{()
=>
{
const
isShare
=
getParam
(
'share_code'
)?
true
:
false
;
this
.
handleToClose
(
false
,
isShare
);
...
...
@@ -968,7 +976,7 @@ class RedPacket extends PureComponent {
{
/* 手机号绑定提示 */
}
{
type
===
10
&&
type
===
10
&&
<
div
className
=
"popup-bind"
>
<
div
className
=
"popup-bind__content"
>
<
h4
className
=
"popup-bind__title"
>
绑定确认
<
/h4
>
...
...
@@ -977,7 +985,7 @@ class RedPacket extends PureComponent {
{
bindInfo
[
'email'
]
&&
<
li
className
=
"popup-bind__account"
>
{
/* 邮箱 */
}
<
i
className
=
"iconfont iconduanxin"
><
/i
>
<
p
className
=
"popup-bind__account--name"
>
{
bindInfo
[
'email'
]}
<
/p
>
...
...
@@ -1012,16 +1020,16 @@ class RedPacket extends PureComponent {
}
<
/ul
>
<
div
className
=
"popup-bind__button"
>
<
button
className
=
"popup-bind__button--cancle"
<
button
className
=
"popup-bind__button--cancle"
onClick
=
{()
=>
this
.
handleToClose
(
false
)}
>
取消
<
/button
>
<
button
className
=
"popup-bind__button--confirm"
<
button
className
=
"popup-bind__button--confirm"
onClick
=
{()
=>
this
.
toContinueBind
(
0
)}
>
继续绑定
<
/button
>
<
/div
>
<
/div
>
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
onClick
=
{()
=>
this
.
handleToClose
(
false
)}
/
>
<
/div
>
...
...
@@ -1083,7 +1091,7 @@ const Packet = ({type, packetInfo, handleToClose, handleToOpen }) => {
})
}
<
/p
>
<
button
<
button
className
=
"popup-packet__button--bundle"
onClick
=
{
btn
.
onClick
}
>
...
...
@@ -1099,7 +1107,7 @@ const Packet = ({type, packetInfo, handleToClose, handleToOpen }) => {
红包仅能当日领取,下次
<
br
/>
早点来哦
~
<
/p
>
<
button
<
button
className
=
"popup-packet__button--bundle"
onClick
=
{
btn
.
onClick
}
>
...
...
@@ -1108,8 +1116,8 @@ const Packet = ({type, packetInfo, handleToClose, handleToOpen }) => {
<
/
>
}
<
/div
>
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
<
i
className
=
"popup-password__button--close iconfont iconiconfront-2"
onClick
=
{
handleToClose
}
/
>
<
/div
>
...
...
src/components/passport/login/index.js
View file @
29ff89a7
...
...
@@ -148,7 +148,7 @@ const FormikConfig = {
validateOnChange
:
true
,
validate
:
(
values
)
=>
{
let
errors
=
{}
if
(
!
validateTel
(
values
.
tel
))
{
if
(
!
/
\d
/
.
test
(
values
.
tel
))
{
errors
.
tel
=
'请填写正确格式的手机号'
}
if
(
!
/
[
0-9
]{6}
/
.
test
(
values
.
veriCode
))
{
...
...
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