<template>
    <!-- 弹出框表单 -->
    <el-drawer
            :title="title"
            :visible.sync="open"
            :direction="direction"
            :destroy-on-close="true"
            size="50%">
        <el-form ref="form" :model="form" :rules="rules" label-width="120px">
            <el-row>
                                            <Field label="问卷标题" prop="title" v-model="form.title" placeholder="请输入问卷标题"/>
                            <Field label="反馈开始时间" prop="feedbackTimeStart" v-model="form.feedbackTimeStart" type="date" />
                            <Field label="反馈结束时间" prop="feedbackTimeEnd" v-model="form.feedbackTimeEnd" type="date" />
                            <Field label="邀请人数" prop="inviteNum" v-model="form.inviteNum" placeholder="请输入邀请人数"/>
                            <Field label="反馈人数" prop="feedbackNum" v-model="form.feedbackNum" placeholder="请输入反馈人数"/>
                            <Field label="状态 " prop="processStatus" v-model="form.processStatus" type="select" :enumData="dict.processStatus" placeholder="请选择状态 "/>
                            <Field label="问卷是否外链" prop="weblink" v-model="form.weblink" type="select" :enumData="dict.weblink" placeholder="请选择问卷是否外链"/>
                            <Field label="问题外链地址" prop="webUrl" v-model="form.webUrl" type="textarea" placeholder="请输入问题外链地址"/>
                            <Field label="备注" prop="remark" v-model="form.remark" type="textarea" placeholder="请输入备注"/>

            </el-row>
                <el-divider content-position="center">绩效反馈问题信息</el-divider>
                <br/>
                <el-row :gutter="10" class="mb8">
                    <el-col :span="1.5">
                        <el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAddFeedbackQuestion">添加</el-button>
                    </el-col>
                    <el-col :span="1.5">
                        <el-button type="danger" icon="el-icon-delete" size="mini" @click="handleDeleteFeedbackQuestion">删除</el-button>
                    </el-col>
                </el-row>

                <el-table :data="feedbackQuestionList" :row-class-name="rowFeedbackQuestionIndex" @selection-change="handleFeedbackQuestionSelectionChange" ref="feedbackQuestion">
                    <el-table-column type="selection" width="50" align="center" />
                    <el-table-column label="序号" align="center" prop="index" width="50"/>
                            <el-table-column label="问题内容" prop="content">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.content" placeholder="请输入问题内容" />
                                </template>
                            </el-table-column>
                            <el-table-column label="问题类型 " prop="questionType">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.questionType" placeholder="请输入问题类型 " />
                                </template>
                            </el-table-column>
                            <el-table-column label="是否必填" prop="require">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.require" placeholder="请输入是否必填" />
                                </template>
                            </el-table-column>
                            <el-table-column label="备注" prop="remark">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.remark" placeholder="请输入备注" />
                                </template>
                            </el-table-column>
                            <el-table-column label="创建用户" prop="createUserId">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.createUserId" placeholder="请输入创建用户" />
                                </template>
                            </el-table-column>
                            <el-table-column label="创建时间" prop="createTime">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.createTime" placeholder="请输入创建时间" />
                                </template>
                            </el-table-column>
                            <el-table-column label="更新用户" prop="updateUserId">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.updateUserId" placeholder="请输入更新用户" />
                                </template>
                            </el-table-column>
                            <el-table-column label="更新时间" prop="updateTime">
                                <template slot-scope="scope">
                                    <el-input v-model="scope.row.updateTime" placeholder="请输入更新时间" />
                                </template>
                            </el-table-column>
                </el-table>

            <form-buttons @submit='submitForm' v-if="pageInfo.type!='view'" noCancelBtn />
        </el-form>

    </el-drawer>
</template>

<script>
    import form from "@/assets/mixins/formdialog";
    export default {
        name: "FeedbackDetail",
        mixins: [form],
        components: {

        },
        created() {
            this.changePath("feedback")
        },
        data() {
            return {
                // 子表选中数据
                checkedFeedbackQuestion: [],
                // 绩效反馈问题表格数据
                feedbackQuestionList: [],
                // 遮罩层
                loading: true,
                // 弹出层标题
                title: "绩效反馈记录信息",
                // 是否显示弹出层
                open: false,
                direction:"rtl",
                toString:[
                    "processStatus",
                    "weblink",
                ],
                toDate:[
                    "feedbackTimeStart",
                    "feedbackTimeEnd",
                ],
                // 表单校验
                rules: {
                    title: [
                        {required: true,message: "请输入问卷标题", trigger: "blur" },
                        {max: 64,message: "最多只能录入64个字符",trigger: "blur",},
                    ],
                }
            };
        },

        methods: {
            /** 绩效反馈问题序号 */
            rowFeedbackQuestionIndex({ row, rowIndex }) {
                row.index = rowIndex + 1;
            },
            /** 绩效反馈问题添加按钮操作 */
            handleAddFeedbackQuestion() {
                let obj = {};
                obj.content = "";
                obj.questionType = "";
                obj.require = "";
                obj.remark = "";
                obj.createUserId = "";
                obj.createTime = "";
                obj.updateUserId = "";
                obj.updateTime = "";
                this.feedbackQuestionList.push(obj);
            },
            /** 绩效反馈问题删除按钮操作 */
            handleDeleteFeedbackQuestion() {
                if (this.checkedFeedbackQuestion.length == 0) {
                    this.$alert("请先选择要删除的绩效反馈问题数据", "提示", { confirmButtonText: "确定", });
                } else {
                    this.feedbackQuestionList.splice(this.checkedFeedbackQuestion[0].index - 1, 1);
                }
            },
            /** 单选框选中数据 */
            handleFeedbackQuestionSelectionChange(selection) {
                if (selection.length > 1) {
                    this.$refs.feedbackQuestion.clearSelection();
                    this.$refs.feedbackQuestion.toggleRowSelection(selection.pop());
                } else {
                    this.checkedFeedbackQuestion = selection;
                }
            },
            // 渲染前置处理
            beforeRender(data) {
                if(data.entity.feedbackQuestionList) {
                    this.feedbackQuestionList = data.entity.feedbackQuestionList;
                }
                return data
            },
            /** 编辑 */
            edit(row) {
                this.reset()
                this.query = { id: row.id };
                this.urls.currUrl ="feedback/edit";
                this.getData();
                this.pageInfo.type="edit"
                this.title = "修改绩效反馈记录信息";
            },
            /** 新增 */
            add(row) {
                this.reset()
                this.urls.currUrl = "feedback/add";
                this.getData();
                this.pageInfo.type="add"
                this.title = "新增绩效反馈记录信息";
            },
            /** 查看*/
            view(row) {
                this.reset()
                this.query = { id: row.id };
                this.urls.currUrl ="feedback/view";
                this.getData();
                this.pageInfo.type="view"
                this.title = "绩效反馈记录信息详细";
            },
            /**取消按钮 */
            cancel() {
                this.open = false;
            },
            /**获取数据后弹框 */
            afterRender(data) {
                this.open = true;
            },

            afterSubmit(data) {
                this.open = false;
                this.$emit("ok");
            },

            // 表单重置
            reset() {
                this.form = {
                    title : "",
                    feedbackTimeStart : null,
                    feedbackTimeEnd : null,
                    inviteNum : 0,
                    feedbackNum : 0,
                    processStatus : 0,
                    weblink : 0,
                    webUrl : "",
                    remark : "",
                };
                this.resetForm("form");
            },
            resetForm(refName) {
                if (this.$refs[refName]) {
                    this.$refs[refName].resetFields();
                }
            },
        },
    };
</script>