import config from '../../../config'
const app = getApp()
Page({

    /**
     * 页面的初始数据
     */
    data: {
        maxDate: new Date(2088, 1, 1).getTime(),
        deptName: "",
        userId: "",
        myUserId: "",
        nickName: "",
        loginName: "",
        projectId: "",
        projectName: "",
        procInsId: "",
        infoData: {},
        procDefName: "",
        deployId: "",
        activeName: "",
        flowNodeList: [],
        flowNodes: [],
        imageList: [],
        filesData: [],
        taskId: "",
        procInsId: "",
        taskName: "",
        passState: true,
        backName: "",
        stopShow: false,
        deleteShow: false,
        revocationShow: false,
        finishTime: "",
        ret: "",
        comment: "",
        stopBtnShow: false,
        imageType: ["png", "jpg", "jpeg"],
        fileType: ["pdf"],
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad(options) {
        let {
            deployId,
            procInsId,
            procDefName,
            deptName,
            nickName,
            taskId,
            taskName,
            projectName,
            userId,
            finishTime,
            ret
        } = options
        //获取缓存数据
        wx.getStorage({
            key: 'userinfo',
            success: res => {
                this.setData({
                    projectId: app.globalData.projectId,
                    projectName,
                    procInsId,
                    procDefName,
                    deployId,
                    deptName,
                    nickName,
                    taskId,
                    taskName,
                    userId,
                    finishTime,
                    ret,
                    myUserId: res.data.userId,
                    loginName: res.data.loginName,
                })
                this.getFlowNodes();
                this.getFlowRecordList();
                this.getFormDatasList();
            }
        })
    },

    getFlowNode(val) {
        let flowNodeList = this.data.flowNodeList;
        for (let i = 0; i < flowNodeList.length; i++) {
            if (flowNodeList[i].id == val) {
                let list = this.data.flowNodes;
                if (this.data.passState) {
                    if (flowNodeList[i].name == this.data.taskName) {
                        list.push({
                            id: flowNodeList[i].id,
                            name: flowNodeList[i].name,
                            state: 'transact'
                        });
                        this.setData({
                            passState: false
                        })
                    } else {
                        list.push({
                            id: flowNodeList[i].id,
                            name: flowNodeList[i].name,
                            state: 'pass'
                        });
                    }
                } else {
                    list.push({
                        id: flowNodeList[i].id,
                        name: flowNodeList[i].name,
                        state: 'none'
                    });
                }
                this.setData({
                    flowNodes: list
                })
                if (flowNodeList[i].outgoingFlows && flowNodeList[i].outgoingFlows.length > 0) {
                    return this.getFlowNode(flowNodeList[i].outgoingFlows[0].targetRef);
                }
            }
        }
    },

    //查询工作流节点
    getFlowNodes() {
        let that = this;
        wx.request({
            url: app.globalData.reqUrl + '/wechat/flowTask/readNotes/' + that.data.deployId,
            method: "get",
            data: {},
            header: {
                "Content-Type": "application/json"
            },
            success(res) {
                res = res.data
                if (res.code == 200) {
                    that.setData({
                        flowNodeList: res.data
                    })
                    if (res.data.length > 0) {
                        let list = that.data.flowNodes;
                        list.push({
                            id: res.data[0].id,
                            name: res.data[0].name,
                            state: 'pass'
                        });
                        that.setData({
                            flowNodes: list
                        })
                        return that.getFlowNode(res.data[0].outgoingFlows[0].targetRef);
                    }
                } else {
                    app.toast(res.msg);
                }
            }
        })
    },

    //查询审批日志
    getFlowRecordList() {
        let that = this;
        wx.request({
            url: app.globalData.reqUrl + '/wechat/flowTask/findCommentByProcInsId',
            method: "get",
            data: {
                procInsId: this.data.procInsId
            },
            header: {
                "Content-Type": "application/json"
            },
            success(res) {
                res = res.data
                if (res.code == 200) {
                    that.setData({
                        flowRecordList: res.data
                    })
                    let list = [];
                    res.data.forEach(item => {
                        if (item.deleteReason) {
                            item.deleteReason = that.getDeleteReason(item.deleteReason);
                        }
                        if (item.duration) {
                            item.duration = that.getDurationDate(item.duration);
                        }
                        list.push(item);
                    })
                    that.setData({
                        flowRecordList: list
                    })
                } else {
                    app.toast(res.msg);
                }
            }
        })
    },

    //查询审批表单参数
    getFormDatasList() {
        let that = this;
        wx.request({
            url: app.globalData.reqUrl + '/wechat/flowTask/findFormDatasByProcInsId',
            method: "get",
            data: {
                procInsId: this.data.procInsId
            },
            header: {
                "Content-Type": "application/json"
            },
            success(res) {
                res = res.data
                if (res.code == 200) {
                    that.setData({
                        infoData: res.data
                    })
                    let filesData = [];
                    let imageList = [];
                    //判断附件
                    if (res.data.files) {
                        res.data.files.split(',').forEach(element => {
                            let ft = element.split('.');
                            if (that.data.imageType.indexOf(ft[ft.length - 1].toLowerCase()) > -1) {
                                imageList.push({
                                    minPath: config.baseUrl + element,
                                    path: element
                                });
                            } else {
                                let it = element.split('/');
                                filesData.push({
                                    name: it[it.length - 1],
                                    path: element
                                });
                            }
                        });
                    }
                    that.setData({
                        filesData,
                        imageList,
                        stopShow: !that.data.finishTime && that.data.userId == that.myUserId,
                        deleteShow: !that.data.finishTime && that.data.userId == that.myUserId,
                        revocationShow: !that.data.finishTime
                    })
                } else {
                    app.toast(res.msg);
                }
            }
        })
    },

    //退回
    onStop() {
        if (!this.data.stopBtnShow) {
            app.toast("请填写终止原因!")
            this.setData({
                stopBtnShow: true
            })
            return;
        } else {
            if (this.data.comment == "") {
                app.toast("请填写终止原因!")
                this.setData({
                    stopBtnShow: true
                })
                return;
            }
        }
        this.setData({
            loadShow: true
        })
        let that = this
        let params = {
            instanceId: this.data.procInsId,
            comment: this.data.comment,
            userId: this.data.myUserId,
            taskId: this.data.taskId
        }
        //弹出确认
        wx.showModal({
            title: '提示',
            content: '是否终止当前流程申请?',
            success: function (sm) {
                if (sm.confirm) {
                    wx.request({
                        url: app.globalData.reqUrl + '/wechat/flowTask/stopProcess',
                        method: "POST",
                        data: params,
                        header: {
                            "Username": that.data.loginName,
                            "Content-Type": "application/json"
                        },
                        success(res) {
                            that.setData({
                                loadShow: false
                            })
                            res = res.data
                            if (res.code == 200) {
                                app.toast("终止流程申请成功!")
                                if (that.data.ret == "finished") {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../finished/index',
                                        })
                                    }, 200)
                                } else {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../myProcessIns/index',
                                        })
                                    }, 200)
                                }
                            } else {
                                app.toast(res.msg);
                            }
                        }
                    })
                } else if (sm.cancel) {
                    that.setData({
                        loadShow: false
                    })
                    console.log('用户点击取消');
                }
            }
        })
    },

    //通过
    onDelete() {
        this.setData({
            loadShow: true
        })
        let that = this
        //弹出确认
        wx.showModal({
            title: '提示',
            content: '是否确认删除流程申请?',
            success: function (sm) {
                if (sm.confirm) {
                    wx.request({
                        url: app.globalData.reqUrl + '/wechat/flowTask/delete/' + that.data.procInsId,
                        method: "delete",
                        data: {},
                        header: {
                            "Username": that.data.loginName,
                            "Content-Type": "application/json"
                        },
                        success(res) {
                            that.setData({
                                loadShow: false
                            })
                            res = res.data
                            if (res.code == 200) {
                                app.toast("删除流程申请成功!")
                                if (that.data.ret == "finished") {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../finished/index',
                                        })
                                    }, 200)
                                } else {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../myProcessIns/index',
                                        })
                                    }, 200)
                                }
                            } else {
                                app.toast(res.msg);
                            }
                        }
                    })
                } else if (sm.cancel) {
                    that.setData({
                        loadShow: false
                    })
                    console.log('用户点击取消');
                }
            }
        })
    },

    //撤回
    onRevocation() {
        this.setData({
            loadShow: true
        })
        let that = this
        let params = {
            procInsId: this.data.procInsId,
            instanceId: this.data.procInsId,
            taskId: this.data.taskId,
            userId: this.data.myUserId,
            assignee: this.data.nickName
        }
        //弹出确认
        wx.showModal({
            title: '提示',
            content: '是否确认撤回当前任务流程?',
            success: function (sm) {
                if (sm.confirm) {
                    wx.request({
                        url: app.globalData.reqUrl + '/wechat/flowTask/revokeProcess',
                        method: "POST",
                        data: params,
                        header: {
                            "Username": that.data.loginName,
                            "Content-Type": "application/json"
                        },
                        success(res) {
                            that.setData({
                                loadShow: false
                            })
                            res = res.data
                            if (res.code == 200) {
                                app.toast("撤回流程申请成功!")
                                if (that.data.ret == "finished") {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../finished/index',
                                        })
                                    }, 200)
                                } else {
                                    setTimeout(() => {
                                        wx.redirectTo({
                                            url: '../myProcessIns/index',
                                        })
                                    }, 200)
                                }
                            } else {
                                app.toast(res.msg);
                            }
                        }
                    })
                } else if (sm.cancel) {
                    that.setData({
                        loadShow: false
                    })
                    console.log('用户点击取消');
                }
            }
        })
    },

    // 手风琴
    onChange(event) {
        this.setData({
            activeName: event.detail,
        });
    },

    getDeleteReason(val) {
        val = val.replace("Change activity to ", "");
        let flowRecordList = this.data.flowRecordList;
        for (let i = 0; i < flowRecordList.length; i++) {
            if (flowRecordList[i].taskDefKey == val) {
                return "驳回至" + flowRecordList[i].taskName;
            }
        }
    },

    getDurationDate(val) {
        // 计算出相差天数
        let days = Math.floor(val / (24 * 3600 * 1000))
        // 计算出小时数
        let leave1 = val % (24 * 3600 * 1000) // 计算天数后剩余的毫秒数
        let hours = Math.floor(leave1 / (3600 * 1000))
        // 计算相差分钟数
        let leave2 = leave1 % (3600 * 1000) // 计算小时数后剩余的毫秒数
        let minutes = Math.floor(leave2 / (60 * 1000))
        // 计算相差秒数
        let leave3 = leave2 % (60 * 1000) // 计算分钟数后剩余的毫秒数
        let seconds = Math.round(leave3 / 1000)
        if (days > 0) {
            if (days < 10) days = "0" + days;
            if (hours < 10) hours = "0" + hours;
            if (minutes < 10) minutes = "0" + minutes;
            if (seconds < 10) seconds = "0" + seconds;
            return days + '天' + hours + '小时' + minutes + '分钟' + seconds + '秒';
        }
        if (hours > 0) {
            if (hours < 10) hours = "0" + hours;
            if (minutes < 10) minutes = "0" + minutes;
            if (seconds < 10) seconds = "0" + seconds;
            return hours + '小时' + minutes + '分钟' + seconds + '秒';
        }
        if (minutes > 0) {
            if (minutes < 10) minutes = "0" + minutes;
            if (seconds < 10) seconds = "0" + seconds;
            return minutes + '分钟' + seconds + '秒';
        }
        if (seconds > 0) {
            if (seconds < 10) seconds = "0" + seconds;
            return seconds + '秒';
        }
    },

    //选择退回节点
    onSelectTargetKey(e) {
        this.setData({
            targetKey: e.detail.id,
            backName: e.detail.name
        })
    },

    returnToPage: function () {
        /*关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面*/
        if (this.data.ret == "finished") {
            wx.redirectTo({
                url: '../finished/index',
            })
        } else {
            wx.redirectTo({
                url: '../myProcessIns/index',
            })
        }
    },

    //展示图片详细
    showImg: function (e) {
        let {
            path
        } = e.currentTarget.dataset.set
        wx.previewImage({
            urls: this.data.imageList,
            current: path
        })
    },

    /**
     * 下载并打开文档
     * @param {*} e 
     */
    downFile: function (e) {
        let {
            path
        } = e.currentTarget.dataset.set
        wx.downloadFile({
            // 示例 url,并非真实存在
            url: app.globalData.uploadUrl + '/common/download/resource?resource=' + path,
            success: function (res) {
                const filePath = res.tempFilePath
                let fpt = filePath.split(".");
                wx.openDocument({
                    filePath: filePath,
                    fileType: fpt[fpt.length - 1],
                    success: function (res) {
                        console.log('打开文档成功')
                    },
                    fail: function (res) {
                        console.log(res)
                    }
                })
            }
        })
        //app.toast("暂不支持下载!如需下载请前往后台管理系统!!")
    },

    //终止原因
    commentblur: function (options) {
        this.data.comment = options.detail.value;
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady() {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow() {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide() {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload() {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh() {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom() {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage() {

    }
})