123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284 |
- <template>
- <!-- 添加或修改项目信息对话框 -->
- <div class="el-drawer__wrapper">
- <el-drawer :title="title" v-model="visible" direction="rtl" size="100%">
- <div class="page-container form-container">
- <div class="form-btns-container">
- <span class="title-label"
- ><el-icon>
- <Document />
- </el-icon>
- 支出信息</span
- >
- <template
- v-if="
- checkPermission(['business:payment:edit', 'business:payment:add'])
- "
- >
- <el-button
- v-if="editStatus"
- type="primary"
- size="small"
- icon="Finished"
- @click="submitForm"
- >保存</el-button
- >
- <el-button
- v-else-if="form.verifyStatus === 0"
- type="warning"
- size="small"
- icon="Edit"
- @click="editStatus = true"
- >修改</el-button
- >
- <el-button
- v-if="form.id && editStatus"
- size="small"
- icon="Close"
- @click="editStatus = false"
- >取消修改</el-button
- >
- </template>
- <el-button
- v-show="form.id && !editStatus && form.verifyStatus === 0"
- v-hasPermi="['business:payment:financialVerify']"
- type="primary"
- size="small"
- icon="Check"
- @click="verifyHandler"
- >财务审核</el-button
- >
- <el-button
- v-show="form.id && !editStatus && form.verifyStatus === 1"
- v-hasPermi="['business:payment:cashierVerify']"
- type="primary"
- size="small"
- icon="Check"
- @click="cashierVerifyHandler"
- >出纳审核</el-button
- >
- <div class="screen-btn" @click="handleScreen">
- <template v-if="!isFullscreen">
- <i class="fa fa-window-maximize" aria-hidden="true" />
- <!-- <span>全屏</span> -->
- </template>
- <template v-else>
- <i class="fa fa-window-restore" aria-hidden="true" />
- <!-- <span>还原</span> -->
- </template>
- </div>
- <div class="close-btn" @click="cancel">
- <i class="fa fa-times" aria-hidden="true" />
- <!-- <span>关闭</span> -->
- </div>
- </div>
- <div
- class="Y-scrollbar"
- style="
- position: absolute;
- top: 32px;
- bottom: 0;
- width: 100%;
- overflow: auto;
- "
- ></div>
- <el-form
- ref="orderRef"
- class="master-container"
- size="small"
- :model="form"
- :rules="rules"
- label-width="100px"
- >
- <el-row :gutter="30">
- <el-col :span="6">
- <el-form-item label="支出流水号:">
- <el-input
- v-if="editStatus"
- style="width: 100%"
- v-model.trim="form.flowNo"
- readonly
- size="small"
- type="text"
- placeholder="支出流水号"
- :clearable="true"
- />
- <span v-else>{{ form.flowNo }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="申请日期" prop="formDate" required>
- <el-date-picker
- v-if="editStatus"
- style="width: 100%"
- v-model="form.formDate"
- size="small"
- :clearable="true"
- format="YYYY-MM-DD"
- value-format="YYYY-MM-DD"
- align="center"
- type="date"
- placeholder="申请日期"
- />
- <span v-else>{{ form.formDate }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="支出类目:">
- <el-select
- v-if="editStatus"
- style="width: 100%"
- v-model.trim="form.paymentCauseId"
- placeholder="支出类目"
- size="small"
- :clearable="true"
- @change="paymentCauseChange"
- >
- <el-option
- v-for="item in paymentTypes"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- />
- </el-select>
- <span v-else>{{ form.paymentCause }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="支出科目:">
- <el-select
- v-if="editStatus"
- style="width: 100%"
- v-model.trim="form.paymentSubjectId"
- placeholder="支出科目"
- size="small"
- :clearable="true"
- @change="paymentSubjectChange"
- >
- <el-option
- v-for="item in paymentSubjects"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- />
- </el-select>
- <span v-else>{{ form.paymentSubject }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="收款账户名:">
- <el-input
- v-if="editStatus"
- style="width: 100%"
- v-model.trim="form.acceptAccount"
- size="small"
- type="text"
- placeholder="收款账户名"
- :clearable="true"
- />
- <span v-else>{{ form.acceptAccount }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="收款账号:">
- <template v-if="editStatus">
- <el-input
- v-model.trim="form.acceptAccountNo"
- size="small"
- type="text"
- style="width: 100%"
- placeholder="收款账号"
- :clearable="true"
- />
- </template>
- <span v-else
- >{{ form.acceptAccountType }} -
- {{ form.acceptAccountNo }}</span
- >
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="收款账户开户银行:" label-width="120px">
- <template v-if="editStatus">
- <el-input
- v-model.trim="form.bankNo"
- size="small"
- type="text"
- style="width: 100%"
- placeholder="收款账户开户银行"
- :clearable="true"
- />
- </template>
- <span v-else>{{ form.bankNo }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="客户名称:" prop="companyName" required>
- <el-autocomplete
- v-if="editStatus"
- style="width: 100%"
- :fetch-suggestions="querySearchCompanyAsync"
- :trigger-on-focus="true"
- v-model="form.companyName"
- placeholder="请输入客户名称"
- popper-class="my-autocomplete"
- @select="handleSelectCompany"
- >
- <template #default="{ item }">
- <div
- style="
- display: flex;
- flex-direction: row;
- justify-content: space-between;
- "
- >
- <div class="name" style="font-size: 12px">
- {{ item.name }}
- </div>
- <!-- <span class="code" style="font-size: 10px; color: darkgrey">{{ item.code }}</span> -->
- </div>
- </template>
- </el-autocomplete>
- <span v-else>{{ form.companyName }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="合同编号:" required>
- <el-input
- v-if="editStatus"
- style="width: 100%"
- v-model.trim="form.contractNo"
- size="small"
- type="text"
- placeholder="请选择"
- :clearable="true"
- >
- <template #append>
- <el-button
- icon="Search"
- @click="() => contractChoiceHandler()"
- />
- </template>
- </el-input>
- <span v-else style="width: 100%">
- <el-tooltip :content="form.contractNo">
- <!-- <el-button class="text-overflow" type="primary" link @click="(showContractDialog(currentContract.contractId))">{{ currentContract.formNo }}</el-button> -->
- {{ form.contractNo }}
- </el-tooltip>
- </span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="应收款金额:" prop="remark">
- <span>{{ rowNum(form.contractAmount) }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="已支出金额:" prop="remark">
- <span>{{ rowNum(form.payedAmount) }}</span>
- </el-form-item>
- </el-col>
- <el-col :span="6">
- <el-form-item label="支出金额:" required>
- <el-input-number
- v-if="editStatus"
- v-model.trim="form.amount"
- size="small"
- readonly
- placeholder="支出金额"
- :clearable="true"
- :precision="2"
- controls-position="right"
- :controls="false"
- @change="amountChange"
- />
- <span v-else>{{ rowNum(form.amount) }}</span>
- </el-form-item>
- </el-col>
- <el-col
- v-if="form.verifyStatus === 2 || form.verifyStatus === 4"
- :span="6"
- >
- <el-form-item label="驳回原因:" required>
- <span>{{ form.verifyComment }}</span>
- </el-form-item>
- </el-col>
-
-
- <el-col :span="12">
- <el-form-item label="备注:">
- <el-input
- v-if="editStatus"
- v-model.trim="form.remark"
- size="small"
- type="text"
- placeholder="备注"
- :clearable="true"
- />
- <span v-else style="word-break: break-all">{{
- form.remark
- }}</span>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- <div class="details-container">
- <el-row :gutter="2" style="height: 100%">
- <el-col :span="18">
- <div class="details-head">
- <div class="title">
- <i class="fa fa-th-list" aria-hidden="true" /> 收款明细
- </div>
- </div>
- <div class="details-body">
- <el-table
- ref="filesTable"
- :data="form.details"
- size="small"
- height="100%"
- border
- header-row-class-name="list-header-row"
- highlight-current-row
- >
- <el-table-column
- type="index"
- label="序号"
- width="47"
- align="center"
- />
- <el-table-column
- label="任务名称"
- prop="taskTypeName"
- align="center"
- show-overflow-tooltip
- >
- </el-table-column>
- <el-table-column
- label="任务金额"
- prop="amount"
- width="100"
- align="center"
- >
- <template #default="scope">
- <span>{{ rowNum(scope.row.amount) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- label="已收款金额"
- prop="reallyAmount"
- width="100"
- align="center"
- >
- <template #default="scope">
- <span>{{ rowNum(scope.row.reallyAmount) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- label="本次支出金额"
- prop="paymentAmount"
- width="100"
- align="center"
- >
- <template #default="scope">
- <template v-if="editStatus">
- <el-input-number
- v-model="scope.row.paymentAmount"
- size="small"
- placeholder="本次支出金额"
- :precision="2"
- :controls="false"
- style="width: 100%"
- @change="
- (arg) =>
- amountChangeHandler(
- arg,
- scope.row,
- 'paymentAmount'
- )
- "
- />
- </template>
- <template v-else>{{
- rowNum(scope.row.paymentAmount)
- }}</template>
- </template>
- </el-table-column>
- <el-table-column
- label="已支付金额"
- prop="payment"
- width="100"
- align="center"
- >
- <template #default="scope">
- <span>{{ rowNum(scope.row.payment) }}</span>
- </template>
- </el-table-column>
- </el-table>
- </div>
- </el-col>
- <el-col :span="6">
- <div class="details-head">
- <div class="title">
- <i class="fa fa-th-list" aria-hidden="true" /> 附件
- <i style="color: red">*</i>
- </div>
- <el-upload
- v-if="editStatus"
- action="#"
- :http-request="upload"
- :with-credentials="true"
- :show-file-list="false"
- multiple
- >
- <el-button size="small" type="primary" icon="Upload"
- >点击上传</el-button
- >
- </el-upload>
- </div>
- <div class="details-body">
- <el-table
- ref="filesTable"
- :data="form.files"
- size="small"
- height="100%"
- border
- header-row-class-name="list-header-row"
- highlight-current-row
- >
- <el-table-column
- type="index"
- label="序号"
- width="47"
- align="center"
- />
- <el-table-column
- label="文件名"
- prop="originalFileName"
- align="center"
- show-overflow-tooltip
- >
- <template #default="scope">
- <el-button
- size="small"
- type="primary"
- link
- @click="openFile(scope.row)"
- >{{ scope.row.originalFileName }}</el-button
- >
- </template>
- </el-table-column>
- <el-table-column label="操作" width="50" align="center">
- <template #default="scope">
- <div v-if="editStatus">
- <el-button
- size="small"
- link
- type="danger"
- @click="handlerDelAttach(scope.row, scope.$index)"
- >删除</el-button
- >
- </div>
- </template>
- </el-table-column>
- </el-table>
- </div>
- </el-col>
- </el-row>
- </div>
- </div>
- </el-drawer>
- <el-dialog
- title="财务审核详情"
- v-model="rejectOpen"
- width="500px"
- append-to-body
- draggable
- :close-on-click-modal = "false"
- >
- <el-form ref="dictRef" :model="rejectForm" label-width="100" size="small">
- <el-form-item label="审核状态">
- <el-select
- v-model.trim="rejectForm.verifyStatus"
- placeholder="请选择"
- size="small"
- >
- <el-option
- v-for="i in verified"
- :key="i.value"
- :label="i.label"
- :value="i.value"
- />
- </el-select>
- </el-form-item>
- <el-form-item
- :label="rejectForm.verifyStatus == 2 ? '驳回原因' : '审核意见'"
- :prop="verifyRemark"
- >
- <el-input
- v-model.trim="rejectForm.verifyComment"
- type="textarea"
- maxlength="200"
- show-word-limit
- :rows="3"
- placeholder="请输入审核意见"
- />
- </el-form-item>
- <el-form-item label="附件" required>
- <el-upload
- action="#"
- :http-request="upload2"
- :with-credentials="true"
- :show-file-list="false"
- multiple
- :limit="5"
- >
- <el-button size="small" type="primary" icon="Upload"
- >点击上传</el-button
- >
- </el-upload>
- <el-table
- ref="dbTable"
- :data="rejectForm.evidenceFiles"
- size="small"
- border
- header-row-class-name="list-header-row"
- row-class-name="list-row"
- >
- <el-table-column
- label="文件名"
- prop="originalFileName"
- align="center"
- show-overflow-tooltip
- >
- <template #default="scope">
- <el-button
- size="small"
- type="text"
- @click="openFile(scope.row)"
- >{{
- scope.row.originalFileName == ""
- ? "打开文件"
- : scope.row.originalFileName
- }}</el-button
- >
- </template>
- </el-table-column>
- <el-table-column
- label="操作"
- width="80"
- prop="fileType"
- align="center"
- >
- <template #default="scope">
- <el-button
- size="small"
- link
- type="danger"
- @click="handlerEportFilesDel(scope.row, scope.$index)"
- >删除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </el-form-item>
- </el-form>
- <template #footer>
- <div class="dialog-footer">
- <el-button
- type="primary"
- icon="Finished"
- size="small"
- @click="verifyUpload()"
- >确 定</el-button
- >
- <el-button icon="close" size="small" @click="rejectCancel"
- >取 消</el-button
- >
- </div>
- </template>
- </el-dialog>
- <el-dialog
- title="出纳审核详情"
- v-model="cashierOpen"
- width="500px"
- append-to-body
- draggable
- >
- <el-form ref="dictRef" :model="form" label-width="100" size="small">
- <el-form-item label="审核状态">
- <el-select
- v-model.trim="cashierForm.verifyStatus"
- placeholder="请选择"
- size="small"
- >
- <el-option
- v-for="i in cashierVerified"
- :key="i.value"
- :label="i.label"
- :value="i.value"
- />
- </el-select>
- </el-form-item>
- <el-form-item label="实际支出时间" required>
- <el-date-picker
- v-model.trim="cashierForm.actuallyDate"
- size="small"
- :clearable="true"
- format="YYYY-MM-DD HH:mm:ss"
- value-format="YYYY-MM-DD HH:mm:ss"
- align="center"
- type="datetime"
- placeholder="实际付款时间"
- />
- </el-form-item>
- <!-- <el-form-item label="支出附件上传" required>
- </el-form-item> -->
- <el-form-item
- :label="cashierForm.verifyStatus == 4 ? '驳回原因' : '审核意见'"
- :prop="verifyComment"
- >
- <el-input
- v-model.trim="cashierForm.verifyComment"
- type="textarea"
- maxlength="200"
- show-word-limit
- :rows="3"
- placeholder="请输入审核意见"
- />
- </el-form-item>
- <el-form-item label="附件" required>
- <el-upload
- action="#"
- :http-request="upload3"
- :with-credentials="true"
- :show-file-list="false"
- multiple
- :limit="5"
- >
- <el-button size="small" type="primary" icon="Upload"
- >点击上传</el-button
- >
- </el-upload>
- <el-table
- ref="dbTable"
- :data="cashierForm.evidenceFiles"
- size="small"
- border
- header-row-class-name="list-header-row"
- row-class-name="list-row"
- >
- <el-table-column
- label="文件名"
- prop="originalFileName"
- align="center"
- show-overflow-tooltip
- >
- <template #default="scope">
- <el-button
- size="small"
- type="text"
- @click="openFile(scope.row)"
- >{{
- scope.row.originalFileName == ""
- ? "打开文件"
- : scope.row.originalFileName
- }}</el-button
- >
- </template>
- </el-table-column>
- <el-table-column
- label="操作"
- width="80"
- prop="fileType"
- align="center"
- >
- <template #default="scope">
- <el-button
- size="small"
- link
- type="danger"
- @click="handlerEportFilesDel(scope.row, scope.$index)"
- >删除</el-button
- >
- </template>
- </el-table-column>
- </el-table>
- </el-form-item>
- </el-form>
- <template #footer>
- <div class="dialog-footer">
- <el-button
- type="primary"
- icon="Finished"
- size="small"
- @click="cashierVerifyUpload()"
- >确 定</el-button
- >
- <el-button icon="close" size="small" @click="cashierVerifyCancel"
- >取 消</el-button
- >
- </div>
- </template>
- </el-dialog>
- <dialog-contract-choice
- ref="contractChoiceRef"
- @choice="contractChoiceHandle"
- />
- </div>
- </template>
- <script setup>
- import { uploadFile } from "@/api/tool/file";
- // import {
- // getOrder,
- // initTaskTypes,
- // addOrder,
- // updateOrder,
- // verifyOrder,
- // alterOrder,
- // dissolutionOrder,
- // } from "@/api/business/crm/contract";
- import {
- listCompany,
- getPayment,
- savePayment,
- listTypes,
- listContractDetail,
- verifyPayment,
- } from "@/api/business/financial/payment";
- import { listSource } from "@/api/settings/source";
- import { listUser } from "@/api/system/user";
- import CustomerFormCom from "@/components/CustomerFormCom";
- import DialogContractChoice from "@/views/dialog/DialogContractChoice.vue";
- import { formatDate, rowNum } from "@/utils/index";
- import { ref } from "vue";
- import useUserStore from "@/store/modules/user";
- const { proxy } = getCurrentInstance();
- const baseUrl = import.meta.env.VITE_APP_BASE_API;
- /** 父组件传参 */
- const props = defineProps({
- getList: {
- type: Function,
- default: () => {},
- },
- });
- const { getList } = toRefs(props);
- /** 字典数组区 */
- const { virtual_address } = proxy.useDict("virtual_address");
- /** 表单抽屉 页变量 */
- const title = ref("");
- const loading = ref(false);
- const multiple = ref(true);
- const visible = ref(false);
- const editStatus = ref(false);
- const sourceCategories = ref([]);
- const type = ref("");
- const rejectOpen = ref(false);
- const rejectForm = ref({});
- const cashierForm = ref({});
- const detailEmpty = {
- id: null,
- taskTypeName: "",
- taskTypeId: null,
- serviceNum: undefined,
- freeNum: undefined,
- price: undefined,
- amount: undefined,
- addressStyle: undefined,
- address: undefined,
- fictionAddressId: undefined,
- tenantId: undefined,
- province: "",
- city: "",
- district: "",
- addressStyle: 1,
- provinceId: undefined,
- processes: [],
- defaultProcesses: [],
- };
- const provinces = ref(proxy.region.getProvinces());
- provinces.value.unshift({ code: "", name: "全部" });
- const cities = ref([]);
- const districts = ref([]);
- const paymentTypes = ref([]);
- const paymentSubjects = ref([]);
- const paymentEmpty = {
- id: null,
- flowNo: "",
- paymentCauseId: null,
- paymentSubjectId: null,
- acceptAccountTypeId: null,
- subsidiaryId: null,
- subsidiary: null,
- subsidiaryName: "",
- subsidiaryBankAccount: "",
- subsidiaryBankName: "",
- companyId: null,
- companyName: "",
- amount: 0,
- verifyStatus: 0,
- acceptAccount: "",
- accountBank: "",
- applierId: useUserStore().user.userId,
- applierName: "",
- creatorName: useUserStore().user.nickName,
- details: [],
- files: [],
- };
- const isFullscreen = ref(false);
- const webHost = import.meta.env.VITE_APP_BASE_API;
- const data = reactive({
- form: {},
- rules: {
- companyName: [
- { required: true, message: "客户名称不能为空", trigger: "blur" },
- ],
- formDate: [
- { required: true, message: "支出日期不能为空", trigger: "blur" },
- ],
- },
- timeOptions: { start: "08:30", step: "00:15", end: "18:30" },
- verified: [
- {
- value: 0,
- label: "未审核",
- },
- {
- value: 1,
- label: "通过",
- },
- {
- value: 2,
- label: "驳回",
- },
- ],
- cashierVerified: [
- {
- value: 1,
- label: "未审核",
- },
- {
- value: 3,
- label: "通过",
- },
- {
- value: 4,
- label: "驳回",
- },
- ],
- cashierOpen: false,
- });
- const { form, rules, timeOptions, verified, cashierVerified, cashierOpen } =
- toRefs(data);
- /*********************** 方法区 ****************************/
- /** 打开抽屉 */
- function open(id) {
- reset();
- visible.value = true;
- editStatus.value = true;
- if (id != null) {
- getPayment(id).then((res) => {
- form.value = res.data;
- editStatus.value = false;
- paymentCauseChange(form.value.paymentCauseId);
- paymentSubjectChange(form.value.paymentSubjectId);
- });
- }
- }
- function init() {
- Promise.all([listTypes()]).then((res) => {
- paymentTypes.value = res[0].rows;
- });
- }
- /** 取消按钮 */
- function cancel() {
- visible.value = false;
- reset();
- }
- /** 表单重置 */
- function reset() {
- form.value = JSON.parse(JSON.stringify(paymentEmpty));
- paymentSubjects.value = [];
- }
- /** 全屏缩放 */
- function handleScreen() {
- const dom = document.querySelector(
- ".list-container > .el-drawer__wrapper > .el-overlay"
- );
- isFullscreen.value = !isFullscreen.value;
- dom.style.position = isFullscreen.value ? "fixed" : "absolute";
- }
- /** 提交按钮 */
- function submitForm() {
- if (form.value.contractId === 0 || form.value.contractId == null) {
- proxy.$modal.msgError("请输入合同");
- return;
- }
- if (form.value.amount == null || form.value.amount === 0) {
- proxy.$modal.msgError("请输入支出金额");
- return;
- }
- if (form.value.amount > form.value.contractAmount - form.value.payedAmount) {
- proxy.$modal.msgError("支出金额大于合同金额");
- return;
- }
- proxy.$refs["orderRef"].validate((valid) => {
- if (valid && detailValid()) {
- const formValue = form.value;
- savePayment(formValue).then((res) => {
- open(res.data.id);
- getList.value();
- });
- }
- });
- }
- function detailValid() {
- if (form.value.files.length === 0) {
- proxy.$modal.msgError("收款附件为空");
- return false;
- }
- return true;
- }
- /** 查询表单信息 */
- function getForm() {
- loading.value = true;
- getOrder(form.value.id).then((response) => {
- loading.value = false;
- form.value = response.data;
- });
- }
- function handleServiceTypeClick(tab) {
- computedService();
- }
- function verifyHandler() {
- rejectHandler();
- }
- function cashierVerifyHandler() {
- cashierOpen.value = true;
- cashierForm.value = proxy.deepClone(form.value);
- }
- function rejectHandler() {
- rejectOpen.value = true;
- rejectForm.value = proxy.deepClone(form.value);
- }
- function rejectCancel() {
- rejectOpen.value = false;
- rejectForm.value = {};
- }
- function cashierVerifyCancel() {
- cashierOpen.value = false;
- cashierForm.value = {};
- }
- function upload2(param) {
- const formData = new FormData();
- formData.append("file", param.file);
- uploadFile(formData).then((res) => {
- if (res.code === 200) {
- const file = {};
- file.fileName = res.newFileName;
- file.url = res.url;
- file.fileType =
- res.newFileName.split(".")[res.newFileName.split(".").length - 1];
- file.originalFileName = res.originalFilename;
- file.fileUrl = res.fileName;
- console.log(11212,file);
- if(rejectForm.value.evidenceFiles == null){
- rejectForm.value.evidenceFiles = [];
- }
- rejectForm.value.evidenceFiles.push(file);
- }
- });
- }
- function upload3(param) {
- const formData = new FormData();
- formData.append("file", param.file);
- uploadFile(formData).then((res) => {
- if (res.code === 200) {
- const file = {};
- file.fileName = res.newFileName;
- file.url = res.url;
- file.fileType =
- res.newFileName.split(".")[res.newFileName.split(".").length - 1];
- file.originalFileName = res.originalFilename;
- file.fileUrl = res.fileName;
- console.log(11212,file);
- if(cashierForm.value.evidenceFiles == null){
- cashierForm.value.evidenceFiles = [];
- }
- cashierForm.value.evidenceFiles.push(file);
- }
- });
- }
- function handleDelFile2(index) {
- rejectForm.value.files.splice(index, 1);
- }
- function rejectSubmitHandler() {
- if (form.value.verifyRemark === "" || form.value.verifyRemark == null) {
- proxy.$modal.msgError("请填写驳回原因");
- return;
- }
- }
- function verifyUpload() {
- if (rejectForm.value.verifyStatus === 0) {
- proxy.$modal.msgError("请选择审核结果");
- return;
- }
- if (
- rejectForm.value.verifyStatus === 2 &&
- (rejectForm.value.verifyComment == null ||
- rejectForm.value.verifyComment === "")
- ) {
- proxy.$modal.msgError("请输入审核意见");
- return;
- }
- if (
- rejectForm.value.evidenceFiles == null ||
- rejectForm.value.evidenceFiles.length === 0 || rejectForm.value.evidenceFiles.length>5
- ) {
- proxy.$modal.msgError("请上传附件并至多上传5个");
- return;
- }
- verifyPayment(rejectForm.value).then((res) => {
- open(form.value.id);
- getList.value();
- rejectCancel();
- proxy.$modal.msgSuccess("保存成功");
- });
- }
- function cashierVerifyUpload() {
- if (cashierForm.value.verifyStatus === 1) {
- proxy.$modal.msgError("请选择审核结果");
- return;
- }
- if (
- cashierForm.value.actuallyDate == null ||
- cashierForm.value.actuallyDate === ""
- ) {
- proxy.$modal.msgError("请选择支出时间");
- return;
- }
- if (
- cashierForm.value.evidenceFiles == null ||
- cashierForm.value.evidenceFiles.length === 0 || cashierForm.value.evidenceFiles.length>5
- ) {
- proxy.$modal.msgError("请上传附件并至多上传5个");
- return;
- }
- if (
- cashierForm.value.verifyStatus === 4 &&
- (cashierForm.value.verifyComment == null ||
- cashierForm.value.verifyComment === "")
- ) {
- proxy.$modal.msgError("请输入审核意见");
- return;
- }
- cashierForm.value.paymentStatus =
- cashierForm.value.verifyStatus === 3 ? 1 : 0;
- verifyPayment(cashierForm.value).then((res) => {
- open(cashierForm.value.id);
- getList.value();
- cashierVerifyCancel();
- proxy.$modal.msgSuccess("保存成功");
- });
- }
- /** 文件上传 */
- function upload(param) {
- const fileForm = new FormData();
- fileForm.append("file", param.file);
- uploadFile(fileForm).then((res) => {
- if (res.code === 200) {
- const file = {};
- file.fileName = res.newFileName;
- file.url = res.url;
- file.originalFileName = res.originalFilename;
- file.fileUrl = res.fileName;
- form.value.files.push(file);
- }
- });
- }
- function handleDelFile(index) {
- form.value.files.splice(index, 1);
- }
- function amountChangeHandler(arg, row, field) {
- computeTotalAmount();
- }
- function computeTotalAmount() {
- let amount = 0;
- for (let index = 0; index < form.value.details.length; index++) {
- const element = form.value.details[index];
- amount += element.paymentAmount == null ? 0 : element.paymentAmount;
- }
- form.value.amount = amount;
- }
- function handlerEportFilesDel(row, index) {
- proxy.$modal
- .confirm("确定删除吗?")
- .then((_) => {
- rejectForm.value.evidenceFiles.splice(index, 1);
- })
- .catch((_) => {
- proxy.$modal.msg("已取消删除");
- });
- }
- function handlerEportFilesDel2(row, index) {
- proxy.$modal
- .confirm("确定删除吗?")
- .then((_) => {
- cashierForm.value.evidenceFiles.splice(index, 1);
- })
- .catch((_) => {
- proxy.$modal.msg("已取消删除");
- });
- }
- function amountChange() {
- let amount = 0;
- if (form.value.details.length > 0) {
- for (let i = 0; i < form.value.details.length; i++) {
- amount = amount + form.value.details[i].paymentAmount;
- }
- // 判断到款状态
- form.value.amount = amount;
- if (form.value.payedAmount > 0)
- form.value.arriveStatus =
- form.value.payedAmount === form.value.amount ? 1 : 2;
- else form.value.arriveStatus = 0;
- }
- }
- function openFile(row) {
- window.open(`${baseUrl}${row.fileUrl}`);
- }
- function querySearchCompanyAsync(queryString, cb) {
- const query =
- queryString.length > 0
- ? {
- keyword: queryString,
- pageSize: 50,
- pageNum: 1,
- orderByColumn: "create_time",
- }
- : { pageSize: 50, pageNum: 1, orderByColumn: "create_time" };
- listCompany(query).then((res) => {
- cb(res.rows);
- });
- }
- function handleSelectCompany(item) {
- form.value.companyName = item.name;
- form.value.companyId = item.id;
- }
- function paymentCauseChange(arg) {
- const index = paymentTypes.value.findIndex((v) => v.id === arg);
- if (index >= 0) {
- paymentSubjects.value = [{ id: "0", name: "请选择" }].concat(
- paymentTypes.value[index].bizPaymentSubjectList
- );
- form.value.paymentCause = paymentTypes.value[index].name;
- if (
- paymentSubjects.value.findIndex(
- (v) => v.id === form.value.paymentSubjectId
- ) < 0
- ) {
- form.value.paymentSubjectId = null;
- form.value.paymentSubject = "";
- }
- }
- }
- function contractChoiceHandler() {
- if (form.value.companyId == null || form.value.companyId === "") {
- proxy.$modal.msgError("请选择客户");
- return;
- }
- proxy.$refs.contractChoiceRef.open({ companyId: form.value.companyId });
- }
- function contractChoiceHandle(info) {
- form.value.details = []
- form.value.contractId = info.id;
- form.value.contractNo = info.contractNo;
- form.value.contractAmount = info.trueAmount;
- form.value.payedAmount = info.paidAmount;
- listContractDetail({ contractId: info.id }).then((res) => {
- const rows = res.rows;
- rows.forEach((item) => {
- const detail = {
- contractId: item.contractId,
- contractDetailId: item.id,
- companyId: form.value.companyId,
- taskTypeId: item.taskTypeId,
- amount: item.amount,
- taskTypeName: item.taskTypeName,
- payment: item.payment,
- reallyAmount:item.reallyAmount,
- };
- form.value.details.push(detail);
- });
- });
- }
- function handlerDelAttach(row, index) {
- proxy.$modal
- .confirm("确认删除该项么?")
- .then((_) => {
- form.value.files.splice(index, 1);
- })
- .catch((err) => {
- proxy.$modal.msgError("取消删除");
- });
- }
- function paymentSubjectChange(id) {
- const index = paymentSubjects.value.findIndex((v) => v.id === id);
- if (index >= 0) {
- form.value.paymentSubjectId = paymentSubjects.value[index].id;
- }
- }
- function checkPermission(templatePermission) {
- const all_permission = "*:*:*";
- const permissions = useUserStore().permissions;
- const hasPermissions = permissions.some((permission) => {
- return (
- all_permission === permission || templatePermission.includes(permission)
- );
- });
- return hasPermissions;
- }
- init();
- /** 暴露给父组件的方法 */
- defineExpose({
- open,
- });
- </script>
|