123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543 |
- <template>
- <view style="background-color: #f2f2f6;padding-bottom: 0.01rpx;" :class="mask ? 'tl-show': ''">
- <!-- <u-navbar title="代收款" bgColor="#FD4B09" :autoBack="true" :placeholder="true" leftIconColor="#fff" :titleStyle="{color: '#fff'}"> -->
- <!-- <view slot="right">
- <u-icon name="clock" size="40rpx" color="#fff" @click="historical0rders()"></u-icon>
- </view> -->
- <!-- </u-navbar> -->
- <view style="background-color: #fff;position: fixed;top: var(--window-top);width: 100%;z-index: 8;">
- <u-tabs :list="tabsList" keyName="dictValue" itemStyle="height:88rpx;" lineColor="#FD4B09"
- @click="tabsClick" :current="current">
- <!-- <view slot="right" style="font-size: 15px;" @click="sortOpen = !sortOpen,mask = !mask">
- <text style="margin-left: 10rpx;">|<text style="margin:0rpx 15rpx">排序</text></text>
- </view> -->
- </u-tabs>
- <view style="background-color: #fff;padding: 10rpx 20rpx;">
- <u-search placeholder="请输入销售单号" v-model="form.ordNo" @custom="custom" @search="custom"></u-search>
- </view>
- </view>
- <view class="content" style="margin-top: 100px;">
- <view class="contentBox" v-for="(item,index) in dataList" :key="index" @click="choice(item,index)">
- <view style="width: 100%;margin: 0 auto;">
- <u-cell-group :border="false">
- <u-cell :border="false" center :title="item.ordNo" arrow-direction="down">
- <view slot="icon" style="width: 10rpx;height: 35rpx;background-color: #fd4b09;"></view>
- <view slot="value">
- <view
- style="padding: 5rpx 30rpx;border:1rpx solid #FD4B09;border-radius: 100rpx;color: #FD4B09;">
- {{item.status}}
- </view>
- </view>
- </u-cell>
- </u-cell-group>
- <view class="textBox">
- <view style="font-size: 32rpx;">{{item.customerName}}</view>
- <view>{{item.businesDate?item.businesDate.slice(0,10):''}}</view>
- </view>
- <view class="textBox">
- <view class="widthdian">{{item.goodsNameJoin}}</view>
- </view>
- <!-- <view class="textBox">
- <view style="font-size: 28rpx;">数量:{{Number(item.goodsTotalNum).toFixed(0)}}</view>
- </view> -->
- <!-- <view class="textBox">
- <view>订单金额:¥{{item.totalMoney}}</view>
- <view style="color: #FD4B09;font-size: 32rpx;">
- {{(item.totalMoney - item.paymentAmountTl) == 0?'已结清':'未收款:¥' + (item.totalMoney - item.paymentAmountTl) +'元'}}
- </view>
- </view> -->
- <view class="textBox">
- <view style="font-size: 28rpx;">资金方:</view>
- <view style="font-size: 28rpx;">{{item.fundingPartyName}}</view>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">配资比例:</view>
- <view style="font-size: 28rpx;">{{item.proportion}}</view>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">保证金:</view>
- <view style="font-size: 28rpx;">{{item.bondAmount}}</view>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">融资金额:</view>
- <view style="font-size: 28rpx;">{{item.fundingAmount}}</view>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">采购数量/采购金额:</view><span
- style="font-size: 28rpx;">{{item.goodsTotalNum}}/{{item.totalMoney}}</span>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">到货数量/到货金额:</view><span
- style="font-size: 28rpx;">{{item.outGoodsTotalShipNum}}/{{item.goodsTotalShipAmount}}</span>
- </view>
- <view class="textBox">
- <view style="font-size: 28rpx;">在库数量/在库金额:</view><span
- style="font-size: 28rpx;">{{item.surplusShipNum}}/{{item.surplusShipAmount}}</span>
- </view>
- </view>
- </view>
- </view>
- </view>
- </template>
- <script>
- import {
- queryBrand
- } from '@/api/views/stock/index.js'
- import {
- queryList,
- corpsDescList,
- gainUser
- } from '@/api/views/sale/salesOrderList.js'
- import {
- collectPayment,
- getCorpDesc
- } from '@/api/views/sale/salesOrderDetails.js'
- import {
- dateFormat
- } from '@/common/dateFormat'
- import {
- logo
- } from '../../../common/setting'
- export default {
- data() {
- return {
- timeOpen: false,
- datetime: Number(new Date()),
- dataList: [],
- screen: [],
- columns: [],
- show: false,
- openPopup: false,
- sortOpen: false,
- mask: false,
- current: 0,
- total: 0,
- keyName: 'cname',
- status: 'loadmore',
- form: {
- current: 1,
- size: 20,
- bsType: "RZCG",
- },
- formTwo: {},
- tabsList: [{
- dictKey: null,
- dictValue: '全部'
- }, {
- dictKey: "录入",
- dictValue: "录入"
- }, {
- dictKey: "待确认",
- dictValue: "待确认"
- }, {
- dictKey: "已收货",
- dictValue: "已收货"
- }],
- scrollTop: 0,
- // 会员卡余额
- balanceAmount: 0,
- // 深拷贝的优惠金额数据
- JsonthisUsedProfit: 0
- }
- },
- onLoad() {
- this.dataList = []
- this.query()
- },
- onReachBottom() {
- this.status = 'loading'
- if (this.dataList.length < this.total) {
- this.form.current++
- this.query()
- } else {
- this.status = 'nomore'
- }
- },
- onPageScroll(e) {
- this.scrollTop = e.scrollTop;
- },
- methods: {
- newCompany() {
- uni.$u.route('/pages/views/product/createCompany', {
- code: "account",
- title: "收款账户"
- });
- },
- custom(e) {
- this.form.current = 1
- this.dataList = []
- this.query()
- },
- //时间确认选择
- confirmTiem(e) {
- this.formTwo[this.screen[1]] = dateFormat(new Date(e.value), "YYYY-MM-DD HH:mm:ss")
- this.timeOpen = false
- this.mask = false
- },
- thisUsedProfitchange() {
- // 订单金额
- this.formTwo.orderAmount = this.formTwo.orderAmount ? Number(this.formTwo.orderAmount) : 0
- // 优惠金额
- this.formTwo.thisUsedProfit = this.formTwo.thisUsedProfit ? Number(this.formTwo.thisUsedProfit) : 0
- // 已收金额
- this.formTwo.settlmentAmount = this.formTwo.settlmentAmount ? Number(this.formTwo.settlmentAmount) : 0
- // 应收金额
- this.formTwo.debitAmount = this.formTwo.debitAmount ? Number(this.formTwo.debitAmount) : 0
- // 会员卡金额
- this.formTwo.memberAmout = this.formTwo.memberAmout ? Number(this.formTwo.memberAmout) : 0
- if (this.formTwo.thisUsedProfit < 0) {
- this.$refs.uToast.show({
- type: 'error',
- icon: false,
- message: "优惠金额不能小于零",
- })
- this.formTwo.thisUsedProfit = 0
- }
- if (this.formTwo.thisUsedProfit > this.formTwo.orderAmount) {
- this.$refs.uToast.show({
- type: 'error',
- icon: false,
- message: "优惠金额不能大于订单金额",
- })
- this.formTwo.thisUsedProfit = 0
- }
- this.formTwo.debitAmount = this.formTwo.orderAmount - this.formTwo.thisUsedProfit
- this.formTwo.memberAmout = this.formTwo.debitAmount - this.formTwo.currentAmount
- this.formTwo.currentAmount = this.formTwo.debitAmount - this.formTwo.memberAmout
- },
- // 会员卡收款监听事件
- memberBalancechange() {
- // 订单金额
- this.formTwo.orderAmount = this.formTwo.orderAmount ? Number(this.formTwo.orderAmount) : 0
- // 优惠金额
- this.formTwo.thisUsedProfit = this.formTwo.thisUsedProfit ? Number(this.formTwo.thisUsedProfit) : 0
- // 已收金额
- this.formTwo.settlmentAmount = this.formTwo.settlmentAmount ? Number(this.formTwo.settlmentAmount) : 0
- // 应收金额
- this.formTwo.debitAmount = this.formTwo.debitAmount ? Number(this.formTwo.debitAmount) : 0
- // 会员卡金额
- this.formTwo.memberAmout = this.formTwo.memberAmout ? Number(this.formTwo.memberAmout) : 0
- if (this.formTwo.memberAmout < 0) {
- this.$delete(this.formTwo, 'memberAmout')
- this.$set(this.formTwo, 'memberAmout', 0)
- this.$refs.uToast.show({
- type: 'error',
- icon: false,
- message: "会员卡金额不能小于零",
- })
- // this.formTwo.memberAmout = 0
- }
- if (this.formTwo.memberAmout >= this.balanceAmount) {
- this.$delete(this.formTwo, 'memberAmout')
- this.$set(this.formTwo, 'memberAmout', this.balanceAmount)
- // this.formTwo.memberAmout = this.balanceAmount
- this.formTwo.currentAmount = 0
- this.$refs.uToast.show({
- type: 'error',
- icon: false,
- message: "会员卡金额不能大于余额",
- })
- }
- const curr = this.formTwo.debitAmount - this.formTwo.settlmentAmount
- if (this.formTwo.memberAmout > curr) {
- // this.formTwo.memberAmout = curr
- this.$delete(this.formTwo, 'memberAmout')
- this.$set(this.formTwo, 'memberAmout', curr)
- }
- this.formTwo.currentAmount = this.formTwo.debitAmount - this.formTwo.settlmentAmount - this.formTwo
- .memberAmout
- },
- discount(type) {
- if (type == 0) {
- if (this.formTwo.thisUsedProfit < 0) {
- return this.formTwo.thisUsedProfit = null
- }
- this.formTwo.debitAmount = (this.formTwo.orderAmount - this.formTwo.thisUsedProfit).toFixed(2)
- if (this.formTwo.debitAmount < 0) {
- this.$set(this.formTwo, "debitAmount", null)
- this.$set(this.formTwo, "thisUsedProfit", null)
- uni.showToast({
- icon: "none",
- title: '优惠金额不能大于订单金额',
- mask: true
- });
- }
- if ((this.formTwo.currentAmount - this.formTwo.debitAmount) > 0) {
- this.formTwo.overPayment = (this.formTwo.currentAmount - this.formTwo.debitAmount).toFixed(2)
- } else {
- this.formTwo.overPayment = '0.00'
- }
- } else if (type == 1) {
- // 已收金额
- this.formTwo.settlmentAmount = this.formTwo.settlmentAmount ? Number(this.formTwo.settlmentAmount) : 0
- // 应收金额
- this.formTwo.debitAmount = this.formTwo.debitAmount ? Number(this.formTwo.debitAmount) : 0
- this.formTwo.memberAmout = this.formTwo.memberAmout ? Number(this.formTwo.memberAmout) : 0
- this.formTwo.currentAmount = this.formTwo.currentAmount ? Number(this.formTwo.currentAmount) : 0
- console.log((this.formTwo.debitAmount - this.formTwo.settlmentAmount - this.formTwo.memberAmout), 353);
- if (this.formTwo.currentAmount > (this.formTwo.debitAmount - this.formTwo.settlmentAmount - this
- .formTwo.memberAmout)) {
- this.$refs.uToast.show({
- type: 'error',
- icon: false,
- message: "收款和会员卡金额不能大于应收金额",
- })
- this.formTwo.currentAmount = 0
- }
- if (this.formTwo.currentAmount < 0) {
- return this.formTwo.currentAmount = 0
- }
- // if ((this.formTwo.currentAmount - this.formTwo.orderAmount) > 0) {
- // this.formTwo.overPayment = (this.formTwo.currentAmount - this.formTwo.orderAmount).toFixed(2)
- // } else {
- // this.formTwo.overPayment = '0.00'
- // }
- }
- },
- collectionConfirm() {
- if (!this.formTwo.orderAmount) {
- return uni.showToast({
- icon: "none",
- title: '合同金额不能为空',
- mask: true
- });
- }
- // 判断本次收款和会员卡收款不能为空
- if (!this.formTwo.currentAmount || this.formTwo.currentAmount == 0) {
- if (!this.formTwo.memberAmout || this.formTwo.memberAmout == 0) {
- return uni.showToast({
- icon: "none",
- title: '本次收款金额或会员卡金额不能为空或零',
- mask: true
- });
- }
- }
- if (!this.formTwo.account) {
- return uni.showToast({
- icon: "none",
- title: '收款账户不能为空',
- mask: true
- });
- }
- this.formTwo.currentAmount = this.formTwo.currentAmount ? this.formTwo.currentAmount : 0
- let this_ = this
- uni.showModal({
- title: '收款:',
- content: '现金收款:' + this_.formTwo.currentAmount + '元\n会员卡:' + this_.formTwo.memberAmout + '元',
- success: function(rest) {
- if (rest.confirm == true) {
- uni.showLoading({
- title: '加载中',
- mask: true
- });
- collectPayment(this_.formTwo).then(res => {
- uni.showToast({
- icon: "none",
- title: '收款成功',
- mask: true,
- duration: 2000
- });
- this_.openPopup = false
- this_.mask = false
- setTimeout(function() {
- uni.hideLoading();
- this_.dataList = []
- this_.query()
- }, 2000);
- })
- }
- }
- })
- },
- //集合筛选条件
- filterAll(screen) {
- this.screen = screen
- switch (screen[1]) {
- case "account":
- this.$u.api.getWorkDicts('account').then(res => {
- this.columns = [res.data]
- this.keyName = "dictValue"
- this.mask = true
- this.show = true
- })
- break;
- case "advanceCollectionDate":
- this.timeOpen = true
- this.mask = true
- break;
- }
- },
- collection(item, index) {
- this.formTwo = JSON.parse(JSON.stringify(item))
- this.formTwo.advanceCollectionDate = dateFormat(new Date(), "YYYY-MM-DD HH:mm:ss")
- // 深拷贝优惠金额判断是否可以编辑
- this.JsonthisUsedProfit = JSON.parse(JSON.stringify(this.formTwo.thisUsedProfit))
- const curr = this.formTwo.debitAmount - this.formTwo.settlmentAmount
- // const curr = (this.formTwo.orderAmount - this.formTwo.thisUsedProfit - this.formTwo.settlmentAmount).toFixed(2)
- // this.formTwo.currentAmount = (this.formTwo.orderAmount - this.formTwo.settlmentAmount).toFixed(2)
- // 判断剪掉的值是不是大于会员卡余额
- getCorpDesc({
- id: item.corpId
- }).then(res => {
- console.log(res, 478);
- this.balanceAmount = res.data.balanceAmount ? res.data.balanceAmount : 0
- if (curr > this.balanceAmount) {
- this.formTwo.memberAmout = this.balanceAmount
- this.formTwo.currentAmount = curr - this.formTwo.memberAmout
- } else {
- this.formTwo.memberAmout = curr
- this.formTwo.currentAmount = 0
- }
- })
- this.openPopup = true
- this.mask = true
- },
- sortQuery(val, sort = 0) {
- this.form = {
- current: 1,
- size: 10,
- sort: sort,
- typeSort: val
- }
- this.dataList = []
- this.sortOpen = false
- this.mask = false
- this.current = 0
- this.query()
- },
- dropdownOpen() {
- this.sortOpen = false
- this.mask = false
- },
- choice(item, index) {
- uni.$u.route('/pages/views/procurement/details', {
- id: item.id,
- corpId: item.corpId
- });
- },
- //查询
- query() {
- uni.showLoading({
- title: '加载中',
- mask: true
- });
- queryList({
- notComplete: 1,
- ...this.form,
- }).then(res => {
- if (res.data.records) {
- this.dataList = this.dataList.concat(res.data.records)
- }
- this.total = res.data.total || 0
- uni.hideLoading();
- if (this.total < 10) {
- this.status = 'nomore'
- }
- })
- },
- // tabs切换
- tabsClick(item) {
- this.current = item.index
- this.form.current = 1
- this.form.status = item.dictKey
- this.mask = false
- this.dataList = []
- this.query()
- },
- confirm(e) {
- if (this.screen[0] == "corpId") {
- this.form = {
- current: 1,
- size: 20,
- corpId: e.value[0].id
- }
- this.dataList = []
- this.query()
- this.show = false
- this.mask = false
- } else if (this.screen[1] == "salesName") {
- this.form = {
- current: 1,
- size: 20,
- salesName: e.value[0].id
- }
- this.dataList = []
- this.query()
- this.show = false
- this.mask = false
- } else {
- this.formTwo.account = e.value[0].dictValue
- this.show = false
- this.mask = false
- }
- },
- //确认日期
- confirmCalendar(e) {
- this.form = {
- current: 1,
- size: 20,
- orderStartDate: e.range.before + ' 00:00:00',
- orderEndDate: e.range.after + ' 23:59:59'
- }
- this.dataList = []
- this.query()
- },
- }
- }
- </script>
- <style scoped>
- .contentBox {
- width: 96%;
- margin: 20rpx auto;
- background-color: #FFFFFF;
- border-radius: 20rpx;
- /* box-shadow: 0 5rpx 14rpx 0 rgba(101, 176, 249, 0.42); */
- padding-top: 15rpx;
- padding-bottom: 10rpx;
- }
- .textBox {
- padding: 0 15px;
- display: flex;
- justify-content: space-between;
- font-size: 24rpx;
- margin-bottom: 10rpx;
- align-items: flex-end;
- }
- .dropdown {
- position: absolute;
- z-index: 9;
- background: rgba(0, 0, 0, .3);
- width: 100%;
- left: 0;
- top: calc(var(--status-bar-height) + 90px);
- bottom: 0;
- }
- .tl-show {
- overflow: hidden;
- position: fixed;
- height: 100%;
- width: 100%;
- }
- /* 长度过长截取 */
- .widthdian {
- width: 100%;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- }
- </style>
|