<template>
|
<div class="Modifydetailscla">
|
<div class="boxdiv">
|
<div class="top-text">{{ title }}</div>
|
<el-form ref="form" :model="form" :rules="rules" label-width="120px">
|
<el-row
|
><el-col :span="5">
|
<el-form-item label="申请日期" prop="applyTime">
|
<el-date-picker
|
style="width: 100%"
|
v-model="form.applyTime"
|
type="date"
|
value-format="yyyy-MM-dd HH:mm:ss"
|
placeholder="申请日期"
|
:disabled="true"
|
>
|
</el-date-picker>
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="经办人" prop="username">
|
<el-select
|
v-model="form.username"
|
clearable
|
filterable
|
allow-create
|
ref="getReportname"
|
default-first-option
|
placeholder="请选择"
|
>
|
<el-option
|
v-for="item in personsList"
|
:key="item.reportNo"
|
:label="item.reportName"
|
:value="item.reportName"
|
>
|
</el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="所属组别" prop="deptmentname">
|
<el-input v-model="form.deptmentname" placeholder="所属组别" />
|
<!--<treeselect v-model="form.deptId" :options="deptOptions" :show-count="true" placeholder="请选择归属部门" />-->
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="组长" prop="managername">
|
<el-input v-model="form.managername" placeholder="组长" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<el-col :span="15">
|
<el-form-item label="出差事由" prop="reason">
|
<el-input v-model="form.reason" placeholder="出差事由" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="捐献者" prop="infoid">
|
<el-select
|
v-model="form.infoid"
|
@change="selectbaseinfo"
|
filterable
|
placeholder="请选择捐献者"
|
>
|
<el-option
|
v-for="item in baselist"
|
:key="item.index"
|
:label="item.name"
|
:value="item.infoid"
|
>
|
</el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row style="margin-top: 10px">
|
<el-col :span="5">
|
<el-form-item label="报销金额" prop="amountrequested">
|
<el-input
|
:disabled="true"
|
v-model="form.amountrequested"
|
placeholder="报销合计金额"
|
/>
|
</el-form-item>
|
</el-col>
|
<el-col :span="7">
|
<el-form-item label="大写金额" prop="bigstrmoney">
|
<el-input
|
:disabled="true"
|
v-model="form.bigstrmoney"
|
placeholder="报销大写金额"
|
/>
|
</el-form-item> </el-col
|
><el-col :span="4">
|
<el-form-item label="审核状态" prop="flowlevel">
|
<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-form-item>
|
</el-col>
|
</el-row>
|
<!--
|
<el-row>
|
<el-col :span="15">
|
<el-form-item label="出差事由" prop="reason">
|
<el-input v-model="form.reason" placeholder="出差事由" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="报销分类" prop="costtype">
|
<el-select v-model="form.costtype" value-key="value" placeholder="请选择出差人分类" @change="getTravelers">
|
<el-option v-for="dict in dict.type.sys_travelexpensebelong" :key="dict.value" :label="dict.label"
|
:value="dict.value"></el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="出差人" prop="travelers">
|
<el-select v-model="form.travelers" clearable filterable allow-create ref="getReportname"
|
default-first-option placeholder="请选择" @change="getAccountinfo()">
|
<el-option v-for="item in travelers" :key="item.reportNo" :label="item.reportName"
|
:value="item.reportName">
|
</el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="收款银行" prop="depositbank">
|
<el-input v-model="form.depositbank" placeholder="开户银行" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="银行账号" prop="bankcardno">
|
<el-input v-model="form.bankcardno" placeholder="开户银行" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="联系电话" prop="phone">
|
<el-input v-model="form.phone" placeholder="联系电话" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<el-col :span="20"><el-divider></el-divider></el-col>
|
</el-row>
|
<el-row>
|
<el-col :span="5">
|
<el-form-item label="家属费用" prop="donoramount">
|
<el-input :disabled="true" v-model="form.donoramount" placeholder="家属费用" @blur="
|
(val) => {
|
sumTotalFee();
|
}
|
" onchange="if(/[^0-9.]/.test(this.value)){alert('请正确输入整数数字或小数!');this.value='';}" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="15">
|
<el-form-item label="费用说明" prop="donorremark">
|
<el-input :disabled="true" v-model="form.donorremark" placeholder="家属费用说明" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row>
|
<el-col :span="5">
|
<el-form-item label="家属人数" prop="donorrelatives">
|
<el-input v-model="form.donorrelatives" placeholder="家属人数" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="收款人" prop="donorpayee">
|
<el-input v-model="form.donorpayee" placeholder="亲属收款人" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="收款银行" prop="donorbank">
|
<el-input v-model="form.donorbank" placeholder="家属银行" />
|
</el-form-item>
|
</el-col>
|
<el-col :span="5">
|
<el-form-item label="银行卡号" prop="donorbankcard">
|
<el-input v-model="form.donorbankcard" placeholder="银行卡号" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
-->
|
<!--
|
<el-row type="flex" :gutter="10" align="right" class="mb8">
|
<el-col :span="6">
|
<el-button
|
type="primary"
|
plain
|
icon="el-icon-plus"
|
size="mini"
|
@click="addDetailRow"
|
>新增一行</el-button
|
>
|
</el-col>
|
</el-row>
|
-->
|
<el-row v-if="jurisdiction">
|
<!-- <el-alert title="当前为查看状态,不支持修改存储。" type="warning">
|
</el-alert> -->
|
<el-alert
|
title="当前为查看状态,不支持修改存储。"
|
type="warning"
|
show-icon
|
>
|
</el-alert>
|
</el-row>
|
<el-row style="margin-top: 25px; margin-bottom: 5px">
|
<el-col :span="20">报销明细</el-col>
|
</el-row>
|
<el-row>
|
<el-table
|
:data="rbDetails"
|
ref="table"
|
border
|
max-height="800"
|
highlight-current-row
|
:summary-method="getSummaries"
|
show-summary
|
>
|
<el-table-column
|
prop="orderno"
|
slot=""
|
label="序号"
|
align="center"
|
fixed
|
width="88"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.orderno" placeholder="序号" />
|
</template>
|
</el-table-column>
|
<!--主键、外不展示-->
|
<el-table-column
|
prop="id"
|
slot=""
|
label="主键"
|
align="center"
|
fixed
|
width="95"
|
v-if="false"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.id" placeholder="id" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="rbid"
|
slot=""
|
label="外键"
|
align="center"
|
fixed
|
width="95"
|
v-if="false"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.rbid" placeholder="rbid" />
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="persontype"
|
slot=""
|
label="人员类别"
|
align="center"
|
fixed
|
width="130"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.persontype"
|
value-key="value"
|
placeholder="人员类别"
|
@change="getPersons(scope.row)"
|
>
|
<el-option
|
v-for="dict in dict.type.sys_travelexpensebelong"
|
:key="dict.value"
|
:label="dict.label"
|
:value="dict.label"
|
></el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="personname"
|
slot=""
|
label="费用人员"
|
align="center"
|
fixed
|
width="110"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.personname"
|
clearable
|
filterable
|
allow-create
|
default-first-option
|
placeholder="请选择"
|
@focus1="getPersons(scope.row)"
|
>
|
<el-option
|
v-for="item in personsSel"
|
:key="item.reportNo"
|
:label="item.reportName"
|
:value="item.reportName"
|
>
|
</el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="starttime"
|
slot=""
|
label="开始日期"
|
fixed
|
align="center"
|
width="150"
|
>
|
<template slot-scope="scope">
|
<el-date-picker
|
:picker-options="{
|
disabledDate: time => {
|
if (scope.row.endtime) {
|
return (
|
time.getTime() >
|
new Date(scope.row.endtime.replace(/-/g, '/'))
|
);
|
}
|
}
|
}"
|
clearable
|
size="small"
|
style="width: 100%"
|
v-model="scope.row.starttime"
|
type="date"
|
value-format="yyyy-MM-dd HH:mm:ss"
|
placeholder="开始日期"
|
@blur="getdays(scope.row)"
|
>
|
</el-date-picker>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="endtime"
|
slot=""
|
label="结束日期"
|
align="center"
|
fixed
|
width="150"
|
>
|
<template slot-scope="scope">
|
<el-date-picker
|
:picker-options="{
|
disabledDate: time => {
|
if (scope.row.starttime) {
|
return (
|
time.getTime() <
|
new Date(scope.row.starttime.replace(/-/g, '/'))
|
);
|
}
|
}
|
}"
|
clearable
|
size="small"
|
style="width: 100%"
|
v-model="scope.row.endtime"
|
type="date"
|
value-format="yyyy-MM-dd HH:mm:ss"
|
placeholder="结束日期"
|
@blur="getdays(scope.row)"
|
>
|
</el-date-picker>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="departure"
|
slot=""
|
label="出发地"
|
align="center"
|
width="100"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.departure" placeholder="出发地" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
label="到达地"
|
prop="destination"
|
align="center"
|
width="140"
|
>
|
<template slot-scope="scope">
|
<!-- <el-input v-model="scope.row.destination" placeholder="到达地" @blur="getallowance(scope.row)" /> -->
|
<el-select
|
filterable
|
allow-create
|
v-model="scope.row.destination"
|
value-key="value"
|
placeholder="到达地"
|
@change="getallowance(scope.row)"
|
>
|
<el-option
|
v-for="dict in dict.type.sys_area_name"
|
:key="dict.value"
|
:label="dict.label"
|
:value="dict.label"
|
></el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="days"
|
label="天数"
|
width="100"
|
align="center"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.days"
|
@blur="getallowance(scope.row)"
|
placeholder="天数"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="traffictype"
|
label="出发交通工具"
|
align="center"
|
width="100"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.traffictype"
|
placeholder="出发交通工具"
|
>
|
<el-option
|
v-for="dict in dict.type.sys_traffictype"
|
:key="dict.value"
|
:label="dict.label"
|
:value="dict.label"
|
></el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="traffictype2"
|
label="返回交通工具"
|
align="center"
|
width="100"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.traffictype2"
|
placeholder="返回交通工具"
|
>
|
<el-option
|
v-for="dict in dict.type.sys_traffictype"
|
:key="dict.value"
|
:label="dict.label"
|
:value="dict.label"
|
></el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="trafficexpense"
|
label="交通费"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.trafficexpense"
|
placeholder="交通费"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="cityfee"
|
label="市内交通费"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.cityfee"
|
placeholder="市内交通费"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
>{{ Number(scope.row.cityfee).toFixed(2) }}
|
</el-input>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="hotelexpense"
|
label="住宿费"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.hotelexpense"
|
placeholder="住宿费"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column>
|
|
<!-- <el-table-column
|
prop="foodexpenses"
|
label="餐费报销"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.foodexpenses"
|
placeholder="伙食费报销"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column> -->
|
<el-table-column
|
prop="foodallowance"
|
label="伙食补助"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.foodallowance"
|
placeholder="伙食费补助"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="otherexpense"
|
label="公杂费补助"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.otherexpense"
|
placeholder="杂费"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="otherfeeamount"
|
label="其他费用"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.otherfeeamount"
|
placeholder="其他费用"
|
@blur="
|
val => {
|
sumRowFee(scope.row);
|
}
|
"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="departure"
|
slot=""
|
label="其他费用说明"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.otherfeedesc"
|
placeholder="其他费用说明"
|
/>
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="total"
|
label="合计"
|
align="center"
|
width="110"
|
fixed="right"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.total" placeholder="合计" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
fixed="right"
|
label="操作"
|
align="center"
|
width="120"
|
>
|
<template slot-scope="scope">
|
<el-button
|
type="text"
|
size="mini"
|
@click="addDetailRow(scope.$index)"
|
v-if="operationType == 'edit'"
|
>新增</el-button
|
>
|
<el-button
|
@click.native.prevent="
|
deleteDetailRow(scope.$index, rbDetails, scope.row)
|
"
|
type="text"
|
size="small"
|
v-if="operationType == 'edit'"
|
>删除</el-button
|
>
|
<el-button
|
@click.native.prevent="
|
Filepopup(scope.$index, rbDetails, scope.row)
|
"
|
type="text"
|
size="small"
|
>票据</el-button
|
>
|
</template>
|
</el-table-column>
|
</el-table>
|
</el-row>
|
<el-row style="margin-top: 25px; margin-bottom: 5px">
|
<el-col :span="20">打款明细</el-col>
|
</el-row>
|
<el-row style="margin-top: 5px">
|
<el-table
|
:data="rbPayees"
|
border
|
max-height="400"
|
highlight-current-row
|
:summary-method="getSummaries"
|
show-summary
|
>
|
<el-table-column
|
prop="orderno"
|
slot=""
|
label="序号"
|
align="center"
|
fixed
|
width="65"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.orderno" placeholder="序号" />
|
</template>
|
</el-table-column>
|
|
<!--主键、外键不展示-->
|
<el-table-column
|
prop="id"
|
slot=""
|
label="主键"
|
align="center"
|
fixed
|
width="95"
|
v-if="false"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.id" placeholder="id" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="rbid"
|
slot=""
|
label="外键"
|
align="center"
|
fixed
|
width="95"
|
v-if="false"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.rbid" placeholder="rbid" />
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="persontype"
|
slot=""
|
label="收款人类别"
|
align="center"
|
fixed
|
width="150"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.persontype"
|
value-key="value"
|
placeholder="收款人类别"
|
@change="getPersons(scope.row)"
|
>
|
<el-option
|
v-for="dict in dict.type.sys_travelexpensebelong"
|
:key="dict.value"
|
:label="dict.label"
|
:value="dict.label"
|
></el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="personname"
|
slot=""
|
label="收款人"
|
align="center"
|
fixed
|
width="200"
|
>
|
<template slot-scope="scope">
|
<el-select
|
v-model="scope.row.personname"
|
clearable
|
filterable
|
allow-create
|
ref="getReportname"
|
default-first-option
|
placeholder="请选择"
|
@change="getAccountinfo2(scope.row, scope.row.persontype)"
|
>
|
<el-option
|
v-for="item in personsSel"
|
:key="item.reportNo"
|
:label="item.reportName"
|
:value="item.reportName"
|
>
|
</el-option>
|
</el-select>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="bankname"
|
slot=""
|
label="收款银行"
|
align="center"
|
fixed
|
width="250"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.bankname" placeholder="收款银行" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="bankcardno"
|
slot=""
|
label="银行账号"
|
align="center"
|
fixed
|
width="200"
|
>
|
<template slot-scope="scope">
|
<el-input
|
v-model="scope.row.bankcardno"
|
placeholder="银行账号"
|
/>
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="amount"
|
slot=""
|
label="打款金额"
|
align="center"
|
fixed
|
width="130"
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.amount" placeholder="打款金额" />
|
</template>
|
</el-table-column>
|
<el-table-column
|
prop="remark"
|
slot=""
|
label="请款说明"
|
align="center"
|
fixed
|
>
|
<template slot-scope="scope">
|
<el-input v-model="scope.row.remark" placeholder="说明" />
|
</template>
|
</el-table-column>
|
<!--
|
<el-table-column prop="paiddate" slot="" label="打款日期" fixed align="center" width="150">
|
<template slot-scope="scope">
|
<el-date-picker clearable size="small" style="width: 100%" v-model="scope.row.paiddate" type="date"
|
value-format="yyyy-MM-dd HH:mm:ss" placeholder="打款日期" :disabled="true">
|
</el-date-picker>
|
</template>
|
</el-table-column>-->
|
<el-table-column
|
label="操作"
|
align="center"
|
width="100"
|
v-if="operationType == 'edit'"
|
>
|
<template slot-scope="scope">
|
<el-button
|
type="text"
|
size="mini"
|
@click="addPayeeRow(scope.$index)"
|
>新增</el-button
|
>
|
<el-button
|
@click.native.prevent="
|
deletePayeeRow(scope.$index, rbPayees, scope.row)
|
"
|
type="text"
|
size="small"
|
>
|
删除
|
</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</el-row>
|
<el-row
|
style="margin-top: 25px; margin-bottom: 5px"
|
v-if="operationType != 'edit'"
|
>
|
<el-col :span="20">审核记录</el-col>
|
</el-row>
|
<el-row v-if="operationType != 'add'">
|
<el-table :data="fundflowList" border>
|
<el-table-column
|
label="审核日期"
|
align="center"
|
width="200"
|
prop="createTime"
|
/>
|
<el-table-column
|
label="审核人"
|
align="center"
|
width="150"
|
prop="checkusername"
|
/>
|
<el-table-column
|
label="审核结果"
|
align="center"
|
width="200"
|
prop="flowconclusion"
|
>
|
<template slot-scope="scope">
|
<span v-if="scope.row.flowconclusion == 1">通过</span>
|
<span v-if="scope.row.flowconclusion == 2">不通过</span>
|
</template>
|
</el-table-column>
|
<el-table-column
|
label="审核备注"
|
align="center"
|
prop="flowcontent"
|
/>
|
</el-table>
|
</el-row>
|
<el-row
|
style="margin-top: 25px; margin-bottom: 5px"
|
v-if="operationType == 'check' && userprofile.nickName == '陈慕华'"
|
>
|
<el-col :span="12">
|
<el-form-item label="预审材料" prop="infoid">
|
<el-radio-group v-model="form.checkstatus" align="left">
|
<el-radio label="1">待申请材料</el-radio>
|
<el-radio label="2">审核通过等待邮寄纸质材料</el-radio>
|
<el-radio label="3">已收到报销材料</el-radio>
|
</el-radio-group>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
|
<el-row
|
style="margin-top: 25px; margin-bottom: 5px"
|
v-if="operationType == 'check'"
|
>
|
<el-col :span="7">
|
<el-form-item label="审核结果" align="left">
|
<el-radio-group v-model="checkObj.flowlevelone" align="left">
|
<el-radio label="1">通过</el-radio>
|
<el-radio label="2">不通过</el-radio>
|
</el-radio-group>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
<el-row v-if="operationType == 'check'">
|
<el-col :span="17">
|
<el-form-item label="审核备注" align="left">
|
<el-input v-model="checkObj.flowconclusion" placeholder="备注" />
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
<div slot="footer" class="dialog-footer">
|
<el-button
|
type="primary"
|
@click="submitForm"
|
v-if="operationType == 'edit' || userprofile.nickName == '陈慕华'"
|
>保 存</el-button
|
>
|
<el-button
|
type="primary"
|
@click="checksubmit"
|
v-if="operationType == 'check'"
|
>提交审核</el-button
|
>
|
<!--<el-button @click="cancel">退 出</el-button>-->
|
</div>
|
</div>
|
|
<el-dialog
|
v-dialogDrags
|
:modal="false"
|
:close-on-click-modal="false"
|
:title="pdftitle"
|
:visible.sync="pdfVisible"
|
width="60%"
|
>
|
<div>
|
<el-table :data="tableDatatop" style="width: 100%">
|
<el-table-column prop="orderno" label="序号"> </el-table-column>
|
<el-table-column prop="personname" label="费用人员">
|
</el-table-column>
|
<el-table-column prop="starttime" label="开始日期"> </el-table-column>
|
<el-table-column prop="endtime" label="结束日期"> </el-table-column>
|
<el-table-column prop="departure" label="出发地"> </el-table-column>
|
<el-table-column prop="destination" label="到达地"> </el-table-column>
|
<el-table-column prop="days" label="天数"> </el-table-column>
|
</el-table>
|
<el-table :data="tableDatatop" style="width: 100%">
|
<el-table-column prop="traffictype" label="出发交通工具">
|
</el-table-column>
|
<el-table-column prop="traffictype2" label="返回交通工具">
|
</el-table-column>
|
<el-table-column prop="trafficexpense" label="交通费">
|
</el-table-column>
|
<el-table-column prop="cityfee" label="市内交通费"> </el-table-column>
|
<el-table-column prop="hotelexpense" label="住宿费">
|
</el-table-column>
|
<el-table-column prop="foodallowance" label="伙食补助">
|
</el-table-column>
|
<el-table-column prop="otherexpense" label="公杂费补助">
|
</el-table-column>
|
<el-table-column prop="otherfeeamount" label="其他费用">
|
</el-table-column>
|
</el-table>
|
</div>
|
<el-tabs
|
style="margin-top: 20px;"
|
v-model="activeName"
|
type="border-card"
|
@tab-click="handleClick"
|
>
|
<el-tab-pane label="普通附件" :name="1">
|
<div class="pdfimg">
|
<div class="box-pdf">
|
<div>
|
<el-upload
|
size="mini"
|
class="upload-demo"
|
:action="uploadFileUrl"
|
:file-list="fileListto"
|
:show-file-list="false"
|
multiple
|
drag
|
:headers="headers"
|
:on-success="
|
(response, file, fileList) =>
|
uploadSccess(response, file, fileList)
|
"
|
:on-preview="downFile"
|
:disabled="operationType == 'detail'"
|
:on-error="handleUploadError"
|
:on-remove="remove"
|
accept="image/*,.pdf"
|
>
|
<i class="el-icon-upload"></i>
|
<div class="el-upload__text">
|
将票据拖到此处,或
|
<em
|
><el-button
|
:disabled="operationType == 'detail'"
|
size="small"
|
type="primary"
|
>点击上传</el-button
|
></em
|
>
|
</div>
|
</el-upload>
|
<el-table
|
:data="fileListto"
|
@row-click="downFile"
|
style="width: 100%"
|
height="400"
|
>
|
<el-table-column
|
prop="name"
|
:show-overflow-tooltip="true"
|
label="名称"
|
>
|
<template slot-scope="scope">
|
<i style="color:#409EFF" class=" el-icon-s-order" />{{
|
scope.row.name
|
}}
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="name"
|
width="180"
|
:show-overflow-tooltip="true"
|
label="功能"
|
>
|
<template slot-scope="scope">
|
<el-button
|
type="primary"
|
size="mini"
|
@click.native.prevent.stop="deletedowfile(scope.row)"
|
>删除</el-button
|
>
|
<el-button
|
type="primary"
|
size="mini"
|
@click.native.prevent.stop="moveupdowfile(scope.row)"
|
>上移</el-button
|
>
|
</template>
|
</el-table-column>
|
</el-table>
|
</div>
|
</div>
|
|
<div
|
v-if="this.previewpdf && pdfimgsrcList.length"
|
class="pdfimgmin"
|
>
|
<!-- <img :src="pdfimg" /> -->
|
<el-image
|
style="width: 95%; height: 90%"
|
:src="pdfimg"
|
:preview-src-list="pdfimgsrcList"
|
>
|
<!-- <div slot="error" class="image-slot">
|
<i class="el-icon-picture-outline"></i>
|
</div> -->
|
</el-image>
|
</div>
|
<div v-else class="pdfimgmins">{{ hintitle }}</div>
|
</div>
|
</el-tab-pane>
|
<el-tab-pane label="发票文件" :name="2">
|
<div class="pdfimg">
|
<div class="box-pdf">
|
<div>
|
<el-upload
|
size="mini"
|
class="upload-demo"
|
:action="uploadFileUrl"
|
:file-list="invoicefileList"
|
:show-file-list="false"
|
multiple
|
drag
|
:headers="headers"
|
:on-success="
|
(response, file, fileList) =>
|
uploadSccess(response, file, fileList)
|
"
|
:on-preview="downFile"
|
:disabled="operationType == 'detail'"
|
:on-error="handleUploadError"
|
:on-remove="remove"
|
accept="image/*,.pdf"
|
>
|
<i class="el-icon-upload"></i>
|
<div class="el-upload__text">
|
将发票文件拖到此处,或
|
<em
|
><el-button
|
:disabled="operationType == 'detail'"
|
size="small"
|
type="primary"
|
>点击上传</el-button
|
></em
|
>
|
</div>
|
</el-upload>
|
<el-table
|
:data="invoicefileListto"
|
@row-click="downFile"
|
style="width: 100%"
|
height="400"
|
>
|
<el-table-column
|
prop="name"
|
:show-overflow-tooltip="true"
|
label="名称"
|
>
|
<template slot-scope="scope">
|
<i style="color:#409EFF" class=" el-icon-s-order" />{{
|
scope.row.name
|
}}
|
</template>
|
</el-table-column>
|
|
<el-table-column
|
prop="name"
|
width="180"
|
:show-overflow-tooltip="true"
|
label="功能"
|
>
|
<template slot-scope="scope">
|
<el-button
|
type="primary"
|
size="mini"
|
@click.native.prevent.stop="deletedowfile(scope.row)"
|
>删除</el-button
|
>
|
<el-button
|
type="primary"
|
size="mini"
|
@click.native.prevent.stop="moveupdowfile(scope.row)"
|
>上移</el-button
|
>
|
</template>
|
</el-table-column>
|
</el-table>
|
</div>
|
</div>
|
|
<div
|
v-if="this.previewpdf && invoicepdfimgsrcList.length"
|
class="pdfimgmin"
|
>
|
<!-- <img :src="pdfimg" /> -->
|
<el-image
|
style="width: 95%; height: 90%"
|
:src="invoicepdfimg"
|
:preview-src-list="invoicepdfimgsrcList"
|
>
|
<!-- <div slot="error" class="image-slot">
|
<i class="el-icon-picture-outline"></i>
|
</div> -->
|
</el-image>
|
</div>
|
<div v-else class="pdfimgmins">{{ hintitle }}</div>
|
</div>
|
</el-tab-pane>
|
</el-tabs>
|
</el-dialog>
|
<el-dialog title="提示" :visible.sync="Savereminder" width="30%">
|
<el-alert
|
:title="
|
'您已添加' +
|
totalquantity +
|
'条数据,为防止数据丢失是否提交保存再继续添加。'
|
"
|
type="warning"
|
>
|
</el-alert>
|
<span slot="footer" class="dialog-footer">
|
<el-button @click="unsave">取 消</el-button>
|
<el-button type="primary" @click="Savenow">确 定</el-button>
|
</span>
|
</el-dialog>
|
</div>
|
</template>
|
|
<script>
|
import pdf from "vue-pdf";
|
import Treeselect from "@riophae/vue-treeselect";
|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
import { listDonatebaseinfo } from "@/api/project/donatebaseinfo";
|
import {
|
listReimbursementpayee,
|
addReimbursementpayee,
|
updateReimbursementpayee,
|
delReimbursementpayee
|
} from "@/api/project/reimbursementpayee";
|
import {
|
listReimbursement,
|
getReimbursement,
|
delReimbursement,
|
addReimbursement,
|
updateReimbursement,
|
exportReimbursement,
|
getdownload,
|
checkfund,
|
fundSubmit
|
} from "@/api/project/reimbursement";
|
import {
|
addReimbursementdetail,
|
updateReimbursementdetail,
|
listReimbursementdetailid,
|
getReimbursementdetaillist,
|
delReimbursementdetail,
|
addOrupdateReimbursementdetaillist,
|
getTravelStandard
|
} from "@/api/project/reimbursementdetail";
|
import { listFundflow } from "@/api/project/fundflow";
|
import { getInfoBytheUserNo } from "@/api/project/externalperson";
|
import { regionDataPlus, CodeToText } from "element-china-area-data";
|
import Li_area_select from "@/components/Address";
|
import { getUser, getUserProfile } from "@/api/system/user";
|
import { treeselect } from "@/api/system/dept";
|
import { getSubsidy } from "@/api/project/travelcity";
|
import { listReportname, listUser } from "@/api/project/organization";
|
import { getToken } from "@/utils/auth";
|
import debounce from "lodash/debounce";
|
export default {
|
components: {
|
Treeselect,
|
Li_area_select,
|
pdf
|
},
|
name: "Funddetail",
|
dicts: [
|
"sys_finsubject",
|
"sys_0_1",
|
"sys_fund_type",
|
"sys_financeitemtype",
|
"sys_recordstatus",
|
"sys_travelexpensebelong",
|
"sys_traffictype",
|
"sys_area_name"
|
],
|
data() {
|
return {
|
//OPO协调员
|
personsXty: [],
|
//OPO专职人员
|
personsZzry: [],
|
//OPO管理人员
|
personsManager: [],
|
//OPO专家
|
personsExpert: [],
|
//全部人员
|
personsList: [],
|
//下拉可以选择人员列表
|
personsSel: [],
|
activeName: 1, //文件类型
|
// 部门树选项
|
|
deptOptions: undefined,
|
//票据文件
|
pdftitle: "",
|
pdfimg: "",
|
pdfVisible: false,
|
costtypeobj: {
|
value: 0,
|
label: ""
|
},
|
ICDtoken: getToken(),
|
pdfimgsrcList: [],
|
Savereminder: false, //提醒保存弹框
|
Reminderquantity: 0, //提醒数量
|
totalquantity: 0, //总数量
|
|
hintitle: "选中左侧已上传文件预览查看",
|
atpresent: "",
|
iframeurl: "",
|
options: regionDataPlus,
|
selectedOptions: [],
|
searchAddress: {
|
sheng: "",
|
shi: "",
|
qu: ""
|
},
|
value1: "",
|
previewpdf: false,
|
// 遮罩层
|
loading: true,
|
// 导出遮罩层
|
exportLoading: false,
|
// 网络请求头
|
Networkheader: null,
|
|
// 当前单据ID
|
curId: 0,
|
// 选中数组
|
ids: [],
|
// 非单个禁用
|
single: true,
|
// 非多个禁用
|
multiple: true,
|
// 显示搜索条件
|
showSearch: true,
|
// 总条数
|
total: 0,
|
// 费用申请明细表格数据
|
funddetailList: [],
|
// 弹出层标题
|
title: "",
|
// 是否显示弹出层
|
open: false,
|
queryParams2: {
|
persontype: null,
|
arriveAddr: null
|
},
|
feesParams: {
|
beneficiaryNo: null,
|
starttime: null,
|
endtime: null
|
},
|
tableDatatop: [
|
{
|
date: "2016-05-02",
|
name: "王小虎",
|
address: "上海市普陀区金沙江路 1518 弄"
|
}
|
],
|
//查询付款
|
queryParamsPayee: {
|
rbid: null
|
},
|
// 当前用户信息
|
userprofile: {},
|
// 表单参数
|
form: {},
|
reimbursementList: [],
|
|
// 表单校验
|
rules: {
|
reason: [
|
{ required: true, message: "请输入出差事由", trigger: "blur" }
|
],
|
deptmentname: [
|
{ required: true, message: "请输入所属业务组", trigger: "blur" }
|
]
|
},
|
//费用申请单form
|
applicationForm: {
|
applicationType: null,
|
donorno: null,
|
donorname: null,
|
bigstrmoney: null
|
},
|
|
rbDetails: [],
|
rbPayees: [],
|
arrr2: [],
|
baselisttages: [
|
{
|
id: 1,
|
name: "待申请材料"
|
},
|
{
|
id: 2,
|
name: "审核通过等待邮寄纸质材料"
|
},
|
{
|
id: 3,
|
name: "已收到报销材料"
|
}
|
],
|
baselist: [],
|
donatorList: [],
|
standardlevel: 0,
|
defaultperson: {},
|
fundflowList: [],
|
showApproveRecordDialog: false,
|
operationType: "edit",
|
|
//上传发票文件路径
|
uploadFileUrl: process.env.VUE_APP_BASE_API + "/common/upload",
|
//文件列表
|
fileList: [],
|
fileListto: [],
|
invoicefileList: [],
|
invoicefileListto: [],
|
invoicepdfimg: "",
|
invoicepdfimgsrcList: [],
|
//人员类别
|
persontype: null,
|
//到达地
|
arriveAddr: null,
|
headers: {
|
Authorization: "Bearer " + getToken()
|
},
|
|
//审批信息
|
checkObj: {
|
flowlevelone: null,
|
flowconclusion: null,
|
fundid: null
|
},
|
jurisdiction: false,
|
|
//保存按钮控制
|
idisabled: false
|
};
|
},
|
|
created() {
|
this.Getnetworkheader();
|
|
//获取记录列表
|
// this.getList();
|
|
//获取报销中的人员信息
|
this.getPersonList();
|
|
//获取登录者信息
|
getUserProfile().then(response => {
|
this.userprofile = response.data;
|
this.defaultperson = response.data;
|
this.standardlevel = response.data.standardlevel;
|
console.log("this.defaultperson", this.defaultperson);
|
});
|
|
//获取捐献者姓名
|
listDonatebaseinfo().then(res => {
|
let list = res.rows;
|
let baseinfolist = [];
|
this.donatorList = list;
|
list.forEach(element => {
|
baseinfolist.push({
|
infoid: element.id,
|
name: element.name
|
});
|
});
|
|
if (baseinfolist != 0) {
|
this.baselist = baseinfolist;
|
}
|
});
|
|
//获取部门信息
|
//this.getTreeselect();
|
},
|
|
mounted() {
|
window.addEventListener("beforeunload", e => this.beforeunloadHandler(e));
|
|
//选择业务类型:1、新增;2、修改;3、查看
|
let curId = this.$route.query.id;
|
let pos = this.$route.query.pos;
|
this.defaultperson = this.$route.query.routerparam;
|
if (pos == 1) {
|
this.handleAdd(curId);
|
} else if (pos == 2) {
|
this.handleUpdate(curId);
|
} else if (pos == 3) {
|
this.handleDetail(curId);
|
} else if (pos == 4) {
|
this.handleCheck(curId);
|
}
|
},
|
updated() {
|
this.$nextTick(() => {
|
this.$refs["table"].doLayout();
|
});
|
},
|
destroyed() {
|
window.removeEventListener("beforeunload", e => this.beforeunloadFn(e));
|
}, //生命周期 - 销毁完成
|
|
methods: {
|
// 浏览器页面关闭或刷新提示
|
beforeunloadHandler(e) {
|
if (
|
(JSON.stringify(this.form) == sessionStorage.getItem("apiform") &&
|
JSON.stringify(this.rbDetails) ==
|
sessionStorage.getItem("apifunddetail")) ||
|
!sessionStorage.getItem("apifunddetail")
|
) {
|
} else {
|
this._beforeUnload_time = new Date().getTime();
|
e = e || window.event;
|
if (e) {
|
e.returnValue = "关闭提示";
|
}
|
return "关闭提示";
|
}
|
},
|
|
handleUploadError() {},
|
// 获取请求头
|
Getnetworkheader() {
|
console.log(window.location.href);
|
let string = window.location.href;
|
if (string.includes("9091")) {
|
const index = string.indexOf("9091");
|
this.Networkheader = string.slice(0, index + 4); // 截取9091及其前部字符
|
console.log(this.Networkheader);
|
} else {
|
const index = string.indexOf("8032");
|
this.Networkheader = string.slice(0, index + 4); // 截取8032及其前部字符
|
console.log(this.Networkheader);
|
}
|
},
|
// 发票切换
|
handleClick(tab, event) {
|
if (this.activeName == 1) {
|
this.pdftitle = "共" + this.pdfimgsrcList.length + "项";
|
} else {
|
this.pdftitle = "共" + this.invoicepdfimgsrcList.length + "项";
|
}
|
},
|
remove(file, fileList) {
|
const rbDetails = [...this.rbDetails];
|
if (this.activeName == 1) {
|
this.fileListto.splice(this.fileListto.indexOf(file), 1);
|
rbDetails[this.atpresent].annexfilesList = this.fileListto;
|
} else {
|
this.invoicefileListto.splice(this.invoicefileListto.indexOf(file), 1);
|
rbDetails[this.atpresent].invoicefilesList = this.invoicefileListto;
|
}
|
},
|
|
handleExceed() {
|
this.$message.error(`上传文件数量不能超过 ${5} 个!`);
|
},
|
|
//文件上传成功回调
|
uploadSccess(response, file, fileList) {
|
this.rbDetails;
|
const config = {
|
headers: { Authorization: "Bearer " + this.ICDtoken }
|
};
|
const pdfimg = this.Networkheader + "/prod-api" + response.fileName;
|
//获取票据信息位置
|
if (this.activeName == 1) {
|
if (response.code == 200) {
|
this.previewpdf = true;
|
|
fetch(pdfimg, config)
|
.then(response => response.blob())
|
.then(blob => {
|
// 将获取的数据流转换为URL
|
this.pdfimg = URL.createObjectURL(blob);
|
this.pdfimgsrcList.push(URL.createObjectURL(blob));
|
this.fileListto.push({
|
name: file.name,
|
url: URL.createObjectURL(blob)
|
});
|
})
|
.catch(error => {
|
console.error("Error loading image", error);
|
return;
|
});
|
|
this.$modal.msgSuccess(response.msg);
|
|
console.log(this.fileListto, "新增后");
|
if (!this.rbDetails[this.atpresent].annexfilesList) {
|
this.rbDetails[this.atpresent].annexfilesList = [];
|
}
|
this.rbDetails[this.atpresent].annexfilesList.push({
|
name: file.name,
|
url: response.fileName
|
});
|
this.pdftitle = "共" + this.pdfimgsrcList.length + "项";
|
} else {
|
console.log(response.msg);
|
}
|
} else {
|
if (response.code == 200) {
|
this.previewpdf = true;
|
fetch(pdfimg, config)
|
.then(response => response.blob())
|
.then(blob => {
|
// 将获取的数据流转换为URL
|
this.invoicepdfimg = URL.createObjectURL(blob);
|
this.invoicepdfimgsrcList.push(URL.createObjectURL(blob));
|
this.invoicefileListto.push({
|
name: file.name,
|
url: URL.createObjectURL(blob)
|
});
|
})
|
.catch(error => {
|
console.error("Error loading image", error);
|
return;
|
});
|
|
this.$modal.msgSuccess(response.msg);
|
|
console.log(this.invoicefileListto, "新增后");
|
if (!this.rbDetails[this.atpresent].invoicefilesList) {
|
this.rbDetails[this.atpresent].invoicefilesList = [];
|
}
|
this.rbDetails[this.atpresent].invoicefilesList.push({
|
name: file.name,
|
url: response.fileName
|
});
|
this.pdftitle = "共" + this.invoicepdfimgsrcList.length + "项";
|
}
|
}
|
},
|
// 点击票据
|
Filepopup(index, rows, row) {
|
const config = {
|
headers: { Authorization: "Bearer " + this.ICDtoken }
|
};
|
|
this.tableDatatop = [];
|
this.fileListto = [];
|
this.invoicefileListto = [];
|
this.pdfimg = [];
|
this.invoicepdfimg = [];
|
this.pdfimgsrcList = [];
|
this.invoicepdfimgsrcList = [];
|
this.tableDatatop.push(row);
|
this.atpresent = index;
|
this.pdfVisible = true;
|
|
if (this.rbDetails[index].annexfilesList) {
|
this.rbDetails[index].annexfilesList.forEach((value, indexson) => {
|
const pdfimg = this.Networkheader + "/prod-api" + value.url;
|
fetch(pdfimg, config)
|
.then(response => response.blob())
|
.then(blob => {
|
// 将获取的数据流转换为URL
|
this.fileListto.push({
|
name: value.name,
|
url: URL.createObjectURL(blob)
|
});
|
if (this.fileListto.length == 1) {
|
this.pdfimg = URL.createObjectURL(blob);
|
}
|
this.pdfimgsrcList.push(URL.createObjectURL(blob));
|
})
|
.catch(error => {
|
console.error("Error loading image", error);
|
return;
|
});
|
});
|
this.previewpdf = true;
|
} else {
|
this.fileListto = [];
|
this.pdfimg = "";
|
this.pdftitle = "";
|
}
|
//发票
|
if (this.rbDetails[index].invoicefilesList) {
|
this.rbDetails[index].invoicefilesList.forEach((value, indexson) => {
|
const pdfimg = this.Networkheader + "/prod-api" + value.url;
|
fetch(pdfimg, config)
|
.then(response => response.blob())
|
.then(blob => {
|
// 将获取的数据流转换为URL
|
this.invoicefileListto.push({
|
name: value.name,
|
url: URL.createObjectURL(blob)
|
});
|
if (this.invoicefileListto.length == 1) {
|
this.invoicepdfimg = URL.createObjectURL(blob);
|
}
|
this.invoicepdfimgsrcList.push(URL.createObjectURL(blob));
|
})
|
.catch(error => {
|
console.error("Error loading image", error);
|
return;
|
});
|
});
|
this.previewpdf = true;
|
} else {
|
this.invoicefileListto = [];
|
this.invoicepdfimg = "";
|
this.pdftitle = "";
|
}
|
|
if (this.activeName == 1) {
|
this.pdftitle = "共" + this.pdfimgsrcList.length + "项";
|
} else {
|
this.pdftitle = "共" + this.invoicepdfimgsrcList.length + "项";
|
}
|
},
|
|
// 点击已上传文件
|
downFile(item) {
|
if (this.activeName == 1) {
|
this.pdftitle =
|
"共" + this.pdfimgsrcList.length + "项,当前选中" + item.name;
|
let name = item.name.split(".");
|
if (name[1] == "pdf") {
|
this.$modal.msgWarning("当前文件暂不支持预览");
|
this.previewpdf = false;
|
this.hintitle = "当前文件暂不支持预览";
|
} else if (name[1] == "jpg" || "png") {
|
console.log(item, "展示");
|
this.previewpdf = true;
|
if (item.url) {
|
this.pdfimg = item.url;
|
} else {
|
this.pdfimg = "";
|
}
|
} else {
|
this.hintitle = "当前文件暂不支持预览";
|
this.$modal.msgWarning("当前文件暂不支持预览");
|
this.previewpdf = false;
|
}
|
} else {
|
this.pdftitle =
|
"共" + this.invoicepdfimgsrcList.length + "项,当前选中" + item.name;
|
let name = item.name.split(".");
|
if (name[1] == "pdf") {
|
this.$modal.msgWarning("当前文件暂不支持预览");
|
this.previewpdf = false;
|
this.hintitle = "当前文件暂不支持预览";
|
} else if (name[1] == "jpg" || "png") {
|
this.previewpdf = true;
|
if (item.url) {
|
this.invoicepdfimg = item.url;
|
} else {
|
this.invoicepdfimg = "";
|
}
|
} else {
|
this.hintitle = "当前文件暂不支持预览";
|
this.$modal.msgWarning("当前文件暂不支持预览");
|
this.previewpdf = false;
|
}
|
}
|
},
|
getIndexInArray(arr, obj) {
|
return arr.indexOf(obj);
|
},
|
// 点击删除
|
deletedowfile(row) {
|
console.log(row);
|
let indexvalue = "";
|
if (this.activeName == 1) {
|
const indexlist = this.getIndexInArray(this.pdfimgsrcList, row.url);
|
this.pdfimgsrcList.splice(indexlist, 1);
|
const index = this.getIndexInArray(this.fileListto, row);
|
this.fileListto.splice(index, 1);
|
console.log(this.rbDetails[this.atpresent].annexfilesList);
|
indexvalue = this.rbDetails[this.atpresent].annexfilesList.find(
|
(item, index) => {
|
return item.name == row.name;
|
}
|
);
|
console.log(indexvalue, "删除索引");
|
this.rbDetails[this.atpresent].annexfilesList.splice(indexvalue, 1);
|
} else {
|
const indexlist = this.getIndexInArray(
|
this.invoicepdfimgsrcList,
|
row.url
|
);
|
this.invoicepdfimgsrcList.splice(indexlist, 1);
|
const index = this.getIndexInArray(this.invoicefileListto, row);
|
this.invoicefileListto.splice(index, 1);
|
console.log(this.rbDetails[this.atpresent].invoicefilesList);
|
indexvalue = this.rbDetails[this.atpresent].invoicefilesList.find(
|
(item, index) => {
|
return item.name == row.name;
|
}
|
);
|
console.log(indexvalue, "删除索引");
|
this.rbDetails[this.atpresent].invoicefilesList.splice(indexvalue, 1);
|
}
|
},
|
// 点击上移
|
moveupdowfile(row) {
|
if (this.activeName == 1) {
|
const index = this.getIndexInArray(this.fileListto, row);
|
const item = this.fileListto.splice(index, 1)[0]; // 移除指定索引处的元素,并保存到item变量中
|
this.fileListto.splice(index - 1, 0, item); // 将item插入到索引位置的前一位
|
} else {
|
const index = this.getIndexInArray(this.invoicefileListto, row);
|
const item = this.invoicefileListto.splice(index, 1)[0]; // 移除指定索引处的元素,并保存到item变量中
|
this.invoicefileListto.splice(index - 1, 0, item); // 将item插入到索引位置的前一位
|
}
|
},
|
|
/** 查询部门下拉树结构 */
|
getTreeselect() {
|
treeselect().then(response => {
|
this.deptOptions = response.data;
|
});
|
},
|
cellCilicksa(row) {
|
console.log(row);
|
},
|
|
//获取人员列表
|
getPersonList() {
|
//获取OPO协调员名单
|
listReportname("xty1").then(res => {
|
this.personsXty = res.data;
|
this.personsList = this.personsXty;
|
|
//OPO专职人员名单
|
listReportname("zzry").then(res => {
|
this.personsZzry = res.data;
|
this.personsList = this.personsList.concat(this.personsZzry);
|
|
//OPO管理人员名单
|
listReportname("fzr").then(res => {
|
this.personsManager = res.data;
|
this.personsList = this.personsList.concat(this.personsManager);
|
|
//OPO专家名单
|
listReportname("expert").then(res => {
|
this.personsExpert = res.data;
|
this.personsList = this.personsList.concat(this.personsExpert);
|
});
|
});
|
});
|
});
|
},
|
|
//获取一个类别的人员列表
|
getPersons(row) {
|
//专职人员-1,协调员-2,专家-3,家属-4,其他人员-5
|
let tmpList = null;
|
if (row.persontype == "专职人员") {
|
this.personsSel = this.personsZzry;
|
} else if (row.persontype == "协调员") {
|
this.personsSel = this.personsXty;
|
} else if (row.persontype == "专家") {
|
this.personsSel = this.personsExpert;
|
} else if (row.persontype == "家属") {
|
this.personsSel = tmpList;
|
} else if (row.persontype == "管理人员") {
|
this.personsSel = this.personsManager;
|
}
|
},
|
|
//获取设置人员账号信息
|
getAccountinfo() {
|
this.coltravelers.map(res => {
|
if (res.reportName == this.form.travelers) {
|
getInfoBytheUserNo(res.reportNo).then(res => {
|
this.form.depositbank = res.data.depositbank;
|
this.form.bankcardno = res.data.bankcardno;
|
this.form.phone = res.data.telephone;
|
});
|
}
|
});
|
},
|
|
//获取设置人员账号信息
|
getAccountinfo2(row, personType) {
|
let dataArr = [];
|
if (personType == "专职人员") {
|
dataArr = this.personsZzry;
|
} else if (personType == "协调员") {
|
dataArr = this.personsXty;
|
} else if (personType == "专家") {
|
dataArr = this.personsExpert;
|
} else if (personType == "管理人员") {
|
dataArr = this.personsManager;
|
}
|
|
for (let m = 0; m < dataArr.length; m++) {
|
if (dataArr[m].reportName == row.personname) {
|
row.bankname = dataArr[m].depositbank;
|
row.bankcardno = dataArr[m].bankcardno;
|
}
|
}
|
},
|
|
//计算日期
|
getdays(row) {
|
if (
|
row.starttime != "" &&
|
row.starttime != null &&
|
row.endtime != "" &&
|
row.endtime != null
|
) {
|
//计算天数
|
row.days = (
|
Math.floor(
|
Math.abs(Date.parse(row.starttime) - Date.parse(row.endtime)) /
|
(1000 * 3600 * 24)
|
) + 1
|
).toString();
|
} else {
|
row.days = 0;
|
}
|
|
//计算补助
|
this.getallowance(row);
|
},
|
|
//计算补助
|
getallowance(row) {
|
if (
|
row.persontype == "专职人员" ||
|
row.persontype == "协调员" ||
|
row.persontype == "管理人员"
|
) {
|
//公杂费补助:杭州桐庐,建德,淳安60,杭州其他地区0,非杭州地区80
|
if (row.destination != "") {
|
var tempStr = row.destination;
|
|
//验证城市
|
if (tempStr == "杭州") {
|
row.otherexpense = "";
|
} else if (
|
tempStr == "杭州-桐庐" ||
|
tempStr == "杭州-建德" ||
|
tempStr == "杭州-淳安"
|
) {
|
row.otherexpense = (parseInt(row.days) * 60).toString();
|
} else {
|
row.otherexpense = (parseInt(row.days) * 80).toString();
|
}
|
}
|
|
//伙食费补助:城市(西藏,新疆,青海.120)(其他100)
|
if (tempStr == "杭州") {
|
row.foodallowance = "";
|
} else if (
|
tempStr == "西藏" ||
|
tempStr == "新疆" ||
|
tempStr == "青海"
|
) {
|
row.foodallowance = (parseInt(row.days) * 120).toString();
|
} else {
|
row.foodallowance = (parseInt(row.days) * 100).toString();
|
}
|
|
//计算合计
|
this.sumRowFee(row);
|
}
|
},
|
|
getStandard(row) {
|
if (
|
row.searchAddress.sheng != "" &&
|
row.searchAddress.shi != "" &&
|
row.searchAddress.qu != "" &&
|
row.starttime != "" &&
|
row.starttime != null &&
|
row.days != ""
|
) {
|
//计算住宿费
|
let info = {
|
pabegindate: this.$moment(row.starttime).format("YYYY-MM-DD"),
|
pacitycode: this.$refs["residenceSelect_" + row.index].getShi(),
|
paenddate: this.$moment(row.starttime)
|
.add(row.days, "day")
|
.format("YYYY-MM-DD"),
|
paprovincecode: this.$refs["residenceSelect_" + row.index].getSheng(),
|
patowncode: this.$refs["residenceSelect_" + row.index].getQu(),
|
standardlevel: this.standardlevel
|
};
|
|
getTravelStandard(info)
|
.then(response => {
|
let fee = 0;
|
for (let i = 0; i < response.data.length; i++) {
|
fee += response.data[i].reimbursementamout;
|
}
|
row.hotelexpense = fee;
|
})
|
.finally(() => {
|
this.sumTotalFee();
|
});
|
}
|
},
|
|
selcetdestination(row) {
|
console.log("目的地选择事件", row, row.searchAddress);
|
//row.searchAddress = this.searchAddress;
|
if (
|
row.searchAddress.sheng != "" &&
|
row.searchAddress.shi != "" &&
|
row.searchAddress.qu != ""
|
) {
|
row.destination =
|
row.searchAddress.sheng +
|
row.searchAddress.shi +
|
row.searchAddress.qu;
|
row.travelprovincename = row.searchAddress.sheng;
|
row.travelprovince = this.$refs[
|
"residenceSelect_" + row.index
|
].getSheng();
|
row.travelcityname = row.searchAddress.shi;
|
row.travelcity = this.$refs["residenceSelect_" + row.index].getShi();
|
row.traveltownname = row.searchAddress.qu;
|
row.traveltown = this.$refs["residenceSelect_" + row.index].getQu();
|
this.getStandard(row);
|
}
|
},
|
|
getCodeToText(codeArray) {
|
// 参数 codeStr,
|
// if (null === codeStr && null === codeArray) {
|
// return null;
|
// } else if (null === codeArray) {
|
// codeArray = codeStr.split(",");
|
// }
|
|
let area = "";
|
switch (codeArray.length) {
|
case 1:
|
area += CodeToText[codeArray[0]];
|
break;
|
case 2:
|
area += CodeToText[codeArray[0]] + "/" + CodeToText[codeArray[1]];
|
break;
|
case 3:
|
area +=
|
CodeToText[codeArray[0]] +
|
"/" +
|
CodeToText[codeArray[1]] +
|
"/" +
|
CodeToText[codeArray[2]];
|
break;
|
default:
|
break;
|
}
|
return area;
|
},
|
|
//获取捐献者基本信息:捐献编号、捐献者姓名
|
selectbaseinfo() {
|
let list = this.donatorList;
|
list.forEach(item => {
|
if (item.id == this.form.infoid) {
|
this.form.donorno = item.donorno;
|
this.form.donorname = item.name;
|
}
|
});
|
},
|
|
onpick(e) {
|
// console.log(e,this.value1)
|
},
|
|
gettable(e) {
|
const id = e.id;
|
getdownload(e.id).then(res => {
|
var fileUrl = res;
|
//获取当前网址
|
var urlBase = process.env.VUE_APP_BASE_API;
|
var curWWWPath = window.document.location.href;
|
var pos = curWWWPath.indexOf(window.document.location.pathname);
|
// 创建a标签
|
var aEle = document.createElement("a");
|
aEle.href =
|
curWWWPath.substring(0, pos) + urlBase + fileUrl["downloadUrl"];
|
console.log(aEle.href);
|
// 添加Authorization头部
|
fetch(aEle.href, {
|
headers: this.headers
|
})
|
.then(response => {
|
// 将文件下载链接作为blob对象进行下载
|
return response.blob();
|
})
|
.then(blob => {
|
const url = window.URL.createObjectURL(new Blob([blob]));
|
console.log(url);
|
const link = document.createElement("a");
|
link.href = url;
|
const name = fileUrl["downloadName"];
|
link.setAttribute("download", name); // 替换file.pdf为实际的文件名
|
document.body.appendChild(link);
|
link.click();
|
link.parentNode.removeChild(link);
|
});
|
});
|
},
|
|
/** 查询报销申请列表 */
|
getList() {
|
this.loading = true;
|
listReimbursement(this.queryParams).then(response => {
|
this.reimbursementList = response.rows;
|
console.log(this.reimbursementList);
|
this.total = response.total;
|
this.loading = false;
|
});
|
},
|
|
// 取消按钮
|
cancel() {
|
window.close();
|
},
|
|
// 表单重置
|
reset() {
|
this.fileListto = [];
|
this.form = {
|
ceshi: {},
|
bigstrmoney: null,
|
id: null,
|
delFlag: null,
|
createBy: null,
|
createTime: null,
|
updateBy: null,
|
updateTime: null,
|
userno: null,
|
username: null,
|
idcardtype: null,
|
idcardno: null,
|
phone: null,
|
depositbank: null,
|
bankcardno: null,
|
branchbankname: null,
|
annexbankcard: null,
|
annexfiles: null,
|
amountrequested: null,
|
prepaidamount: null,
|
invoicecount: null,
|
attachcount: null,
|
managerno: null,
|
managername: null,
|
deptmentno: null,
|
deptmentname: null,
|
opochecker: null,
|
finvicepresident: null,
|
busvicepresident: null,
|
officedirector: null,
|
financedirector: null,
|
financechecher: null,
|
infoid: null,
|
donorno: null,
|
bigstrmoney: null,
|
remark: null,
|
reason: null,
|
recordstatus: "-1",
|
uploadflag: null,
|
uploadtime: null,
|
costtype: null,
|
costtypename: null
|
};
|
this.rbDetails = [];
|
this.rbPayees = [];
|
this.resetForm("form");
|
},
|
|
//
|
handup(e) {
|
console.log("上报", e);
|
},
|
|
/** 搜索按钮操作 */
|
handleQuery() {
|
// console.log('pop',this.value1)
|
if (this.value1.length > 0) {
|
this.queryParams.starttime = this.value1[0] + " 00:00:00";
|
this.queryParams.endtime = this.value1[1] + " 00:00:00";
|
console.log("开始时间", this.queryParams.starttime);
|
}
|
// this.queryParams.pacitycode= this.$refs["residenceSelect"].getShi();
|
// this.queryParams.paprovincecode= this.$refs["residenceSelect" ].getSheng();
|
// this.queryParams.patowncode= this.$refs["residenceSelect" ].getQu();
|
this.queryParams.pageNum = 1;
|
// this.getList();
|
},
|
|
/** 重置按钮操作 */
|
resetQuery() {
|
this.resetForm("queryForm");
|
this.handleQuery();
|
},
|
// 多选框选中数据
|
handleSelectionChange(selection) {
|
this.ids = selection.map(item => item.id);
|
this.single = selection.length !== 1;
|
this.multiple = !selection.length;
|
},
|
|
/** 新增按钮操作 */
|
handleAdd() {
|
this.reset();
|
// this.open = true;
|
this.title = "新增差旅申请单";
|
this.operationType = "edit";
|
this.fundflowList = [];
|
|
console.log(this.title, this.defaultperson);
|
|
this.form.userno = this.defaultperson.userName;
|
this.form.username = this.defaultperson.nickName;
|
this.form.deptmentname = this.defaultperson.dept.deptName;
|
this.form.deptmentno = this.defaultperson.dept.deptId;
|
this.form.managername = this.defaultperson.dept.leader;
|
|
this.addDetailRow(0);
|
this.addPayeeRow(0);
|
},
|
|
/** 修改按钮操作 */
|
handleUpdate(curId) {
|
// this.$router.push({
|
// path: "/finance/travelexpenseslist/Modifydetails/",
|
// query: { id: ids }
|
// });
|
|
this.operationType = "edit";
|
this.reset();
|
// this.open = true;
|
this.title = "报销申请修改";
|
|
//获取报销主信息
|
getReimbursement(curId).then(response => {
|
this.form = response.data;
|
|
this.fileListto = this.form.annexfiles
|
? this.form.annexfiles
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
this.invoicefileListto = this.form.invoicefilesList
|
? this.form.invoicefilesList
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
this.form.recordstatus = response.data.recordstatus + "";
|
sessionStorage.removeItem("apiform");
|
sessionStorage.setItem("apiform", JSON.stringify(this.form));
|
|
//获取报销明细信息
|
getReimbursementdetaillist(curId).then(res => {
|
this.rbDetails = res.data;
|
console.log(this.rbDetails);
|
if (this.rbDetails.length == 0) {
|
this.addDetailRow(0);
|
}
|
//实时合计金额
|
//this.sumTotalFee();
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
this.sumRowFee(this.rbDetails[i]);
|
}
|
sessionStorage.removeItem("apifunddetail");
|
sessionStorage.setItem(
|
"apifunddetail",
|
JSON.stringify(this.rbDetails)
|
);
|
});
|
|
//获取报销打款信息
|
this.queryParamsPayee.rbid = curId;
|
listReimbursementpayee(this.queryParamsPayee).then(res => {
|
this.rbPayees = res.rows;
|
if (this.rbPayees.length == 0) {
|
this.addPayeeRow(0);
|
}
|
});
|
|
//审核状态
|
this.form.recordstatus = response.data.recordstatus + "";
|
let listFundflowparams = {
|
fundid: curId,
|
fundtype: 1
|
};
|
listFundflow(listFundflowparams).then(res => {
|
this.fundflowList = res.rows;
|
});
|
});
|
},
|
|
/** 查看按钮操作 */
|
handleDetail(ids) {
|
this.operationType = "detail";
|
this.title = "报销申请详情";
|
this.jurisdiction = true;
|
this.reset();
|
this.open = true;
|
const id = ids || this.ids;
|
getReimbursement(id).then(response => {
|
this.form = response.data;
|
//票据
|
this.fileListto = this.form.annexfiles
|
? this.form.annexfiles
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
this.invoicefileListto = this.form.invoicefilesList
|
? this.form.invoicefilesList
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
//审核状态
|
this.form.recordstatus = response.data.recordstatus + "";
|
let ids = response.data.id;
|
let listFundflowparams = {
|
fundid: ids,
|
fundtype: 1
|
};
|
listFundflow(listFundflowparams).then(res => {
|
this.fundflowList = res.rows;
|
});
|
|
//报销明细
|
getReimbursementdetaillist(ids).then(res => {
|
this.rbDetails = res.data;
|
//合计费用
|
// if (this.rbDetails.length > 0) this.sumTotalFee();
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
this.sumRowFee(this.rbDetails[i]);
|
}
|
});
|
|
//付款信息
|
this.queryParamsPayee.rbid = ids;
|
listReimbursementpayee(this.queryParamsPayee).then(res => {
|
this.rbPayees = res.rows;
|
if (this.rbPayees.length == 0) {
|
this.addPayeeRow(0);
|
}
|
});
|
sessionStorage.removeItem("apiform");
|
sessionStorage.setItem("apiform", JSON.stringify(this.form));
|
});
|
},
|
|
/** 审核按钮操作 */
|
handleCheck(ids) {
|
this.operationType = "check";
|
this.title = "报销申请详情";
|
|
this.reset();
|
this.open = true;
|
const id = ids || this.ids;
|
this.checkObj.fundid = id;
|
|
getReimbursement(id).then(response => {
|
this.form = response.data;
|
|
//票据
|
this.fileListto = this.form.annexfiles
|
? this.form.annexfiles
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
this.invoicefileListto = this.form.invoicefilesList
|
? this.form.invoicefilesList
|
.split(",")
|
.map(item => ({ url: item, name: item }))
|
: [];
|
|
//审核状态
|
this.form.recordstatus = response.data.recordstatus + "";
|
|
let ids = response.data.id;
|
let listFundflowparams = {
|
fundid: ids,
|
fundtype: 1
|
};
|
listFundflow(listFundflowparams).then(res => {
|
this.fundflowList = res.rows;
|
});
|
|
//报销明细
|
getReimbursementdetaillist(ids).then(res => {
|
this.rbDetails = res.data;
|
console.log(this.rbDetails);
|
|
//合计费用
|
// if (this.rbDetails.length > 0) this.sumTotalFee();
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
this.sumRowFee(this.rbDetails[i]);
|
}
|
});
|
|
//付款信息
|
this.queryParamsPayee.rbid = ids;
|
listReimbursementpayee(this.queryParamsPayee).then(res => {
|
this.rbPayees = res.rows;
|
if (this.rbPayees.length == 0) {
|
this.addPayeeRow(0);
|
}
|
});
|
sessionStorage.removeItem("apiform");
|
sessionStorage.setItem("apiform", JSON.stringify(this.form));
|
});
|
},
|
|
//提交审核意见
|
checksubmit() {
|
if (
|
this.form.checkstatus != 3 &&
|
this.userprofile.nickName == "陈慕华" &&
|
this.checkObj.flowlevelone == 1
|
) {
|
this.$modal.msgError("请选确认材料状态已收到!");
|
return;
|
}
|
let checkfundobj = {
|
flowconclusion: this.checkObj.flowlevelone,
|
flowcontent: this.checkObj.flowconclusion,
|
fundid: this.checkObj.fundid
|
};
|
|
if (
|
checkfundobj.flowconclusion == null ||
|
checkfundobj.flowconclusion == undefined ||
|
checkfundobj.flowconclusion == ""
|
) {
|
this.$modal.msgError("请选择审核结论后再提交审批结果!");
|
return;
|
}
|
if (this.userprofile.nickName == "陈慕华") {
|
this.Savenow();
|
console.log("保存");
|
}
|
this.$modal.loading("正在提交审核,请稍候!");
|
|
checkfund(checkfundobj).then(res => {
|
this.$modal.closeLoading();
|
this.$modal.msgSuccess("提交审核成功!");
|
// 关闭窗口
|
this.$store.dispatch("tagsView/delView", this.$route);
|
this.$router.go(-1);
|
});
|
},
|
|
/** 提交保存按钮 */
|
submitForm: debounce(function(data) {
|
this.$refs["form"].validate(valid => {
|
if (valid) {
|
//票据文件处理
|
const addnumber = this.rbPayees.reduce(
|
(amount, item) => amount + Number(item.amount),
|
0
|
);
|
|
//校验请款金额合计是否等于报销单金额
|
if (this.form.amountrequested != addnumber) {
|
this.$message({
|
message:
|
"报销请款表中合计金额不等于报销单的报销金额,请更正后再保存!",
|
type: "warning"
|
});
|
return;
|
}
|
|
const rbDetails = [...this.rbDetails];
|
const rbPayees = [...this.rbPayees];
|
if (this.form.id != null) {
|
console.log(this.form);
|
updateReimbursement(this.form);
|
// .then(res => {
|
//保存明细
|
for (let i = 0; i < rbDetails.length; i++) {
|
if (rbDetails[i].rbid != null) {
|
if (rbDetails[i].persontype == "家属") {
|
if (this.form.infoid) {
|
updateReimbursementdetail(rbDetails[i]);
|
} else {
|
return this.$message.error(
|
`因家属分配要求,请选择捐献者信息`
|
);
|
}
|
} else {
|
updateReimbursementdetail(rbDetails[i]);
|
}
|
} else {
|
if (rbDetails[i].persontype == "家属") {
|
if (this.form.infoid) {
|
//rbid关联主表Id
|
rbDetails[i].rbid = this.form.id;
|
addReimbursementdetail(rbDetails[i]);
|
} else {
|
return this.$message.error(
|
`因家属分配要求,请选择捐献者信息`
|
);
|
}
|
} else {
|
//rbid关联主表Id
|
rbDetails[i].rbid = this.form.id;
|
addReimbursementdetail(rbDetails[i]);
|
}
|
}
|
}
|
|
//保存账户
|
for (let i = 0; i < rbPayees.length; i++) {
|
if (rbPayees[i].rbid != null) {
|
updateReimbursementpayee(rbPayees[i]);
|
} else {
|
//rbid关联主表Id
|
rbPayees[i].rbid = this.form.id;
|
addReimbursementpayee(rbPayees[i]);
|
}
|
}
|
if (this.userprofile.nickName != "陈慕华") {
|
this.$modal.msgSuccess("修改报销单保存成功!");
|
}
|
this.open = false;
|
|
// 关闭窗口
|
this.$store.dispatch("tagsView/delView", this.$route);
|
this.$router.go(-1);
|
} else {
|
this.form.recordstatus = -1;
|
// 申请时间
|
var currenttime = new Date();
|
this.form.applyTime =
|
currenttime.getFullYear() +
|
"-" +
|
(currenttime.getMonth() + 1) +
|
"-" +
|
currenttime.getDate() +
|
" " +
|
currenttime.getHours() +
|
":" +
|
currenttime.getMinutes() +
|
":" +
|
currenttime.getSeconds();
|
|
addReimbursement(this.form)
|
.then(response => {
|
//保存明细
|
for (let i = 0; i < rbDetails.length; i++) {
|
//rbid关联主表Id
|
rbDetails[i].rbid = response.data;
|
addReimbursementdetail(rbDetails[i]);
|
}
|
|
//保存账号
|
for (let i = 0; i < rbPayees.length; i++) {
|
//rbid关联主表Id
|
rbPayees[i].rbid = response.data;
|
addReimbursementpayee(rbPayees[i]);
|
}
|
sessionStorage.setItem(
|
"apifunddetail",
|
JSON.stringify(this.rbDetails)
|
);
|
sessionStorage.setItem("apiform", JSON.stringify(this.form));
|
|
this.$modal.msgSuccess("新增报销单保存成功!");
|
this.open = false;
|
|
// 关闭窗口
|
this.$store.dispatch("tagsView/delView", this.$route);
|
this.$router.go(-1);
|
})
|
.catch(err => {
|
this.$modal.msgError("新增报销单保存失败!" + res);
|
});
|
}
|
}
|
});
|
}, 500),
|
|
/** 删除按钮操作 */
|
handleDelete(row) {
|
const ids = row.id || this.ids;
|
this.$modal
|
.confirm("是否确认删除该条记录?")
|
.then(function() {
|
// 删除details内的数据
|
return delReimbursement(ids);
|
})
|
.then(() => {
|
delReimbursementdetail(ids);
|
this.getList();
|
this.$modal.msgSuccess("删除成功");
|
})
|
.catch(() => {});
|
},
|
|
/** 导出按钮操作 */
|
handleExport() {
|
const queryParams = this.queryParams;
|
this.$modal
|
.confirm("是否确认导出所有报销申请数据项?")
|
.then(() => {
|
this.exportLoading = true;
|
return exportReimbursement(queryParams);
|
})
|
.then(response => {
|
this.$download.name(response.msg);
|
this.exportLoading = false;
|
})
|
.catch(() => {});
|
},
|
// 取消提醒
|
unsave() {
|
this.Savereminder = false;
|
this.Reminderquantity = 0;
|
},
|
// 接受提醒立刻保存
|
Savenow() {
|
this.Savereminder = false;
|
this.Reminderquantity = 0;
|
this.totalquantity = 0;
|
const addnumber = this.rbPayees.reduce(
|
(amount, item) => amount + Number(item.amount),
|
0
|
);
|
console.log(addnumber, "addnumber");
|
this.$refs["form"].validate(valid => {
|
if (valid) {
|
//票据文件处理
|
//校验请款金额合计是否等于报销单金额
|
if (this.form.amountrequested != addnumber) {
|
this.$message({
|
message:
|
"报销请款表中合计金额不等于报销单的报销金额,请更正后再保存!",
|
type: "warning"
|
});
|
return;
|
}
|
|
const rbDetails = [...this.rbDetails];
|
const rbPayees = [...this.rbPayees];
|
if (this.form.id != null) {
|
console.log(this.form);
|
updateReimbursement(this.form);
|
// .then(res => {
|
//保存明细
|
for (let i = 0; i < rbDetails.length; i++) {
|
if (rbDetails[i].rbid != null) {
|
updateReimbursementdetail(rbDetails[i]);
|
} else {
|
//rbid关联主表Id
|
rbDetails[i].rbid = this.form.id;
|
addReimbursementdetail(rbDetails[i]);
|
}
|
}
|
|
//保存账户
|
for (let i = 0; i < rbPayees.length; i++) {
|
if (rbPayees[i].rbid != null) {
|
updateReimbursementpayee(rbPayees[i]);
|
} else {
|
//rbid关联主表Id
|
rbPayees[i].rbid = this.form.id;
|
addReimbursementpayee(rbPayees[i]);
|
}
|
}
|
|
this.$modal.msgSuccess("修改报销单保存成功!");
|
} else {
|
this.form.recordstatus = -1;
|
addReimbursement(this.form)
|
.then(response => {
|
//保存明细
|
for (let i = 0; i < rbDetails.length; i++) {
|
//rbid关联主表Id
|
rbDetails[i].rbid = response.data;
|
addReimbursementdetail(rbDetails[i]);
|
}
|
|
//保存账号
|
for (let i = 0; i < rbPayees.length; i++) {
|
//rbid关联主表Id
|
rbPayees[i].rbid = response.data;
|
addReimbursementpayee(rbPayees[i]);
|
}
|
|
this.$modal.msgSuccess("新增报销单保存成功!");
|
})
|
.catch(err => {
|
this.$modal.msgError("新增报销单保存失败!");
|
});
|
}
|
}
|
});
|
},
|
|
//新增一行
|
addDetailRow(rowIndex) {
|
console.log(rowIndex);
|
|
let rowData = {
|
//index: this.rbDetails.length,
|
searchAddress: {
|
sheng: "",
|
shi: "",
|
qu: ""
|
},
|
id: null,
|
rbid: null,
|
starttime: null,
|
departure: null,
|
endtime: null,
|
destination: null,
|
days: null,
|
persontype: null,
|
personname: null,
|
trafficexpense: 0,
|
traffictype: null,
|
traffictype2: null,
|
cityfee: 0,
|
hotelexpense: 0,
|
invoicecount: null,
|
attachcount: null,
|
otherexpense: 0,
|
foodexpenses: 0,
|
foodallowance: 0,
|
otherfeeamount: 0,
|
annexfiles: null,
|
remark: null,
|
delFlag: null,
|
createBy: null,
|
createTime: null,
|
updateBy: null,
|
updateTime: null,
|
uploadFlag: null,
|
uploadTime: null,
|
total: 0,
|
orderno: null,
|
personname2: null,
|
destination: null
|
};
|
if (this.rbDetails.length) {
|
console.log(this.rbDetails[rowIndex].persontype);
|
console.log(this.rbDetails[rowIndex].personname);
|
rowData.persontype = this.rbDetails[rowIndex].persontype;
|
rowData.personname = this.rbDetails[rowIndex].personname;
|
}
|
// if (this.Reminderquantity >= 5) {
|
// this.Savereminder = true;
|
// return;
|
// }
|
if (rowIndex == undefined || rowIndex == null || rowIndex < 0) {
|
this.rbDetails.push(rowData);
|
} else {
|
this.rbDetails.splice(rowIndex + 1, 0, rowData);
|
}
|
this.Reminderquantity++;
|
this.totalquantity++;
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
this.rbDetails[i].orderno = i + 1;
|
}
|
},
|
|
addPayeeRow(rowIndex) {
|
let rowData = {
|
id: null,
|
personType: null,
|
personname: null,
|
bankname: null,
|
bankcardno: null,
|
paiddate: null,
|
remark: null,
|
orderno: null,
|
personname: null,
|
amount: null
|
};
|
// if (this.Reminderquantity >= 5) {
|
// this.Savereminder = true;
|
// return;
|
// }
|
if (rowIndex == undefined || rowIndex == null || rowIndex <= 0) {
|
this.rbPayees.push(rowData);
|
} else {
|
this.rbPayees.splice(rowIndex + 1, 0, rowData);
|
}
|
this.Reminderquantity++;
|
this.totalquantity++;
|
for (let i = 0; i < this.rbPayees.length; i++) {
|
this.rbPayees[i].orderno = i + 1;
|
}
|
},
|
|
deleteDetailRow(index, rows, row) {
|
this.$confirm("是否确认删除?", "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "success"
|
})
|
.then(() => {
|
console.log(row);
|
if (row.id !== null) {
|
delReimbursementdetail(row.id).then(res => {
|
this.$modal.msgSuccess("删除成功");
|
rows.splice(index, 1);
|
this.recountOrderNo();
|
this.sumTotalFee();
|
});
|
} else {
|
rows.splice(index, 1);
|
this.sumTotalFee();
|
this.$modal.msgSuccess("删除成功");
|
this.recountOrderNo();
|
}
|
})
|
.catch(() => {
|
//几点取消的提示
|
});
|
},
|
|
deletePayeeRow(index, rows, row) {
|
this.$confirm("是否确认删除?", "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "success"
|
})
|
.then(() => {
|
console.log(row);
|
let arrow = [];
|
arrow.push(row.id);
|
if (row.id !== null) {
|
delReimbursementpayee(arrow).then(res => {
|
this.$modal.msgSuccess("删除成功");
|
rows.splice(index, 1);
|
this.recountOrderNo2();
|
this.sumTotalFee();
|
});
|
} else {
|
rows.splice(index, 1);
|
this.sumTotalFee();
|
this.$modal.msgSuccess("删除成功");
|
this.recountOrderNo2();
|
}
|
})
|
.catch(() => {
|
//几点取消的提示
|
});
|
},
|
//重新计算排序
|
recountOrderNo() {
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
this.rbDetails[i].orderno = i + 1;
|
}
|
},
|
//重新计算排序
|
recountOrderNo2() {
|
for (let i = 0; i < this.rbPayees.length; i++) {
|
this.rbPayees[i].orderno = i + 1;
|
}
|
},
|
|
//上报
|
handleup(row) {
|
this.$confirm("是否确认将登记记录上报?", "提示", {
|
confirmButtonText: "确定",
|
cancelButtonText: "取消",
|
type: "warning"
|
})
|
.then(() => {
|
//调用差旅费上报接口
|
let tempParam = {
|
fundid: row.id
|
};
|
fundSubmit(tempParam).then(response => {
|
if (response.code == 200) {
|
this.getList();
|
this.$message({
|
type: "success",
|
message: "上报成功"
|
});
|
} else {
|
this.$message({
|
type: "error",
|
message: "上报失败"
|
});
|
}
|
this.loading = false;
|
});
|
})
|
.catch(() => {
|
this.$message({
|
type: "info",
|
message: "已取消申请"
|
});
|
});
|
},
|
|
//计算一行合计
|
//计算当前行报销内容费用合计
|
sumRowFee(row) {
|
let totalFee = 0;
|
if (!isNaN(parseFloat(row.trafficexpense))) {
|
totalFee += parseFloat(row.trafficexpense);
|
}
|
if (!isNaN(parseFloat(row.cityfee))) {
|
totalFee += parseFloat(row.cityfee);
|
}
|
if (!isNaN(parseFloat(row.hotelexpense))) {
|
totalFee += parseFloat(row.hotelexpense);
|
}
|
if (!isNaN(parseFloat(row.otherexpense))) {
|
totalFee += parseFloat(row.otherexpense);
|
}
|
if (!isNaN(parseFloat(row.foodexpenses))) {
|
totalFee += parseFloat(row.foodexpenses);
|
}
|
if (!isNaN(parseFloat(row.foodallowance))) {
|
totalFee += parseFloat(row.foodallowance);
|
}
|
if (!isNaN(parseFloat(row.otherfeeamount))) {
|
totalFee += parseFloat(row.otherfeeamount);
|
}
|
row.total = totalFee.toFixed(2);
|
|
/*
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].trafficexpense))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].trafficexpense);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].cityfee))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].cityfee);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].hotelexpense))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].hotelexpense);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].otherexpense))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].otherexpense);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].foodexpenses))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].foodexpenses);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].foodallowance))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].foodallowance);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[rowIndex].otherfeeamount))) {
|
totalFee += parseFloat(this.rbDetails[rowIndex].otherfeeamount);
|
}
|
this.rbDetails[rowIndex].total = parseFloat(totalFee).toFixed(2);
|
this.$set(this.rbDetails, rowIndex, this.rbDetails[rowIndex]);
|
*/
|
//重新计算整个报销单的合计
|
this.sumTotalFee();
|
},
|
|
//计算费用合计
|
sumTotalFee() {
|
let allSum = 0;
|
|
//捐献者家属费用
|
if (!isNaN(parseFloat(this.form.donoramount))) {
|
allSum += parseFloat(this.form.donoramount);
|
}
|
|
//报销明细费用
|
try {
|
for (let i = 0; i < this.rbDetails.length; i++) {
|
/*
|
let totalFee = 0;
|
//计算当前报销内容费用合计
|
if (!isNaN(parseFloat(this.rbDetails[i].total))) {
|
totalFee += parseFloat(this.rbDetails[i].total);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].cityfee))) {
|
totalFee += parseFloat(this.rbDetails[i].cityfee);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].hotelexpense))) {
|
totalFee += parseFloat(this.rbDetails[i].hotelexpense);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].otherexpense))) {
|
totalFee += parseFloat(this.rbDetails[i].otherexpense);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].foodexpenses))) {
|
totalFee += parseFloat(this.rbDetails[i].foodexpenses);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].foodallowance))) {
|
totalFee += parseFloat(this.rbDetails[i].foodallowance);
|
}
|
if (!isNaN(parseFloat(this.rbDetails[i].otherfeeamount))) {
|
totalFee += parseFloat(this.rbDetails[i].otherfeeamount);
|
}
|
this.rbDetails[i].total = parseFloat(totalFee).toFixed(2);
|
this.$set(this.rbDetails, i, this.rbDetails[i]);
|
*/
|
|
if (!isNaN(parseFloat(this.rbDetails[i].total))) {
|
allSum += parseFloat(this.rbDetails[i].total);
|
}
|
}
|
|
this.form.amountrequested = allSum.toFixed(2);
|
this.form.bigstrmoney = this.convertCurrency(this.form.amountrequested);
|
} catch {}
|
},
|
|
//金额数字转换成大写
|
convertCurrency(money) {
|
//汉字的数字
|
var cnNums = new Array(
|
"零",
|
"壹",
|
"贰",
|
"叁",
|
"肆",
|
"伍",
|
"陆",
|
"柒",
|
"捌",
|
"玖"
|
);
|
//基本单位
|
var cnIntRadice = new Array("", "拾", "佰", "仟");
|
//对应整数部分扩展单位
|
var cnIntUnits = new Array("", "万", "亿", "兆");
|
//对应小数部分单位
|
var cnDecUnits = new Array("角", "分", "毫", "厘");
|
//整数金额时后面跟的字符
|
var cnInteger = "整";
|
//整型完以后的单位
|
var cnIntLast = "元";
|
//最大处理的数字
|
var maxNum = 999999999999999.9999;
|
//金额整数部分
|
var integerNum;
|
//金额小数部分
|
var decimalNum;
|
//输出的中文金额字符串
|
var chineseStr = "";
|
//分离金额后用的数组,预定义
|
var parts;
|
if (money == "") {
|
return "";
|
}
|
money = parseFloat(money);
|
if (money >= maxNum) {
|
//超出最大处理数字
|
return "";
|
}
|
if (money == 0) {
|
chineseStr = cnNums[0] + cnIntLast + cnInteger;
|
return chineseStr;
|
}
|
//转换为字符串
|
money = money.toString();
|
if (money.indexOf(".") == -1) {
|
integerNum = money;
|
decimalNum = "";
|
} else {
|
parts = money.split(".");
|
integerNum = parts[0];
|
decimalNum = parts[1].substr(0, 4);
|
}
|
//获取整型部分转换
|
if (parseInt(integerNum, 10) > 0) {
|
var zeroCount = 0;
|
var IntLen = integerNum.length;
|
for (var i = 0; i < IntLen; i++) {
|
var n = integerNum.substr(i, 1);
|
var p = IntLen - i - 1;
|
var q = p / 4;
|
var m = p % 4;
|
if (n == "0") {
|
zeroCount++;
|
} else {
|
if (zeroCount > 0) {
|
chineseStr += cnNums[0];
|
}
|
//归零
|
zeroCount = 0;
|
chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
|
}
|
if (m == 0 && zeroCount < 4) {
|
chineseStr += cnIntUnits[q];
|
}
|
}
|
chineseStr += cnIntLast;
|
}
|
//小数部分
|
if (decimalNum != "") {
|
var decLen = decimalNum.length;
|
for (var i = 0; i < decLen; i++) {
|
var n = decimalNum.substr(i, 1);
|
if (n != "0") {
|
chineseStr += cnNums[Number(n)] + cnDecUnits[i];
|
}
|
}
|
}
|
if (chineseStr == "") {
|
chineseStr += cnNums[0] + cnIntLast + cnInteger;
|
} else if (decimalNum == "") {
|
chineseStr += cnInteger;
|
}
|
return chineseStr;
|
},
|
|
//表格合计
|
getSummaries(param) {
|
const { columns, data } = param;
|
const sums = [];
|
var columnnames = [
|
"bankname",
|
"bankcardno",
|
"remark",
|
"personname",
|
"starttime",
|
"endtime",
|
"departure",
|
"destination",
|
"traffictype",
|
"traffictype2"
|
];
|
columns.forEach((column, index) => {
|
if (index === 0) {
|
sums[index] = "合计";
|
return;
|
}
|
if (index === 18) {
|
sums[index] = this.form.amountrequested;
|
return;
|
}
|
//去除部分字段计算
|
if (columnnames.indexOf(column.property) > -1) {
|
return;
|
}
|
|
const values = data.map(item => Number(item[column.property]));
|
if (!values.every(value => isNaN(value))) {
|
sums[index] = values.reduce((prev, curr) => {
|
const value = Number(curr);
|
if (!isNaN(value)) {
|
return prev + curr;
|
} else {
|
return prev;
|
}
|
}, 0);
|
sums[index] = sums[index].toFixed(2); // 保留2位小数,解决小数合计列;
|
} else {
|
sums[index] = "";
|
}
|
});
|
return sums;
|
}
|
}
|
};
|
</script>
|
|
<style lang="scss" scoped>
|
.Modifydetailscla {
|
padding: 10px;
|
|
.boxdiv {
|
font-size: 18px;
|
padding: 0 30px;
|
padding-bottom: 60px;
|
|
.top-text {
|
text-align: center;
|
|
font-size: 23px;
|
font-weight: 600;
|
margin: 20px 0;
|
margin-bottom: 50px;
|
}
|
|
.dialog-footer {
|
text-align: left;
|
margin-top: 10px;
|
}
|
}
|
}
|
|
.upload-demo {
|
text-align: center;
|
}
|
|
.pdfimg {
|
display: flex; // text-align: center;
|
width: 100%;
|
height: 600px;
|
|
.box-pdf {
|
width: 400px;
|
padding-top: 20px;
|
margin-right: 30px;
|
border: 1px solid #dcdfe6;
|
-webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
|
0 0 6px 0 rgba(0, 0, 0, 0.04);
|
box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.1); // <- Add this to fix.
|
}
|
|
.pdftit {
|
width: 200px;
|
padding: 20px;
|
font-size: 18px;
|
}
|
|
.pdftit:hover {
|
background: #c0cef7;
|
}
|
|
.pdfimgmin {
|
width: 60%;
|
|
img {
|
width: 100%;
|
}
|
}
|
|
.pdfimgmins {
|
font-size: 28px;
|
width: 60%;
|
text-align: center;
|
}
|
}
|
|
::v-deep .el-input--medium .el-input__inner {
|
height: 36px;
|
line-height: 36px;
|
text-align: center;
|
}
|
|
::v-deep .el-alert__title {
|
font-size: 20px;
|
line-height: 20px;
|
}
|
</style>
|