1
yxh
2023-07-20 935c201bdcf4adde998d46893dd0fa3eddf400bb
src/views/project/fund/expertFeeFundApply/index.vue
@@ -34,8 +34,7 @@
              </el-row>
            </el-col>
          </el-row>
          <el-table v-loading="loading" border highlight-current-row :data="donatebaseinfoList"
            @row-click="selectDonotor">
          <el-table v-loading="loading" highlight-current-row :data="donatebaseinfoList" @row-click="selectDonotor">
            <!-- <el-table-column label="捐献编号" align="center" prop="donorno" /> -->
            <el-table-column label="捐献进度" align="center" prop="recordstate">
              <template slot-scope="scope">
@@ -59,12 +58,12 @@
              </el-col>
              <el-col :span="9">
                <el-form-item label="捐献编号">
                  <el-input v-model="curCase.donorno" disabled></el-input>
                  <el-input v-model="curCase.donorno" :disabled="true"></el-input>
                </el-form-item>
              </el-col>
              <el-col :span="9">
                <el-form-item label="姓名">
                  <el-input v-model="curCase.name" disabled></el-input>
                  <el-input v-model="curCase.name" :disabled="true"></el-input>
                </el-form-item>
              </el-col>
              <el-col>
@@ -86,33 +85,32 @@
                    <dict-tag :options="dict.type.sys_recordstatus" :value="scope.row.recordstatus" />
                  </template>
                </el-table-column>
              <!-- <el-table-column
                <el-table-column label="所属组别" align="center" prop="deptmentname" width="220px" />
                <el-table-column label="组长" align="center" prop="managername" width="150px" />
                <!-- <el-table-column
                  label="申请金额"
                  align="center"
                  prop="amountrequested"
                  width="120px"
                                      /> -->
                                      />
                <el-table-column label="联系电话" align="center" prop="phone" width="150px" />
                <el-table-column label="工作单位" align="center" prop="unitname" width="220px" />
                <el-table-column label="工作单位" align="center" prop="unitname" width="220px" /> -->
                <el-table-column label="操作" fixed="right" align="center" class-name="small-padding fixed-width"
                  width="280px">
                  <template slot-scope="scope">
                    <el-button v-if="
                      scope.row.recordstatus == -1 ||
                    <el-button v-if="scope.row.recordstatus == -1 ||
                      scope.row.recordstatus == 1
                    " size="mini" type="text" icon="el-icon-edit" @click="handleup(scope.row)">上报</el-button>
                    <el-button v-if="
                      scope.row.recordstatus == -1 ||
                      " size="mini" type="text" icon="el-icon-edit" @click="handleup(scope.row)">上报</el-button>
                    <el-button v-if="scope.row.recordstatus == -1 ||
                      scope.row.recordstatus == 1
                    " size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)">修改</el-button>
                      " size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)">修改</el-button>
                    <el-button size="mini" type="text" icon="el-icon-edit" @click="handleDetail(scope.row)">查看</el-button>
                    <!-- v-hasPermi="['project:expretfund:edit']" -->
                    <el-button v-if="
                      scope.row.recordstatus == -1 ||
                    <el-button v-if="scope.row.recordstatus == -1 ||
                      scope.row.recordstatus == 1
                    " size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)">删除</el-button>
                      " size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)">删除</el-button>
                    <!-- v-hasPermi="['project:expretfund:delete']" -->
                  <!-- <el-button
                    <!-- <el-button
                      size="mini"
                      type="text"
                      icon="el-icon-download"
@@ -135,35 +133,33 @@
      <el-form style="height: 550px; overflow-y: auto; overflow-x: hidden" ref="form" :model="form" label-width="120px"
        :rules="rules">
        <el-row style="text-align: left">
          <el-col :span="7">
            <el-form-item label="费用类型">
              <el-radio v-model="form.applytype" label="1">专家费用申请</el-radio>
          <el-col :span="5">
            <el-form-item label="申请日期" prop="createTime">
              <el-date-picker clearable style="width: 100%" v-model="form.createTime" type="date"
                value-format="yyyy-MM-dd HH:mm:ss" placeholder="申请日期">
              </el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="7">
            <el-form-item label="捐献者" prop="name">
              <el-input disabled v-model="form.name" placeholder="请输入捐献者姓名" clearable />
          <el-col :span="5">
            <el-form-item label="所属组别" prop="deptmentname">
              <el-input v-model="form.deptmentname" placeholder="请输入所属组别" clearable />
            </el-form-item>
          </el-col>
          <el-col :span="7">
            <el-form-item label="审核状态" prop="recordstatus">
              <!-- <el-input v-model="form.recordstatus" placeholder="审核意见"/> -->
              <el-select v-model="form.recordstatus" placeholder="请选择审核状态" clearable :disabled="true" size="small">
                <el-option v-for="dict in dict.type.sys_recordstatus" :key="dict.value" :label="dict.label"
                  :value="dict.value" />
              </el-select>
          <el-col :span="5">
            <el-form-item label="组长" prop="managername">
              <el-input v-model="form.managername" placeholder="请输入组长" clearable />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="text-align: left">
          <el-col :span="7">
            <el-form-item label="申请人" prop="username">
          </el-col><el-col :span="5">
            <el-form-item label="经办人" prop="username">
              <el-select v-model="form.username" placeholder="申请人" clearable filterable allow-create style="width: 100%">
                <el-option v-for="dict in userlist" :key="dict.index" :label="dict.nickname"
                  :value="dict.nickname"></el-option>
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="text-align: left">
          <!--
          <el-col :span="7">
            <el-form-item label="联系电话" prop="phone">
              <el-input v-model="form.phone" placeholder="请输入申请者的联系方式" clearable />
