<template>
    <div class="evaluationAmendment">
        <div class="evaluationAmendmentBtn">
            <div class="collectSeach" :style="$utils.collectSeachSty()">
                <div class="exceed">
                    <span class="exceedSpan">业务编号:</span>
                    <el-input v-model="rescode" placeholder="请输入业务编号"></el-input>
                </div>
                <div class="exceed">
                    <span class="exceedSpan">业务简述:</span>
                    <el-input v-model="resDes" placeholder="请输入业务简述"></el-input>
                </div>
                <seachs @handleSeach="getSeachData" @handleRest="resetSeach"></seachs>
            </div>
            <div class="PeriodBtn" :style="$utils.PeriodBtnSty()">
                <btns
                :showImport="false"
                :showExport="false"
                :showSave="false"
                :showAdd="true"
                :showDelete="true"
                :disDelete="changeDateSelect.length === 0"
                :disImport="true"
                :disExport="true"
                @handleAdd="handleAdd"
                @handleDelete="handleDelete"
                ></btns>
            </div>
            <div class="evaluationAmendmentTableData">
                <el-table :data="evaluationAmendmentData" style="width: 100%" @select="rowClick" :class="evalAmendmentTableSty()"
                 @select-all="rowClick" @row-dblclick="getDetail" @cell-click="clickDes">
                    <el-table-column type="selection" label="操作" align="center"></el-table-column>
                    <el-table-column label="业务编号" prop="responsibilityCode" />
                    <el-table-column label="考评单位" width="400">
                        <template #default="scope">
                            <el-tooltip
                                class="box-item"
                                effect="customized"
                                :content="scope.row.createOrgName"
                                placement="right"
                            >
                                <span class="tooltipCC">{{scope.row.createOrgName}}</span>
                            </el-tooltip>
                        </template>
                    </el-table-column>
                    <el-table-column label="考评年度" prop="year" width="120" />
                    <el-table-column label="业务简述" prop="des" width="400">
                        <template #default="scope">
                            <div v-if="!scope.row.chngeDes">
                                <el-tooltip
                                    class="box-item"
                                    effect="customized"
                                    :content="scope.row.des"
                                    placement="top"
                                >
                                    <span class="tooltipCC">{{scope.row.des}}</span>
                                </el-tooltip>
                            </div>
                            <div v-else>
                                <el-input v-model="scope.row.des" :rows="1" 
                                type="textarea" placeholder="请输入描述" @blur="modifyDesFn(scope.row)"></el-input>
                            </div>
                        </template>
                    </el-table-column>
                    <el-table-column label="流程状态" prop="stage" width="200">
                        <template #default="scope">
                            <p class="indicitem" @click="seeStates(scope.row)">{{scope.row.stage}}</p>
                        </template>
                    </el-table-column>
                    <el-table-column label="操作" width="100">
                        <template #default="scope">
                            <p class="indicitem" v-if="scope.row.stage === '流程未启动'" @click="agetdeptresponsibility(scope.row)">启动</p>
                            <!-- <p class="indicitem" v-else @click="getDetail(scope.row)">详情</p> -->
                            <p style="font-size: 12px;margin-right: 20px;" v-else-if="scope.row.stage === '流程已结束'" >已结束</p>
                            <p style="font-size: 12px;margin-right: 20px;" v-else >已启动</p>
                        </template>
                    </el-table-column>
                </el-table>
                <el-pagination
                    @size-change="handleSizeChange"
                    @current-change="handleCurrentChange"
                    :current-page="page.currentPage"
                    :page-size="page.pagesize"
                    layout="total, prev, pager, next, jumper"
                    :total="page.total">
                </el-pagination>
            </div>
            <el-dialog :title="title" custom-class="startToDia" v-model="dialogVisible" width="600px" :close-on-click-modal="false">
                <div class="periodFrom">
                    <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm" :validate-on-rule-change="false">
                        <el-form-item label="考评类别" prop="organizationType">
                            <el-select v-model="ruleForm.organizationType" placeholder="请选择考评类别"
                            disabled>
                                <el-option
                                v-for="item in organizationType"
                                :key="item.code"
                                :label="item.label"
                                :value="item.code">
                                </el-option>
                            </el-select>
                        </el-form-item>                            
                        <el-form-item label="考评周期" prop="evaluationCycle">
                            <el-select v-model="ruleForm.evaluationCycle" placeholder="请选择考评周期"
                             disabled>
                                <el-option
                                v-for="item in periodData"
                                :key="item.keyValue"
                                :label="item.keyName"
                                :value="item.keyValue"
                                :disabled="item.keyValue === 'YDKP' || item.keyValue === 'JDKP'">
                                </el-option>
                            </el-select>
                        </el-form-item>
                        <el-form-item label="年份" prop="year">
                            <el-date-picker
                                v-model="ruleForm.year"
                                disabled
                                type="year"
                                value-format="YYYY"
                                placeholder="请选择年份"
                                />
                        </el-form-item>
                        <el-form-item label="描述" prop="desc">
                            <el-input v-model="ruleForm.desc" :rows="5" type="textarea" placeholder="请输入描述"></el-input>
                        </el-form-item>
                    </el-form>
                </div>
                <template #footer>
                    <span class="dialog-footer">
                        <el-button @click="dialogVisible = false">取 消</el-button>
                        <el-button type="primary" @click="saveevaluaStart('ruleForm')">确 定</el-button>
                    </span>
                </template>
            </el-dialog>
            <el-dialog title="流程详情" v-model="statesVisible" :fullscreen="true" :close-on-click-modal="false">
                <div class="flowSty">
                    <iframe id="iframeContain" width="100%" height="500px"
                     frameborder="0" class="iframe" name="iframeContain" seamless scrolling="no" :src="iframeURL">            
                    </iframe>
                    <el-table :data="stageArr" style="width: 100%">
                        <el-table-column type="index" label="序号" align="center" />
                        <el-table-column label="任务名称" prop="taskName" />
                        <el-table-column label="任务创建时间" prop="createTime" />
                        <el-table-column label="任务处理时间" prop="approveTime" />
                        <el-table-column label="候选人" prop="assignInfo" width="300">
                            <template #default="scope">
                                <span>{{changeAssignInfo(scope.row)}}</span>
                            </template>
                        </el-table-column>
                        <el-table-column label="执行人" prop="approverName" />
                        <el-table-column label="处理状态" prop="status">
                            <template #default="scope">
                                <div v-if="scope.row.status === 'start'">启动</div>
                                <div v-else-if="scope.row.status === 'agree'">同意</div>
                                <div v-else-if="scope.row.status === 'awaiting_check'">等待,待审批</div>
                                <div v-else-if="scope.row.status === 'reject'">驳回</div>
                            </template>
                        </el-table-column>
                        <el-table-column label="备注/意见" prop="opinion" />
                    </el-table>
                </div>
            </el-dialog>
        </div>
        <!-- @approveMsg="approveMsg" -->
        <start-from-list ref="startFromDetail" ></start-from-list>
    </div>
