<template>
  <div class="eContainer">
    <el-form :model="model" :rules="rules" ref="modelForm" label-width="120px" label-position="right" size="small"
      :validate-on-rule-change="false">
      <c-tabs v-model="tabVal" ref="elment" type="card" @tab-click="myTabClick">
        <el-tab-pane label="业务信息" name="ovwp">
          <c-content>
            <m-ovwp :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>

        <!--limmod PD000001 统一授信 -->
        <el-tab-pane label="统一授信" name="limitbody">
          <c-content>
            <m-limitbody :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>

        <el-tab-pane label="费用/账务" name="engp,setpan,glepan">
          <c-content>
            <div class="eibs-tab">
              <el-collapse v-model="activeNames">
                <el-collapse-item title="表外记账" name="engp">
                  <!-- 表外记账 -->
                  <m-engp :model="model" :codes="codes" />
                </el-collapse-item>
                <el-collapse-item title="结算" name="setpan">
                  <!-- 结算 -->
                  <m-setpan :model="model" :codes="codes" />
                </el-collapse-item>
                <el-collapse-item title="会计分录" name="glepan">
                  <!-- 会计分录 -->
                  <m-glepan :model="model" :codes="codes" />
                </el-collapse-item>
              </el-collapse>
            </div>
          </c-content>
        </el-tab-pane>

        <!--PD000510 -->
        <el-tab-pane label="备查/附言" name="addbcb">
          <c-content>
            <m-addbcb :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>

        <el-tab-pane label="申报信息" name="cnyp">
          <c-content>
            <m-cnyp :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>

        <el-tab-pane label="报文/面函" name="docpan">
          <c-content>
            <m-docpan :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>

        <!--trndoc PD000546 Attachments -->
        <el-tab-pane label="附件" name="doctre">
          <c-content>
            <m-doctre :model="model" :codes="codes" />
          </c-content>
        </el-tab-pane>
      </c-tabs>
    </el-form>
    <c-grid-ety-prompt-dialog ref="etyDialog" :promptData="promptData" v-on:select-ety="selectEty">
    </c-grid-ety-prompt-dialog>
    <c-grid-ety-prompt-dialog ref="doxpDialog" :isPty="false" :promptData="promptData" @select-ety="selectMsg">
    </c-grid-ety-prompt-dialog>
    <c-function-btn :handleSubmit="handleSubmit" :handleCheck="handleCheck" :handleStash="handleStash">
      <!-- <el-button size="small">用户确认</el-button>
      <el-button size="small">检核</el-button>
      <el-button size="small">日志</el-button>
      <el-button size="small">inc to Ben</el-button>
      <el-button size="small">imgyge</el-button>
      <el-button size="small">img</el-button>
      <el-button size="small">His.img</el-button> -->
    </c-function-btn>
  </div>
</template>
<script>
import Api from '~/service/Api'
import CodeTable from '~/config/CodeTable'
import Betsnd from '~/model/Betsnd'
import commonProcess from '~/mixin/commonProcess'
import commonFuncs from '~/mixin/commonFuncs'
import Check from '~/model/Betsnd/Check'
import Default from '~/model/Betsnd/Default'
import Pattern from '~/model/Betsnd/Pattern'

import Ovwp from "./Ovwp";
import Limitbody from '~/views/Public/Limitbody';
import Engp from "~/views/Public/Engp";
import Setpan from "~/views/Public/Setpan";
import Glepan from "~/views/Public/Glepan";
import Addbcb from "./Addbcb";
import Cnyp from './Cnyp'
import Docpan from "~/views/Public/Docpan";
import Doctre from '~/views/Public/Doctre';


export default {
  name: 'Betsnd',
  components: {
    'm-ovwp': Ovwp,
    'm-limitbody': Limitbody,
    'm-engp': Engp,
    'm-setpan': Setpan,
    'm-glepan': Glepan,
    'm-addbcb': Addbcb,
    'm-cnyp': Cnyp,
    'm-docpan': Docpan,
    'm-doctre': Doctre,
  },
  provide() {
    return {
      root: this,
    }
  },
  mixins: [commonProcess, commonFuncs], // 里面包含了Default、Check等的公共处理
  data() {
    return {
      tabVal: 'ovwp',
      activeNames: ["engp"],
      trnName: 'betsnd',
      trnType: '',
      model: new Betsnd().data,
      checkRules: Check,
      defaultRules: Default,
      pattern: Pattern,
      rules: null,
      codes: { ...CodeTable },
    }
  },
  methods: {
    myTabClick(tab) {
      this.tabClick(tab)
      /**
       *  do it yourself
       **/
    },
  },
  created: async function () {
    console.log('进入betsnd交易')
    let rtnmsg = await this.init({})
    if (rtnmsg.respCode == SUCCESS) {
      this.updateModel(rtnmsg.data)
      //TODO 处理数据逻辑
      if (this.isInDisplay) {
        this.restoreDisplay()
      }
    } else {
      this.$notify.error({ title: '错误', message: '服务请求失败!' })
    }
  },
}
</script>
<style>

</style>