@@ -174,73 +170,101 @@
              <org-selecter ref="orgSelecter" :org-type="'3'" v-model="form.unitno" />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="text-align: left">
          <el-col :span="14">
          -->
          <el-col :span="5">
            <el-form-item label="费用类型">
              <el-radio v-model="form.applytype" label="1">专家费用申请</el-radio>
            </el-form-item>
          </el-col>
          <el-col :span="10">
            <el-form-item label="申请说明" prop="remark">
              <el-input v-model="form.remark" placeholder="申请说明" />
            </el-form-item>
          </el-col>
          <el-col :span="7">
            <el-form-item label="申请日期" prop="createTime">
              <el-date-picker clearable style="width: 100%" v-model="form.createTime" type="date"
                value-format="yyyy-MM-dd HH:mm:ss" placeholder="申请日期">
              </el-date-picker>
          <el-col :span="5">
            <el-form-item label="捐献者" prop="name">
              <el-input :disabled="true" v-model="form.name" placeholder="请输入捐献者姓名" />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="text-align: left">
          <el-col :span="5">
            <el-form-item label="合计金额" prop="amountrequested">
              <el-input v-model="form.amountrequested" placeholder="申请金额" :disabled="true" />
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="税前金额" prop="pretaxcost">
              <el-input v-model="form.pretaxcost" placeholder="税前金额合计" :disabled="true" />
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="税后金额" prop="pretaxcost">
              <el-input v-model="form.taxedcost" placeholder="税后金额合计" :disabled="true" />
            </el-form-item>
          </el-col>
          <el-col :span="5">
            <el-form-item label="申请状态" prop="recordstatus">
              <!-- <el-input v-model="form.recordstatus" placeholder="审核意见"/> -->
              <el-select v-model="form.recordstatus" placeholder="请选择审核状态" clearable size="small" :disabled="true">
                <el-option v-for="dict in dict.type.sys_recordstatus" :key="dict.value" :label="dict.label"
                  :value="dict.value" />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="margin-top: 5px; margin-bottom: 5px">
          <el-row style="margin-bottom: 10px">
            <el-col :span="4">
              <el-button @click.native.prevent="addAlls" type="primary" size="small">
              <el-button @click.native.prevent="addAllItems" type="primary" size="small">
                导入服务项目
              </el-button>
            </el-col>
          </el-row>
          <el-table :data="fundDetailArr" v-loading="loading" border highlight-current-row>
          <el-table :data="fundDetails" v-loading="loading" border highlight-current-row>
            <el-table-column prop="orderno" align="center" label="序号" width="65">
              <template slot-scope="scope">
                <el-input v-model="scope.row.orderno" placeholder="序号" />
              </template>
            </el-table-column>
            <el-table-column prop="applytype" align="center" label="费用类型" width="200">
            <el-table-column prop="applytype" align="center" label="服务费用类型" width="200">
              <template slot-scope="scope">
                <el-select v-model="scope.row.applytype" placeholder="费用类型" @change="LoadItemTypeArr(scope.row)">
                  <el-option v-for="dict in fundtypeArr" :key="dict.index" :label="dict.label"
                <el-select v-model="scope.row.applytype" placeholder="服务费用类型" @change="loadItemType(scope.row)">
                  <el-option v-for="dict in rowfeeItemTypes" :key="dict.index" :label="dict.label"
                    :value="dict.value"></el-option>
                </el-select>
              </template>
            </el-table-column>
            <el-table-column prop="itemtype" align="center" label="服务项目" width="260">
            <el-table-column prop="itemid" align="center" label="服务项目名称" width="260">
              <template slot-scope="scope">
                <el-select v-model="scope.row.itemid" placeholder="服务项目" filterable @change="select(scope.row)"
                  :filter-method="(val) => SearchItem(val, scope)">
                <el-select v-model="scope.row.itemid" placeholder="服务项目名称" filterable @change="verifyFeeItem(scope.row)"
                  :filter-method="(val) => searchItemType(val, scope)">
                  <el-option v-for="dict in scope.row.itemArr" :key="dict.index" :label="dict.itemName"
                    :value="dict.id"></el-option>
                </el-select>
              </template>
            </el-table-column>
            <el-table-column prop="itemcode" align="center" label="项目编号" show-overflow-tooltip="" v-if="false" >
            <el-table-column prop="itemcode" align="center" label="项目编号" show-overflow-tooltip="" v-if="false">
            </el-table-column>
            <el-table-column prop="servicesscopename" align="center" label="费用说明" width="180">
            <el-table-column prop="servicesscope" align="center" label="费用说明" width="180">
              <template slot-scope="scope">
                <el-select v-model="scope.row.servicesscope" placeholder="费用说明" clearable allow-create filterable
                  @change="selectedRemark(scope.row)">
                  <el-option v-for="dict in scope.row.fundblock" :key="dict.servicesscope" :label="dict.expensedescribe"
                  <el-option v-for="dict in scope.row.rowfeeblocks" :key="dict.servicesscope" :label="dict.remark"
                    :value="dict.servicesscope"></el-option>
                </el-select>
              </template>
            </el-table-column>
            <el-table-column v-if="this.ismanager == true" prop="amount" align="center" label="税前金额" width="100">
            <el-table-column v-if="this.ismanager == true" prop="amount" align="center" label="税前金额" width="120">
              <template slot-scope="scope">
                <el-select v-model="scope.row.amount" placeholder="税前金额" clearable filterable allow-create
                  @change="selectamount(scope.row)">
                  <el-option v-for="dict in scope.row.fundblock" :key="dict.expensedescribe" :label="dict.expense"
                  <el-option v-for="dict in scope.row.rowfeeblocks" :key="dict.expensedescribe" :label="dict.expense"
                    :value="dict.expense"></el-option>
                </el-select>
              </template>
            </el-table-column>
            <el-table-column prop="taxedamount" align="center" label="税后金额" width="100" v-if="this.ismanager == true">
            <el-table-column prop="taxedamount" align="center" label="税后金额" width="120" v-if="this.ismanager == true">
              <!-- v-if="form.applytype != '3'"上同 -->
              <template slot-scope="scope">
                <el-input v-model="scope.row.taxedamount" placeholder="税后金额" />
