import React, { Component } from 'react' import './index.scss' import { getParam, http, browser } from "@/utils"; import { Toast } from 'antd-mobile'; import { Link, withRouter } from "react-router-dom"; import { compose } from "redux"; import { connect } from "react-redux"; import { differenceInHours, differenceInMinutes, differenceInSeconds } from "date-fns"; class Single extends Component { constructor(props) { super(props) this.state = { // status: 1, orderId: '', nowPrice: '', laterPrice: '', hour: '', min: '', sec: '', endTime: '', groupOrderId: '', payType: '0', // 1支付宝 0微信 // singleBox: false, } } componentDidMount() { } componentWillReceiveProps(nextProps, nextContext) { // console.log(nextProps); // this.setState({ // singleBox: nextProps.singleBox // }) } // 选择支付方式 check = (type) => { this.setState({ payType: type }) } // 确定购买 toBuy = () => { const videoID = this.props.data.video_id || this.props.data.id; http.get(`${API.home}/sys/createClassOrder/${videoID}`).then((res) => { if (res.data.code === 200) { this.setState({ orderId: res.data.data.order_id }) this.state.payType === '1' ? this.alipayPay(res.data.data.order_id) : this.weixinPay(res.data.data.order_id) } else { Toast.info(res.data.msg, 2) } }) } // 微信支付 weixinPay = (orderId) => { // 微信内部-支付 if (browser.isWeixin) { window.location.href = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx23dac6775ac82877&redirect_uri=" + encodeURIComponent(window.location.href + "&aa=bb&oid=" + orderId).toLowerCase() + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect"; } else { // 微信外部-支付 http.get(`${API['base-api']}/pay/wxpay/wap_charge/oid/${orderId}`).then((res) => { if (res.data.errno === 0) { window.location.href = res.data.data.url + "&redirect_url=" + encodeURIComponent(window.location.href + "&weixinpay=1&oid=" + orderId).toLowerCase(); } else { Toast.info(res.data.msg, 2) } }) } } // 支付宝支付 alipayPay = (orderId) => { const courseId = getParam('id'); http.get(`${API['base-api']}/pay/alipay/wap_charge_new/oid/${orderId}`).then((res) => { if (res.data.errno === 0) { window.location = res.data.data.url; courseId && window.localStorage.setItem('payCourse', courseId); } else { Toast.info(res.data.msg, 2) } }) } // 特价购买全集 toBuyAll = (vcourseId) => { if(Number(this.props.isPdd) === 1) { this.props.history.push(`/order?id=${this.props.courseId}`, {group: 1}) }else{ let cidArr = JSON.stringify([Number(vcourseId)]); http.get(`${API['base-api']}/m/cart/addtopreorder/${cidArr}`).then((res) => { if (res.data.errno === 0) { this.props.history.push("/order?id=" + res.data.data[0], {simple: 1}); } else { Toast.info(res.data.msg, 2); } }) } } // 0元购买全集 zerobuyReceive = () => { Toast.success('购买全集成功', 3) this.colse() } // 0元参团 zerogroupBuy = () => { this.getOrderId() } // 获取订单号-0元参团 getOrderId = () => { let data = { course_id: getParam('id') } http.post(`${API['base-api']}/pdd/sys`, data).then((res) => { if (res.data.errno === 0) { this.setState({ groupOrderId: res.data.data.order_id }) this.getOrderStatus(res.data.data.order_id) } else { Toast.info(res.data.msg, 2) } }) } // 获取订单状态-0元参团 getOrderStatus = (id) => { http.get(`${API.home}/m/pdd/order_status/${id}`).then((res) => { if (res.data.code === 200) { this.getTime(res.data.data.pdd_order_id) } else { Toast.info(res.data.msg, 2) } }) } // 获取倒计时-0元参团 getTime = (id) => { http.get(`${API.home}/m/pdd_order_end_time/${id}`).then((res) => { if (res.data.code === 200) { this.setState({ endTime: res.data.data.end_time, status: 7 }) } else { Toast.info(res.data.msg, 2) } }) } // 邀请好友参团 toGroup = () => { this.props.history.push(`/togroup?id=${this.state.groupOrderId}`) } toLearn = (vcourseId, videoID) => { this.props.boxHide(false); this.props.history.push(`/play/video?id=${vcourseId}&video_id=${videoID}`); } // 关闭弹窗 colse = () => { this.props.boxHide(false); this.setState({ status: 1 }) } render() { let {singleBox} = this.state; if (this.state.endTime) { let date = this.state.endTime * 1000 let now = Date.now() setInterval(() => { date -= 1000 let s = differenceInSeconds(new Date(date), now) % 60, m = differenceInMinutes(new Date(date), now) % 60, h = differenceInHours(new Date(date), now) % 24 this.setState({ hour: h, min: m, sec: s, }) }, 1000) } const { singleType } = this.props; // console.log(this.props); const videoID = this.props.data.video_id || this.props.data.id; return ( <div className='popup-box'> { singleType === 2 && <div className='content payment-success'> <div className="header"> <i className='iconfont icondanseshixintubiao-5'></i> <span>购买成功</span> </div> <div className="dec">· 3天内购买全集,可直接抵扣该集费用,{this.props.nowPrice}元购买。</div> <div className="dec">· 超过3天,按照未购集数/全部集数等比例计费,{this.props.laterPrice}元购买全集。</div> <span onClick={()=>this.toLearn(this.props.vcourseId,videoID)} className='btn btn-18B4ED'>开始学习</span> <div className='btn btn-FF4000' onClick={()=>{this.toBuyAll(this.props.courseId)}}>¥{this.props.nowPrice}购买全集 </div> </div> } { singleType === 3 && <div className='content zero'> <div className="header"> <i className='iconfont icondanseshixintubiao-5'></i> <span>购买成功</span> </div> <div className="dec">· 恭喜您获得0元拼团购买剩余课时的机会。</div> <div className='btn btn-FF4000' onClick={this.zerogroupBuy}>0元参团</div> </div> } { singleType === 4 && <div className='content zero'> <div className="header"> <i className='iconfont icondanseshixintubiao-5'></i> <span>购买成功</span> </div> <div className="dec">· 恭喜您获得0元购买剩余课时的机会。</div> <div className='btn btn-FF4000' onClick={this.zerobuyReceive}>0元购</div> </div> } { singleType === 6 && <div className='content zero'> <div className="header"> <i className='iconfont icondanseshixintubiao-5'></i> <span>购买成功</span> </div> {/*<Link to={`/play/video?id=${this.props.vcourseId}&video_id=${videoID}`} className='btn btn-18B4ED'>去学习</Link>*/} <span onClick={()=>this.toLearn(this.props.vcourseId,videoID)} className='btn btn-18B4ED'>去学习</span> </div> } { singleType === 7 && <div className='content group'> <div className="header"> <i className='iconfont icondanseshixintubiao-5'></i> <span>参团成功</span> </div> <div className='group-img'> <img src={this.props.user.data.avatar} alt=""/> <img src="https://julyedu-cdn.oss-cn-beijing.aliyuncs.com/images/weekend/train7/ellipsis.png" alt=""/> <img src="https://julyedu-cdn.oss-cn-beijing.aliyuncs.com/images/weekend/train7/ellipsis.png" alt=""/> </div> <div className='btn-l btn-FF4000' onClick={this.toGroup}> 剩余{String(this.state.hour).padStart(2, 0)}:{String(this.state.min).padStart(2, 0)}:{String(this.state.sec).padStart(2, 0)} 邀请好友参团 </div> </div> } <i onClick={this.colse} className={'iconfont iconiconfront-2 close'}></i> </div> ); } } export default compose( connect( state => ({user: state.user}), null ), withRouter )(Single)