<template>
    <div class="eibs-tab">
        <el-form
            ref="paramsForm"
            label-position="right"
            label-width="110px"
            size="small"
        >
            <c-col :span="24" style="margin-top: 10px">
                <!-- ================左=============== -->
                <c-col :span="8">
                    <c-col :span="24">
                        <el-form-item
                            label="开始处理"
                            prop="wfetsk.tsklist.strflg"
                            style="width: 100%"
                        >
                            <c-select
                                v-model="model.wfetsk.tsklist.strflg"
                                style="width: 100%"
                                placeholder="请选择Automatic Start Flag"
                            >
                                <el-option
                                    v-for="item in codes.strflg"
                                    :key="item.value"
                                    :label="item.label"
                                    :value="item.value"
                                >
                                </el-option>
                            </c-select>
                        </el-form-item>
                    </c-col>

                    <c-col :span="24">
                        <el-form-item
                            label="业务编号"
                            prop="wfetsk.refno"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.refno"
                                placeholder="请输入"
                            ></c-input>
                        </el-form-item>
                    </c-col>
                </c-col>

                <!-- ================中=============== -->
                <c-col :span="8">
                    <c-col :span="24"
                        ><el-form-item
                            label="初始化文件"
                            prop="wfetsk.tsklist.ininam"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.tsklist.ininam"
                                placeholder=""
                                style="width: 100%"
                            ></c-input>
                        </el-form-item>
                    </c-col>

                    <c-col :span="24">
                        <el-form-item
                            label="重启周期"
                            prop="wfetsk.tsklist.redotime"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.tsklist.redotime"
                                placeholder="请输入重启周期"
                                style="width: 100%"
                            ></c-input>
                        </el-form-item>
                    </c-col>
                </c-col>

                <!-- ================右=============== -->
                <c-col :span="8">
                    <c-col :span="14">
                        <el-form-item
                            label="开始时间"
                            prop="wfetsk.tsklist.jobstrdat"
                            style="width: 100%"
                        >
                            <c-date-picker
                                type="date"
                                v-model="model.wfetsk.tsklist.jobstrdat"
                                disabled
                                style="width: 100%"
                                placeholder="请选择"
                            ></c-date-picker>
                        </el-form-item>
                    </c-col>
                    <c-col :span="4" :offset="1">
                        <el-form-item
                            label="时"
                            prop="wfetsk.tsklist.jobstrtimhh"
                            label-width="25px"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.tsklist.jobstrtimhh"
                                disabled
                                placeholder="请输入"
                                style="width: 100%"
                            ></c-input>
                        </el-form-item>
                    </c-col>
                    <c-col :span="4" :offset="1">
                        <el-form-item
                            label="分"
                            label-width="25px"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.tsklist.jobstrtimmm"
                                placeholder="请输入"
                                disabled
                                style="width: 100%"
                            ></c-input>
                        </el-form-item>
                    </c-col>

                    <c-col :span="14">
                        <el-form-item
                            label="结束时间"
                            prop="wfetsk.tsklist.terflg"
                            style="width: 100%"
                        >
                            <c-select
                                v-model="model.wfetsk.tsklist.terflg"
                                style="width: 100%"
                                placeholder="请选择Automatic Termination Flag"
                            >
                                <el-option
                                    v-for="item in codes.terflg"
                                    :key="item.value"
                                    :label="item.label"
                                    :value="item.value"
                                >
                                </el-option>
                            </c-select>
                        </el-form-item>
                    </c-col>
                    <c-col :span="4" :offset="1">
                        <el-form-item
                            label="时"
                            prop="wfetsk.tsklist.downtimehh"
                            label-width="25px"
                            style="width: 100%"
                        >
                            <c-input
                                v-model="model.wfetsk.tsklist.downtimehh"
                                disabled
                                placeholder="请输入"
                            ></c-input>
                        </el-form-item>
                    </c-col>

                    <c-col :span="4" :offset="1">
                        <el-form-item label="分" prop="" label-width="25px" style="width: 100%">
                            <c-input
                                v-model="model.wfetsk.tsklist.downtimemm"
                                disabled
                                placeholder=""
                                style="width: 100%"
                            ></c-input>
                        </el-form-item>
                    </c-col>
                </c-col>
            </c-col>
            <c-col :span="24" style="text-align: right">
                <c-button
                    size="small"
                    type="primary"
                    style="margin-left: 10px"
                    :disabled="buttonFlag"
                    @click="Update"
                    >更新</c-button
                >
                <c-button
                    size="small"
                    type="primary"
                    style="margin-left: 10px"
                    :disabled="buttonFlag"
                    @click="Start"
                    >开始</c-button
                >
                <c-button
                    size="small"
                    type="primary"
                    style="margin-left: 10px"
                    :disabled="!buttonFlag"
                    @click="Stop"
                    >停止</c-button
                >
            </c-col>
        </el-form>

        <c-col :span="24" style="margin-top:12px">
            <div style="border-bottom: 10px solid rgb(232, 232, 232)"></div>
        </c-col>

        <!-- <c-col :span="16">
          <span
            v-text="model.wfetsk.tsklist.ininam"
            data-path=".wfetsk.tsklist.ininam"
          >
            Initialization File
          </span>
        </c-col> -->
        <!-- <c-col :span="12">
      <el-form-item label="Automatic Start Flag" prop="wfetsk.tsklist.strflg">
        <c-select
          v-model="model.wfetsk.tsklist.strflg"
          style="width: 100%"
          placeholder="请选择Automatic Start Flag"
        >
        </c-select>
      </el-form-item>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onTsklistButstr">
        &Start
      </c-button>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onTsklistButstp">
        S&top
      </c-button>
    </c-col>

    <c-col :span="12">
      <span
        v-text="model.wfetsk.tsklist.bcklab"
        data-path=".wfetsk.tsklist.bcklab"
      >
      </span>
    </c-col>

    <c-col :span="12">
      <span v-text="model.wfetsk.labetyextkey" data-path=".wfetsk.labetyextkey">
      </span>
    </c-col>

    <c-col :span="12">
      <el-form-item label="Selected Entity ID" prop="wfetsk.seletyextkey">
        <c-select
          v-model="model.wfetsk.seletyextkey"
          style="width: 100%"
          placeholder="请选择Selected Entity ID"
        >
        </c-select>
      </el-form-item>
    </c-col>

    <c-col :span="12">
      <span
        v-text="model.wfetsk.tsklist.timzonlab"
        data-path=".wfetsk.tsklist.timzonlab"
      >
      </span>
    </c-col>

    <c-col :span="12">
      <span v-text="model.wfetsk.labetgextkey" data-path=".wfetsk.labetgextkey">
      </span>
    </c-col>

    <c-col :span="12">
      <el-form-item label="Selected Entity Group" prop="wfetsk.seletgextkey">
        <c-input
          v-model="model.wfetsk.seletgextkey"
          maxlength="8"
          placeholder="请输入Selected Entity Group"
        ></c-input>
      </el-form-item>
    </c-col>

    <c-col :span="12">
      <el-form-item label="Stream of WFE entries" prop="wfetsk.wfestm">
        <c-input
          v-model="model.wfetsk.wfestm"
          placeholder="请输入Stream of WFE entries"
        ></c-input>
      </el-form-item>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onTsklistButexe">
        &Do Entry
      </c-button>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onTsklistButupd">
        &Upd. List
      </c-button>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onLogdspButdsp">
        &View Log
      </c-button>
    </c-col>

    <c-col :span="12">
      <c-button size="small" type="primary" @click="onTsklistButexi">
        E&xit
      </c-button>
    </c-col> -->
        <c-col :span="24">
            <c-istream-table :list="stmData.data" :columns="stmData.columns">
                <el-table-column fixed="right" label="操作">
                    <template slot-scope="scope">
                        <el-button
                            size="mini"
                            type="primary"
                            :disabled="buttonFlag"
                            @click="Entry(scope.$index, scope.row)"
                            >Entry</el-button
                        >
                    </template>
                </el-table-column>
            </c-istream-table>
        </c-col>
    </div>