</template>

<script>
import startFromList from './evaluationAmendmentNewFrom.vue'
import btns from '../elbuttonS.vue'
import seachs from '../seachGroup.vue'
import {apiGetevaluationrevisionList, apiGetevaluatiorevisionSave,apiGetdoAction,apiGetworkflowgetOpinion,apievaluationrevisiontargetStart,
apiGetdeptresponsibilitygenerate, apiGetdatadictionaryList, apiPostevaluationrevisionDelete} from '../../api/api'
export default {
    components: {
        startFromList,
        btns,
        seachs
    },
    data() {
        return {
            dialogVisible: false,
            statesVisible: false,
            title: '',
            iframeURL: '',
            windframradio: {},
            deleteSelect: [],
            changeDateSelect: [],
            evaluationAmendmentData:[],
            page:{
                pagesize: 12,
                currentPage: 1,
                total: 0
            },
            ruleForm: {
                organizationType: '',
                evaluationCycle: '',
                year: '',
                desc: ''
            },
            rules: {
                desc: [
                    { required: true, message: '请输入描述', trigger: 'blur' }
                ]
            },
            organizationType: [],
            periodData: [],
            ruleDataAll: [],
            rescode: '',
            resDes: '',
            stageArr: [],
            winPix: window.devicePixelRatio,
            innerWidth: window.innerWidth
        }
    },
    created() {
        this.organizationType = [
            {
                label: '单位考评',
                code: 'DWKP'
            },
            {
                label: '部门考评',
                code: 'BMKP'
            }
        ]
        this.getevaluAmendmentList()
        this.getPeriodData()
    },
    methods:{
        // 查询列表页面
        getevaluAmendmentList() {
            let that = this
            let params = {
                pageNum: that.page.currentPage,
                pageSize: that.page.pagesize,
                chechCycle: 'NDKP',
                responsibilityCode: that.rescode,
                des: that.resDes
            }
            apiGetevaluationrevisionList(params).then(datas =>{
                if (datas && datas.data) {
                    that.evaluationAmendmentData = datas.data.records
                    that.page.total = datas.data.total
                }
            })
        },
        //考评周期
        getPeriodData() {
            let that = this
            let params = {
                superKey: 'KPZQ0001'
            }
            apiGetdatadictionaryList(params).then(datas =>{
                if (datas && datas.data) {
                    that.periodData = datas.data
                }
            })
        },
        modifyDesFn(row) {
            let that = this
            apiGetdeptresponsibilitySave(row).then(datas =>{
                if (!datas.success) {
                    that.$message({
                        message: datas.message,
                        type: 'error'
                    });
                } else {
                    that.$message({
                        message: '考评目标修改成功',
                        type: 'success'
                    });
                    that.getevaluAmendmentList()
                }
            })
        },
        saveevaluaStart(formName) {
            let that = this
            that.$refs[formName].validate((valid) => {
                if (valid) {
                    that.saveAndEditIndicatorData()
                }
            });
        },
        //新增/修改考评启动数据
        saveAndEditIndicatorData() {
            let that = this
            let userMes = JSON.parse(window.sessionStorage.getItem('user'))
            let params = {
                organizationType: that.ruleForm.organizationType,
                checkCycle: that.ruleForm.evaluationCycle,
                year: that.ruleForm.year,
                des: that.ruleForm.desc,
                createOrgId: userMes.unitId,
                createOrgName: userMes.unitName,
                createBy: userMes.id,
                createName: userMes.name
            }
            if (that.isSave) {
                params.id = this.evalradio.id
            }
            apiGetevaluatiorevisionSave(params).then(datas =>{
                if (!datas.success) {
                    that.$message({
                        message: datas.message,
                        type: 'error'
                    });
                } else {
                    if (!that.isSave) {
                        that.$message({
                            message: '考评目标新增成功',
                            type: 'success'
                        });
                    } else {
                        that.$message({
                            message: '考评目标修改成功',
                            type: 'success'
                        });
                    }
                    that.dialogVisible = false
                    that.changeDateSelect = []
                    that.getevaluAmendmentList()
                }
            })
        },
        agetdeptresponsibility(row) {
            let that = this
            let par = {
                defKey: "dwkpmbxd",
                businessKey: row.id,
                action: "start",
                opinion: "考评目标修订",
                iamCode: window.localStorage.getItem('code')
            }
            if (row.instId === null || row.instId === '') {
                apiGetdoAction(par).then(datas =>{
                    if (datas && datas.data) {
                        if (datas.data.isOk) {
                            that.$message({
                                message: '考评修订已启动',
                                type: 'success'
                            });
                            that.getrevisiontargetStart(row)
                        } else {
                            that.$message({
                                message: datas.data.msg,
                                type: 'error'
                            });
                        }
                    }
                })
            }
        },
        // 修改状态
        getrevisiontargetStart(row) {
            let that = this
            let params = {
                id: row.id,
                stage: '流程启动'
            }
            apievaluationrevisiontargetStart(params).then(datas =>{
                if (datas && datas.data) {
                    if (!datas.success) {
                        that.$message({
                            message: datas.message,
                            type: 'error'
                        });
                    }
                    that.getevaluAmendmentList()
                }
            })
        },
        clickDes(row, column, cell, event) {
            if (row.stage === '流程已结束') {
                row.chngeDes = false
            } else {
                let userMes = JSON.parse(window.sessionStorage.getItem('user'))
                if (userMes.id === row.createBy && row.stage === '流程未启动') {
                    if (column.label === '业务简述') {
                        row.chngeDes = true
                    } else {
                        row.chngeDes = false
                    }
                }
            }
        },
        //明细
        getDetail(row) {
            this.$refs.startFromDetail.init(row)
        },
        changeAssignInfo(row) {
            let showStr = ''
            if (row.assignInfo) {
                showStr = row.assignInfo.substring(row.assignInfo.indexOf('-')+1, row.assignInfo.length).substring(0, row.assignInfo.substring(row.assignInfo.indexOf('-')+1, row.assignInfo.length).indexOf('-'))
            }
            return showStr
        },
        seeStates(row) {
            if (!row.instId) {
                this.$message({
                    type: 'error',
                    message: '无法查看流程'
                });
            } else {
                this.statesVisible = true
                let url = ''
                if (window.location.hostname === '10.65.78.81') {
                    url = 'http://10.65.79.85:8080'
                } else {
                    url = 'http://10.65.78.23:8080'
                }
                this.iframeURL = url+'/agilebpm-ui/bpm/instance/instanceImageDialog.html?instanceId='+row.instId+'&iamCode='+window.localStorage.getItem('code')
                this.getstageData(row.instId)
            }
        },
        // 根据流程id获取业务id
        getstageData(id) {
            let that = this
            let params = {
                instId: id,
                iamCode: window.localStorage.getItem('code')
            }
            apiGetworkflowgetOpinion(params).then(datas =>{
                if (datas && datas.data) {
                    that.stageArr = datas.data.data                    
                }
            })
        },
        getSeachData() {
            this.page.currentPage = 1
            this.getevaluAmendmentList()
        },
        resetSeach() {
            this.page.currentPage = 1
            this.rescode = ''
            this.resDes = ''
            this.getevaluAmendmentList()
        },
        handleSizeChange(val){
            this.page.pagesize = val
            this.getevaluAmendmentList()
        },
        handleCurrentChange(val){
            this.page.currentPage =val
            this.getevaluAmendmentList()
        },
        rowClick(selection, row) {
            this.changeDateSelect = selection
        },
        approveMsg(val) {
            if (val) {
                this.getevaluAmendmentList()
            }
        },
        handleAdd() {
            this.dialogVisible = true
            this.title = '新建表单填报'
            this.$nextTick(() =>{
                this.$refs['ruleForm'].resetFields()
                this.ruleForm = {
                    organizationType: 'DWKP',
                    evaluationCycle: 'NDKP',
                    year: new Date().getFullYear().toString(),
                    desc: ''
                }
            })
        },
        //删除
        handleDelete() {
            this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
                confirmButtonText: '确定',
                cancelButtonText: '取消',
                type: 'warning'
            }).then(() => {
                let that = this
                let paramsArr = []
                that.changeDateSelect.forEach(it =>{
                    paramsArr.push(it.id)
                })
                apiPostevaluationrevisionDelete(paramsArr.join(',')).then(datas =>{
                    that.$message({
                        type: 'success',
                        message: '删除成功!'
                    });
                    that.getevaluAmendmentList()
                    that.changeDateSelect = []
                })
            })
        },
        evalAmendmentTableSty() {
            if (this.winPix === 1.25 || this.innerWidth < 1800) {
                return 'evalAmendment125Table'
            } else {
                return 'evalAmendment100Table'
            }
        }
    }
}
</script>

