/* eslint-disable jsx-a11y/anchor-is-valid, no-script-url */
import React, { Component } from "react"
import "./index.scss"
import { Tabs, Toast } from "antd-mobile"
import { http } from "src/utils"
import storage from "store2"
import { html } from "src/utils"
import { compareDesc } from "date-fns"
import { Link } from "react-router-dom"
import { connect } from "react-redux"

class Scores extends Component {
  store = storage.namespace("aiTestEntry")

  state = {
    selfTabs: [
      { title: "当前成绩" },
      { title: "今日最佳" },
      { title: "本月最佳" },
    ],
    rankList: [],
    rankListTabs: [{ title: "日榜" }, { title: "总榜" }],
    isExpandRankList: false,
    icons: [
      require("./rank-1.png"),
      require("./rank-2.png"),
      require("./rank-3.png"),
    ],
    isShowRule: false,
    isNeverShow: this.store.get("isNeverShow"),
    pageState: {},
    availableTestNum: 0,
    userScore: {},
    userAddress: {
      name: "",
      phone: "",
      address: "",
    },
    isShowUserAddress: false,
    entryButtonInRule: false,
  }

  componentDidMount() {
    this.getInitialData()
    this.getRankList(null, 0)
    if (!this.props.user.hasError) {
      this.getUserScores(0)
      this.getUserAddress()
    }
  }

  componentDidUpdate(prevProps, prevState) {
    if (this.props.user.hasError !== prevProps.user.hasError) {
      this.getUserScores(0)
      this.getUserAddress()
    }
  }

  handleChange = (e) => {
    const isNeverSHow = e.target.checked
    this.setState({
      isNeverSHow,
    })
    this.store.set("isNeverShow", isNeverSHow)
  }

  startTest = () => {
    this.props.history.push("/ai-test/exam")
  }

  getInitialData = () => {
    http.get(`${API.home}/sys/activity_data`).then((res) => {
      const { code, msg, data } = res.data
      if (code === 200) {
        this.setState({
          pageState: data,
        })
      } else if (code === 3009) {
        this.props.history.push("/")
      } else {
        Toast.fail(msg, 2, null, false)
      }
    })
  }

  getRankList = (tab, type) => {
    http.get(`${API.home}/sys/at/ranks/${type === 0 ? 0 : 2}`).then((res) => {
      const { code, msg, data } = res.data
      if (code === 200) {
        this.setState({
          rankList: data,
        })
      } else {
        Toast.fail(msg, 2, null, false)
      }
    })
  }

  getUserScores = (type) => {
    http.get(`${API.home}/sys/at/user_score/${type}/0`).then((res) => {
      const { code, msg, data } = res.data

      if (code === 200) {
        this.setState({
          userScore: data,
        })
      } else {
        Toast.fail(msg, 2, null, false)
      }
    })
  }

  getUserAddress = () => {
    http.get(`${API.home}/sys/user_address_info`).then((res) => {
      const { code, data } = res.data
      if (code === 200) {
        this.setState({
          userAddress: data,
        })
      }
    })
  }

  inputText = (e) => {
    const key = e.target.name
    const value = e.target.value
    this.setState((state) => {
      return {
        userAddress: {
          ...state.userAddress,
          ...{
            [key]: value,
          },
        },
      }
    })
  }

  submitForm = (e) => {
    e.preventDefault()
    const { userAddress } = this.state
    if (!Object.values(userAddress).every((item) => !!item)) {
      Toast.info("请填写完整")
      return
    }
    http.post(`${API.home}/sys/update_address`, userAddress).then((res) => {
      const { code, msg } = res.data
      if (code === 200) {
        Toast.success("提交成功", 2, null, false)
        this.setState({
          isShowUserAddress: false,
        })
      } else {
        Toast.fail(msg, 2, null, false)
      }
    })
  }

