更新财务相关功能
This commit is contained in:
parent
fc748d6f6a
commit
7fac744129
@ -37,7 +37,7 @@ export function setTicketsVoid(data){
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// 结算
|
// 收款
|
||||||
export function setTicketsPaid(data){
|
export function setTicketsPaid(data){
|
||||||
return request({
|
return request({
|
||||||
url: preUrl + "/paid",
|
url: preUrl + "/paid",
|
||||||
@ -46,6 +46,31 @@ export function setTicketsPaid(data){
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 结算
|
||||||
|
export function setTicketsSettlement(data){
|
||||||
|
return request({
|
||||||
|
url: preUrl + "/settlement",
|
||||||
|
method: 'post',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 结算审核
|
||||||
|
export function settlementReview(data){
|
||||||
|
return request({
|
||||||
|
url: preUrl + "/settlementReview",
|
||||||
|
method: 'post',
|
||||||
|
data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// 查询审批金额
|
||||||
|
export function getSettlement(data){
|
||||||
|
return request({
|
||||||
|
url: preUrl + "/getSettlement",
|
||||||
|
method: 'GET',
|
||||||
|
params: data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
export function print(id) {
|
export function print(id) {
|
||||||
return request({
|
return request({
|
||||||
|
|||||||
@ -114,14 +114,21 @@ export default {
|
|||||||
async getPage() {
|
async getPage() {
|
||||||
switch (this.TicketType) {
|
switch (this.TicketType) {
|
||||||
case "tu":
|
case "tu":
|
||||||
this.queryParams.ticketsStatus = "01"
|
// this.queryParams.ticketsStatus = "01"
|
||||||
|
this.queryParams.payStatus = "02"
|
||||||
break
|
break
|
||||||
case "tp":
|
case "tp":
|
||||||
this.queryParams.ticketsStatus = "02"
|
// this.queryParams.ticketsStatus = "02"
|
||||||
|
this.queryParams.payStatus = "03"
|
||||||
break
|
break
|
||||||
case "tv":
|
case "tv":
|
||||||
|
// this.queryParams.ticketsStatus = "03"
|
||||||
this.queryParams.ticketsStatus = "03"
|
this.queryParams.ticketsStatus = "03"
|
||||||
break
|
break
|
||||||
|
case "ts":
|
||||||
|
// this.queryParams.ticketsStatus = "04"
|
||||||
|
this.queryParams.payStatus = "01"
|
||||||
|
break
|
||||||
default:
|
default:
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|||||||
@ -110,8 +110,16 @@
|
|||||||
</el-button>
|
</el-button>
|
||||||
<el-button v-hasPermi="['repair:tk:paid']" size="mini" type="text" icon="el-icon-finished"
|
<el-button v-hasPermi="['repair:tk:paid']" size="mini" type="text" icon="el-icon-finished"
|
||||||
@click="handlePaid(scope.row)" v-if="TicketType === 'tu'"
|
@click="handlePaid(scope.row)" v-if="TicketType === 'tu'"
|
||||||
|
>收款
|
||||||
|
</el-button>
|
||||||
|
<el-button v-hasPermi="['repair:tk:settlement']" size="mini" type="text" icon="el-icon-finished"
|
||||||
|
@click="handleSettlement(scope.row,'js')" v-if="TicketType === 'ts' && !scope.row.settlement"
|
||||||
>结算
|
>结算
|
||||||
</el-button>
|
</el-button>
|
||||||
|
<el-button v-hasPermi="['repair:tk:settlement']" size="mini" type="text" icon="el-icon-finished"
|
||||||
|
@click="handleSettlement(scope.row,'jssh')" v-if="TicketType === 'ts' && scope.row.settlement"
|
||||||
|
>结算审核
|
||||||
|
</el-button>
|
||||||
<!-- <el-button v-if="TicketType === 'tp'" size="mini" type="text" icon="el-icon-refresh-right"-->
|
<!-- <el-button v-if="TicketType === 'tp'" size="mini" type="text" icon="el-icon-refresh-right"-->
|
||||||
<!-- >返结-->
|
<!-- >返结-->
|
||||||
<!-- </el-button>-->
|
<!-- </el-button>-->
|
||||||
@ -126,7 +134,8 @@
|
|||||||
<!-- <el-button size="mini" v-hasPermi="['repair:tk:edit']" type="text" icon="el-icon-setting" @click="handleEditTicket(scope.row)">-->
|
<!-- <el-button size="mini" v-hasPermi="['repair:tk:edit']" type="text" icon="el-icon-setting" @click="handleEditTicket(scope.row)">-->
|
||||||
<!-- 编辑工单-->
|
<!-- 编辑工单-->
|
||||||
<!-- </el-button>-->
|
<!-- </el-button>-->
|
||||||
<el-button size="mini" v-hasPermi="['repair:tk:remove']" type="text" icon="el-icon-remove" @click="handleRemove(scope.row)">
|
<el-button size="mini" v-hasPermi="['repair:tk:remove']" type="text" icon="el-icon-remove"
|
||||||
|
@click="handleRemove(scope.row)">
|
||||||
删除
|
删除
|
||||||
</el-button>
|
</el-button>
|
||||||
</template>
|
</template>
|
||||||
@ -157,21 +166,58 @@
|
|||||||
<TicketsShow ref="ticketsShow"/>
|
<TicketsShow ref="ticketsShow"/>
|
||||||
<EditTickets ref="editTicket" @success="returnSuccess"/>
|
<EditTickets ref="editTicket" @success="returnSuccess"/>
|
||||||
|
|
||||||
<el-dialog title="结算信息" :visible.sync="dialogVisible" width="40%" v-dialogDrag append-to-body>
|
<el-dialog title="收款信息" :visible.sync="dialogVisible" width="40%" v-dialogDrag append-to-body>
|
||||||
|
<el-form :model="settlementFormData" ref="formRefSettlement" :inline="true" label-width="10rem"
|
||||||
|
:rules="settlementFormRules">
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="金额" prop="payType">
|
||||||
|
<el-input disabled v-model="settlementFormData.money"></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="优惠类型" prop="payType">
|
||||||
|
<el-radio-group disabled v-model="settlementFormData.discountType" @change="jisuan">
|
||||||
|
<el-radio :label="item.value" :key="item.value" v-for="item in discountTypeList">{{ item.label }}
|
||||||
|
</el-radio>
|
||||||
|
</el-radio-group>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="优惠" prop="payType">
|
||||||
|
<el-input-number disabled v-model="settlementFormData.discount" @change="jisuan"></el-input-number>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="实付金额" prop="payType">
|
||||||
|
<el-input disabled v-model="settlementFormData.actualMoney"></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
|
||||||
|
</el-form>
|
||||||
<el-form :model="formData" ref="formRef" :inline="true" label-width="10rem" :rules="formRules">
|
<el-form :model="formData" ref="formRef" :inline="true" label-width="10rem" :rules="formRules">
|
||||||
<el-row :gutter="1">
|
<el-row :gutter="1">
|
||||||
<el-col :span="24">
|
<el-col :span="24">
|
||||||
<el-form-item label="结算方法" prop="payType">
|
<el-form-item label="收款方法" prop="payType">
|
||||||
<el-select v-model="formData.payType">
|
<el-select v-model="formData.payType">
|
||||||
<el-option v-for="item in this.getDictDataByCode(DICT_TYPE.REPAIR_PAY_TYPE)" :key="item.value" :label="item.label" :value="item.value" />
|
<el-option v-for="item in this.getDictDataByCode(DICT_TYPE.REPAIR_PAY_TYPE)" :key="item.value"
|
||||||
|
:label="item.label" :value="item.value"/>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
<el-row :gutter="1">
|
<el-row :gutter="1">
|
||||||
<el-col :span="24">
|
<el-col :span="24">
|
||||||
<el-form-item label="结算备注" prop="remark">
|
<el-form-item label="收款备注" prop="remark">
|
||||||
<el-input style="width:30rem" type="textarea" v-model="formData.remark" :autosize="{ minRows: 4, maxRows: 8}"/>
|
<el-input style="width:30rem" type="textarea" v-model="formData.remark"
|
||||||
|
:autosize="{ minRows: 4, maxRows: 8}"/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
@ -181,11 +227,67 @@
|
|||||||
<el-button @click="dialogVisible = false">取 消</el-button>
|
<el-button @click="dialogVisible = false">取 消</el-button>
|
||||||
</div>
|
</div>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
|
|
||||||
|
<el-dialog :title="settlementType === 'jssh' ? '结算审核': '结算信息'" :visible.sync="dialogVisibleSettlement"
|
||||||
|
width="40%" v-dialogDrag append-to-body>
|
||||||
|
<el-form :model="settlementFormData" ref="formRefSettlement" :inline="true" label-width="10rem"
|
||||||
|
:rules="settlementFormRules">
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="金额" prop="payType">
|
||||||
|
<el-input disabled v-model="settlementFormData.money"></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="优惠类型" prop="payType">
|
||||||
|
<el-radio-group v-model="settlementFormData.discountType" @change="jisuan">
|
||||||
|
<el-radio :label="item.value" :key="item.value" v-for="item in discountTypeList">{{ item.label }}
|
||||||
|
</el-radio>
|
||||||
|
</el-radio-group>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="优惠" prop="payType">
|
||||||
|
<el-input-number v-model="settlementFormData.discount" @change="jisuan"></el-input-number>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<el-row :gutter="1">
|
||||||
|
<el-col :span="24">
|
||||||
|
<el-form-item label="实付金额" prop="payType">
|
||||||
|
<el-input v-model="settlementFormData.actualMoney"></el-input>
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
<!-- <el-row :gutter="1">-->
|
||||||
|
<!-- <el-col :span="24">-->
|
||||||
|
<!-- <el-form-item label="结算备注" prop="remark">-->
|
||||||
|
<!-- <el-input style="width:30rem" type="textarea" v-model="formData.remark"-->
|
||||||
|
<!-- :autosize="{ minRows: 4, maxRows: 8}"/>-->
|
||||||
|
<!-- </el-form-item>-->
|
||||||
|
<!-- </el-col>-->
|
||||||
|
<!-- </el-row>-->
|
||||||
|
</el-form>
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="doSettlement">确 定</el-button>
|
||||||
|
<el-button @click="dialogVisibleSettlement = false">取 消</el-button>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import {setTicketsVoid, setTicketsPaid, setTicketsPrint, removeTicketById} from '@/api/repair/tickets/Tickets'
|
import {
|
||||||
|
setTicketsVoid,
|
||||||
|
setTicketsPaid,
|
||||||
|
setTicketsPrint,
|
||||||
|
removeTicketById,
|
||||||
|
setTicketsSettlement, settlementReview, getSettlement
|
||||||
|
} from '@/api/repair/tickets/Tickets'
|
||||||
import TicketsShow from "@/views/repair/tickets/Components/TicketsShow.vue";
|
import TicketsShow from "@/views/repair/tickets/Components/TicketsShow.vue";
|
||||||
import {getByNameAndMobile} from "@/api/base/customer";
|
import {getByNameAndMobile} from "@/api/base/customer";
|
||||||
import EditTickets from "@/views/repair/tickets/form/EditTickets.vue";
|
import EditTickets from "@/views/repair/tickets/form/EditTickets.vue";
|
||||||
@ -205,6 +307,10 @@ export default {
|
|||||||
},
|
},
|
||||||
isWXCW: {
|
isWXCW: {
|
||||||
type: Boolean
|
type: Boolean
|
||||||
|
},
|
||||||
|
defaultDiscountType: {
|
||||||
|
type: [Number, String],
|
||||||
|
default: '1'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
@ -216,11 +322,32 @@ export default {
|
|||||||
billingRemark: null,
|
billingRemark: null,
|
||||||
payType: null
|
payType: null
|
||||||
},
|
},
|
||||||
|
settlementFormData: {
|
||||||
|
actualMoney: 0,
|
||||||
|
discountType: this.defaultDiscountType,
|
||||||
|
discount: 0
|
||||||
|
},
|
||||||
formRules: {
|
formRules: {
|
||||||
payType: [{required: true, message: '支付方式不能为空', trigger: 'blur'}]
|
payType: [{required: true, message: '支付方式不能为空', trigger: 'blur'}]
|
||||||
},
|
},
|
||||||
|
settlementFormRules: {
|
||||||
|
discountType: [{required: true, message: '优惠类型不能为空', trigger: 'blur'}],
|
||||||
|
discount: [{required: true, message: '优惠不能为空', trigger: 'blur'}]
|
||||||
|
},
|
||||||
dialogVisible: false,
|
dialogVisible: false,
|
||||||
isHangAccount: false
|
dialogVisibleSettlement: false,
|
||||||
|
isHangAccount: false,
|
||||||
|
settlementType: null,
|
||||||
|
discountTypeList: [
|
||||||
|
{
|
||||||
|
label: '金额',
|
||||||
|
value: '1'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: '折扣',
|
||||||
|
value: '2'
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
@ -262,7 +389,19 @@ export default {
|
|||||||
} catch {
|
} catch {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
jisuan() {
|
||||||
|
// 根据优惠类型计算
|
||||||
|
if (this.settlementFormData.discountType === '1') {
|
||||||
|
this.settlementFormData.actualMoney = this.settlementFormData.money - this.settlementFormData.discount
|
||||||
|
} else if (this.settlementFormData.discountType === '2') {
|
||||||
|
// 保留小数点后两位
|
||||||
|
this.settlementFormData.actualMoney = this.settlementFormData.money * (1 - this.settlementFormData.discount / 100)
|
||||||
|
this.settlementFormData.actualMoney = parseFloat(this.settlementFormData.actualMoney).toFixed(2)
|
||||||
|
}
|
||||||
|
console.log(this.settlementFormData)
|
||||||
|
},
|
||||||
|
|
||||||
|
//收款
|
||||||
handlePaid(row) {
|
handlePaid(row) {
|
||||||
this.formData = {
|
this.formData = {
|
||||||
id: null,
|
id: null,
|
||||||
@ -274,6 +413,26 @@ export default {
|
|||||||
this.formData['ticketsStatus'] = '02'
|
this.formData['ticketsStatus'] = '02'
|
||||||
this.dialogVisible = true
|
this.dialogVisible = true
|
||||||
this.checkIsHangAccount(row)
|
this.checkIsHangAccount(row)
|
||||||
|
this.getSettlement(row)
|
||||||
|
},
|
||||||
|
|
||||||
|
//结算
|
||||||
|
handleSettlement(row, type) {
|
||||||
|
this.settlementType = type
|
||||||
|
if (type == 'js') {
|
||||||
|
this.settlementFormData = {
|
||||||
|
ticketId: row.id,
|
||||||
|
money: row.totalPrice,
|
||||||
|
actualMoney: row.totalPrice,
|
||||||
|
discountType: this.defaultDiscountType, // 加上这一行
|
||||||
|
discount: 0 // 加上这一行
|
||||||
|
}
|
||||||
|
} else if (type === 'jssh') {
|
||||||
|
this.settlementFormData = row.settlement
|
||||||
|
this.settlementFormData['ticketId'] = row.id
|
||||||
|
}
|
||||||
|
this.dialogVisibleSettlement = true
|
||||||
|
|
||||||
},
|
},
|
||||||
async checkIsHangAccount(row) {
|
async checkIsHangAccount(row) {
|
||||||
const data = {
|
const data = {
|
||||||
@ -282,6 +441,23 @@ export default {
|
|||||||
const res = await getByNameAndMobile(data)
|
const res = await getByNameAndMobile(data)
|
||||||
this.isHangAccount = res.data.isHangAccount === '1'
|
this.isHangAccount = res.data.isHangAccount === '1'
|
||||||
},
|
},
|
||||||
|
async getSettlement(row) {
|
||||||
|
const data = {
|
||||||
|
id: row.id
|
||||||
|
}
|
||||||
|
const res = await getSettlement(data)
|
||||||
|
if (res.data) {
|
||||||
|
this.settlementFormData = res.data
|
||||||
|
}else {
|
||||||
|
this.settlementFormData = {
|
||||||
|
ticketId: null,
|
||||||
|
money: null,
|
||||||
|
actualMoney: null,
|
||||||
|
discountType: null,
|
||||||
|
discount: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
async doPaid() {
|
async doPaid() {
|
||||||
try {
|
try {
|
||||||
await this.$refs['formRef'].validate()
|
await this.$refs['formRef'].validate()
|
||||||
@ -289,7 +465,22 @@ export default {
|
|||||||
this.$modal.msgSuccess(this.formData.payType === '01' ? "等待客户支付" : "结算成功")
|
this.$modal.msgSuccess(this.formData.payType === '01' ? "等待客户支付" : "结算成功")
|
||||||
this.dialogVisible = false
|
this.dialogVisible = false
|
||||||
this.$emit("setVoid")
|
this.$emit("setVoid")
|
||||||
}catch{}
|
} catch {
|
||||||
|
}
|
||||||
|
},
|
||||||
|
async doSettlement() {
|
||||||
|
try {
|
||||||
|
await this.$refs['formRefSettlement'].validate()
|
||||||
|
if (this.settlementType === 'jssh') {
|
||||||
|
await settlementReview(this.settlementFormData)
|
||||||
|
} else {
|
||||||
|
await setTicketsSettlement(this.settlementFormData)
|
||||||
|
}
|
||||||
|
this.$modal.msgSuccess("提交成功")
|
||||||
|
this.dialogVisibleSettlement = false
|
||||||
|
this.$emit("setVoid")
|
||||||
|
} catch {
|
||||||
|
}
|
||||||
},
|
},
|
||||||
getDictDataByCode(code) {
|
getDictDataByCode(code) {
|
||||||
const data = this.getDictDatas(code);
|
const data = this.getDictDatas(code);
|
||||||
@ -314,7 +505,8 @@ export default {
|
|||||||
await this.listTickets()
|
await this.listTickets()
|
||||||
this.$modal.msgSuccess("删除成功")
|
this.$modal.msgSuccess("删除成功")
|
||||||
}
|
}
|
||||||
}catch{}
|
} catch {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
22
src/views/repair/tickets/SettlementTicket.vue
Normal file
22
src/views/repair/tickets/SettlementTicket.vue
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<TicketSearch :ticket-type="'ts'"/>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
import TicketSearch from "@/views/repair/tickets/Components/TicketSearch.vue";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: "UnpaidTicket",
|
||||||
|
components: {TicketSearch},
|
||||||
|
data() {
|
||||||
|
return {}
|
||||||
|
},
|
||||||
|
methods: {}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped lang="scss">
|
||||||
|
|
||||||
|
</style>
|
||||||
Loading…
Reference in New Issue
Block a user