import React, {Component} from 'react';
import {Accordion, Toast} from 'antd-mobile';
import {HeaderBar, CallApp} from '@/common';
import {http, getParam} from '@/utils';
import './index.scss';
import {Link} from "react-router-dom"
import {connect} from "react-redux";
import Mask from './../poup/index.js'
import ShareRank from "@components/detail/shareRank"

class PythonStudy extends Component {
    constructor(props) {
        super(props);
        this.state = {
            toApp: false,
            courseInfo: '',
            syllabus: '',
            learning: '',
            isShowChannel: window.sessionStorage.getItem('isShowSiteWindowByChannel')
        };
    }

    componentDidMount() {
        this.fetchCourseDetail();
    }

    fetchCourseDetail = () => {
        http.get(`${API['home']}/web/it_detail?course_id=${getParam('id')}&is_pay=1`).then(res => {
            const {data, code, msg} = res.data;
            if (code === 200) {
                this.setState({
                    courseInfo: data.course_info,
                    syllabus: data.syllabus,
                    learning: data.learning
                })
            } else {
                Toast.info(msg, 2)
            }
        });
    }

    Change = (data) => {
        let cn = ["一", "二", "三", "四", "五", "六", "七", "八", "九", '十'];
        let newStr = ''
        let str = data.toString()
        let ci = Number(str) % 10
        let cs = Math.floor(Number(str) / 10)
        let cv = ''
        if (str.length > 1) {
            if (cs == 1) {
                cv = ci >= 1 ? cn[9] + cn[ci - 1] : cn[9]
            } else {
                cv = ci > 1 ? cn[cs - 1] + cn[9] + cn[ci - 1] : cn[cs - 1] + cn[9]
            }
        } else {
            cv = cn[ci - 1]
        }
        newStr = str.replace(str, cv)
        return newStr;
    }

    onChange = (key) => {
        console.log(key);
    }

    toPythonHome = (isUnlock) => {
        if (isUnlock == 1) {
            this.setState({
                toApp: true
            })
        }
    }

    toLearn = () => {
        this.setState({
            toApp: true
        })
    }
    closePop = () => {
        this.setState({
            toApp: false,
        })
    }

    render() {
        const {user} = this.props;
        const uid = user && user.data && user.data.uid
        const {courseInfo, syllabus, learning, toApp} = this.state;
        return (
            <div className="python-study">
                <HeaderBar title='Python基础语法' arrow={true}/>
                <div className="python-study__header">
                    <div className="python-study__course">
                        <h2 className="python-study__course-name">Python人工智能</h2>
                        <p className="python-study__course-contact">
                            <span>{courseInfo.contact_type == 1 ? '上课请加QQ学习群' : '添加助教微信入群'}:{courseInfo.course_qq}</span>
                            <span>并备注您的学号:{uid}</span>
                        </p>
                    </div>
                    {
                        learning.schedule > 0 &&
                        <div className="python-study__progress">
                            <h2 className="python-study__progress-title">学习进度</h2>
                            <div className="python-study__progress-bar">
                                <i style={{width: learning.schedule + '%'}}/>
                                <span className="python-study__progress-tip"
                                      style={{left: learning.schedule + '%'}}>{learning.schedule + '%'}</span>
                            </div>
                        </div>
                    }

                </div>
                {
                    !!courseInfo.is_dist && <div className={'dist-wrapper'}>
                        <ShareRank courseInfo={courseInfo}/>
                    </div>
                }

                {
                    this.state.isShowChannel == 1 &&
                    <CallApp className='toapp'/>
                }

                <Accordion
                    defaultActiveKey="0"
                    className="python-study__stage"
                    onChange={this.onChange}
                >
                    {
                        syllabus && syllabus.length > 0 && syllabus.map((syllabusItem, index) => {
                            let header = `第${this.Change(syllabusItem.stage)}阶段:${syllabusItem.name}`
                            return (
                                <Accordion.Panel header={header} className="pad" key={index}>
                                    {
                                        syllabusItem.lessons && syllabusItem.lessons.length > 0 && syllabusItem.lessons.map((lessonsItem, index) => {
                                            return (
                                                <div key={index}>
                                                    <h2 className="python-study__pass">
                                                        第{lessonsItem.shut}关 {lessonsItem.name}
                                                        {
                                                            lessonsItem.complete == 1 &&
                                                            <i className="python-study__pass-tag">闯关完成</i>
                                                        }
                                                    </h2>

                                                    <div className="python-study__subject"
                                                         style={{opacity: lessonsItem.info.is_unlock == 0 ? '.6' : '1'}}
                                                         onClick={() => {
                                                             this.toPythonHome(lessonsItem.info.is_unlock)
                                                         }}
                                                         key={index}>
                                                        <img className="python-study__subject-icon"
                                                             src={lessonsItem.info.img_url} alt=""/>
                                                        {
                                                            lessonsItem.info.is_unlock == 1 && lessonsItem.info.complete == 1 &&
                                                            <i className="python-study__subject-status"
                                                               data-status="complete"/>
                                                        }
                                                        {
                                                            lessonsItem.info.is_unlock == 0 &&
                                                            <i className="python-study__subject-status"
                                                               data-status="lock"/>
                                                        }
                                                        <div className="python-study__subject-content">
                                                            <h2 className="python-study__subject-title text-overflow-1">{lessonsItem.info.name}</h2>
                                                        </div>
                                                    </div>

                                                    {
                                                        lessonsItem.questions && lessonsItem.questions.length > 0 && lessonsItem.questions.map((item, index) => {
                                                            return (
                                                                <div className="python-study__subject"
                                                                     style={{opacity: item.is_unlock == 0 ? '.6' : '1'}}
                                                                     onClick={() => {
                                                                         this.toPythonHome(item.is_unlock)
                                                                     }}
                                                                     key={index}>
                                                                    <img className="python-study__subject-icon"
                                                                         src={item.icon} alt=""/>
                                                                    {
                                                                        item.is_unlock == 1 && item.complete == 1 &&
                                                                        <i className="python-study__subject-status"
                                                                           data-status="complete"/>
                                                                    }
                                                                    {
                                                                        item.is_unlock == 1 && item.complete == 0 &&
                                                                        <i className="python-study__subject-status"
                                                                           data-status="lock"/>
                                                                    }
                                                                    <div className="python-study__subject-content">
                                                                        <h2 className="python-study__subject-title text-overflow-1">{item.name}</h2>
                                                                        {
                                                                            item.is_must == 1 &&
                                                                            <span
                                                                                className="python-study__subject-tag">必做练习</span>
                                                                        }
                                                                    </div>
                                                                </div>
                                                            )
                                                        })
                                                    }
                                                </div>
                                            )
                                        })
                                    }
                                </Accordion.Panel>
                            )
                        })
                    }
                </Accordion>
                {
                    learning.schedule == 0 &&
                    <span onClick={this.toLearn} className="python-study__button">开始学习</span>
                }
                {
                    learning.schedule != 0 && learning.schedule != 100 &&
                    <span onClick={this.toLearn} className="python-study__button">继续学习</span>
                }
                {
                    learning.schedule == 100 &&
                    <button className="python-study__button python-study__over">已学完全部课时</button>
                }

                {
                    toApp && <Mask closePop={this.closePop} type={2} />
                }
            </div>
        )
    }
}


export default connect(
    state => ({user: state.user}),
    null
)(PythonStudy);