/* eslint-disable arrow-body-style */
/* eslint-disable no-useless-escape */
/* eslint-disable no-lonely-if */
/* eslint-disable no-unused-expressions */
/* eslint-disable prefer-template */
/* eslint-disable react/jsx-boolean-value */
import React, { useState, useEffect } from 'react';
import { Modal, Collapse, notification, Upload, Input, Empty, Tooltip } from 'antd';
import { GetImageOrderByFile, GetImageOrderByPath } from '@/services/integratedLogin/api';
import classnames from 'classnames';
import styles from './PreviewModal.less';

const { Panel } = Collapse;

const PreviewModal = props => {
  const { callBackSubmit = () => {}, visible, onCancel, imageUrl, keepImgeUrl, type } = props;
  const [imgData, setImgData] = useState([]);
  const [pickItem, setPickItem] = useState('');
  const [chooseItem, setChooseItem] = useState('');
  const [keepItem, setKeepItem] = useState('');
  const [keepGroupName, setKeepGroupName] = useState([]);
  const [search, setSearch] = useState('');

  const { Search } = Input;

  useEffect(() => {
    if (visible) {
      setChooseItem(imageUrl);
      update();
    } else {
      setPickItem('');
      setKeepItem('');
      setChooseItem('');
    }
  }, [visible]);

  const update = () => {
    GetImageOrderByFile({
      maxLength: 279.1525423728813,
      path: 'assets/images/caseCenter/events',
    })
      .then(resdata => {
        if (resdata.code === 0) {
          let bb = [];
          let aa = [];
          resdata.data.map((i, a) => {
            if (i.list.length > 0) {
              bb.push(i);
              aa.push(i.text);
            }
          });
          setKeepGroupName(aa);
          setImgData(bb);
          resdata.data.map(i => {
            i.list.map((j, index) => {
              if (keepImgeUrl) {
                if (j.value == keepImgeUrl) {
                  setKeepItem(i.text);
                  setPickItem(index);
                  setChooseItem(j.value);
                }
              } else {
                if (chooseItem == j.value) {
                  setKeepItem(i.text);
                  setPickItem(index);
                  setChooseItem(j.value);
                }
              }
            });
          });
        } else {
          notification.error({
            message: '获取失败',
            description: resdata.msg,
          });
        }
      })
      .catch(err => {
        console.error(err);
      });
  };

  // 提交
  const onSubmit = () => {
    if (keepItem) {
      let aa = imgData.find(i => i.text === keepItem);
      callBackSubmit(chooseItem);
    }
    onCancel();
  };

  const handleCollapseChange = key => {
    setKeepGroupName(key);
  };

  const onSearch = e => {
    setSearch(e.target.value);
  };

  const submitSearch = () => {
    GetImageOrderByPath({
      maxLength: 279.1525423728813,
      path: 'assets/images/caseCenter/events',
      fileName: search,
    })
      .then(resdata => {
        if (resdata.code === 0) {
          let bb = [];
          let aa = [];
          resdata.data.map((i, a) => {
            if (i.list.length > 0) {
              bb.push(i);
              aa.push(i.text);
            }
          });
          setKeepGroupName(aa);
          setImgData(bb);
          resdata.data.map(i => {
            i.list.map((j, index) => {
              if (`/${chooseItem}` == j.value) {
                setKeepItem(i.text);
                setPickItem(index);
                setChooseItem(j.value);
              }
            });
          });
        } else {
          notification.error({
            message: '获取失败',
            description: resdata.msg,
          });
        }
      })
      .catch(err => {
        console.error(err);
      });
  };

  return (
    <Modal
      title="图片库"
      style={{ top: '100px' }}
      width="1000px"
      destroyOnClose
      maskClosable={false}
      cancelText="取消"
      okText="确认"
      {...props}
      onOk={() => onSubmit()}
      forceRender={true}
      getContainer={false}
    >
      <Search
        placeholder="搜索图库"
        // size="middle"
        value={search}
        enterButton
        style={{ width: '50%' }}
        onChange={e => onSearch(e)}
        onSearch={submitSearch}
        allowClear
      />
      {imgData.length > 0 ? (
        <Collapse
          style={{ height: '600px', overflow: 'scroll', marginTop: '20px' }}
          bordered={false}
          activeKey={keepGroupName}
          onChange={handleCollapseChange}
        >
          {imgData.map((i, j) => {
            return (
              <Panel
                header={i.text}
                key={i.text}
                style={{
                  marginBottom: '24px',
                  overflow: 'hidden',
                  border: '0px',
                  background: '#f7f7f7',
                  borderRadius: '2px',
                }}
              >
                {i.list &&
                  i.list.map((k, index) => {
                    return (
                      <div className={styles.divItem} key={index}>
                        <img
                          src={window.location.origin + `/civweb4/${k.value}`}
                          className={classnames({
                            [styles.imgHidden]: k.value !== chooseItem,
                            [styles.imgItem]: k.value == chooseItem,
                          })}
                          height="80px"
                          width="80px"
                          alt="集成登录默认"
                          onClick={e => {
                            setPickItem(index);
                            setKeepItem(i.text);
                            setChooseItem(k.value);
                          }}
                        />
                        <div
                          style={{
                            textAlign: 'center',
                            width: '100px',
                          }}
                        >
                          <Tooltip title={k.text}>
                            <p
                              style={{
                                height: '22px',
                                overflow: 'hidden',
                                whiteSpace: 'nowrap',
                                textOverflow: 'ellipsis',
                              }}
                            >
                              {k.text}
                            </p>
                          </Tooltip>
                        </div>
                      </div>
                    );
                  })}
              </Panel>
            );
          })}
        </Collapse>
      ) : (
        <Empty
          image={Empty.PRESENTED_IMAGE_SIMPLE}
          description="暂无数据"
          style={{ height: '600px', margin: '20px auto 0px auto', paddingTop: '50px' }}
        />
      )}
    </Modal>
  );
};
export default PreviewModal;