<style lang="less">
.evaluationAmendment{
    .evaluationAmendmentBtn{
        .collectSeach{
                display: flex;
                padding: 24px 20px;
                border-bottom: 1px solid#D6DBEA;
                .exceed{
                    display: flex;
                    .exceedSpan{
                        width: 100px;
                        height: 12px;
                        font-size: 14px;
                        font-family: Microsoft YaHei;
                        font-weight: 400;
                        color: #8991B0;
                        line-height: 12px;
                        margin-top: 14px;
                    }
                    .el-input{
                        margin-right:10px;
                        height: 40px;
                        .el-input__inner{
                            height:40px;
                        }
                        .el-input__suffix{
                            .el-select__caret{
                                line-height:30px;
                            }
                        }
                    }
                }
                .el-select{
                    margin-right:10px;
                    .el-input__inner{
                        height:30px;
                    }
                    .el-input__suffix{
                        .el-select__caret{
                            line-height:30px;
                        }
                    }
                }
        }
        span{
            font-size:14px;
        }
        .PeriodBtn{
            display: flex;
                justify-content: flex-end;
                padding: 20px 0;
        }
        .el-button{
            height: 30px;
            // width:100px;
            padding: 0 20px ;
            // padding-top: 8px;
            span{
                margin:0;
            }
        }
        .evaluationAmendmentTableData{
            .evalAmendment125Table{
                .el-table__body-wrapper{
                    height: 53vh !important;
                }
            }
            .evalAmendment100Table{
                .el-table__body-wrapper{
                    height: 60vh !important;
                }
            }
            .el-table{
                .el-input__inner{
                    height: 30px !important;
                }
                .el-radio__label{
                    display: none;
                }
                .tooltipCC{
                    width: 300px;
                    display: inline-block;
                    overflow: hidden;
                    text-overflow: ellipsis;
                    white-space: nowrap;
                }
                .tooltipCCDes{
                    width: 200px;
                    display: inline-block;
                    overflow: hidden;
                    text-overflow: ellipsis;
                    white-space: nowrap;
                }
                .indicitem{
                    color: #409EFF;
                    font-size: 12px;
                    margin-right: 20px;
                    cursor:pointer;
                    &:hover{
                        text-decoration: underline;
                    }
                }
            }
            .el-pagination{
                margin-top: 20px;
                text-align: end;
                position: relative;
            }
        }
        .el-overlay{
            .startToDia{
                .el-dialog__body{
                    padding: 30px 60px 30px 20px !important;
                    .periodFrom{
                        .el-select, .el-input{
                            width: 100%;
                        }
                        .el-input{
                            height: 30px;
                        }
                    }
                    .flowSty{
                        width: 100%;
                        height: 70vh;
                    }
                }
            }
        }
    }
    
}
</style>