@@ -250,7 +274,7 @@
              <template slot-scope="scope">
                <el-button type="primary" plain @click="ShowDetailDialog(scope, 'name')">{{ scope.row.beneficiaryname
                }}</el-button>
              <!-- <el-select
                <!-- <el-select
                  filterable
                  allow-create
                  ref="getReportname"
@@ -273,7 +297,7 @@
              <template slot-scope="scope">
                <el-button type="primary" plain @click="ShowDetailDialog(scope, 'unit')">{{ scope.row.unitname
                }}</el-button>
              <!-- <el-select
                <!-- <el-select
                  v-model="scope.row.unitno"
                  placeholder="单位"
                  clearable
@@ -291,20 +315,18 @@
            </el-table-column>
            <el-table-column prop="quantity" align="center" label="数量" width="120" v-if="form.applytype == '3'">
              <template slot-scope="scope">
                <el-input v-model="scope.row.quantity" placeholder="数量" @blur="
                  (val) => {
                    sumTotalFee(scope.row);
                  }
                " />
                <el-input v-model="scope.row.quantity" placeholder="数量" @blur="(val) => {
                  sumTotalFee(scope.row);
                }
                  " />
              </template>
            </el-table-column>
            <el-table-column prop="price" align="center" label="价格" width="120" v-if="form.applytype == '3'">
              <template slot-scope="scope">
                <el-input v-model="scope.row.price" placeholder="价格" @blur="
                  (val) => {
                    sumTotalFee(scope.row);
                  }
                " />
                <el-input v-model="scope.row.price" placeholder="价格" @blur="(val) => {
                  sumTotalFee(scope.row);
                }
                  " />
              </template>
            </el-table-column>
            <el-table-column prop="remark" align="center" label="备注" width="210" v-if="form.applytype == '3'">
@@ -312,7 +334,6 @@
                <el-input v-model="scope.row.remark" placeholder="备注" />
              </template>
            </el-table-column>
            <el-table-column prop="title" align="center" label="职称" width="120" v-if="form.applytype != '3'">
              <template slot-scope="scope">
                <el-input v-model="scope.row.title" placeholder="职称" />
@@ -337,40 +358,22 @@
            <el-table-column fixed="right" align="center" label="操作" width="180" v-if="dialogType == 'edit'">
              <template slot-scope="scope">
                <el-button type="text" size="mini" @click="addRow(scope.$index)">新增</el-button>
                <el-button @click.native.prevent="
                  deleteRows(scope.row, scope.$index, fundDetailArr)
                " type="text" size="small">
                  deleteRows(scope.row, scope.$index, fundDetails)
                  " type="text" size="small">
                  删除
                </el-button>
              </template>
            </el-table-column>
          </el-table>
        </el-row>
        <el-row>
          <el-col :span="7">
            <el-form-item label="申请金额" prop="amountrequested">
              <el-input v-model="form.amountrequested" placeholder="申请金额" />
            </el-form-item>
          </el-col> <el-col :span="7">
            <el-form-item label="税前合计" prop="pretaxcost">
              <el-input v-model="form.pretaxcost" placeholder="税前金额合计" />
            </el-form-item>
          </el-col>
          <el-col :span="7">
            <el-form-item label="税后合计" prop="pretaxcost">
              <el-input v-model="form.taxedcost" placeholder="税后金额合计" />
            </el-form-item>
          </el-col>
        <!--
        </el-row> <!--
        <el-row>
          <el-col :span="7">
            <el-form-item label="预支金额" prop="prepaidamount">
              <el-input v-model="form.prepaidamount" placeholder="申请金额" />
            </el-form-item>
          </el-col>
            -->
        </el-row>
      <!--
          </el-col>
        </el-row>
        <el-row>          
          <el-col :span="7">
            <el-form-item label="OPO中心签字" prop="opochecker">
@@ -407,11 +410,10 @@
        <el-row>
          <el-col :span="12">
            <el-form-item label="费用申请附件" align="left" prop="annexbankcard">
              <el-upload size="mini" class="upload-demo" :action="uploadFileUrl" :file-list="fileList" multiple :limit="5"
                :headers="headers" :on-success="
                  (response, file, fileList) =>
                    uploadSccess(response, file, fileList)
                " :on-preview="downFile" :disabled='dialogType == "detail"' :on-error="handleUploadError"
              <el-upload size="mini" class="upload-demo" :action="uploadFileUrl" :file-list="fileList" multiple
                :limit="20" :headers="headers" :on-success="(response, file, fileList) =>
                  uploadSccess(response, file, fileList)
                  " :on-preview="downFile" :disabled='dialogType == "detail"' :on-error="handleUploadError"
                :on-exceed="handleExceed" :on-remove="remove" accept="image/*,.pdf">
                <el-button :disabled='dialogType == "detail"' size="small" type="primary">上传</el-button>
              </el-upload>
@@ -507,6 +509,11 @@
  getFundType,
  getFundTypeAll,
  listcountItem,
  getDataBybeneficiaryNo,
  getTaxByBeneFiciaryNo,
  getTaxBeforeByBeneFiciaryNo,
  getTaxationByBeneFiciaryNo,
  getTaxBeforeByAfterMoney
} from "@/api/project/funddetail";
import { listFundflow } from "@/api/project/fundflow";
import {
@@ -585,6 +592,14 @@
        applytype: "1",
        createBy: null,
      },
      //计算个税参数
      taxParam: {
        beneficiaryNo: '',
        money: '0',
        startTime: '',
      },
      // 表单参数
      form: {},
      personlist: [],
