import React, { useState, useEffect, useRef } from 'react'
import SiteModal from '@/components/Modal/SiteModa';
import { Form, Input, notification, Select, Checkbox, message, Button } from 'antd'
import BaseForm from '@/components/BaseForm/index';
import { Switch } from 'react-router';
import { iteratee } from 'lodash';
import styles from './EditModal.less';
import v from 'voca';
import VisibleRoleModal from './RolseSelect/VisibleRoleModal'
import VisibleIISAgentConfig from './IISAgentConfig/VisibleIISAgentConfig'
import { GetMessageTemplate } from '@/services/platform/messagemanage'
import moment from 'moment'
import { UpdateMessageConfig, InsertMessageConfig, AddIISAgentConfig } from '@/services/platform/messagemanage'

const { Item } = Form;

const EditModal = props => {


    const [form] = Form.useForm();
    const [loading, setLoading] = useState(false);
    const [isStart, setIsStart] = useState(false);
    const [IISConfig, setIISConfig] = useState(null)

    const { template, confirmModal } = props
    const [currentTrench, setCurrentTrench] = useState({
        isMessageShow: false,
        isAPPShow: false,
        isWEBShow: false,
        isWXShow: false
    })
    const plainOptions = ['平台弹框', '短信推送', '公众号推送'];
    const [APP_ITEMS, setAPP_ITEMS] = useState([])
    const [WEB_ITEMS, setWEB_ITEMS] = useState([])
    const [WX_ITEMS, setWX_ITEMS] = useState([])
    const [MES_ITEMS, setMES_ITEMS] = useState([])


    useEffect(() => {
        GetMessageTemplate().then(
            res => {
                if (res.code === 0) {
                    let arr1 = []
                    let arr2 = []
                    let arr3 = []
                    let arr4 = []
                    res.data.map((item, index) => {
                        if (item.Type === "公众号") {
                            arr1.push(item)
                        }
                        if (item.Type === "短信") {
                            arr2.push(item)
                        }
                        if (item.Type === "APP") {
                            arr3.push(item)
                        }
                        if (item.Type === "WEB") {
                            arr4.push(item)
                        }
                    })
                    setAPP_ITEMS(arr3)
                    setMES_ITEMS(arr2)
                    setWX_ITEMS(arr1)
                    setWEB_ITEMS(arr4)
                }
            }
        )
    }, [])
    useEffect(() => {

        if (template.ThemeName) {
            form.setFieldsValue({
                name: template.MsgType,
                isStart: template.IsStarted === "0" ? "关闭" : "开启",
                to_person: template.PushGroup,
                push_plan: template.MsgType,
                push_mode: template.PushMode.split(","),
                app_template: template.AppTemplateID,
                app_path: template.AppFunctionPath,
                wx_template: parseInt(template.PublicTemplateID),
                h5_path: template.PublicPath,
                miniprogram_path: template.MiniAppRoute,
                web_template: template.WebTemplateID,
                web_path: template.WebFunctionPath,
                message_template: template.MsgTemplateID,
            })
            setCurrentTrench({
                isAPPShow: template.PushMode.split(",").indexOf("平台弹框") > -1 ? true : false,
                isWXShow: template.PushMode.split(",").indexOf("公众号推送") > -1 ? true : false,
                isWEBShow: template.PushMode.split(",").indexOf("平台弹框") > -1 ? true : false,
                isMessageShow: template.PushMode.split(",").indexOf("短信推送") > -1 ? true : false,
            })
        }

    }, [props])
    const onNameChange = (e) => {
        form.setFieldsValue({
            push_plan: e.target.value
        })
    }

    const onSubmit = () => {
        console.log(form.getFieldValue())
        let fv = form.getFieldValue()
        if (template.ThemeName) {

            let a = {
                ID: template.ID,
                ThemeName: template.ThemeName,
                MsgType: fv.name,
                PublicTemplateID: fv.wx_template,
                PublicConfig: template.PublicConfig,
                PublicPath: fv.h5_path,
                MsgTemplateName: template.MsgTemplateName,
                MsgTemplateCode: template.MsgTemplateCode,
                MsgConfig: template.MsgConfig,
                MiniAppRoute: fv.miniprogram_path,
                AppFunctionPath: fv.app_path,
                AppConfig: template.AppConfig,
                WebFunctionPath: fv.web_path,
                WebConfig: template.WebConfig,
                IsDelete: template.IsDelete,
                InputTime: moment().format("YYYY-MM-DD HH:mm:ss"),
                Pusher: template.Pusher,
                PushMode: fv.push_mode.toString(),
                PushPath: template.PushPath,
                IsStarted: fv.isStart,
                MsgTemplateID: fv.message_template,
                AppTemplateID: fv.app_template,
                WebTemplateID: fv.web_template,
                PushGroup: fv.to_person.toString()
            }
            console.log(a)
            UpdateMessageConfig(a).then(
                res => {
                    if (res.code === 0) {
                        if (IISConfig) {
                            AddIISAgentConfig(IISConfig).then(
                                res => {
                                    if (res.code === 0) {
                                        message.success("保存成功")
                                        confirmModal()
                                    }
                                }
                            )
                        } else {
                            message.success("保存成功")
                            confirmModal()
                        }



                    }
                }
            )

        } else {
            let b = {
                ThemeName: "定时推送",
                MsgType: fv.name,
                PublicTemplateID: fv.wx_template,
                PublicConfig: template.PublicConfig,
                PublicPath: fv.h5_path,
                MsgTemplateName: template.MsgTemplateName,
                MsgTemplateCode: template.MsgTemplateCode,
                MsgConfig: template.MsgConfig,
                MiniAppRoute: fv.miniprogram_path,
                AppFunctionPath: fv.app_path,
                AppConfig: template.AppConfig,
                WebFunctionPath: fv.web_path,
                WebConfig: template.WebConfig,
                IsDelete: template.IsDelete,
                InputTime: moment().format("YYYY-MM-DD HH:mm:ss"),
                Pusher: template.Pusher,
                PushMode: fv.push_mode.toString(),
                PushPath: template.PushPath,
                IsStarted: fv.isStart,
                MsgTemplateID: fv.message_template,
                AppTemplateID: fv.app_template,
                WebTemplateID: fv.web_template,
                PushGroup: fv.to_person.toString()
            }
            console.log(b)
            InsertMessageConfig(b).then(
                res => {
                    if (res.code === 0) {
                        if (IISConfig) {
                            AddIISAgentConfig(IISConfig).then(
                                res => {
                                    if (res.code === 0) {
                                        message.success("保存成功")
                                        confirmModal()
                                    }
                                }
                            )
                        } else {
                            message.success("保存成功")
                            confirmModal()
                        }
                    }
                }
            )
        }

    }
    const operateProject = () => {

    }
    const onTypeChange = (value) => {
        console.log(value)
        setCurrentTrench({
            isAPPShow: value.indexOf("平台弹框") > -1 ? true : false,
            isWXShow: value.indexOf("公众号推送") > -1 ? true : false,
            isWEBShow: value.indexOf("平台弹框") > -1 ? true : false,
            isMessageShow: value.indexOf("短信推送") > -1 ? true : false,
        })
    }
    const onIISAgentSubmit = (value) => {
        console.log(value, "IIS配置")
        setIISConfig(value)

    }

    const onPushSubmit = (value) => {
        console.log(value, "onPushSubmit")
    }

    return (
        <SiteModal
            {...props}
            title={template.ThemeName ? "编辑推送方案" : "新增推送方案"}
            bodyStyle={{ width: '100%', minHeight: '100px' }}
            style={{ top: 200, borderRadius: '20px' }}
            width="1200px"
            destroyOnClose
            cancelText="取消"
            okText="确认"
            onOk={() => onSubmit()}
            confirmLoading={loading}
        >
            <div className={styles.editModal_container}>
                <Form form={form} labelCol={{ span: 4 }}>
                    <Item
                        label="方案名称"
                        name="name"
                        rules={[
                            {
                                required: true,
                                message: '请输入方案名称',
                            },
                        ]}
                    >
                        <Input placeholder="请输入方案名称" disabled={template.ThemeName ? true : false} onChange={onNameChange} />
                    </Item>
                    <Item
                        label="是否开启"
                        name="isStart"

                    >
                        <Select >
                            <Option value="1">开启</Option>
                            <Option value="0">关闭</Option>
                        </Select>
                    </Item>
                    <Item
                        label="推送人"
                        name="to_person"

                    >
                        <VisibleRoleModal
                            onSubmit={onPushSubmit}
                            title={"推送人员"}
        
                        />
                    </Item>
                    <Item
                        label="定时计划"
                        name="push_plan"
                    >
                        <VisibleIISAgentConfig agentConfig={template.item && template.item.AgentConfig} onIISAgentSubmit={onIISAgentSubmit} />
                    </Item>
                    <Item
                        label="推送方式"
                        name="push_mode"
                    >
                        <Checkbox.Group
                            options={plainOptions}
                            onChange={onTypeChange}

                        />
                    </Item>
                    <div className={styles.push_trench}>
                        {
                            currentTrench.isAPPShow && (
                                <div className={styles.trench_card}>
                                    <div className={styles.card_title}>
                                        <div className={styles.lable}>APP</div>
                                    </div>
                                    <div className={styles.card_body}>
                                        <Item
                                            label="模板"
                                            name="app_template"
                                        >
                                            <Select >
                                                {
                                                    APP_ITEMS.map((item, idx) => {
                                                        return (
                                                            <Option value={item.Id} key={idx}>{item.LikeName}</Option>
                                                        )
                                                    })
                                                }
                                            </Select>
                                        </Item>
                                        <Item
                                            label="功能路径"
                                            name="app_path"
                                        >
                                            <Input placeholder="请输入功能路径" />
                                        </Item>
                                    </div>
                                </div>
                            )
                        }
                        {
                            currentTrench.isWXShow && (
                                <div className={styles.trench_card}>
                                    <div className={styles.card_title}>
                                        <div className={styles.lable}>微信</div>
                                    </div>
                                    <div className={styles.card_body}>
                                        <Item
                                            label="模板"
                                            name="wx_template"
                                        >
                                            <Select >
                                                {
                                                    WX_ITEMS.map((item, idx) => {
                                                        return (
                                                            <Option value={item.Id} key={idx}>{item.LikeName}</Option>
                                                        )
                                                    })
                                                }
                                            </Select>
                                        </Item>
                                        <Item
                                            label="H5路由"
                                            name="h5_path"
                                        >
                                            <Input placeholder="请输入功能路径" />
                                        </Item>
                                        <Item
                                            label="小程序路由"
                                            name="miniprogram_path"
                                        >
                                            <Input placeholder="请输入功能路径" />
                                        </Item>
                                    </div>
                                </div>
                            )
                        }
                        {
                            currentTrench.isWEBShow && (
                                <div className={styles.trench_card}>
                                    <div className={styles.card_title}>
                                        <div className={styles.lable}>WEB</div>
                                    </div>
                                    <div className={styles.card_body}>
                                        <Item
                                            label="模板"
                                            name="web_template"
                                        >
                                            <Select >
                                                {
                                                    WEB_ITEMS.map((item, idx) => {
                                                        return (
                                                            <Option value={item.Id} key={idx}>{item.LikeName}</Option>
                                                        )
                                                    })
                                                }
                                            </Select>
                                        </Item>
                                        <Item
                                            label="功能路径"
                                            name="web_path"
                                        >
                                            <Input placeholder="请输入功能路径" />
                                        </Item>
                                    </div>
                                </div>
                            )
                        }

                        {
                            currentTrench.isMessageShow && (
                                <div className={styles.trench_card}>
                                    <div className={styles.card_title}>
                                        <div className={styles.lable}>短信推送</div>
                                    </div>
                                    <div className={styles.card_body}>
                                        <Item
                                            label="模板"
                                            name="message_template"
                                        >
                                            <Select >
                                                {
                                                    MES_ITEMS.map((item, idx) => {
                                                        return (
                                                            <Option value={item.Id} key={idx}>{item.LikeName}</Option>
                                                        )
                                                    })
                                                }
                                            </Select>
                                        </Item>
                                    </div>
                                </div>
                            )
                        }
                    </div>
                </Form>
            </div>

        </SiteModal>
    )
}
export default EditModal;