|  | @@ -0,0 +1,818 @@
 | 
	
		
			
				|  |  | +<template>
 | 
	
		
			
				|  |  | +    <!--  支付过程 控制  -->
 | 
	
		
			
				|  |  | +    <div 
 | 
	
		
			
				|  |  | +    v-bind="$attrs" 
 | 
	
		
			
				|  |  | +    v-on="$listeners"
 | 
	
		
			
				|  |  | +    :style="{ zIndex: payStatus ? 999 : 0 }" 
 | 
	
		
			
				|  |  | +    class="increase-viewers-pay-status">
 | 
	
		
			
				|  |  | +        <div v-if="payStatus && !loading" class="increase-viewers-pay-status-info">
 | 
	
		
			
				|  |  | +            <span style="font-weight: 600;font-size: 20px;">提示</span>
 | 
	
		
			
				|  |  | +            <span style="padding: 10px 0;">
 | 
	
		
			
				|  |  | +                {{ tipFun(payStatus) }}
 | 
	
		
			
				|  |  | +            </span>
 | 
	
		
			
				|  |  | +            <span v-if="payStatus == 2">需支付{{ rebookForm.payAmount }}元</span>
 | 
	
		
			
				|  |  | +            <!-- 重新生成订单 1  -->
 | 
	
		
			
				|  |  | +            <div v-if="payStatus == 1" style="display: flex;">
 | 
	
		
			
				|  |  | +                <el-button @click="payStatus = null" type="success">修改信息</el-button>
 | 
	
		
			
				|  |  | +                <el-button @click="orderInfoSubmitFun()" style="margin-left: 20px;" type="primary">重新生成订单</el-button>
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +            <!--  生成订单成功 选择支付方式  -->
 | 
	
		
			
				|  |  | +            <div>
 | 
	
		
			
				|  |  | +                <!-- 扫码支付 2 -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 2" @click="vbar_open(orderId)" type="success">扫码支付</el-button>
 | 
	
		
			
				|  |  | +                <!-- 扫码支付 4 -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 4" @click="vbar_open(orderId)" type="success">重新扫码支付</el-button>
 | 
	
		
			
				|  |  | +                <!-- 重新支付 3 -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 3" @click="gotoCashPayFun(orderId)" type="success">重新提交入库</el-button>
 | 
	
		
			
				|  |  | +                <!-- 重新支付 6  7 -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 6 || payStatus == 7" @click="vbar_open(orderId)"
 | 
	
		
			
				|  |  | +                    type="success">重新连接扫码支付</el-button>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                <!--   现金支付  -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 2" @click="vbar_open(orderId)" type="success">扫码支付</el-button>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                <!--   现金支付  -->
 | 
	
		
			
				|  |  | +                <el-button v-if="payStatus == 2" @click="vbar_open(orderId)" type="success">扫码支付</el-button>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            <!-- 打印 8  -->
 | 
	
		
			
				|  |  | +            <div v-if="payStatus == 8">
 | 
	
		
			
				|  |  | +                <el-select v-model="printListId" placeholder="选择打印机">
 | 
	
		
			
				|  |  | +                    <el-option :label="item.deviceName" :key="item.id" :value="item.id"
 | 
	
		
			
				|  |  | +                        v-for="(item) in printList"></el-option>
 | 
	
		
			
				|  |  | +                </el-select>
 | 
	
		
			
				|  |  | +                <el-button style="margin-left: 15px" @click="print" type="success">打印门票</el-button>
 | 
	
		
			
				|  |  | +                <el-button style="margin-left: 15px" @click="goTicketingCollections" type="success">跳转取票界面</el-button>
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +            <!-- 支付超时 9  -->
 | 
	
		
			
				|  |  | +            <div v-if="payStatus == 9">
 | 
	
		
			
				|  |  | +                <!-- <el-button @click="print" type="danger">取消支付</el-button> -->
 | 
	
		
			
				|  |  | +                <el-button @click="orderInfoSubmitFun()" type="primary">重新扫码</el-button>
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +            <!-- 订单被关闭 10  -->
 | 
	
		
			
				|  |  | +            <div v-if="payStatus == 10">
 | 
	
		
			
				|  |  | +                <!-- <el-button @click="print" type="danger">取消支付</el-button> -->
 | 
	
		
			
				|  |  | +                <el-button @click="handleClose()" type="primary">关闭</el-button>
 | 
	
		
			
				|  |  | +            </div>
 | 
	
		
			
				|  |  | +        </div>
 | 
	
		
			
				|  |  | +    </div>
 | 
	
		
			
				|  |  | +</template>
 | 
	
		
			
				|  |  | +<script>
 | 
	
		
			
				|  |  | +import { getDateTimeAll } from '@/api/windowTicketSales/rebook'
 | 
	
		
			
				|  |  | +import {
 | 
	
		
			
				|  |  | +    orderInfoSubmit,
 | 
	
		
			
				|  |  | +    gotoMicroPay,
 | 
	
		
			
				|  |  | +    gotoCashPay,
 | 
	
		
			
				|  |  | +    gotoCorporatePay,
 | 
	
		
			
				|  |  | +    gotoBalancePay,
 | 
	
		
			
				|  |  | +    gotoQuotaPay,
 | 
	
		
			
				|  |  | +    payQuery,
 | 
	
		
			
				|  |  | +    selectRegion,
 | 
	
		
			
				|  |  | +    orderInfoCancel,
 | 
	
		
			
				|  |  | +    factorAuth,
 | 
	
		
			
				|  |  | +    selectMarketTeamBySourceApi,
 | 
	
		
			
				|  |  | +    querySeatListNew,
 | 
	
		
			
				|  |  | +    querySeatList,
 | 
	
		
			
				|  |  | +} from '@/api/windowTicketSales/ticketingSales'
 | 
	
		
			
				|  |  | +import { pageList as getPrintListApi } from "@/api/device/pda";
 | 
	
		
			
				|  |  | +import { printApi } from '@/api/windowTicketSales/ticketingCollection'
 | 
	
		
			
				|  |  | +import { rebookApi } from '@/api/windowTicketSales/rebook'
 | 
	
		
			
				|  |  | +import { countBySeatTyp } from '@/api/ticketMr/InventoryTemplate'
 | 
	
		
			
				|  |  | +import { pageList as getSeatType } from '@/api/seatTypeMr/seatTypeMr'
 | 
	
		
			
				|  |  | +import seatBox from '@/components/seatBox/index.vue';
 | 
	
		
			
				|  |  | +const mathM = require('mathjs')
 | 
	
		
			
				|  |  | +const https = require('https');
 | 
	
		
			
				|  |  | +const axios = require('axios');
 | 
	
		
			
				|  |  | +export default {
 | 
	
		
			
				|  |  | +    name: "PaymentBox",
 | 
	
		
			
				|  |  | +    components: { seatBox },
 | 
	
		
			
				|  |  | +    data() {
 | 
	
		
			
				|  |  | +        return {
 | 
	
		
			
				|  |  | +            loading: false,
 | 
	
		
			
				|  |  | +            rules: {
 | 
	
		
			
				|  |  | +                performDate: [{ required: true, message: '请选择日期', trigger: ['blur', 'change'] }],
 | 
	
		
			
				|  |  | +                performTimeId: [{ required: true, message: '请选择场次', trigger: ['blur', 'change'] }]
 | 
	
		
			
				|  |  | +            },
 | 
	
		
			
				|  |  | +            // 场次列表
 | 
	
		
			
				|  |  | +            intervalList: [],
 | 
	
		
			
				|  |  | +            intervalListLoading: false,
 | 
	
		
			
				|  |  | +            // 支付相关
 | 
	
		
			
				|  |  | +            payDialog: false,
 | 
	
		
			
				|  |  | +            payStatus: null,
 | 
	
		
			
				|  |  | +            code: '',
 | 
	
		
			
				|  |  | +            websocketData: null,
 | 
	
		
			
				|  |  | +            codeTime: null,
 | 
	
		
			
				|  |  | +            // 成功对话框
 | 
	
		
			
				|  |  | +            successDialog: false,
 | 
	
		
			
				|  |  | +            newOrderId: '',
 | 
	
		
			
				|  |  | +            printList: [],
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            configStockNumObj: {},
 | 
	
		
			
				|  |  | +            countBySeatTypList: [],
 | 
	
		
			
				|  |  | +            seatTypeListAll: [],
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            seatLoading: false,
 | 
	
		
			
				|  |  | +            seatLoadText: '获取座位中...',
 | 
	
		
			
				|  |  | +            setList: [],
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    created() {
 | 
	
		
			
				|  |  | +        this.getSeatTypeAllList()
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    methods: {
 | 
	
		
			
				|  |  | +        async initData(row) {
 | 
	
		
			
				|  |  | +            this.payStatus = null
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  取消订单   */
 | 
	
		
			
				|  |  | +        async orderInfoCancelFun(type) {
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loading = true
 | 
	
		
			
				|  |  | +                this.loadingText = "取消订单中..."
 | 
	
		
			
				|  |  | +                orderInfoCancel({
 | 
	
		
			
				|  |  | +                    orderId: this.orderId
 | 
	
		
			
				|  |  | +                }).then((res) => {
 | 
	
		
			
				|  |  | +                    if (res.code == 200) {
 | 
	
		
			
				|  |  | +                        if (type) { // 关闭弹窗
 | 
	
		
			
				|  |  | +                            if (this.codeTime) {
 | 
	
		
			
				|  |  | +                                clearInterval(this.codeTime)
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +                            this.orderId = null
 | 
	
		
			
				|  |  | +                            this.payStatus = null
 | 
	
		
			
				|  |  | +                            this.$emit('clearDialogVisible')
 | 
	
		
			
				|  |  | +                            this.rebookDialog = false
 | 
	
		
			
				|  |  | +                        } else {
 | 
	
		
			
				|  |  | +                            this.payStatus = 9
 | 
	
		
			
				|  |  | +                            this.loading = false
 | 
	
		
			
				|  |  | +                        }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                    } else {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                }).catch(() => {
 | 
	
		
			
				|  |  | +                    this.$message.error('订单关闭失败!!!');
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  生成订单  */
 | 
	
		
			
				|  |  | +        async orderInfoSubmitFun() {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.orderId = null
 | 
	
		
			
				|  |  | +                this.loadingText = "生成订单中..."
 | 
	
		
			
				|  |  | +                let res = await rebookApi({
 | 
	
		
			
				|  |  | +                    ...this.rebookForm
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    this.orderId = res.data.orderId
 | 
	
		
			
				|  |  | +                    if (this.ruleForm.paymentType == 2) { // 现金支付
 | 
	
		
			
				|  |  | +                        this.gotoCashPayFun(this.orderId)
 | 
	
		
			
				|  |  | +                    } else if (this.ruleForm.paymentType == 3) { // 对公支付
 | 
	
		
			
				|  |  | +                        this.gotoCorporatePayFun(this.orderId)
 | 
	
		
			
				|  |  | +                    } else if (this.ruleForm.paymentType == 4) { // 账户余额
 | 
	
		
			
				|  |  | +                        this.gotoBalancePayFun(this.orderId)
 | 
	
		
			
				|  |  | +                    } else if (this.ruleForm.paymentType == 5) { // 授信余额
 | 
	
		
			
				|  |  | +                        this.gotoQuotaPayFun(this.orderId)
 | 
	
		
			
				|  |  | +                    } else {
 | 
	
		
			
				|  |  | +                        // 扫码支付
 | 
	
		
			
				|  |  | +                        this.loading = false
 | 
	
		
			
				|  |  | +                        this.payStatus = 2
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('生成订单失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 1
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('生成订单失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 1
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 调取 订单支付码支付  */
 | 
	
		
			
				|  |  | +        async gotoMicroPayFun(orderId, code) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loadingText = "订单支付中..."
 | 
	
		
			
				|  |  | +                this.payStatus = ''
 | 
	
		
			
				|  |  | +                let res = await gotoMicroPay({
 | 
	
		
			
				|  |  | +                    "orderId": orderId, // 订单编号-提交订单返回
 | 
	
		
			
				|  |  | +                    "authCode": code // 微信扫码支付-支付码
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    this.payTimeNum = 0
 | 
	
		
			
				|  |  | +                    this.websocketClear()
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.payTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                        this.payQueryFun(this.orderId)
 | 
	
		
			
				|  |  | +                    }, 1500)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('支付失败!!!');
 | 
	
		
			
				|  |  | +                    this.payStatus = ''
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 6
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('支付失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 6
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  对公支付  */
 | 
	
		
			
				|  |  | +        async gotoCorporatePayFun(orderId) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loadingText = "订单入库中..."
 | 
	
		
			
				|  |  | +                let res = await gotoCorporatePay({
 | 
	
		
			
				|  |  | +                    "orderId": orderId, // 订单编号-提交订单返回
 | 
	
		
			
				|  |  | +                    "payAmount": this.ruleForm.realPrice
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.payTimeNum = 0
 | 
	
		
			
				|  |  | +                    this.payTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                        this.payQueryFun(this.orderId)
 | 
	
		
			
				|  |  | +                    }, 1000)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 3
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 3
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  授信额度支付  */
 | 
	
		
			
				|  |  | +        async gotoQuotaPayFun(orderId) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loadingText = "订单入库中..."
 | 
	
		
			
				|  |  | +                let res = await gotoQuotaPay({
 | 
	
		
			
				|  |  | +                    "orderId": orderId, // 订单编号-提交订单返回
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.payTimeNum = 0
 | 
	
		
			
				|  |  | +                    this.payTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                        this.payQueryFun(this.orderId)
 | 
	
		
			
				|  |  | +                    }, 1000)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 3
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 3
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  余额支付  */
 | 
	
		
			
				|  |  | +        async gotoBalancePayFun(orderId) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loadingText = "订单入库中..."
 | 
	
		
			
				|  |  | +                let res = await gotoBalancePay({
 | 
	
		
			
				|  |  | +                    "orderId": orderId, // 订单编号-提交订单返回
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.payTimeNum = 0
 | 
	
		
			
				|  |  | +                    this.payTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                        this.payQueryFun(this.orderId)
 | 
	
		
			
				|  |  | +                    }, 1000)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 3
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 3
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  订单现金支付  */
 | 
	
		
			
				|  |  | +        async gotoCashPayFun(orderId) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.loadingText = "订单入库中..."
 | 
	
		
			
				|  |  | +                let res = await gotoCashPay({
 | 
	
		
			
				|  |  | +                    "orderId": orderId, // 订单编号-提交订单返回
 | 
	
		
			
				|  |  | +                    "payAmount": this.ruleForm.realPrice
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.payTimeNum = 0
 | 
	
		
			
				|  |  | +                    this.payTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                        this.payQueryFun(this.orderId)
 | 
	
		
			
				|  |  | +                    }, 1000)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 3
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('订单入库中失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 3
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        // 跳转取票界面
 | 
	
		
			
				|  |  | +        goTicketingCollections() {
 | 
	
		
			
				|  |  | +            this.$router.push({
 | 
	
		
			
				|  |  | +                path: "/windowTicketSales/ticketingCollections",
 | 
	
		
			
				|  |  | +                query: {
 | 
	
		
			
				|  |  | +                    orderId: this.orderId
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            })
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  查看支付 状态  */
 | 
	
		
			
				|  |  | +        async payQueryFun(orderId) {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                this.payTimeNum = this.payTimeNum + 1
 | 
	
		
			
				|  |  | +                if (this.payTimeNum == 15) {
 | 
	
		
			
				|  |  | +                    if (this.payTime) {
 | 
	
		
			
				|  |  | +                        clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    this.orderInfoCancelFun()
 | 
	
		
			
				|  |  | +                    return
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                if (this.ruleForm.paymentType == 2) {
 | 
	
		
			
				|  |  | +                    this.loadingText = "订单入库中..."
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.loadingText = "订单支付中..."
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                this.payStatus = ''
 | 
	
		
			
				|  |  | +                let res = await payQuery({
 | 
	
		
			
				|  |  | +                    orderId: orderId
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    if (res.data) {
 | 
	
		
			
				|  |  | +                        if (res.data.payStatus == 0) {
 | 
	
		
			
				|  |  | +                            if (this.payTime) {
 | 
	
		
			
				|  |  | +                                clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +                            if (this.ruleForm.paymentType == 2) {
 | 
	
		
			
				|  |  | +                                this.$message.error('"订单入库中失败"');
 | 
	
		
			
				|  |  | +                                this.loading = false
 | 
	
		
			
				|  |  | +                                this.payStatus = 3
 | 
	
		
			
				|  |  | +                            } else {
 | 
	
		
			
				|  |  | +                                if (res.data.orderStatus == 9 || res.data.orderStatus == 4 || res.data.orderStatus == 5) {
 | 
	
		
			
				|  |  | +                                    this.$message.error('订单已关闭,请重新选择座位,再购买!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 10
 | 
	
		
			
				|  |  | +                                } else {
 | 
	
		
			
				|  |  | +                                    this.$message.error('用户未支付!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 7
 | 
	
		
			
				|  |  | +                                }
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                        } else if (res.data.payStatus == 1) {
 | 
	
		
			
				|  |  | +                            if (this.payTime) {
 | 
	
		
			
				|  |  | +                                clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +                            if (this.ruleForm.paymentType == 2) {
 | 
	
		
			
				|  |  | +                                this.$message({
 | 
	
		
			
				|  |  | +                                    message: '订单入库成功',
 | 
	
		
			
				|  |  | +                                    type: 'success'
 | 
	
		
			
				|  |  | +                                });
 | 
	
		
			
				|  |  | +                                this.loading = false
 | 
	
		
			
				|  |  | +                                // this.payStatus = 8
 | 
	
		
			
				|  |  | +                                // this.getPrintListApi()
 | 
	
		
			
				|  |  | +                                this.goTicketingCollections()
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                            } else {
 | 
	
		
			
				|  |  | +                                this.$message({
 | 
	
		
			
				|  |  | +                                    message: '用户已支付成功,请打印门票',
 | 
	
		
			
				|  |  | +                                    type: 'success'
 | 
	
		
			
				|  |  | +                                });
 | 
	
		
			
				|  |  | +                                // 开始 打印
 | 
	
		
			
				|  |  | +                                this.loading = false
 | 
	
		
			
				|  |  | +                                // this.payStatus = 8
 | 
	
		
			
				|  |  | +                                // this.getPrintListApi()
 | 
	
		
			
				|  |  | +                                this.goTicketingCollections()
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                        } else if (res.data.payStatus == 2) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                        } else if (res.data.payStatus == 3) {
 | 
	
		
			
				|  |  | +                            if (this.payTime) {
 | 
	
		
			
				|  |  | +                                clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +                            if (this.ruleForm.paymentType == 2) {
 | 
	
		
			
				|  |  | +                                this.$message.error('"订单入库中失败"');
 | 
	
		
			
				|  |  | +                                this.loading = false
 | 
	
		
			
				|  |  | +                                this.payStatus = 3
 | 
	
		
			
				|  |  | +                            } else {
 | 
	
		
			
				|  |  | +                                if (res.data.orderStatus == 9 || res.data.orderStatus == 4 || res.data.orderStatus == 5) {
 | 
	
		
			
				|  |  | +                                    this.$message.error('订单已关闭,请重新选择座位,再购买!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 10
 | 
	
		
			
				|  |  | +                                } else {
 | 
	
		
			
				|  |  | +                                    this.$message.error('用户支付失败!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 7
 | 
	
		
			
				|  |  | +                                }
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +                        } else if (res.data.payStatus == 4) {
 | 
	
		
			
				|  |  | +                            if (this.payTime) {
 | 
	
		
			
				|  |  | +                                clearInterval(this.payTime)
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                            if (this.ruleForm.paymentType == 2) {
 | 
	
		
			
				|  |  | +                                this.$message.error('"订单入库中失败"');
 | 
	
		
			
				|  |  | +                                this.loading = false
 | 
	
		
			
				|  |  | +                                this.payStatus = 3
 | 
	
		
			
				|  |  | +                            } else {
 | 
	
		
			
				|  |  | +                                if (res.data.orderStatus == 9 || res.data.orderStatus == 4 || res.data.orderStatus == 5) {
 | 
	
		
			
				|  |  | +                                    this.$message.error('订单已关闭,请重新选择座位,再购买!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 10
 | 
	
		
			
				|  |  | +                                } else {
 | 
	
		
			
				|  |  | +                                    this.$message.error('支付退款!!!');
 | 
	
		
			
				|  |  | +                                    this.loading = false
 | 
	
		
			
				|  |  | +                                    this.payStatus = 7
 | 
	
		
			
				|  |  | +                                }
 | 
	
		
			
				|  |  | +                            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                        }
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.$message.error('支付失败!!!');
 | 
	
		
			
				|  |  | +                    this.loading = false
 | 
	
		
			
				|  |  | +                    this.payStatus = 7
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.$message.error('支付失败!!!');
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 7
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        /**  连接VBarServer  */
 | 
	
		
			
				|  |  | +        vbar_open() {
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            this.loadingText = "连接扫码盒子中!!!"
 | 
	
		
			
				|  |  | +            this.payStatus = null
 | 
	
		
			
				|  |  | +            this.code = ''
 | 
	
		
			
				|  |  | +            this.websocketClear()
 | 
	
		
			
				|  |  | +            this.payStatus = 5 // 连接成功
 | 
	
		
			
				|  |  | +            document.addEventListener('keydown', this.keydownAdd);
 | 
	
		
			
				|  |  | +            this.loading = false
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  连接结果 */
 | 
	
		
			
				|  |  | +        websocket_open_state(message) {
 | 
	
		
			
				|  |  | +            console.log("连接结果 ===== ", message)
 | 
	
		
			
				|  |  | +            this.codeTime = setInterval(() => {
 | 
	
		
			
				|  |  | +                console.log("检测是否连接")
 | 
	
		
			
				|  |  | +                if (this.websocketData.readyState != WebSocket.OPEN) {
 | 
	
		
			
				|  |  | +                    this.payStatus = 6
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            }, 3000)
 | 
	
		
			
				|  |  | +            //document.getElementById('wsocket').value = "已连接";
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        // 拼接字符串
 | 
	
		
			
				|  |  | +        keydownAdd(e) {
 | 
	
		
			
				|  |  | +            console.log("e=====", e)
 | 
	
		
			
				|  |  | +            console.log("this.code=====", this.code)
 | 
	
		
			
				|  |  | +            if (this.payStatus == 5 && e.key != 'Enter') {
 | 
	
		
			
				|  |  | +                this.code = this.code + e.key
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            if (e.key == 'Enter') {
 | 
	
		
			
				|  |  | +                document.removeEventListener('keydown', this.keydownAdd);
 | 
	
		
			
				|  |  | +                let codeCopy = this.code
 | 
	
		
			
				|  |  | +                this.payStatus == 5.5
 | 
	
		
			
				|  |  | +                this.code = ''
 | 
	
		
			
				|  |  | +                this.gotoMicroPayFun(this.orderId, codeCopy)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        //接收扫码完整结果处理
 | 
	
		
			
				|  |  | +        websocket_decode(code) {
 | 
	
		
			
				|  |  | +            console.log("orderId=========", this.orderId)
 | 
	
		
			
				|  |  | +            console.log("code=========", code)
 | 
	
		
			
				|  |  | +            if (this.orderId && this.payStatus == 5.5 && regex.test(code)) {
 | 
	
		
			
				|  |  | +                this.payStatus = 5.6 // 支付中
 | 
	
		
			
				|  |  | +                let codeCopy = code.replace("%%%", "").replace("%%%", "")
 | 
	
		
			
				|  |  | +                this.gotoMicroPayFun(this.orderId, codeCopy)
 | 
	
		
			
				|  |  | +            } else if (!code) {
 | 
	
		
			
				|  |  | +                this.payStatus = 5
 | 
	
		
			
				|  |  | +                this.code = ''
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 关闭通讯 */
 | 
	
		
			
				|  |  | +        websocketClear() {
 | 
	
		
			
				|  |  | +            document.removeEventListener('keydown', this.keydownAdd);
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  读取身份证 */
 | 
	
		
			
				|  |  | +        readCert() {
 | 
	
		
			
				|  |  | +            this.idcardLoading = true
 | 
	
		
			
				|  |  | +            var result = "";
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                let xmlHttp = new XMLHttpRequest();
 | 
	
		
			
				|  |  | +                let Protocol = window.location.protocol.split(':')[0];
 | 
	
		
			
				|  |  | +                //获取当前协议,并且分割字符串,得到http或者https
 | 
	
		
			
				|  |  | +                if (Protocol === 'https') {
 | 
	
		
			
				|  |  | +                    //创建请求 第一个参数是代表以post方式发送;第二个是请求端口和地址;第三个表示是否异步
 | 
	
		
			
				|  |  | +                    xmlHttp.open("POST", "http://127.0.0.1:18889/api/readCert?ReadSN=" + 0, false);	  //readCert读卡,生成正反面仿复印件	
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    //创建请求 第一个参数是代表以post方式发送;第二个是请求端口和地址;第三个表示是否异步
 | 
	
		
			
				|  |  | +                    xmlHttp.open("POST", "http://127.0.0.1:18889/api/readCert?ReadSN=" + 0, false);	  //readCert读卡,生成正反面仿复印件	
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                //发送请求
 | 
	
		
			
				|  |  | +                xmlHttp.send();
 | 
	
		
			
				|  |  | +                if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {
 | 
	
		
			
				|  |  | +                    result = xmlHttp.responseText;
 | 
	
		
			
				|  |  | +                    xmlHttp.readyState = 1;
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (e) {
 | 
	
		
			
				|  |  | +                console.error("e====", e)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +            let obj = JSON.parse(result)
 | 
	
		
			
				|  |  | +            if (obj.resultContent && obj.resultContent.certNumber) {
 | 
	
		
			
				|  |  | +                this.$set(this.tableForm, "idcard", obj.resultContent.certNumber)
 | 
	
		
			
				|  |  | +                this.$set(this.tableForm, "name", obj.resultContent.partyName)
 | 
	
		
			
				|  |  | +            } else {
 | 
	
		
			
				|  |  | +                this.$message.error('读取失败!!!');
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            this.idcardLoading = false
 | 
	
		
			
				|  |  | +            //return result;
 | 
	
		
			
				|  |  | +            console.log(result, obj)
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 查询打印机列表 */
 | 
	
		
			
				|  |  | +        getPrintListApi() {
 | 
	
		
			
				|  |  | +            getPrintListApi({
 | 
	
		
			
				|  |  | +                deviceType: 5, pageNum: 1,
 | 
	
		
			
				|  |  | +                pageSize: 999,
 | 
	
		
			
				|  |  | +            })
 | 
	
		
			
				|  |  | +                .then(response => {
 | 
	
		
			
				|  |  | +                    this.printList = response.data.rows;
 | 
	
		
			
				|  |  | +                }).catch((error) => {
 | 
	
		
			
				|  |  | +                    console.log("error===", error)
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                );
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        // 打印 
 | 
	
		
			
				|  |  | +        async print(list = []) {
 | 
	
		
			
				|  |  | +            if (!this.printListId) {
 | 
	
		
			
				|  |  | +                this.$message.error('请选择打印机!!');
 | 
	
		
			
				|  |  | +                return
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +            this.loading = true
 | 
	
		
			
				|  |  | +            this.loadingText = '打印中...'
 | 
	
		
			
				|  |  | +            this.payStatus = ''
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                let res = await printApi({
 | 
	
		
			
				|  |  | +                    orderId: this.orderId,
 | 
	
		
			
				|  |  | +                    source: 2,
 | 
	
		
			
				|  |  | +                    deviceId: this.printListId
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    let url = res.data.linkIp
 | 
	
		
			
				|  |  | +                    let printInfo = res.data.printInfo
 | 
	
		
			
				|  |  | +                    this.connectPrint(url, printInfo)
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    throw new Error(res)
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 8
 | 
	
		
			
				|  |  | +                console.error("error=====", error)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /**  连接打印机  */
 | 
	
		
			
				|  |  | +        connectPrint(url, data) {
 | 
	
		
			
				|  |  | +            // 创建忽略 SSL 的 axios 实例
 | 
	
		
			
				|  |  | +            const ignoreSSL = axios.create({
 | 
	
		
			
				|  |  | +                httpsAgent: new https.Agent({
 | 
	
		
			
				|  |  | +                    rejectUnauthorized: false
 | 
	
		
			
				|  |  | +                }),
 | 
	
		
			
				|  |  | +                withCredentials: true, // 跨域请求时发送Cookie
 | 
	
		
			
				|  |  | +                timeout: 60000, // 请求超时
 | 
	
		
			
				|  |  | +                headers: {
 | 
	
		
			
				|  |  | +                    "Content-Type": "application/json; charset=UTF-8;"
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            });
 | 
	
		
			
				|  |  | +            ignoreSSL.post(url,
 | 
	
		
			
				|  |  | +                { ...data }
 | 
	
		
			
				|  |  | +            ).then(() => {
 | 
	
		
			
				|  |  | +                this.rebookDialog = false
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +            }).catch(() => {
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                this.payStatus = 8
 | 
	
		
			
				|  |  | +                // this.rebookDialog = false
 | 
	
		
			
				|  |  | +                // this.loading = false
 | 
	
		
			
				|  |  | +            })
 | 
	
		
			
				|  |  | +            // 在 axios 请求时,选择性忽略 SSL
 | 
	
		
			
				|  |  | +            // const agent = new https.Agent({  
 | 
	
		
			
				|  |  | +            //   rejectUnauthorized: false
 | 
	
		
			
				|  |  | +            // });
 | 
	
		
			
				|  |  | +            // axios.post(
 | 
	
		
			
				|  |  | +            //   url, 
 | 
	
		
			
				|  |  | +            //   { httpsAgent: agent,...data }
 | 
	
		
			
				|  |  | +            //   ).then(()=>{
 | 
	
		
			
				|  |  | +            //   this.rebookDialog = false
 | 
	
		
			
				|  |  | +            //   this.loading = false
 | 
	
		
			
				|  |  | +            // })
 | 
	
		
			
				|  |  | +            // .catch(()=>{
 | 
	
		
			
				|  |  | +            //   this.rebookDialog = false
 | 
	
		
			
				|  |  | +            //   this.loading = false
 | 
	
		
			
				|  |  | +            // })
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 获取授信余额和账户余额  */
 | 
	
		
			
				|  |  | +        async selectMarketTeamBySourceFun(value) {
 | 
	
		
			
				|  |  | +            console.log("value===", value)
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                if (!['10', '11', '13', '14', '18', '19'].includes(value)) return
 | 
	
		
			
				|  |  | +                let res = await selectMarketTeamBySourceApi({
 | 
	
		
			
				|  |  | +                    source: value
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                this.balance = res.data.balance
 | 
	
		
			
				|  |  | +                if (res.data.grantQuota && res.data.grantUsed) {
 | 
	
		
			
				|  |  | +                    this.grantQuota = res.data.grantQuota - res.data.grantUsed
 | 
	
		
			
				|  |  | +                } else if (res.data.grantQuota) {
 | 
	
		
			
				|  |  | +                    this.grantQuota = res.data.grantQuota
 | 
	
		
			
				|  |  | +                } else {
 | 
	
		
			
				|  |  | +                    this.grantQuota = 0
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.balance = null
 | 
	
		
			
				|  |  | +                this.grantQuota = null
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        /**  获取座位  */
 | 
	
		
			
				|  |  | +        async querySeatListFun(type) {
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                let res = await querySeatListNew({
 | 
	
		
			
				|  |  | +                    auditoriumId: this.rebookForm.auditoriumId,
 | 
	
		
			
				|  |  | +                    timeId: this.rebookForm.performTimeId,
 | 
	
		
			
				|  |  | +                    goodsId: this.rebookForm.goodsId,
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    this.setList = res.data;
 | 
	
		
			
				|  |  | +                    let list = []
 | 
	
		
			
				|  |  | +                    let list3 = []
 | 
	
		
			
				|  |  | +                    this.countBySeatTypList.forEach((item, index) => {
 | 
	
		
			
				|  |  | +                        list3.push(item.seatTypeId)
 | 
	
		
			
				|  |  | +                    })
 | 
	
		
			
				|  |  | +                    let list4 = []
 | 
	
		
			
				|  |  | +                    this.seatTypeListAll.forEach((item, index) => {
 | 
	
		
			
				|  |  | +                        if (list3.includes(item.id)) {
 | 
	
		
			
				|  |  | +                            list4.push({ ...item })
 | 
	
		
			
				|  |  | +                        }
 | 
	
		
			
				|  |  | +                    })
 | 
	
		
			
				|  |  | +                    this.$nextTick(() => {
 | 
	
		
			
				|  |  | +                        this.$refs.seatBox.querySeatListFun(true, this.setList, list, list4)
 | 
	
		
			
				|  |  | +                    })
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                this.loading = false
 | 
	
		
			
				|  |  | +                console.error("error===", error)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 获取座位类型  */
 | 
	
		
			
				|  |  | +        async countBySeatTypFun(value) {
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                if (!value) return
 | 
	
		
			
				|  |  | +                let res = await countBySeatTyp({ auditoriumId: value })
 | 
	
		
			
				|  |  | +                this.countBySeatTypList = res.data ? res.data : []
 | 
	
		
			
				|  |  | +                let obj = {}
 | 
	
		
			
				|  |  | +                this.countBySeatTypList.forEach((item, index) => {
 | 
	
		
			
				|  |  | +                    obj['seatNum_' + item.seatTypeId] = {
 | 
	
		
			
				|  |  | +                        stockTotal: item.stock,
 | 
	
		
			
				|  |  | +                        stockSelect: item.stock,
 | 
	
		
			
				|  |  | +                        stockYes: item.stock,
 | 
	
		
			
				|  |  | +                        stockNo: 0,
 | 
	
		
			
				|  |  | +                        isNoSelect: true,
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                    if (item.seatTypeId == this.rebookForm.seatTypeId) {
 | 
	
		
			
				|  |  | +                        obj['seatNum_' + item.seatTypeId].stockYes = item.stock - this.rebookForm.touristNum
 | 
	
		
			
				|  |  | +                        obj['seatNum_' + item.seatTypeId].isNoSelect = false
 | 
	
		
			
				|  |  | +                    }
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                this.configStockNumObj = obj
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +                console.error("error1====", error)
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 获取座位类型 说明 */
 | 
	
		
			
				|  |  | +        async getSeatTypeAllList() {
 | 
	
		
			
				|  |  | +            try {
 | 
	
		
			
				|  |  | +                let res = await getSeatType({
 | 
	
		
			
				|  |  | +                    pageNum: 1,
 | 
	
		
			
				|  |  | +                    pageSize: 999,
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +                if (res.code == 200) {
 | 
	
		
			
				|  |  | +                    this.seatTypeListAll = res.data.rows || [];
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            } catch (error) {
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        /** 选择座位  */
 | 
	
		
			
				|  |  | +        selectSeat(list) {
 | 
	
		
			
				|  |  | +            let list1 = []
 | 
	
		
			
				|  |  | +            list.forEach((item) => {
 | 
	
		
			
				|  |  | +                list1.push({
 | 
	
		
			
				|  |  | +                    seatId: item.id
 | 
	
		
			
				|  |  | +                })
 | 
	
		
			
				|  |  | +            })
 | 
	
		
			
				|  |  | +            this.rebookForm.seatList = list1
 | 
	
		
			
				|  |  | +            console.log("已选择的====", list)
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +        tipFun(payStatus) {
 | 
	
		
			
				|  |  | +            return  payStatus == 1 ? '生成订单失败!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 2 ? '生成订单生成成功,请点击调取扫码盒子' :
 | 
	
		
			
				|  |  | +                    payStatus == 4 ? '扫码支付失败!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 5 ? '请出示付款码!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 5.5 ? '扫码成功,支付中...' :
 | 
	
		
			
				|  |  | +                    payStatus == 5.6 ? '扫码成功,支付中...' :
 | 
	
		
			
				|  |  | +                    payStatus == 6 ? '连接扫码器失败!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 7 ? '用户支付失败或未支付,请重新连接支付!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 8 ? '用户支付成功,请点击打印票!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 9 ? '支付超时!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 10 ? '订单已关闭,请重新选择座位,再购买!!!' :
 | 
	
		
			
				|  |  | +                    payStatus == 3 ? '现金支付记录入库失败,请重新提交' : '未知状态'
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +</script>
 | 
	
		
			
				|  |  | +<style lang="scss" scoped>
 | 
	
		
			
				|  |  | +.rebook1_dialog ::v-deep .el-dialog__body {
 | 
	
		
			
				|  |  | +    padding: 0 !important;
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +.rebook1_box {
 | 
	
		
			
				|  |  | +    width: 100%;
 | 
	
		
			
				|  |  | +    height: 100%;
 | 
	
		
			
				|  |  | +    padding-bottom: 10px;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    .rebook1_from-box {
 | 
	
		
			
				|  |  | +        display: flex;
 | 
	
		
			
				|  |  | +        width: 100%;
 | 
	
		
			
				|  |  | +        height: 80vh;
 | 
	
		
			
				|  |  | +        box-sizing: border-box;
 | 
	
		
			
				|  |  | +        padding: 0 20px 20px;
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    .rebook1_from {
 | 
	
		
			
				|  |  | +        width: 100%;
 | 
	
		
			
				|  |  | +        height: 100%;
 | 
	
		
			
				|  |  | +        padding: 0 20px 0 0;
 | 
	
		
			
				|  |  | +        width: 400px;
 | 
	
		
			
				|  |  | +        box-sizing: border-box;
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    .rebook1_seat {
 | 
	
		
			
				|  |  | +        width: calc(100% - 400px);
 | 
	
		
			
				|  |  | +        height: 100%;
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +.increase-viewers-pay-status {
 | 
	
		
			
				|  |  | +    width: 100%;
 | 
	
		
			
				|  |  | +    height: 100%;
 | 
	
		
			
				|  |  | +    position: absolute;
 | 
	
		
			
				|  |  | +    z-index: 999;
 | 
	
		
			
				|  |  | +    background-color: rgba(0, 0, 0, 0.3);
 | 
	
		
			
				|  |  | +    top: 0;
 | 
	
		
			
				|  |  | +    left: 0;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    .increase-viewers-pay-status-info {
 | 
	
		
			
				|  |  | +        width: 100%;
 | 
	
		
			
				|  |  | +        height: 100%;
 | 
	
		
			
				|  |  | +        display: flex;
 | 
	
		
			
				|  |  | +        flex-direction: column;
 | 
	
		
			
				|  |  | +        justify-content: center;
 | 
	
		
			
				|  |  | +        align-items: center;
 | 
	
		
			
				|  |  | +        color: #fff;
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +</style>
 |