@@ -595,6 +610,9 @@
        ],
        createTime: [
          { required: true, message: "请输入申请日期", trigger: "blur" },
        ],
        deptmentname: [
          { required: true, message: "请输入所属业务组", trigger: "blur" },
        ],
        // amountrequested: [
        //   { required: true, message: "请输入申请金额", trigger: "blur" },
@@ -614,22 +632,26 @@
      // 捐献人道慰问金表格数据
      donateconsolationfundList: [],
      fundDetailArr: [],
      //费用明细列表
      fundDetails: [],
      // 弹出层标题
      title: "",
      userlist: [],
      itemArr: [],
      reporters: [],
      //行记录的费用类型数组
      rowfeeItemTypes: [],
      //费用类型数组
      fundtypeArr: [],
      fundblock: [],
      feeItemTypes: [],
      //费用说明
      rowfeeblocks: [],
      defaultperson: {},
      //是否是专家费的OPO审批人员
      ismanager: false,
      fundtypeArrAll: [],
      unitList: [],
      dialogType: "edit",
      fundflowList: [],
@@ -673,11 +695,12 @@
      this.detailInfoDialogShow = true;
      this.detailInfoDialogShowType = showType;
    },
    ConfirmDetailDialog() {
      let tempIndex = this.funddetailForm.index;
      let tempName = this.funddetailForm.beneficiaryname;
      let tempUnitname = this.funddetailForm.unitname;
      let singleDetail = this.fundDetailArr[tempIndex];
      let singleDetail = this.fundDetails[tempIndex];
      if (this.detailInfoDialogShowType == "name") {
        this.personlist.map((res) => {
          if (tempName == res.username) {
@@ -691,11 +714,9 @@
            singleDetail.title = res.title;
            singleDetail.unitname = res.unitname;
            singleDetail.unitno = parseInt(res.unitno);
          } else {
            singleDetail.beneficiaryname = tempName;
            singleDetail.beneficiaryno = tempName;
          }
        });
      } else if (this.detailInfoDialogShowType == "unit") {
        singleDetail.unitno = this.funddetailForm.unitno;
        try {
@@ -711,13 +732,12 @@
          singleDetail.unitname = singleDetail.unitno;
        }
      }
      debugger;
      this.fundDetailArr[tempIndex] = singleDetail;
      this.fundDetails[tempIndex] = singleDetail;
      this.detailInfoDialogShow = false;
    },
    handleup(row) {
      console.log("rowrowrowrow", row);
    handleup(row) {
      this.$confirm("是否确认将登记记录上报?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
@@ -751,30 +771,22 @@
        });
    },
    // recordstatus
    // updateFund(row).then(res=>{
    //   console.log('状态更新',res);
    // })
    // },
    //获取当前用户信息
    getUsermsg() {
      getUserProfile().then((response) => {
        console.log("登录用户信息", response.data);
        this.defaultperson = response.data;
        this.standardlevel = response.data.standardlevel;
        if (
          this.defaultperson.createBy == "admin" ||
          this.defaultperson.createBy == "001" ||
          this.defaultperson.createBy == "002"
        ) {
        if (this.defaultperson.createBy == "admin" || this.defaultperson.createBy == "001" || this.defaultperson.createBy == "002") {
          this.ismanager = true;
        } else {
          this.ismanager = false;
        }
      });
    },
    //获取费用项目的备注信息
    selectedRemark(row) {
      row.fundblock.forEach((item, i) => {
      row.rowfeeblocks.forEach((item, i) => {
        if (item.servicesscope === row.servicesscope) {
          row.servicesscopename = item.expensedescribe;
          if (row.servicesscopename.includes("税后")) {
@@ -784,14 +796,17 @@
            row.amount = item.expense;
            row.taxedamount = 0.0;
          }
          this.form.serviceFunddetails = 0;
          this.fundDetailArr.map((item) => {
          this.fundDetails.map((item) => {
            this.form.serviceFunddetails += item.amount;
          });
        }
      });
    },
    select(row) {
    //校验收费项目是否重复
    verifyFeeItem(row) {
      row.itemArr.map((res) => {
        if (row.itemid === res.id) {
          row.remark = res.itemDescribe;
@@ -799,41 +814,44 @@
        }
      });
      var repeatNum = 0;
      this.fundDetailArr.map((res) => {
      this.fundDetails.map((res) => {
        if (res.applytype === row.applytype && res.itemid == row.itemid) {
          repeatNum++;
        }
      });
      if (repeatNum > 1) {
        this.$modal.msgWarning("您已经提交过服务项目");
        this.$modal.msgWarning("您已经提交过该服务项目了");
      }
      //获取费用项目的详细信息
      getdetailsByItemId(row.itemid).then((res) => {
        console.log("费用数据", res.data);
        let fundmsg = res.data;
        let fundblock = [];
        let rowfeeblocks = [];
        fundmsg.forEach((item) => {
          fundblock.push({
          rowfeeblocks.push({
            expense: item.expense,
            expensedescribe: item.expensedescribe,
            remark: item.expensedescribe,
            servicesscope: item.id,
          });
        });
        console.log("组装后的数据", fundblock);
        row.fundblock = fundblock;
        row.rowfeeblocks = rowfeeblocks;
        row.servicesscope = null;
        row.servicesscopename = "";
      });
    },
    //
    selectamount(row) {
      console.log("row", row.amount);
      this.fundblock.forEach((item, i) => {
      this.rowfeeblocks.forEach((item, i) => {
        if (item.expense === row.amount) {
          row.remark = item.expensedescribe;
        }
      });
    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
@@ -863,7 +881,6 @@
    },
    getUnitList() {
      listOrganization(3).then((response) => {
        debugger;
        for (let i = 0; i < response.rows.length; i++) {
          this.unitList.push({
            //organizationid: response.rows[i].organizationid,
@@ -893,10 +910,14 @@
        this.form.infoid = this.curCase.id;
        this.form.username = this.defaultperson.nickName;
        this.form.userno = this.defaultperson.userName;
        this.form.deptmentname = this.defaultperson.dept.deptName;
        this.form.deptmentno = this.defaultperson.dept.deptId;
        this.form.managername = this.defaultperson.dept.leader;
        // this.form.createTime = nowdate;
        //this.open = true;
        //this.initFundApplyForm();
        this.fundDetailArr = [];
        this.fundDetails = [];
        this.addRow();
        this.dialogOpen = true;
        this.dialogType = "edit";
@@ -976,41 +997,65 @@
      this.fileList = []
    },
    addAlls() {
    //导入所有项目
    addAllItems() {
      this.loading = true;
      this.fundDetailArr = this.fundDetailArr.filter(
      this.fundDetails = this.fundDetails.filter(
        (r) => r.applytype != "" && r.applytype != null
      );
      let listAdd = [];
      //let listAdd = this.fundDetailArr;
      for (let i = 0; i < this.fundtypeArrAll.length; i++) {
        for (let j = 0; j < this.fundtypeArrAll[i].itemDetails.length; j++) {
          let list = this.fundDetailArr.filter(
      //let listAdd = this.fundDetails;
      for (let i = 0; i < this.feeItemTypes.length; i++) {
        for (let j = 0; j < this.feeItemTypes[i].itemDetails.length; j++) {
          let list = this.fundDetails.filter(
            (r) =>
              r.applytype == this.fundtypeArrAll[i].itemType &&
              r.itemid == this.fundtypeArrAll[i].itemDetails[j].id
              r.applytype == this.feeItemTypes[i].itemType &&
              r.itemid == this.feeItemTypes[i].itemDetails[j].id
          );
          if (list.length == 0) {
            let rowData = {
              id: null,
              orderno: listAdd.length + 1,
              applytype: this.fundtypeArrAll[i].itemType,
              itemid: this.fundtypeArrAll[i].itemDetails[j].id,
              itemcode: this.fundtypeArrAll[i].itemDetails[j].itemCode,
              applytype: this.feeItemTypes[i].itemType,
              itemid: this.feeItemTypes[i].itemDetails[j].id,
              itemcode: this.feeItemTypes[i].itemDetails[j].itemCode,
              recordstatus: "-1",
              beneficiaryname: "点击选择",
              unitname: "点击选择",
              itemArr: this.fundtypeArrAll[i].itemDetails,
              itemArr: this.feeItemTypes[i].itemDetails,
              rowfeeblocks: null,
              servicesscope: null,
              servicesscopename: ""
            };
            //获取收费项目的说明信息
            getdetailsByItemId(rowData.itemid).then((res) => {
              let fundmsg = res.data;
              let rowfeeblocks = [];
              fundmsg.forEach((item) => {
                rowfeeblocks.push({
                  expense: item.expense,
                  expensedescribe: item.expensedescribe,
                  remark: item.expensedescribe,
                  servicesscope: item.id,
                });
              });
              rowData.rowfeeblocks = rowfeeblocks;
              rowData.servicesscope = null;
              rowData.servicesscopename = "";
            });
            listAdd.push(rowData);
          }
        }
      }
      this.fundDetailArr = listAdd;
      this.fundDetails = listAdd;
      this.loading = false;
      // let Outerarr = this.fundDetailArr;
      // let Outerarr = this.fundDetails;
      // Outerarr.map((res) => {
      //   let onelist = this.fundtypeArr;
      //   let onelist = this.rowfeeItemTypes;
      //   onelist.map((item) => {
      //     //第一层不相等时;
      //     if (res.applytype !== item.itemType) {
@@ -1019,8 +1064,8 @@
      //   });
      // });
    },
    addAll(row, i, arr) {
      console.log("cecececececececece", row, row.itemArr);
      row.itemArr.map((res) => {
        if (res.id !== row.itemid) {
          let a = arr.length;
@@ -1030,23 +1075,22 @@
          arr[a].itemid = res.id;
          getdetailsByItemId(arr[a].itemid).then((res) => {
            console.log("费用数据", res.data);
            let fundmsg = res.data;
            let fundblock = [];
            let rowfeeblocks = [];
            fundmsg.forEach((item) => {
              fundblock.push({
              rowfeeblocks.push({
                expense: item.expense,
                expensedescribe: item.expensedescribe,
                remark: item.expensedescribe,
                servicesscope: item.id,
              });
            });
            console.log("组装后的数据", fundblock);
            row.fundblock = fundblock;
            row.rowfeeblocks = rowfeeblocks;
          });
        }
      });
    },
    //新增一行
    addRow(rowIndex) {
      let rowData = {
@@ -1090,21 +1134,21 @@
        uploadtime: null,
        itemArr: [],
        servicesscope: null,
        fundblock: [],
        rowfeeblocks: [],
      };
      if (rowIndex == undefined || rowIndex == null || rowIndex < 0) {
        this.fundDetailArr.push(rowData);
        this.fundDetails.push(rowData);
      } else {
        this.fundDetailArr.splice(rowIndex + 1, 0, rowData);
        this.fundDetails.splice(rowIndex + 1, 0, rowData);
      }
      for (let i = 0; i < this.fundDetailArr.length; i++) {
        this.fundDetailArr[i].orderno = i + 1;
      for (let i = 0; i < this.fundDetails.length; i++) {
        this.fundDetails[i].orderno = i + 1;
      }
    },
    //加载服务项目
    LoadItemTypeArr(row) {
      let list = this.fundtypeArrAll.filter((r) => r.itemType == row.applytype);
    loadItemType(row) {
      let list = this.feeItemTypes.filter((r) => r.itemType == row.applytype);
      row.itemArr = list[0].itemDetails;
      row.itemid = null;
      this.$forceUpdate();
@@ -1125,12 +1169,20 @@
          let totalPreTaxAmount = 0.0;
          let totalAfterTaxAmount = 0.0;
          let totalAmount = 0.0;
          for (let k = 0; k < this.fundDetailArr.length; k++) {
            let tempDetail = this.fundDetailArr[k];
          //保存前校验数据
          for (let k = 0; k < this.fundDetails.length; k++) {
            let tempDetail = this.fundDetails[k];
            if (tempDetail.itemid == null) {
              this.$modal.msgWarning("请选择服务项目");
              this.$modal.msgWarning("服务项目是必选项,请选择服务项目后再提交保存!");
              return;
            }
            if (tempDetail.beneficiaryno == null) {
              this.$modal.msgWarning("服务项目表中,第" + (k + 1).toString() + "行的服务人员姓名为选择,请选择人员后再提交保存!");
              return;
            }
            // //判断单位 unitSel
            // try {
            //   let unitIndex = this.unitList.findIndex(
@@ -1144,15 +1196,41 @@
            // } catch {
            //   tempDetail.unitname = tempDetail.unitno;
            // }
            if (!isNaN(parseFloat(tempDetail.amount))) {
              totalPreTaxAmount += parseFloat(tempDetail.amount);
              totalAmount += parseFloat(tempDetail.amount);
            //计算个税
            //if (isNaN(parseFloat(tempDetail.taxedamount)))
            if (tempDetail.taxedamount == undefined || tempDetail.taxedamount == null || tempDetail.taxedamount == 0 || tempDetail.taxedamount == '') {
              //获取参数
              this.taxParam.beneficiaryNo = tempDetail.beneficiaryno;
              this.taxParam.money = tempDetail.amount.toString();
              this.taxParam.startTime = this.form.createTime.substring(0, 10);
              getTaxByBeneFiciaryNo(this.taxParam).then((res) => {
                if (res.code == 200) {
                  tempDetail.taxamount = res.data;
                  tempDetail.taxedamount = tempDetail.amount - tempDetail.taxamount;
                }
              });
            }
            if (!isNaN(parseFloat(tempDetail.taxedamount))) {
              totalAfterTaxAmount += parseFloat(tempDetail.taxedamount);
              totalAmount += parseFloat(tempDetail.taxedamount);
            //if (isNaN(parseFloat(tempDetail.amount)))
            if (tempDetail.amount == undefined || tempDetail.amount == null || tempDetail.amount == 0 || tempDetail.amount == '') {
              //获取参数
              this.taxParam.beneficiaryNo = tempDetail.beneficiaryno;
              this.taxParam.money = tempDetail.taxedamount.toString();
              this.taxParam.startTime = this.form.createTime.substring(0, 10);
              getTaxBeforeByAfterMoney(this.taxParam).then((res) => {
                console.log("",res);
                if (res.code == 200) {
                  tempDetail.taxamount = res.data.nowTax;
                  tempDetail.amount = res.data.nowTaxBeforeMoney;
                }
              });
            }
            this.fundDetailArr[k] = tempDetail;
            totalAfterTaxAmount += parseFloat(tempDetail.taxedamount);
            totalAmount += parseFloat(tempDetail.amount);
            this.fundDetails[k] = tempDetail;
          }
          this.loading = true;
@@ -1175,8 +1253,8 @@
              this.selectDonotor(this.curCase);
              this.$modal.msgSuccess("修改成功");
              this.loading = false;
              for (let m = 0; m < this.fundDetailArr.length; m++) {
                let tempData = this.fundDetailArr[m];
              for (let m = 0; m < this.fundDetails.length; m++) {
                let tempData = this.fundDetails[m];
                let tempItemArr = tempData.itemArr;
                tempData.fundid = formData.id;
                //获取服务项目明细
@@ -1187,6 +1265,15 @@
                  tempData.itemname = tempItemArr[itemIndex].itemName;
                  tempData.itemid = tempItemArr[itemIndex].id;
                }
                //获取applytypename
                let applytypeIndex = this.rowfeeItemTypes.findIndex(
                  (item) => tempData.applytype == item.value
                );
                if (applytypeIndex > -1) {
                  tempData.applytypename = this.rowfeeItemTypes[applytypeIndex].label;
                }
                if (tempData.id > 0) {
                  updateFunddetail(tempData).then((response2) => { });
                } else {
@@ -1196,9 +1283,10 @@
            });
          } else {
            //保存费用申请
            for (let m = 0; m < this.fundDetailArr.length; m++) {
              let tempData = this.fundDetailArr[m];
            for (let m = 0; m < this.fundDetails.length; m++) {
              let tempData = this.fundDetails[m];
              let tempUtemArr = tempData.itemArr;
              //获取服务项目明细
              let itemIndex = tempUtemArr.findIndex(
                (item) => tempData.itemid == item.id
@@ -1207,21 +1295,24 @@
                tempData.itemname = tempUtemArr[itemIndex].itemName;
                tempData.itemid = tempUtemArr[itemIndex].id;
              }
              //获取applytypename
              let applytypeIndex = this.fundtypeArr.findIndex(
              let applytypeIndex = this.rowfeeItemTypes.findIndex(
                (item) => tempData.applytype == item.value
              );
              if (applytypeIndex > -1) {
                tempData.applytypename = this.fundtypeArr[applytypeIndex].label;
                tempData.applytypename = this.rowfeeItemTypes[applytypeIndex].label;
              }
              this.fundDetailArr[m] = tempData;
              this.fundDetails[m] = tempData;
            }
            this.form.serviceFunddetails = 0;
            this.fundDetailArr.map((item) => {
            this.fundDetails.map((item) => {
              this.form.serviceFunddetails += item.amount;
            });
            this.form.serviceFunddetails = this.fundDetailArr;
            this.form.serviceFunddetails = this.fundDetails;
            this.form.recordstatus = -1;
            batchUploadFund(this.form).then((response) => {
              if (response.code === 200) {
                this.$modal.msgSuccess("新增成功");
@@ -1237,14 +1328,16 @@
        }
      });
    },
    //获取专家列表
    getlistExternalperson() {
      listExternalperson().then((res) => {
        console.log("人员表:", res.rows);
        this.personlist = res.rows;
      });
    },
    //专家人员列表
    selectReporters() {
      //专家人员列表
      let arr = ["expert"];
      let arrreportlist = [];
      for (let i = 0; i < arr.length; i++) {
@@ -1257,12 +1350,11 @@
            });
          }
          this.arrr3 = this.arrr3.concat(this.arrr2);
          console.log("adadadadasdsad", this.arrr3, this.userlist);
        });
      }
    },
    selectpersonmsg(row) {
      console.log("row", row);
      // if(row.beneficiaryname)
      this.personlist.map((res) => {
        if (row.beneficiaryname == res.username) {
@@ -1281,11 +1373,13 @@
        }
      });
    },
    getlistUser() {
      listUser().then((res) => {
        this.userlist = res.data;
      });
    },
    /** 修改按钮操作 */
    handleUpdate(row) {
      this.isopen = 0;
@@ -1305,22 +1399,33 @@
        this.form.name = this.curCase.name;
        //附件处理
        this.fileList = this.form.annexbankcard ? this.form.annexbankcard.split(",").map(item => ({ url: item, name: item })) : []
        getownFundDetail(id).then((res) => {
          console.log("查询明细记录:", res);
          this.fundDetailArr = res.data;
          for (let m = 0; m < this.fundDetailArr.length; m++) {
            this.fundDetailArr[m].itemArr = [];
            this.getItemArr(m, this.fundDetailArr[m]);
            this.fundDetailArr[m].fundblock = [];
            this.fundDetailArr[m].fundblock.push({
              expense: this.fundDetailArr[m].expense,
              expensedescribe: this.fundDetailArr[m].servicesscopename,
              remark: this.fundDetailArr[m].servicesscope,
              servicesscope: this.fundDetailArr[m].servicesscope,
          this.fundDetails = res.data;
          for (let m = 0; m < this.fundDetails.length; m++) {
            this.fundDetails[m].itemArr = [];
            this.getItemArr(m, this.fundDetails[m]);
            //获取费用项目的详细信息
            this.fundDetails[m].rowfeeblocks = [];
            this.fundDetails[m].rowfeeblocks.push({
              servicesscope: this.fundDetails[m].servicesscope,
              expensedescribe: this.fundDetails[m].servicesscopename,
              expense: this.fundDetails[m].expense,
              remark: this.fundDetails[m].servicesscopename,
            });
            // getdetailsByItemId(this.fundDetails[m].itemid).then((res) => {
            //   let fundmsg = res.data;
            //   fundmsg.forEach((item) => {
            //     this.fundDetails[m].rowfeeblocks.push({
            //       servicesscope: item.id,
            //       expensedescribe: item.expensedescribe,
            //       expense: item.expense,
            //       remark: item.expensedescribe,
            //     });
            //   });
            // });
          }
          // console.log("fundDetailArr:" + JSON.stringify(this.fundDetailArr));
        });
      });
    },
@@ -1351,19 +1456,18 @@
          this.fundflowList = res.rows;
        });
        getownFundDetail(id).then((res) => {
          this.fundDetailArr = res.data;
          for (let m = 0; m < this.fundDetailArr.length; m++) {
            this.fundDetailArr[m].itemArr = [];
            this.getItemArr(m, this.fundDetailArr[m]);
            this.fundDetailArr[m].fundblock = [];
            this.fundDetailArr[m].fundblock.push({
              expense: this.fundDetailArr[m].expense,
              expensedescribe: this.fundDetailArr[m].servicesscopename,
              remark: this.fundDetailArr[m].servicesscope,
              servicesscope: this.fundDetailArr[m].servicesscope,
          this.fundDetails = res.data;
          for (let m = 0; m < this.fundDetails.length; m++) {
            this.fundDetails[m].itemArr = [];
            this.getItemArr(m, this.fundDetails[m]);
            this.fundDetails[m].rowfeeblocks = [];
            this.fundDetails[m].rowfeeblocks.push({
              expense: this.fundDetails[m].expense,
              expensedescribe: this.fundDetails[m].servicesscopename,
              remark: this.fundDetails[m].servicesscope,
              servicesscope: this.fundDetails[m].servicesscope,
            });
          }
          // console.log("fundDetailArr:" + JSON.stringify(this.fundDetailArr));
        });
      });
    },
@@ -1406,17 +1510,15 @@
                }).then(() => {
                  this.$set(rows, rows.splice(index, 1));
                  getownFundDetail(this.form.id).then((res) => {
                    this.$set(this.fundDetailArr, res.data);
                    this.$set(this.fundDetails, res.data);
                    this.sumTotalFee();
                    // this.fundDetailArr = res.data
                    // console.log('删除后',this.fundDetailArr)
                    // this.fundDetails = res.data
                  });
                });
              }
              // getownFundDetail(this.form.id).then(res=>{
              // this.$set(this.fundDetailArr,res.data)
              // this.fundDetailArr = res.data
              // console.log('删除后',this.fundDetailArr)
              // this.$set(this.fundDetails,res.data)
              // this.fundDetails = res.data
              // })
            });
          } else {
@@ -1429,37 +1531,40 @@
        });
    },
    //计算个税
    calculateTax() { },
    //计算总金额
    sumTotalFee(row) {
      let allSum = 0;
      if (this.form.applytype != null) {
        for (let i = 0; i < this.fundDetailArr.length; i++) {
        for (let i = 0; i < this.fundDetails.length; i++) {
          let totalFee = 0;
          let taxFee = 0;
          if (this.form.applytype == 1 || this.form.applytype == 2) {
            //计算当前报销内容费用合计
            if (!isNaN(parseFloat(this.fundDetailArr[i].amount))) {
              totalFee += parseFloat(this.fundDetailArr[i].amount);
              taxFee += parseFloat(this.fundDetailArr[i].amount);
            if (!isNaN(parseFloat(this.fundDetails[i].amount))) {
              totalFee += parseFloat(this.fundDetails[i].amount);
              taxFee += parseFloat(this.fundDetails[i].amount);
            }
            if (!isNaN(parseFloat(this.fundDetailArr[i].taxamount))) {
              totalFee -= parseFloat(this.fundDetailArr[i].taxamount);
              taxFee -= parseFloat(this.fundDetailArr[i].taxamount);
            if (!isNaN(parseFloat(this.fundDetails[i].taxamount))) {
              totalFee -= parseFloat(this.fundDetails[i].taxamount);
              taxFee -= parseFloat(this.fundDetails[i].taxamount);
            }
          } else if (this.form.applytype == 3) {
            if (
              !isNaN(parseFloat(this.fundDetailArr[i].price)) &&
              !isNaN(parseFloat(this.fundDetailArr[i].quantity))
              !isNaN(parseFloat(this.fundDetails[i].price)) &&
              !isNaN(parseFloat(this.fundDetails[i].quantity))
            ) {
              totalFee +=
                parseFloat(this.fundDetailArr[i].price) *
                parseFloat(this.fundDetailArr[i].quantity);
                parseFloat(this.fundDetails[i].price) *
                parseFloat(this.fundDetails[i].quantity);
            }
          }
          //税前、税后需要独立录入
          // if (!isNaN(parseFloat(taxFee))) {
          //   this.fundDetailArr[i].taxedamount = taxFee.toFixed(2);
          //   this.fundDetails[i].taxedamount = taxFee.toFixed(2);
          // }
          allSum += totalFee;
@@ -1467,18 +1572,16 @@
      }
      // this.form.amountrequested = allSum.toFixed(2);
      // this.$forceUpdate();
      // console.log(this.form);
    },
    //获取费用类型
    getCurFundType() {
      getFundTypeAll(this.currentApplyType).then((res) => {
        console.log("费用类型", res.data);
        let dataList = res.data;
        this.fundtypeArrAll = dataList;
        this.fundtypeArr = [];
        this.feeItemTypes = dataList;
        this.rowfeeItemTypes = [];
        for (let m = 0; m < dataList.length; m++) {
          this.fundtypeArr.push({
          this.rowfeeItemTypes.push({
            value: dataList[m].itemType,
            label: dataList[m].itemTypeName,
          });
@@ -1487,19 +1590,18 @@
    },
    getItemArr(rowindex, row) {
      let list = this.fundtypeArrAll.filter((r) => r.itemType == row.applytype);
      let list = this.feeItemTypes.filter((r) => r.itemType == row.applytype);
      row.itemArr = list[0].itemDetails;
      this.$set(this.fundDetailArr, rowindex, row);
      this.$set(this.fundDetails, rowindex, row);
      //this.loading = true;
      // getItemNames(row.applytype).then((res) => {
      //   this.loading = false;
      //   row.itemArr = res.data;
      //   this.$set(this.fundDetailArr, rowindex, row);
      //   this.$set(this.fundDetails, rowindex, row);
      // });
    },
    mixExport(scope) {
      console.log(scope);
      this.dayin(scope.row.id);
      //this.totaldayin(id);
    },
@@ -1549,14 +1651,14 @@
      });
    },
    SearchItem(val, scope) {
    //筛查出对应的费用项目
    searchItemType(val, scope) {
      let result = [];
      if (val != "") {
        let tempItemArr = scope.row.itemArr;
        for (let i = 0; i < tempItemArr.length; i++) {
          let pym = tempItemArr[i].itempinyin;
          if (pym != null && pym != undefined && pym != "") {
            console.log(pym);
            if (pym.indexOf(val) != -1) {
              result.push(tempItemArr[i]);
            }
@@ -1566,7 +1668,7 @@
      } else {
        getItemNames(scope.row.applytype).then((res) => {
          scope.row.itemArr = res.data;
          //this.$set(this.fundDetailArr, rowindex, row);
          //this.$set(this.fundDetails, rowindex, row);
        });
      }
    },
@@ -1589,7 +1691,16 @@
      } else {
        this.$modal.msgError(response.msg);
      }
      //console.log("上传文件后:" + JSON.stringify(this.fileList));
    },
    // 下载文件
    downFile(item) {
      const url = process.env.VUE_APP_BASE_API + item.url
      var a = document.createElement('a');
      var event = new MouseEvent('click');
      a.download = item.name;
      a.href = url;
      a.dispatchEvent(event);
    },
  },