<style>
    .page_CompanyAccDetail .query-box li label{display: inline-block;min-width: 80px;text-align: right;font-style: normal;margin: 0 20px 0 0;}
    .page_CompanyAccDetail .query-box{
        padding-bottom: 0;
        margin-top: 20px;
    }
    .page_CompanyAccDetail .query-box li:last-child{top: 34px;}
    ._shoufu_date input.el-input__inner{padding: 0px 0 0 27px;}
    .page_CompanyAccDetail .el-date-editor .el-range-separator{width: 9% !important;}
    .page_CompanyAccDetail .el-date-editor--daterange.el-input__inner{width: auto !important;}
    ._bg__{
        border-radius: 4px;
        cursor: pointer;
        text-decoration: underline;
    }
    .Guid_bg_red{color: #E95252;}
    .Guid_bg_green{color: #2BB87C}
    ._addChuNa_tit{color: gray;margin-bottom: 10px;}
    ._addChuNa_tit span{ color:#333333}
</style>
<template>
    <div  class='flexOne page_CompanyAccDetail'>
        <div class='query-box'>
            <el-form class="_info_box clearfix"  label-width="110px">
                <el-row>
                    <!-- <el-col :span="4" :gutter="35">
                        <el-form-item :label="$t('fnc.zhanghuleixing')">
                            <el-select  filterable  v-model='accType' @change="bankaccount_post_GetList">
                                <el-option v-for='item in AccList'
                                    :label='item.Name'
                                    :value='item.ID'
                                    :key='item.ID'>
                                </el-option>
                            </el-select>
                        </el-form-item>
                    </el-col> -->
                    <!-- <el-col :span="4" :gutter="35">
                        <el-form-item :label="$t('fnc.a_yhzhanghu')">
                            <el-select  filterable  v-model='AccountId' @change="accountListChange">
                                <el-option v-for='item in accountList'
                                    :label='item.Alias'
                                    :value='item.ID'
                                    :key='item.ID'>
                                </el-option>
                            </el-select>
                        </el-form-item>
                    </el-col> -->
                    <!-- <el-col :span="4" :gutter="35">
                        <el-form-item label="出纳审核">
                            <el-select  filterable  v-model='msg.Is_Cashier' >
                                <el-option label='全部' :value='-1'></el-option>
                                <el-option label='已审核' :value='1'></el-option>
                                <el-option label='未审核' :value='0'></el-option>
                            </el-select>
                        </el-form-item>
                    </el-col> -->
                     <el-col :span="4" :gutter="35">
                        <el-form-item label="所属公司">
                            <el-select  filterable  v-model='msg.RB_Branch_Id' >
                              <el-option :value="-1" label="不限"></el-option>
                                <el-option v-for='item in CompanyList'
                                    :label='item.BName'
                                    :value='item.Id'
                                    :key='item.Id'>
                                </el-option>
                            </el-select>
                        </el-form-item>
                    </el-col>
                    <el-col :span="4" :gutter="35">
                        <el-form-item label="领队导游">
                            <el-select  filterable  v-model='msg.ClientID' >
                                <el-option v-for='item in ClientAccountList'
                                    :label='`${item.AccountAlias}(${item.AccountHolder})`'
                                    :value='item.ID'
                                    :key='item.ID'>
                                </el-option>
                            </el-select>
                        </el-form-item>
                    </el-col>
                     <el-col :span="4" :gutter="35">
                        <el-form-item :label="$t('fnc.a_djztai')">
                            <el-select  filterable  v-model='msg.Status' >
                                <el-option :label="$t('pub.unlimitedSel')" :value='-1'></el-option>
                                <el-option :label='$t("fnc.a_shezhong")' :value='1'></el-option>
                                <el-option :label='$t("visa.v_tongguo")' :value='2'></el-option>
                                <el-option :label='$t("fnc.bohui")' :value='3'></el-option>
                                <el-option :label='$t("fnc.a_cnzancun")' :value='5'></el-option>
                            </el-select>
                        </el-form-item>
                    </el-col>
                    <el-col :span="4" :gutter="35">
                        <el-form-item label="类型">
                            <el-select  filterable  v-model='msg.Is_Cashier' >
                                <el-option :label="$t('pub.unlimitedSel')" :value='-1'></el-option>
                                <el-option label='出纳未审' :value='0'></el-option>
                                <el-option label='出纳已审' :value='1'></el-option>
                            </el-select>
                        </el-form-item>
                    </el-col>
                    <!-- <el-col :span="8" :gutter="35">
                        <el-form-item :label="$t('fnc.a_hkfkriqi')">
                                <el-date-picker class="h34"
                                    @change="timeAdd"
                                    v-model="productionDate"
                                    type="daterange"
                                    value-format="yyyy-MM-dd"
                                    :range-separator="$t('restaurant.res_To')">
                                </el-date-picker>
                            </el-form-item>
                    </el-col> -->
                    <el-col :span="6">
                      <el-form-item label="汇款/付款日期">
                        <el-date-picker
                          @change="timeAdd"
                          v-model="productionDate"
                          type="daterange"
                          range-separator="-"
                          start-placeholder="开始日期"
                          end-placeholder="结束日期"
                          value-format="yyyy-MM-dd"
                        ></el-date-picker>
                      </el-form-item>
                    </el-col>
                    <el-col :span="6">
                      <el-form-item label="发团日期">
                        <el-date-picker
                          @change="timeAddByTC"
                          v-model="productionDateByTC"
                          type="daterange"
                          range-separator="-"
                          start-placeholder="开始日期"
                          end-placeholder="结束日期"
                          value-format="yyyy-MM-dd"
                        ></el-date-picker>
                      </el-form-item>
                    </el-col>
                    <!-- <el-col :span="4" :gutter="35">
                        <el-form-item label="费用类型">
                            <el-select  filterable  v-model='msg.CostTypeID' >
                              <el-option :value="0" label="不限"></el-option>
                              <el-option v-for="item in GetCostTypeList" :key="item.ID" :value="item.ID" :label="item.Name"></el-option>
                            </el-select>
                        </el-form-item>
                    </el-col> -->
                   
                </el-row>
            </el-form>
			<ul>
				<li>
          <!-- <input type="button" class="hollowFixedBtn" :value="$t('fnc.a_hbdanju')" @click="addChuNaFun"/> -->
          <input type="button" class="hollowFixedBtn" :value="$t('pub.searchBtn')" @click="getList()"/>
          <input type="button" class="normalBtn" :value="$t('visa.v_daochu')"  @click="Export"/>
          </li>
			</ul>
		</div>
        <div class="cm_content">
            <table class="po_content singeRowTable" style="border:1px solid #E6E6E6;" cellspacing="0" cellpadding="0" v-loading="loading">
                <tr>
                    <th>类型名称</th>
                    <th>{{$t('system.query_company')}}</th>
                    <th>{{$t('fnc.danhao')}}</th>
                    <th>团</th>
                    <th>费用类型</th>
                    <th>{{$t('fnc.a_hkrfkduixiang')}}</th>
                    <th>{{$t('fnc.a_hkfkshijian')}}</th>
                    <th>{{$t('fnc.jylshuihao')}}</th>
                    <th>制单人</th>
                    <th>待收金额</th>
                    <th>待付金额</th>
                    <th>总计</th>
                </tr>
                <!-- <tr>
                    <td :colspan="8">{{$t('fnc.a_qcyue')}}:</td>
                    <td></td>
                    <td></td>
                    <td>{{moneyFormat(dataJson.Balance)}}</td>
                </tr> -->
                <tr v-show="DataList.length>5">
                    <td :colspan="9">{{$t('fnc.a_heji')}}({{$t('hotel.hotel_totalRoom')}}{{ DataList.length }} {{$t('hotel.hotel_item')}})</td>
                    <td>{{ dataJson.Income }}</td>
                    <td>{{ dataJson.Refund }}</td>
                    <td>{{ dataJson.Balance}}</td>
                </tr>
                <tr v-for="(item,index) in DataList" :key="index">
                    <!-- <td>
                      <input type="checkbox" :disabled="item.disabled" v-model="item.check" @change="addCheckbox(item,index)">
                    </td> -->
                    <td>{{item.TypeName}}</td>
                    <td>{{item.BName}}</td>
                    <!-- <td><span class="cursorpointer" :class="item.Type==1?'Guid_bg_green':'Guid_bg_red'" @click="goUrl('FinancialDocumentsDetail',item.FinanceId)">{{ item.FinanceId }}</span> </td> -->
                     <td>
                        <span class="cursorpointer" :class=" item.Type === 1 ? 'Guid_bg_green' : 'Guid_bg_red'" @click="goUrlNew(item)">
                            {{ item.FinanceId }}</span>
                    </td>
                    <td>
                        <p v-for="(tc,tindex) in item.TCList" :key="tindex+100">{{tc.TCNUM}}({{tc.TCID}})</p>
                    </td>
                    <td>
                        <p v-for="(cost,cindex) in item.CostTypeList" :key="cindex+200">{{cost}}</p>
                    </td>
                    <td>
                        <p>{{item.RemitterName}}</p>
                      
                    </td>
                    <td>
                        <span>{{ item.TradeDate }}</span>
                        <span></span>
                    </td>
                    <td>
                        {{ item.AccountNumber }}
                    </td>
                    <td>{{item.EmName}}</td>
                    <td>{{item.Income}}</td>
                    <td>{{item.Refund}}</td>
                    <td>{{item.Balance }}</td>
                </tr>
                <tr>
                    <td :colspan="9">{{$t('fnc.a_heji')}}({{$t('hotel.hotel_totalRoom')}}{{ DataList.length }} {{$t('hotel.hotel_item')}})</td>
                    <td>{{ dataJson.Income }}</td>
                    <td>{{ dataJson.Refund }}</td>
                    <td>{{ dataJson.Balance}}</td>
                </tr>
            </table>
        </div>
        <el-dialog custom-class='w750 height="34px"' :title="$t('fnc.a_hbdanju')" :visible.sync="addChuNa" center :before-close="initAddChuNa" v-loading="allLoading">
          <p class="_addChuNa_tit"><span>{{count}}</span>{{$t('fnc.a_hbtips')}} <span>{{ moneyFormat(allWPrice) }}</span> {{$t('fnc.a_hbtips2')}} <span>{{ moneyFormat(allBPrice) }}</span> </p>
          <table border="1" bordercolor="#D2D2D2" style="border-collapse:collapse;text-align: center;    width: 100%;">
              <template>
                <tr >
                  <th height="34px">{{$t('fnc.zhfenlei')}}</th>
                  <th height="34px">{{$t('fnc.fkfangshi')}}</th>
                  <th height="34px">{{$t('fnc.acc')}}</th>
                  <!-- <th width="100px">账户余额</th> -->
                  <th height="34px">{{$t('fnc.jine')}}</th>
                  <th height="34px" width="70">{{$t('hotel.hotel_Currency')}}</th>
                  <th height="34px" width="50px">{{$t('hotel.hotel_CurrentRate')}}</th>
                  <!-- <th>手续费</th> -->
                  <th height="34px" width="100px">{{$t('fnc.a_zongjine')}}</th>
                  <!-- <th>操作</th> -->
                </tr>
                <template v-for="(item,index) in payMsgList">
                  <tr v-if="!item.show" @click="payMsgList[index].show=true">
                    <td height="34px">{{item.AccName}}</td>
                    <td height="34px">{{item.Name}}</td>
                    <td height="34px">{{item.Account}}</td>
                    <!-- <td>{{item.balance}}</td> -->
                    <td height="34px">{{moneyFormat(item.OriginalMoney)}}</td>
                    <td height="34px">{{item.CurrenName}}</td>
                    <td height="34px">{{item.Rate}}</td>
                    <!-- <td>{{item.Fee}}</td> -->
                    <td height="34px">{{moneyFormat(item.allMoney)}}</td>
                    <!-- <td></td> -->
                  </tr>
                  <tr v-else class="_show_class">
                    <td>
                      <el-select  filterable  v-model='item.AccName'  @change="clearAccBank()" class=" _border_b_1">
                        <el-option v-for='i in AccListT'
                                   :label='i.Name'
                                   :value='i.Name'
                                   :key='i.ID'>
                        </el-option>
                      </el-select>
                    </td>
                    <td>
                      <el-select  filterable  v-model='item.Type'  @change="getAccountList(item.Type)" class=" _border_b_1">
                        <el-option v-for='i in GetAccountType'
                                   :label='i.Name'
                                   :value='i.ID'
                                   :key='i.ID'>
                        </el-option>
                      </el-select>
                    </td>
                    <td>
                      <el-select  filterable  v-model='item.AccountId'  :placeholder="$t('rule.qxzzhanghu')" @change="setAccountName(item.AccountId,1,index)" class=" _border_b_1">
                        <el-option v-for='i in accountList'
                                   :label='i.allName'
                                   :value='i.ID'
                                   :key='i.ID'>
                        </el-option>
                      </el-select>
                    </td>
                    <td>
                      <el-input v-model="item.OriginalMoney" @change="Calculation(1,index)" @blur="item.show=false,CalculationMoney" :placeholder="$t('rule.qsrjine')" type="number"  class=" _border_b_1"></el-input>
                    </td>
                    <td>
                      <p>{{item.CurrenName}}</p>
                    </td>
                    <td>
                      <el-input v-model="item.Rate" @blur="item.show=false,CalculationMoney" @change="Calculation(1,index)" type="number" class=" _border_b_1"></el-input>
                    </td>
                    <td>{{moneyFormat(item.allMoney)}} <i @click="deleteRow(item,index),CalculationMoney" class="_delete_row iconfont icon-img_delete_small"></i></td>
                  </tr>
                </template>
                <tr>
                  <td>
                    <el-select  filterable  v-model='payMsg.AccName'  @change="clearAccBank()" class=" _border_b_1">
                      <el-option v-for='i in AccListT'
                                 :label='i.Name'
                                 :value='i.Name'
                                 :key='i.ID'>
                      </el-option>
                    </el-select>
                  </td>
                  <td>
                    <el-select  filterable  v-model='payMsg.Type'  @change="getAccountList(payMsg.Type)" class=" _border_b_1">
                      <el-option v-for='i in GetAccountType'
                                 :label='i.Name'
                                 :value='i.ID'
                                 :key='i.ID'>
                      </el-option>
                    </el-select>
                  </td>
                  <td>
                    <el-select  filterable  v-model='payMsg.AccountId'  :placeholder="$t('rule.qxzzhanghu')" @change="setAccountName(payMsg.AccountId,2)" class=" _border_b_1">
                      <el-option v-for='i in accountList'
                                 :label='i.allName'
                                 :value='i.ID'
                                 :key='i.ID'>
                      </el-option>
                    </el-select>
                  </td>
                  <td>
                    <el-input v-model="payMsg.OriginalMoney" @change="Calculation(2)" @blur="addList()" :placeholder="$t('rule.qsrjine')" type="number"  class=" _border_b_1"></el-input>
                  </td>
                  <td>
                    <p>{{payMsg.CurrenName}}</p>
                  </td>
                  <td>
                    <el-input v-model="payMsg.Rate" @blur="addList()" @change="Calculation(2)" type="number" class=" _border_b_1"></el-input>
                  </td>
                  <td>{{moneyFormat(payMsg.allMoney)}}</td>
                </tr>
              </template>

            <tr>
              <td height="34px">{{$t('fnc.a_zongjine')}}</td>
              <td height="34px" colspan="7">
                <el-input v-model="listAllMoney"  type="number" :placeholder="$t('rule.qsrzjine')" class=" _border_b_1"></el-input>
                <!--{{moneyFormat(listAllMoney)}}-->
              </td>
            </tr>
            <tr v-if="BillType===2">
              <td>{{$t('fnc.jiaoyiriqi')}}</td>
              <td colspan="7">
                <el-date-picker
                  class="width100b"
                  v-model="addMsg.TradeDate"
                  type="date"
                  :default-value="TradeDate"
                  value-format="yyyy-MM-dd"
                  :placeholder="$t('admin.admin_choDate')">
                </el-date-picker>
              </td>
            </tr>
            <tr v-if="BillType===1">
              <td>{{$t('fnc.huikuanren')}}</td>
              <td colspan="2">
                <el-input v-model="addMsg.RemitterName" type="text" class=" _border_b_1"></el-input>
              </td>
              <td>{{$t('fnc.jiaoyiriqi')}}</td>
              <td colspan="3">
                <el-date-picker
                  class="width100b"
                  v-model="addMsg.TradeDate"
                  type="date"
                  value-format="yyyy-MM-dd"
                  :placeholder="$t('admin.admin_choDate')">
                </el-date-picker>
              </td>
            </tr>
          </table>
          <div slot="footer" class="dialog-footer">
            <button class="normalBtn" type="primary" @click="submitAddChuNa">{{$t('pub.saveBtn')}}</button>
            &nbsp;
            <button class="hollowFixedBtn" @click="initAddChuNa">{{$t('pub.cancelBtn')}}</button>
          </div>
        </el-dialog>
    </div>
</template>
<script>
import moment from "moment"
export default {
    data(){
        return{
            msg:{
                pageIndex:1,
                pageSize:5,
                ClientID:'',
                CostTypeID:0,
                RB_Branch_Id:-1,
                sTradeDate:'',
                eTradeDate:'',
                QStartDate:'',
                QEndDate:'',
                BankList:[],
                Is_Cashier:0,
            },
            Type:1,
            AccountId:'',
            DataList:[],
            dataJson:{
                Balance:0,
                Income:0,
                Refund:0,
            },
            StartMoney:0,
            AccountTypeList:[],
            AccList:[],
            GetAccountType:[],
            accountList:[],
            productionDate:[],
            productionDateByTC:[],
            ClientAccountList:[],
            GetCostTypeList:[],
            CompanyList:[],
            loading:false,
            date:'',
            accType:'',
            allMoney:0,
            OutMoney:0,
            InMoney:0,
            BillType:1, //1 收 2 支  ,
            addChuNa:false,
            allLoading: false,
            payMsgList:[],
            payMsg: {
              ID:0,
              FinanceId:'',
              Type:'',
              AccountId:'',
              OriginalMoney:0,
              CurrencyId:'',
              Rate:0,
              Fee:0,
              Name:'',
              CurrenName:'',
              Account:'',
              balance:'',
              allMoney:0,
              show:false,
            },
            addMsg:{
              FrIDs:'',
              RemitterName:'',
              TradeDate:'',
              BankList:[],
            },
            AccListT:[],
            accountListT:[],
            listAllMoney:0,
            checkList:[],
            count:0,
            allBPrice:0,
            allWPrice:0,
            userInfo:{},
        }
    },
    created(){
      this.userInfo = this.getLocalStorage();
    if(this.$route.query.TypeId&&!this.$route.query.ID){
      this.msg.Is_Cashier = parseInt(this.$route.query.Is_Cashier);
      this.accType = parseInt(this.$route.query.TypeId);
      this.msg.sTradeDate = this.$route.query.sTradeDate?this.$route.query.sTradeDate:"";
      this.msg.eTradeDate = this.$route.query.eTradeDate?this.$route.query.eTradeDate:"";
      this.productionDate = [this.msg.sTradeDate, this.msg.eTradeDate];
      this.productionDateByTC=[this.msg.QStartDate, this.msg.QEndDate];
      this.getList();      
      this.bankaccount_post_GetListS("query");
    }
    if(this.$route.query.ID){
      this.accType = parseInt(this.$route.query.TypeId);      
      this.AccountId=parseInt(this.$route.query.ID);
      let mon1=moment().format("YYYY-MM-DD");      
      let mon2=moment().subtract(1, "months").format("YYYY-MM-DD");
      this.productionDate=[mon2,mon1];
      this.msg.sTradeDate=mon2;
        this.msg.eTradeDate=mon1;
        this.msg.BankList=[];
        this.msg.BankList.push({
                    Type:this.Type,
                    AccountId:this.AccountId
                })
      this.bankaccount_post_GetList();
      this.getList();
      
    }
  },methods:{
    Export(){
            let msg=this.msg;
            msg.EmployeeId = this.userInfo.EmployeeId;
            msg.AccountToExcelType=2;
            var fileName = "领队导游往来账.xls";
            this.GetLocalFile("Financial_post_OutToExcelLeaderDealingsList", msg, fileName);
        },
        goUrlNew(item){
              let status=false;
              if(item.CostTypeList){
                  item.CostTypeList.forEach(cost=>{
                      if(cost=="资金调拨"){
                          status=true;
                      }
                  })
              }
              if(status){
                  this.$router.push({ name: "CapitalAllocationDetail",query:{"id":item.FinanceId,blank:'y'} }) 
              }else{
                  this.$router.push({ name: "FinancialDocumentsDetail",query:{"id":item.FinanceId,blank:'y'} })                 
              }
          },
        goUrl(path,id){
            this.$router.push({ name: path,query:{"id":id,blank:'y'} })
        },
        accountListChange(){
            this.msg.BankList = [];
            this.msg.BankList.push(
                {
                    Type:this.Type,
                    AccountId:this.AccountId
                }
            )
        },
        financeinfo_post_GetClientAccountList(){  //获取付款对象
            let msg = {
                ID:0,
                Type:7,
                ObjID:0,
                CardNum:''
            };
            this.apipost('financeinfo_post_GetClientAccountList',msg, res => {
                let data = res.data.data;
                this.ClientAccountList = data;
            }, err => {})
        },
        timeAdd(){  // 日期格式
            if(!this.productionDate){
                this.msg.sTradeDate = '';
                this.msg.eTradeDate = '';
                return
            }
            this.msg.sTradeDate = this.productionDate[0];
            this.msg.eTradeDate = this.productionDate[1];
        },
        timeAddByTC(){  // 日期格式
            if(!this.productionDateByTC){
                this.msg.QStartDate = '';
                this.msg.QEndDate = '';
                return
            }
            this.msg.QStartDate = this.productionDateByTC[0];
            this.msg.QEndDate = this.productionDateByTC[1];
        },
        bankaccount_post_GetList(){  // 获取银行账户
            // this.AccountId = '';
            this.apipost('bankaccount_post_GetList',{TypeId:this.accType}, res => {
                if(res.data.resultCode == 1) {
                    let data = res.data.data;
                    this.accountList = data;
                }
            }, err => {})
        },
        BankAccount_post_GetAccountType(){   //获取账户类型列表
            this.apipost('BankAccount_post_GetAccountType',{}, res => {
                if(res.data.resultCode == 1) {
                    this.GetAccountType = res.data.data;
                }
            }, err => {})
        },
        AccountType_post_GetList(){  //获取账户类型下拉
            this.apipost('AccountType_post_GetList',this.queryAccMsg,res=>{
                if(res.data.resultCode==1){
                    this.AccList = res.data.data;
                  this.AccListT = res.data.data;

                }else{
                    this.$message.error(res.data.message);
                }
            },err=>{})
        },
        getAccountTypeList() {  //获取账户类型
            this.apipost('AccountType_post_GetList',{}, res => {
                if(res.data.resultCode == 1) {
                    this.AccountTypeList = res.data.data;
                }
            }, err => {})
        },
        getList(){ //获取列表
            this.checkList=[];        
            this.loading = true
            if( this.msg.ClientID == '' ){
                this.msg.ClientID = 0;
            }
           if(this.$route.query.BankID){
            this.msg.BankList.push(
                {
                    Type:1,
                    AccountId:parseInt(this.$route.query.BankID)
                })
            }
            this.allMoney = '';
            this.apipost('Financial_post_GetLeaderDealingsList',this.msg,res=>{
              
                this.loading = false;
                 if(res.data.resultCode==1){
                    let data = res.data.data;
                    this.dataJson=data;
                    
                   this.DataList = data.Rlist;
               
                    
                    if( this.msg.ClientID == 0 ){
                        this.msg.ClientID = '';
                    }
                }else{
                    this.$message.error(res.data.message)
                    this.loading = false;
                    if( this.msg.ClientID == 0 ){
                        this.msg.ClientID = '';
                    }
                }
            },err=>{})
        },
        initAddChuNa(){
          this.payMsgList = [];
          this.listAllMoney = 0;
          this.huikuanren = '';
          this.TradeDate = '';
          this.addChuNa = false;
          this.payMsg = {
            ID:0,
            FinanceId:'',
            Type:'',
            AccountId:'',
            OriginalMoney:0,
            CurrencyId:'',
            Rate:0,
            Fee:0,
            Name:'',
            CurrenName:'',
            Account:'',
            balance:'',
            allMoney:0,
            show:false,
          };
          this.addMsg = {
            FrIDs:'',
            RemitterName:'',
            TradeDate:'',
            BankList:[],
          }
        },
        Calculation(i,index){  //  计算价格
          if(i===1){
            this.payMsgList[index].Fee = isNaN(parseFloat(this.payMsgList[index].Fee))?0:parseFloat(this.payMsgList[index].Fee);
            this.payMsgList[index].Rate = isNaN(parseFloat(this.payMsgList[index].Rate))?0:parseFloat(this.payMsgList[index].Rate);
            this.payMsgList[index].OriginalMoney = isNaN(parseFloat(this.payMsgList[index].OriginalMoney))?0:parseFloat(this.payMsgList[index].OriginalMoney);
            let fee = this.payMsgList[index].Fee,
              Rate = this.payMsgList[index].Rate===0?1:this.payMsgList[index].Rate,
              Money = this.payMsgList[index].OriginalMoney;
            this.payMsgList[index].allMoney = (Money*Rate)+fee;
          }else{
            this.payMsg.Fee = isNaN(parseFloat(this.payMsg.Fee))?0:parseFloat(this.payMsg.Fee);
            this.payMsg.Rate = isNaN(parseFloat(this.payMsg.Rate))?0:parseFloat(this.payMsg.Rate);
            this.payMsg.OriginalMoney = isNaN(parseFloat(this.payMsg.OriginalMoney))?0:parseFloat(this.payMsg.OriginalMoney);
            let fee = this.payMsg.Fee,
              Rate = this.payMsg.Rate===0?1:this.payMsg.Rate,
              Money = this.payMsg.OriginalMoney;
            this.payMsg.allMoney = (Money*Rate)+fee;
          }
        },
        deleteRow(obj,index){
          obj.show = false;
          this.payMsgList.splice(index,1);
          this.$forceUpdate();
        },
        setAccountName(i,type,index){
          if(type===2){
            this.accountList.forEach(x=>{
              if(x.ID===i){
                this.payMsg.Account = x.allName;
                this.payMsg.CurrenName =x.CurrencyName;
                this.payMsg.Rate = x.CurrencyRate?x.CurrencyRate:x.CurrentRate;
                this.payMsg.CurrencyId = x.CurrencyId;
                this.payMsg.balance = x.Initialbalance;
              }
            })
            this.addList()
          }else{
            this.accountList.forEach(x=>{
              if(x.ID===i){
                this.payMsgList[index].Account = x.allName;
                this.payMsgList[index].CurrenName =x.CurrencyName;
                this.payMsgList[index].Rate = x.CurrencyRate?x.CurrencyRate:x.CurrentRate;
                this.payMsgList[index].CurrencyId = x.CurrencyId;
                this.payMsgList[index].balance = x.Initialbalance;
              }
            })
            this.addList()
          }

        },
        getAccountList(i){
          this.payMsg.AccountId = '';
          this.GetAccountType.forEach(x=>{
            if(x.ID===i){
              this.payMsg.Name = x.Name;
            }
          });
          if(i===1){
            this.bankaccount_post_GetListS()
          }
          if(i===2){
            this.BankAccount_post_GetPlatformList()
          }
          if(i===3){
            this.BankAccount_post_GetCashAccountList()
          }
          if(i===4){
            this.BankAccount_post_GetCashPoolList()
          }
        },
        BankAccount_post_GetPlatformList(){  //获取平台账户
          let msg = {
            BackId:0,
            TypeId:0,
            BranchId:-1,
            Alias:''
          };
          this.apipost('BankAccount_post_GetPlatformList',msg, res => {
            if(res.data.resultCode === 1) {
              let data = res.data.data;
              data.forEach(x=>{
                x.allName = x.Alias+' '+x.PlatformNo;
              });
              this.accountList = data;
            }
          }, err => {})
        },
        BankAccount_post_GetCashAccountList(){  // 获取现金账户
          let msg = {
            TypeId:0,
            BranchId:-1,
            Alias:''
          };
          this.apipost('BankAccount_post_GetCashAccountList',msg, res => {
            if(res.data.resultCode === 1) {
              let data = res.data.data;
              data.forEach(x=>{
                x.allName = x.Alias;
              });
              this.accountList = data;
            }
          }, err => {})
        },
        bankaccount_post_GetListS(query){  // 获取银行账户
          this.apipost('bankaccount_post_GetList',{}, res => {
            if(res.data.resultCode === 1) {
              let data = res.data.data;
              data.forEach(x=>{
                x.allName = x.Alias+' '+x.BackNo;
              });
              this.accountList = data;
              if (query) {
                this.AccountId = parseInt(this.$route.query.BankID);
              }
            }
          }, err => {})
        },
        BankAccount_post_GetCashPoolList(){ // 获取资金池账
          this.apipost('BankAccount_post_GetCashPoolList',{TypeId:2,BranchId:-1,Alias:''}, res => {
            if(res.data.resultCode === 1) {
              let data = res.data.data;
              data.forEach(x=>{
                x.allName = x.Alias;
              });
              this.accountList = data;
            }
          }, err => {})
        },
        clearAccBank(){  // 选择账户类型清空数据
          this.payMsg.Type = '';
          this.payMsg.AccountId = '';
        },
        submitAddChuNa(){
          // if(this.payMsgList.length===0) return this.$message.error('请选择交易方式!');
          if(this.addMsg.TradeDate==='') return this.$message.error(this.$t('fnc.a_qxzjyriqi'));
          if(this.BillType===1&&this.addMsg.RemitterName==='') return this.$message.error(this.$t('rule.qtxhkuanren')) ;
          let str = '';
          this.checkList.forEach(x=>{
            if(x.FinanceId){
              str = str+x.FinanceId+','
            }
          });
          this.addMsg.FrIDs = str.substring(0,str.length-1);
          this.addMsg.BankList = this.payMsgList;
          this.addMsg.Money = this.listAllMoney;
          this.allLoading = true
          this.apipost('Financial_post_MergeFinance',this.addMsg,r=>{
            if(r.data.resultCode === 1) {
              this.addChuNa = false
              this.getList()
            }else{
              this.$message.error(r.data.message)
            }
            this.allLoading = false
          },null)
        },
        addCheckbox(obj,index){
          // if(obj.Is_Cashier===1){
          //   obj.check = false;
          //   return this.$message.error('请选择未审核的单据')
          // }
          this.DataList.forEach((x)=>{  //  循环改变check disabled 状态
            if(x.FinanceId===obj.FinanceId){
              x.disabled=false
            }else if(x.Type===obj.Type&&x.ClientID===obj.ClientID&&x.ClientType===obj.ClientType){
              x.disabled=false
            }else{
              x.disabled=true
            }
          });
          if(obj.check){
            this.checkList[index] = {
              FinanceId:obj.FinanceId,
              Type:obj.Type,
              ClientID:obj.ClientID,
              ClientType:obj.ClientType,
              OriginalMoney:obj.OriginalMoney,
              Money:obj.Money,
            }
            this.BillType = obj.Type;
          }else{
            this.checkList[index] = {
              FinanceId:null,
              Type:null,
              ClientID:null,
              ClientType:null,
              OriginalMoney:0,
              Money:0,
            }
          }
          let count = false;
          this.checkList.forEach(x=>{
            if(x.FinanceId){
              return count = true;
            }
          });
          if(!count){
            this.DataList.forEach((x,i)=>{
              x.disabled=false
            })
          }
        },
    addList(){
      if(this.payMsg.AccountId==='')return;
      if(this.payMsg.OriginalMoney===0||this.payMsg.OriginalMoney==='')return;
      if(this.payMsg.AccountId==='')return;
      this.payMsgList.push(this.payMsg);
      this.payMsg = {
        ID:0,
        FinanceId:'',
        Type:'',
        AccountId:'',
        OriginalMoney:0,
        CurrencyId:'',
        Rate:0,
        Fee:0,
        Name:'',
        CurrenName:'',
        Account:'',
        balance:'',
        allMoney:0,
        show:false,
      };
      this.CalculationMoney();
    },
    CalculationMoney(){

    },
    financeinfo_post_GetCostTypeList(){  // 费用类型
            this.apipost('financeinfo_post_GetCostTypeList',{Name:'',type:0,DepartIDs:this.DepartIDs},res=>{
                if(res.data.resultCode==1){
                    this.GetCostTypeList = res.data.data;
                }else{

                }
            },err=>{})
    },
    getCompanyList(){ //获取公司列表
            this.apipost('admin_get_BranchGetList',this.getCompanyMsg,res=>{
                if(res.data.resultCode==1){
                        this.CompanyList=res.data.data;
                }else{}
            },err=>{})
        },
    },mounted(){
        let userInfo=this.getLocalStorage();
        let ClientID = this.$route.query.ClientID;
        if(ClientID){
          this.msg.ClientID = Number(ClientID);
        }
        this.getAccountTypeList();
        this.AccountType_post_GetList();
        this.BankAccount_post_GetAccountType();
        this.financeinfo_post_GetClientAccountList();
        this.financeinfo_post_GetCostTypeList();
        this.getCompanyList();
    }
}
</script>