刘翔宇-旅管家 4 years ago
parent 4d93802cee
commit 39ca7ee65e

@ -176,6 +176,7 @@
</template> </template>
<script> <script>
import { MessageBox } from 'element-ui';
import { import {
addContractSign, addContractSign,
getContractSign, getContractSign,
@ -325,6 +326,15 @@
methods: { methods: {
// //
sign() { sign() {
console.log(this.signList)
console.log(this.signList.length)
if (this.signList.length == 0) {
Message({
type: 'error',
message: '该项目未设置付款计划,请设置付款计划后保存'
})
return false;
}
editorContract({ editorContract({
id: this.contractId, id: this.contractId,
@ -384,6 +394,7 @@
}, },
submit() { submit() {
console.log(this.planForm) console.log(this.planForm)
addContractSign({ addContractSign({
contract_id: this.contract.id, contract_id: this.contract.id,
date: `${new Date(this.planForm.date).getFullYear()}-${new Date(this.planForm.date).getMonth()+1}-${new Date(this.planForm.date).getDate()}`, date: `${new Date(this.planForm.date).getFullYear()}-${new Date(this.planForm.date).getMonth()+1}-${new Date(this.planForm.date).getDate()}`,

@ -2,15 +2,21 @@
<div v-if="registration"> <div v-if="registration">
<xy-dialog title="打印预览" :is-show.sync="isShow" :width="70" @on-ok="print" ok-text=""> <xy-dialog title="打印预览" :is-show.sync="isShow" :width="70" @on-ok="print" ok-text="">
<template v-slot:normalContent> <template v-slot:normalContent>
<div class="print-table1" id="printtable1" ref="printtable"> <div class="print-table1" id="printtable1" ref="printtable">
<div class="print-table1-title">苏州市河道管理处资金划拨审批单</div> <div class="print-table1-title">苏州市河道管理处资金划拨审批单</div>
<div class="print-table1-grid"> <div class="print-table1-grid">
<div style="grid-area: tb1-1" class="print-table1-grid-top">项目名称<span style="font-weight: 600">{{registration.contract.name}}</span></div> <div style="grid-area: tb1-1" class="print-table1-grid-top">项目名称<span
<div style="grid-area: tb1-2;justify-content: center;align-items: center;flex-direction: column;" > style="font-weight: 600">{{registration.contract.name}}</span></div>
<div>本次为第 <span style="font-weight: 600;padding: 0 1vw;">{{payIndex}}</span> 次付款</div> <div>{{registration.remark}}</div></div> <div style="grid-area: tb1-2;justify-content: center;align-items: center;flex-direction: column;">
<div style="grid-area: tb2-1" class="print-table1-grid-top">承包商/供货商<span style="font-weight: 600">{{registration.contract.supply}}</span></div> <div>本次为第 <span style="font-weight: 600;padding: 0 1vw;">{{payIndex}}</span> 次付款</div>
<div style="grid-area: tb2-2" class="print-table1-grid-top">合同服务时间<span style="font-weight: 600">{{registration.contract.start_date}} - {{registration.contract.end_date}}</span></div> <div>{{registration.remark}}</div>
</div>
<div style="grid-area: tb2-1" class="print-table1-grid-top">承包商/供货商<span
style="font-weight: 600">{{registration.contract.supply}}</span></div>
<div style="grid-area: tb2-2" class="print-table1-grid-top">合同服务时间<span
style="font-weight: 600">{{registration.contract.start_date}} -
{{registration.contract.end_date}}</span></div>
<div style="grid-area: tb3-1" class="print-table1-grid-title1">付款情形</div> <div style="grid-area: tb3-1" class="print-table1-grid-title1">付款情形</div>
<div style="grid-area: tb3-2" class="print-table1-grid-title1">金额单位</div> <div style="grid-area: tb3-2" class="print-table1-grid-title1">金额单位</div>
@ -18,7 +24,8 @@
<div style="grid-area: tb4-1" class="print-table1-grid-center">A</div> <div style="grid-area: tb4-1" class="print-table1-grid-center">A</div>
<div style="grid-area: tb4-2" class="print-table1-grid-center">合同金额</div> <div style="grid-area: tb4-2" class="print-table1-grid-center">合同金额</div>
<div style="grid-area: tb4-3" class="print-table1-grid-center">{{priceFormat(registration.contract.money)}}</div> <div style="grid-area: tb4-3" class="print-table1-grid-center">{{priceFormat(registration.contract.money)}}
</div>
<div style="grid-area: tb4-4"></div> <div style="grid-area: tb4-4"></div>
<div style="grid-area: tb5-1" class="print-table1-grid-center">B</div> <div style="grid-area: tb5-1" class="print-table1-grid-center">B</div>
<div style="grid-area: tb5-2" class="print-table1-grid-center">审计金额</div> <div style="grid-area: tb5-2" class="print-table1-grid-center">审计金额</div>
@ -26,15 +33,18 @@
<div style="grid-area: tb5-4"></div> <div style="grid-area: tb5-4"></div>
<div style="grid-area: tb6-1" class="print-table1-grid-center">C</div> <div style="grid-area: tb6-1" class="print-table1-grid-center">C</div>
<div style="grid-area: tb6-2" class="print-table1-grid-center">前期累计已支付</div> <div style="grid-area: tb6-2" class="print-table1-grid-center">前期累计已支付</div>
<div style="grid-area: tb6-3" class="print-table1-grid-center">{{priceFormat(registration.total_act_money)}}</div> <div style="grid-area: tb6-3" class="print-table1-grid-center">{{priceFormat(registration.total_act_money)}}
</div>
<div style="grid-area: tb6-4"></div> <div style="grid-area: tb6-4"></div>
<div style="grid-area: tb7-1" class="print-table1-grid-center">D</div> <div style="grid-area: tb7-1" class="print-table1-grid-center">D</div>
<div style="grid-area: tb7-2" class="print-table1-grid-center">本期扣款</div> <div style="grid-area: tb7-2" class="print-table1-grid-center">本期扣款</div>
<div style="grid-area: tb7-3" class="print-table1-grid-center">{{priceFormat(registration.discount_money)}}</div> <div style="grid-area: tb7-3" class="print-table1-grid-center">{{priceFormat(registration.discount_money)}}
</div>
<div style="grid-area: tb7-4"></div> <div style="grid-area: tb7-4"></div>
<div style="grid-area: tb8-1" class="print-table1-grid-center">E</div> <div style="grid-area: tb8-1" class="print-table1-grid-center">E</div>
<div style="grid-area: tb8-2;font-weight: 600" class="print-table1-grid-center">本期应付款</div> <div style="grid-area: tb8-2;font-weight: 600" class="print-table1-grid-center">本期应付款</div>
<div style="grid-area: tb8-3;font-weight: 600" class="print-table1-grid-center">{{priceFormat(registration.apply_money)}}</div> <div style="grid-area: tb8-3;font-weight: 600" class="print-table1-grid-center">
{{priceFormat(registration.apply_money)}}</div>
<div style="grid-area: tb8-4;padding-left: 0.6vw;display: block;"> <div style="grid-area: tb8-4;padding-left: 0.6vw;display: block;">
<div style="display: flex;align-items: center;"> <div style="display: flex;align-items: center;">
<div><span v-if="registration.type == '进度款'"></span></div> <div><span v-if="registration.type == '进度款'"></span></div>
@ -42,23 +52,29 @@
</div> </div>
<div style="display: flex;align-items: center;"> <div style="display: flex;align-items: center;">
<div><span v-if="registration.type == '质保金'"></span></div> <div><span v-if="registration.type == '质保金'"></span></div>
<div style="height: 1.8vw;min-width: 6vw;border-bottom: 2px #000 solid;margin-left: 2vw;font-size: 15px;"> <div
<span v-if="registration.type!='进度款'&&registration.type!='质保金'&&registration.type!='结算款'"> {{registration.type}} </span> style="height: 1.8vw;min-width: 6vw;border-bottom: 2px #000 solid;margin-left: 2vw;font-size: 15px;">
<span v-if="registration.type!='进度款'&&registration.type!='质保金'&&registration.type!='结算款'">
{{registration.type}} </span>
</div> </div>
<div>其他</div> <div>其他</div>
</div> </div>
</div> </div>
<div style="grid-area: tb9-1" class="print-table1-grid-center">F</div> <div style="grid-area: tb9-1" class="print-table1-grid-center">F</div>
<div style="grid-area: tb9-2" class="print-table1-grid-center">累计支付</div> <div style="grid-area: tb9-2" class="print-table1-grid-center">累计支付</div>
<div style="grid-area: tb9-3" class="print-table1-grid-center">{{priceFormat(Number(registration.total_act_money)+Number(registration.apply_money))}}</div> <div style="grid-area: tb9-3" class="print-table1-grid-center">
{{priceFormat(Number(registration.total_act_money)+Number(registration.apply_money))}}</div>
<div style="grid-area: tb9-4"></div> <div style="grid-area: tb9-4"></div>
<div style="grid-area: tb10-1" class="print-table1-grid-center">G</div> <div style="grid-area: tb10-1" class="print-table1-grid-center">G</div>
<div style="grid-area: tb10-2" class="print-table1-grid-center">累计扣款</div> <div style="grid-area: tb10-2" class="print-table1-grid-center">累计扣款</div>
<div style="grid-area: tb10-3" class="print-table1-grid-center">{{priceFormat(Number(registration.total_discount_money)+Number(registration.discount_money))}}</div> <div style="grid-area: tb10-3" class="print-table1-grid-center">
{{priceFormat(Number(registration.total_discount_money)+Number(registration.discount_money))}}</div>
<div style="grid-area: tb10-4"></div> <div style="grid-area: tb10-4"></div>
<div style="grid-area: tb11-1" class="print-table1-grid-center">H</div> <div style="grid-area: tb11-1" class="print-table1-grid-center">H</div>
<div style="grid-area: tb11-2" class="print-table1-grid-center">质保金</div> <div style="grid-area: tb11-2" class="print-table1-grid-center">质保金</div>
<div style="grid-area: tb11-3;align-items: center;">{{guaranteeRate(registration.contract.guarantee_money,registration.contract.money)}}%质保期{{registration.contract.guarantee_year}}需审计的以审计价为计费依据</div> <div style="grid-area: tb11-3;align-items: center;">
{{guaranteeRate(registration.contract.guarantee_money,registration.contract.money)}}%质保期{{registration.contract.guarantee_year}}需审计的以审计价为计费依据
</div>
<div style="grid-area: tb12" class="print-table1-grid-bottom1"> <div style="grid-area: tb12" class="print-table1-grid-bottom1">
资金列支渠道{{moneyWayFormat(registration.money_way_detail)}} 资金列支渠道{{moneyWayFormat(registration.money_way_detail)}}
@ -77,7 +93,8 @@
<div style="grid-area: tb14-3;" class="print-table1-grid-bottom3">单位负责人</div> <div style="grid-area: tb14-3;" class="print-table1-grid-bottom3">单位负责人</div>
</div> </div>
<div style="text-align: right;padding-top: 0.3vw;font-size: 1.5vw;">打印时间{{new Date().getFullYear()}}.{{new Date().getMonth()+1}}.{{new Date().getDate()}}</div> <div style="text-align: right;padding-top: 0.3vw;font-size: 1.5vw;">
打印时间{{new Date().getFullYear()}}.{{new Date().getMonth()+1}}.{{new Date().getDate()}}</div>
</div> </div>
</template> </template>
</xy-dialog> </xy-dialog>
@ -86,158 +103,175 @@
</template> </template>
<script> <script>
import {detailFundLog,getFundLog} from "@/api/paymentRegistration/fundLog" import {
detailFundLog,
import html2canvas from 'html2canvas' getFundLog
import * as printJS from "print-js"; } from "@/api/paymentRegistration/fundLog"
import {parseTime,moneyRecovery} from "@/utils";
import html2canvas from 'html2canvas'
export default { import * as printJS from "print-js";
data() { import {
return { parseTime,
isShow:false, moneyRecovery
registration:null, } from "@/utils";
beforeTotalMoney:0,
payIndex:1, export default {
} data() {
}, return {
methods: { isShow: false,
moneyWayFormat(arr){ registration: null,
let res = arr.map(item => { beforeTotalMoney: 0,
return item.value payIndex: 1,
}) }
return res.toString()
},
guaranteeRate(gua,money){
if(gua && money) return ((moneyRecovery(gua) / money) * 100).toFixed(2)
}, },
methods: {
moneyWayFormat(arr) {
let res = arr.map(item => {
return item.value
})
return res.toString()
},
guaranteeRate(gua, money) {
if (gua && money) return ((moneyRecovery(gua) / money) * 100).toFixed(2)
},
async getDetailFundLog(id){ async getDetailFundLog(id) {
let res = await detailFundLog({id}) let res = await detailFundLog({
this.registration = res id
let res1 = await getFundLog({contract_id:this.registration.contract.id})
if(res1.data.length>0){
res1.data.map(item => {
this.beforeTotalMoney += Number(item.act_money)
}) })
this.beforeTotalMoney -= Number(this.registration.act_money) this.registration = res
}else{ let res1 = await getFundLog({
this.beforeTotalMoney = 0 page_size: 999,
} contract_id: this.registration.contract.id
})
if (res1.data.length > 0) {
res1.data.map(item => {
this.beforeTotalMoney += Number(item.act_money)
})
this.beforeTotalMoney -= Number(this.registration.act_money)
} else {
this.beforeTotalMoney = 0
}
let nowIndex = res?.id let nowIndex = res?.id
let idList = res1.data.map(item => { let idList = res1.data.map(item => {
return item.id return item.id
}) })
// //
idList.sort((a, b) => { idList.sort((a, b) => {
return a - b; return a - b;
}) })
console.log("nowIndex",nowIndex) console.log("nowIndex", nowIndex)
console.log("idList",idList) console.log("idList", idList)
this.payIndex = idList.indexOf(nowIndex)+1 this.payIndex = idList.indexOf(nowIndex) + 1
}, },
async print(){ async print() {
let canvas = await html2canvas(this.$refs['printtable'],{ let canvas = await html2canvas(this.$refs['printtable'], {
backgroundColor:null, backgroundColor: null,
useCORS: true, useCORS: true,
}) })
printJS({ printJS({
printable: canvas.toDataURL(), printable: canvas.toDataURL(),
type: 'image', type: 'image',
documentTitle: '苏州市河道管理处资金划拨审批单', documentTitle: '苏州市河道管理处资金划拨审批单',
style:'@page{margin:auto;}' style: '@page{margin:auto;}'
}) })
}
},
computed:{
dateFormat(){
return function (date){
return parseTime(new Date(date))
} }
}, },
priceFormat(){ computed: {
return function (price){ dateFormat() {
return Number(price).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, '$1,') return function(date) {
return parseTime(new Date(date))
}
},
priceFormat() {
return function(price) {
return Number(price).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, '$1,')
}
} }
} }
} }
}
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
.print-table1{ .print-table1 {
box-sizing: border-box; box-sizing: border-box;
&-title{
font-size: 2vw;
letter-spacing: 2px;
text-align: center;
font-weight: 600;
border: none;
padding: 1.6vw 0;
}
&-grid{ &-title {
font-size: 1.75vw; font-size: 2vw;
border: 1px #000 solid; letter-spacing: 2px;
display: grid; text-align: center;
grid-template-rows: repeat(14,auto); font-weight: 600;
grid-template-columns: repeat(6,1fr); border: none;
grid-template-areas:
"tb1-1 tb1-1 tb1-1 tb1-2 tb1-2 tb1-2"
"tb2-1 tb2-1 tb2-1 tb2-2 tb2-2 tb2-2"
"tb3-1 tb3-1 tb3-2 tb3-2 tb3-3 tb3-3"
"tb4-1 tb4-2 tb4-3 tb4-3 tb4-4 tb4-4"
"tb5-1 tb5-2 tb5-3 tb5-3 tb5-4 tb5-4"
"tb6-1 tb6-2 tb6-3 tb6-3 tb6-4 tb6-4"
"tb7-1 tb7-2 tb7-3 tb7-3 tb7-4 tb7-4"
"tb8-1 tb8-2 tb8-3 tb8-3 tb8-4 tb8-4"
"tb9-1 tb9-2 tb9-3 tb9-3 tb9-4 tb9-4"
"tb10-1 tb10-2 tb10-3 tb10-3 tb10-4 tb10-4"
"tb11-1 tb11-2 tb11-3 tb11-3 tb11-3 tb11-3"
"tb12 tb12 tb12 tb12 tb12 tb12"
"tb13-1 tb13-1 tb13-2 tb13-2 tb13-3 tb13-3"
"tb14-1 tb14-1 tb14-2 tb14-2 tb14-3 tb14-3";
&>div{
border: 1px #000 solid;
display: flex;
padding: 1.6vw 0;
} }
&-top{
padding: 0.4vw 0 3.6vw 0.4vw; &-grid {
} font-size: 1.75vw;
&-title1{ border: 1px #000 solid;
text-align: center; display: grid;
justify-content: center; grid-template-rows: repeat(14, auto);
grid-template-columns: repeat(6, 1fr);
grid-template-areas:
"tb1-1 tb1-1 tb1-1 tb1-2 tb1-2 tb1-2"
"tb2-1 tb2-1 tb2-1 tb2-2 tb2-2 tb2-2"
"tb3-1 tb3-1 tb3-2 tb3-2 tb3-3 tb3-3"
"tb4-1 tb4-2 tb4-3 tb4-3 tb4-4 tb4-4"
"tb5-1 tb5-2 tb5-3 tb5-3 tb5-4 tb5-4"
"tb6-1 tb6-2 tb6-3 tb6-3 tb6-4 tb6-4"
"tb7-1 tb7-2 tb7-3 tb7-3 tb7-4 tb7-4"
"tb8-1 tb8-2 tb8-3 tb8-3 tb8-4 tb8-4"
"tb9-1 tb9-2 tb9-3 tb9-3 tb9-4 tb9-4"
"tb10-1 tb10-2 tb10-3 tb10-3 tb10-4 tb10-4"
"tb11-1 tb11-2 tb11-3 tb11-3 tb11-3 tb11-3"
"tb12 tb12 tb12 tb12 tb12 tb12"
"tb13-1 tb13-1 tb13-2 tb13-2 tb13-3 tb13-3"
"tb14-1 tb14-1 tb14-2 tb14-2 tb14-3 tb14-3";
padding: 0.2vw 0; &>div {
} border: 1px #000 solid;
&-center{ display: flex;
text-align: center;
justify-content: center;
align-items: center;
padding: 1vw 0; }
}
&-bottom1{
padding: 0.4vw 0 4vw 0.4vw; &-top {
}
&-bottom2{
padding: 0.4vw 0 4vw 0.4vw; padding: 0.4vw 0 3.6vw 0.4vw;
} }
&-bottom3{
&-title1 {
text-align: center;
justify-content: center;
padding: 0.2vw 0;
}
&-center {
text-align: center;
justify-content: center;
align-items: center;
padding: 0.4vw 0 6vw 0.4vw; padding: 1vw 0;
}
&-bottom1 {
padding: 0.4vw 0 4vw 0.4vw;
}
&-bottom2 {
padding: 0.4vw 0 4vw 0.4vw;
}
&-bottom3 {
padding: 0.4vw 0 6vw 0.4vw;
}
} }
} }
}
</style> </style>

Loading…
Cancel
Save