import React, { useEffect, useState, useRef } from 'react';
import { Switch, Button, Message, Spin, Modal } from 'antd';
// import axios from 'axios';

import BaseForm from '@/components/BaseForm/index';
import { getApkNameAndDate, SaveMobileApk } from '@/services/appConfig/api';
import { getMobileFiles } from '@/services/mobileConfig/api';

import styles from './otherConfig.less';

// const JSON_BASE = `${
//   location.origin
// }/cityinterface/rest/services/filedownload.svc/download/BufFile/Mobile/APK/`;

export default props => {
  console.log(props);
  const { clientName } = props;
  const items = [
    {
      label: '更新描述',
      dataIndex: 'describe',
      rules: [
        {
          required: true,
          message: '请输入apk的更新描述',
        },
      ],
      formType: 'INPUT',
    },
    {
      label: '强制更新',
      dataIndex: 'forceUpdate',
      initialValue: 1,
      rules: [
        {
          required: true,
          message: '请选择是否强制更新',
        },
      ],
      options: [
        {
          children: '是',
          value: 1,
        },
        {
          children: '否',
          value: 0,
        },
      ],
      formType: 'SINGLE_RADIO',
    },
  ];

  const formEntity = useRef(null);
  const fileEntity = useRef(null);
  const [loading, setLoading] = useState(false); // 显示请求的loading
  const [showModal, setShowModal] = useState(false); // 显示更新的modal
  const [fileData, setFileData] = useState({}); // 获取到的包名和更新时间
  const [file, setFile] = useState({}); // 上传的文件
  const [fileSuccess, setFileSuccess] = useState(false); // 本地文件是否成功
  const [progress, setProgress] = useState(false); // 是否正在保存
  const [upFlag, setUpFlag] = useState(1);

  // const uploadProps = {
  //   name: 'file',
  //   action: `${window.location.origin}${PUBLISH_SERVICE}/FileCenter/UploadSingleFile`,
  //   headers: {
  //     Authorization: 'Bearer ' + localStorage.getItem('token') || '',
  //   },
  //   onChange(info) {
  //     console.log(info)
  //     setFile(info.file);
  //   },
  // };

  const submitForm = () => {
    console.log(formEntity);
    const { validateFields } = formEntity.current;
    validateFields()
      .then(values => {
        const { describe, forceUpdate } = values;
        const formData = new FormData();
        formData.set('description', describe);
        formData.set('isRefresh', !!forceUpdate);
        formData.set('file', file);
        formData.set('client', clientName);
        setProgress(true);
        SaveMobileApk(formData).then(res => {
          console.log(res);
          setProgress(false);
          if (Number(res.code) === 0) {
            Message.success('更新成功');
            setUpFlag(upFlag + 1);
            setShowModal(false);
            init();
          } else {
            // Message.error(res.msg);
          }
        });
      })
      .catch(res => {
        const { errorFields, values } = res;
        console.log(errorFields, values);
      });
  };

  const handleGetForm = form => {
    formEntity.current = form;
  };

  const handleFileChange = e => {
    console.log(e.target.files);
    setFile(e.target.files[0]);
    setFileSuccess(true);
  };

  const handleUpload = () => {
    fileEntity.current.click();
  };

  const init = () => {
    // getApkNameAndDate({})
    //   .then(res => {
    //     const message = res.ResultMessage || '';
    //     const [fileName = '', updateTime] = message.split(',');
    //     setFileData({
    //       fileName,
    //       updateTime,
    //     });
    //     setLoading(false);
    //     // const index = fileName.lastIndexOf('.');
    //     // axios
    //     //   .get(`${JSON_BASE}${fileName.slice(0, index)}.json`, {})
    //     //   .then(res => {
    //     //     console.log(res);
    //     //   });
    //   })
    //   .catch(err => {
    //     Message.error(err);
    //     setLoading(false);
    //   });
  };

  useEffect(() => {
    init();
  }, []);
  useEffect(() => {
    const hurl = window.location.origin;
    getMobileFiles({ client: clientName }).then(res => {
      if (res.code === 0) {
        const { data } = res;
        let fileName =
          data.apkPath.split('\\')[data.apkPath.split('\\').length - 1] || '';
        let apkUrl = `${hurl}/${data.apkPath.replace(/\\/g, '/')}` || '';
        setFileData({
          ...data,
          fileName,
          apkUrl,
        });
      }
    });
  }, [upFlag]);
  return (
    <div className={loading ? styles.loadingContainer : styles.VersionPublish}>
      {loading ? (
        <Spin />
      ) : (
        <>
          <div className={styles.apkbox}>
            <p className={styles.title}>apk版本管理:</p>
            <div className={styles.row}>
              <div className={styles.label}>当前包名:</div>
              <div className="value">
                {fileData.fileName || '未找到对应的包名'}
              </div>
            </div>
            <div className={styles.row}>
              <div className={styles.label}>更新时间:</div>
              <div className="value">{fileData.updateTime}</div>
            </div>
            <div className={styles.row}>
              <div className={styles.label}>下载地址:</div>
              <div className="value">
                <a href={fileData.apkUrl} target="_blank">
                  {fileData.apkUrl}
                </a>
              </div>
            </div>
            <div className={styles.row}>
              <div className={styles.label}>更新描述:</div>
              <div className="value">{fileData.description}</div>
            </div>
            <div className={styles.row}>
              <div className={styles.label}>强制更新:</div>
              <div className="value">
                <Switch checked={fileData.isRefresh} disabled />
              </div>
            </div>
            <Button
              style={{ marginLeft: '115px', marginTop: '20px' }}
              type="primary"
              onClick={() => setShowModal(true)}
            >
              更新
            </Button>
          </div>
        </>
      )}
      {showModal && (
        <Modal
          visible={showModal}
          closable={false}
          maskClosable={false}
          onCancel={() => setShowModal(false)}
          onOk={submitForm}
          confirmLoading={progress}
        >
          <Spin spinning={progress} tip="loading...">
            <BaseForm items={items} getForm={handleGetForm} />
            <div className={styles.row}>
              <div className={`${styles.label2} ${styles.required}`}>
                apk文件:
              </div>
              <input
                ref={f => {
                  fileEntity.current = f;
                }}
                className={styles['file-item']}
                type="file"
                onChange={handleFileChange}
              />
              <Button type="primary" onClick={handleUpload}>
                {fileSuccess ? '上传成功' : '开始上传'}
              </Button>
            </div>
          </Spin>
        </Modal>
      )}
    </div>
  );
};