  render() {
    const {
      selfTabs,
      rankList,
      rankListTabs,
      icons,
      isExpandRankList,
      isShowRule,
      isNeverShow,
      pageState,
      userScore,
      isShowUserAddress,
      userAddress,
      entryButtonInRule,
    } = this.state
    const { user, history } = this.props
    const _rankList = Array.isArray(rankList)
      ? isExpandRankList
        ? rankList
        : rankList.slice(0, 10)
      : []
    return (
      <div className={"scores"}>
        <div className="banner">
          <img src={pageState.h5_banner} alt="" />
        </div>
        <div className="info">
          <span>已有{pageState.join_num}人参加测试</span>
          <a
            href="javascript:void(0);"
            onClick={() => {
              this.setState({
                isShowRule: true,
              })
            }}
          >
            规则
          </a>
        </div>
        {
          <div className="score-list">
            <Tabs
              tabs={selfTabs}
              tabBarUnderlineStyle={{ display: "none" }}
              onChange={(tab, i) => {
                this.getUserScores(i)
              }}
            >
              {selfTabs.map((tab, index) => {
                return (
                  <div className={"tab-content"} key={index}>
                    <table>
                      <thead>
                        <tr>
                          <th>分数</th>
                          <th>用时</th>
                          <th>{index === 0 && "最终"}排名</th>
                        </tr>
                      </thead>
                      <tbody>
                        {user.hasError ? (
                          <tr>
                            <td>--</td>
                            <td>--</td>
                            <td>--</td>
                          </tr>
                        ) : (
                          <tr>
                            {userScore.score === "-" ? (
                              <td>'-'</td>
                            ) : (
                              <td>
                                {userScore.score}{" "}
                                <Link
                                  to={`/ai-test/analysis/${userScore.r_id}`}
                                >
                                  解析
                                </Link>
                              </td>
                            )}
                            <td>{userScore.cost_time}</td>
                            {userScore.rank === "-" ? (
                              <td>'-'</td>
                            ) : (
                              <td>{userScore.rank}名</td>
                            )}
                          </tr>
                        )}
                      </tbody>
                    </table>
                  </div>
                )
              })}
            </Tabs>
            <div className="share">
              <Link to={"/ai-test/report"}>分享</Link>
            </div>
          </div>
        }
        <div className="rank-list">
          <div className="head">
            <div>测试排行榜</div>
            <div>
              <span>仅显示前50名</span>
              <a
                href="javascript:void(0);"
                onClick={() => {
                  if (user.hasError) {
                    history.push("/passport")
                  } else {
                    this.setState({
                      isShowUserAddress: true,
                    })
                  }
                }}
              >
                收货地址
              </a>
            </div>
          </div>
          <div className="list">
            <Tabs
              tabs={rankListTabs}
              tabBarUnderlineStyle={{ display: "none" }}
              onChange={this.getRankList}
            >
              {rankListTabs.map((item, index) => {
                return (
                  <table key={index}>
                    <thead>
                      <tr>
                        <th>名次</th>
                        <th>昵称</th>
                        <th>成绩</th>
                        <th>奖品</th>
                      </tr>
                    </thead>
                    <tbody>
                      {!!_rankList.length &&
                        _rankList.map((item, index) => {
                          return (
                            <tr key={index}>
                              <td>
                                {index < 3 ? (
                                  <img src={icons[index]} alt="" />
                                ) : (
                                  index + 1
                                )}
                              </td>
                              <td>
                                <img
                                  src={item.avatar}
                                  className={"avatar"}
                                  alt=""
                                />
                                {item.user_name}
                              </td>
                              <td>
                                <span className={"score"}>{item.score}</span>/
                                <span>{item.cost_time}</span>
                              </td>
                              <td>
                                <div>
                                  {item.prize_url ? (
                                    <a href={`${item.prize_url}#goback`}>
                                      {item.prize}
                                    </a>
                                  ) : (
                                    item.prize
                                  )}
                                </div>
                              </td>
                            </tr>
                          )
                        })}
                    </tbody>
                  </table>
                )
              })}
            </Tabs>
            {rankList.length > 10 &&
              (!isExpandRankList ? (
                <div
                  className="expand"
                  onClick={() => {
                    this.setState({
                      isExpandRankList: true,
                    })
                  }}
                >
                  <span>
                    展开更多
                    <i className={"iconfont iconiconfront-69"}></i>
                  </span>
                </div>
              ) : (
                <div
                  className="expand"
                  onClick={() => {
                    this.setState({
                      isExpandRankList: false,
                    })
                  }}
                >
                  <span>
                    收起
                    <i className={"iconfont iconiconfront-71"}></i>
                  </span>
                </div>
              ))}
          </div>
        </div>
        <div className="qrcode">
          <img
            src="https://julyedu-cdn.oss-cn-beijing.aliyuncs.com/ai-test/qr.png"
            alt=""
          />
          <div>得100分,请长按/扫码,免费领课!</div>
        </div>
        <div className="btn">
          {compareDesc(new Date(), pageState.stop_time * 1000) > 0 ? (
            pageState.daily_test_num > 0 ? (
              <button
                className={"available"}
                onClick={() => {
                  isNeverShow
                    ? this.startTest()
                    : this.setState({
                        entryButtonInRule: true,
                        isShowRule: true,
                      })
                }}
              >
                开始测试<span>(今日可测试{pageState.daily_test_num}次)</span>
              </button>
            ) : (
              <Link to={`/ai-test/share?shareCode=${pageState.code}`}>
                <button className={"get-chance"}>
                  获取测试机会<span>(今日可测试0次)</span>
                </button>
              </Link>
            )
          ) : (
            <button className={"unavailable"}>活动已结束</button>
          )}
        </div>
        {isShowRule && (
          <Rule
            rule={pageState.rule}
            startTest={this.startTest}
            neverShow={this.handleChange}
            isNeverShow={isNeverShow}
            close={() => {
              this.setState({
                isShowRule: false,
                entryButtonInRule: false,
              })
            }}
            entryButtonInRule={entryButtonInRule}
          />
        )}
        {isShowUserAddress && (
          <div className="user-address-wrapper">
            <div className="user-address">
              <div className="title">收货信息</div>
              <div className="tip">
                获奖用户(以最终榜单为准)请及时填写收货信息
              </div>
              <form action="" onSubmit={this.submitForm}>
                <input
                  type="text"
                  placeholder={"收件人"}
                  name={"name"}
                  onChange={this.inputText}
                  value={userAddress.name}
                />
                <input
                  type="tel"
                  placeholder={"联系方式"}
                  name={"phone"}
                  onChange={this.inputText}
                  value={userAddress.phone}
                />
                <input
                  type="text"
                  placeholder={"收货地址"}
                  name={"address"}
                  onChange={this.inputText}
                  value={userAddress.address}
                />
                <button
                  type={"submit"}
                  className={
                    Object.values(userAddress).every((value) => !!value)
                      ? "available"
                      : ""
                  }
                >
                  提交
                </button>
              </form>
              <i
                className={"close iconfont iconiconfront-2"}
                onClick={() => {
                  this.setState({
                    isShowUserAddress: false,
                  })
                }}
              />
            </div>
          </div>
        )}
      </div>
    )
  }
}

function Rule({
  neverShow,
  isNeverShow,
  rule,
  close,
  startTest,
  entryButtonInRule,
}) {
  return (
    <div className="rule-mask">
      <div className="rule">
        <div>测试规则</div>
        <div dangerouslySetInnerHTML={html(rule)}></div>
        {entryButtonInRule && (
          <>
            <div className="option">
              <input
                id={"never-show"}
                type="checkbox"
                onChange={neverShow}
                checked={isNeverShow}
              />
              <label htmlFor="never-show">不再提示</label>
            </div>
            <button onClick={startTest}>进入测试</button>
          </>
        )}
        <i className={"close iconfont iconiconfront-2"} onClick={close} />
      </div>
    </div>
  )
}

export default connect(({ user }) => ({ user }), null)(Scores)