</template>
<script>
import Api from "~/service/Api";
import commonProcess from "~/mixin/commonProcess";
import CodeTable from "~/config/CodeTable";
import Event from "~/model/Mgrtsk/Event";
import Utils from "~/utils/index";

export default {
    inject: ["root"],
    props: ["model", "codes"],
    mixins: [commonProcess],
    data() {
        return {
            stmData: {
                columns: [
                    '8 1 "实体" 100 1 0',
                    '7 2 "对象标识" 390 1 0',
                    '6 3 "唯一标识" 100 1 0',
                    '1 4 "服务" 100 1 0 3 SRVTXT',
                    '2 5 "状态" 100 1 0 2 WFE:STA',
                    '3 6 "重试次数" 100 2 20:1 1 FormatRTR',
                    '4 7 "目标" 200 20 30 1',
                ],
                data: [],
            },
            buttonFlag: false,
            timer: null,
        };
    },
    methods: {
        ...Event,
        async Entry(idx, row) {
            const selIds = [idx + 1];
            const selDst = "wfetsk.wfestm"; //列表对应后台模型中的stream
            let params = { selDst, selIds };
            await this.executeRule("wfetsk.tsklist.butexe", params).then((res) => {
                if (res.respCode == SUCCESS) {
                    this.Update();
                } else {
                    const h = this.$createElement;
                    const msg = res.respMsg || "请求执行失败!";
                    this.$notify.error({
                        title: "错误",
                        message: h(
                            "p",
                            { style: "word-break:break-all;" },
                            msg
                        ),
                    });
                }
            });
        },
        async Update() {
            let rtnmsg = await this.executeRule("wfetsk.tsklist.butupd");
            if (rtnmsg.respCode == SUCCESS) {
                //TODO 处理数据逻辑
                // Utils.copyValueFromVO(this.model, rtnmsg.data);
                this.stmData.data = rtnmsg.data.wfetsk_wfestm.rows;
            }
        },
        async Start() {
            this.buttonFlag = true;
            let rtnmsg = await this.executeRule("wfetsk.tsklist.butstr");
            if (rtnmsg.respCode == SUCCESS) {
                //TODO 处理数据逻辑
                this.stmData.data = rtnmsg.data.wfetsk_wfestm.rows;
            }
            //定时任务
            var timeVal = this.model.wfetsk.tsklist.redotime * 1000;
            var that = this;
            this.timer = setInterval(async function () {
                let rtnmsg = await that.executeRule("wfetsk.tsklist.butstr");
                if (rtnmsg.respCode == SUCCESS) {
                    //TODO 处理数据逻辑
                    that.stmData.data = rtnmsg.data.wfetsk_wfestm.rows;
                }
            }, timeVal);
        },
        async Stop() {
            this.buttonFlag = false;
            clearInterval(this.timer);
            let rtnmsg = await this.executeRule("wfetsk.tsklist.butstp");
            if (rtnmsg.respCode == SUCCESS) {
                //TODO 处理数据逻辑
                this.stmData.data = rtnmsg.data.wfetsk_wfestm.rows;
            }
        },
    },
    created: function () {},
    watch: {
        "model.wfetsk.wfestm": function () {
            this.stmData.data = this.model.wfetsk.wfestm.rows;
        },
    },
};
</script>
<style scope>
/* .m-table-search-form .el-form-item__content {
  width: calc(100% - 110px);
} */
</style>