Browse Source

1. 优化

MONSTER-ygh 10 months ago
parent
commit
e93fa518c5

+ 0 - 1228
src/views/windowTicketSales/model/increaseViewers copy.vue

@@ -1,1228 +0,0 @@
-<template>
-    <el-dialog
-    title="添加观影人"
-    :visible.sync="dialogVisible"
-    width="90%"
-    :before-close="handleClose">
-    <div
-    v-loading="loading" 
-    :element-loading-text="loadingText"
-    element-loading-spinner="el-icon-loading"
-    element-loading-background="rgba(0, 0, 0, 0.8)"
-    class="increase-viewers-box">
-        <div class="increase-viewers-info">
-            <el-table
-            :data="viewerList"
-            border
-            style="width: 100%">
-                <el-table-column
-                label="序号"
-                type="index"
-                width="50">
-                </el-table-column>
-                <el-table-column
-                    label="姓名"
-                    width="180">
-                    <template slot-scope="scope">
-                        <div>
-                            <span v-if="actionIndex != scope.row.id">{{ scope.row.name }}</span>
-                            <el-input size="mini" v-else v-model="tableForm.name" placeholder="请输入姓名"></el-input>
-                        </div>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="身份证号"
-                    width="250">
-                    <template slot-scope="scope">
-                        <div>
-                            <span v-if="actionIndex != scope.row.id">{{ scope.row.idcard }}</span>
-                            <el-input
-                                size="mini"
-                                v-else
-                                v-model="tableForm.idcard"
-                                placeholder="请输入身份证号"
-                                clearable
-                                style="width: 230px;"
-                                @keyup.enter.native="handleQuery"
-                            >
-                                <el-button slot="append" :loading="idcardLoading" size="mini" type="primary" @click="readCert">{{ idcardLoading ? '识别中':'识别' }}</el-button>
-                            </el-input>
-                        </div>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="座位类型">
-                    <template slot-scope="scope">
-                        <span>{{ scope.row.seatTypeName }}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    prop="date"
-                    label="座位号">
-                    <template slot-scope="scope">
-                        <span>{{ scope.row.seatName }}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    prop="date"
-                    label="价格(元)">
-                    <template slot-scope="scope">
-                        <span>{{ scope.row.salePrice }}</span>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="人员类别"
-                    width="140">
-                    <template slot-scope="scope">
-                        <div>
-                             <dict-tag v-if="actionIndex != scope.row.id" :options="dict.type.personnel_type" :value="scope.row.identity"/>
-                            <el-select
-                                size="mini"
-                                v-else
-                                v-model="tableForm.identity"
-                                placeholder="请选择人员类别"
-                                clearable
-                                style="width: 100%"
-                            >
-                                <el-option
-                                v-for="dict in dict.type.personnel_type"
-                                :key="dict.value"
-                                :label="dict.label"
-                                :value="dict.value"
-                                />
-                            </el-select>
-                        </div>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="应收金额(元)">
-                    <template slot-scope="scope">
-                        <span v-if="(scope.$index!=0 && oneMany ==1 && personnelNum != 0)">{{ scope.row.realPrice }}</span>
-                        <div v-else>
-                            <span v-if="actionIndex != scope.row.id">{{ scope.row.realPrice }}</span>
-                            <el-input-number size="mini" style="width: 120px;" v-else v-model="tableForm.realPrice" controls-position="right" label="请输入应收金额(元)"></el-input-number>
-                        </div>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="备注"
-                    width="180">
-                    <template slot-scope="scope">
-                        <div>
-                            <span v-if="actionIndex != scope.row.id">{{ scope.row.remark }}</span>
-                            <el-input size="mini" v-else v-model="tableForm.remark" placeholder="请输入备注"></el-input>
-                        </div>
-                    </template>
-                </el-table-column>
-                <el-table-column
-                    label="操作"
-                    width="80"
-                    >
-                    <template slot-scope="scope" v-if="(scope.$index != 0 && oneMany!=2) || scope.$index == 0">
-                        <el-button
-                        size="mini"
-                        type="success"
-                        :loading="factorAuthLoading"
-                        v-if="actionIndex == scope.row.id"
-                        @click="handleSeva(scope.$index, scope.row)">{{ factorAuthLoading ? '保存中....' : '保存' }}</el-button>
-                        <el-button
-                        :disabled="!!actionIndex"
-                        size="mini"
-                        type="primary"
-                        v-if="actionIndex != scope.row.id"
-                        @click="handleEdit(scope.$index, scope.row)">编辑</el-button>
-                        <!-- <el-button
-                        size="mini"
-                        type="danger"
-                        @click="handleDelete(scope.$index, scope.row)">删除</el-button> -->
-                    </template>
-                </el-table-column>
-            </el-table>
-        </div>
-        <div style="padding: 10px 0 20px;">合计:累计观影人员{{ viewerList.length }}人,应收总额¥{{ moneyAll }}(元)</div>
-        <div>
-            <el-form 
-            :model="ruleForm" 
-            :rules="rules" 
-            ref="ruleForm11" 
-            label-width="120px" 
-            class="demo-ruleForm"
-            size="mini"
-            >
-                
-                <div style="display: flex;">
-                    <el-form-item label="用户来源 :" prop="source">
-                        <el-radio-group @input="selectMarketTeamBySourceFun" v-model="ruleForm.source">
-                            <el-radio label="7">窗口</el-radio>
-                            <el-radio label="10">美团</el-radio>
-                            <el-radio label="11">携程</el-radio>
-                            <el-radio label="13">抖音</el-radio>
-                            <el-radio label="14">猫眼</el-radio>
-                            <el-radio label="18">大麦</el-radio>
-                            <el-radio label="19">飞猪</el-radio>
-                            <!-- <el-radio label="15">去哪儿</el-radio> -->
-                            <el-radio label="16">其他</el-radio>
-                        </el-radio-group>
-                    </el-form-item>
-                    <el-form-item label-width="60px" v-if="ruleForm.source && ruleForm.source == 16" label="备注 :" prop="sourceRemark">
-                        <el-input style="width: 200px;" v-model="ruleForm.sourceRemark"></el-input>
-                    </el-form-item>
-                </div>
-                <el-form-item v-if="ruleForm.source && ruleForm.source != 7" label="核销码/订单码" prop="orderIdOrQrCode">
-                    <el-input style="width: 400px;" type="textarea" :rows="2" v-model="ruleForm.orderIdOrQrCode"></el-input>
-                </el-form-item>
-                <el-form-item label="支付方式 :" prop="paymentType">
-                    <el-radio-group v-model="ruleForm.paymentType">
-                        <el-radio label="1">扫码</el-radio>
-                        <el-radio label="2">现金</el-radio>
-                        <!-- <el-radio v-if="['10','11','13','14','18','19'].includes(ruleForm.source)" label="3">对公支付</el-radio> -->
-                        <el-radio v-if="['10','11','13','14','18','19'].includes(ruleForm.source)" label="4">账户余额({{ balance }})</el-radio>
-                        <el-radio v-if="['10','11','13','14','18','19'].includes(ruleForm.source)" label="5">授信余额({{ grantQuota }})</el-radio>
-                    </el-radio-group>
-                </el-form-item>
-                <el-form-item label="应收金额 :">
-                    ¥{{ moneyAll }}元
-                </el-form-item>
-                <!-- <el-form-item label="找零计算(注:只用于找零不提交数据 找零金额 = 收到金额 - 实收金额)" v-if="ruleForm.paymentType == 2 || ruleForm.paymentType == 3" label-width="480px"></el-form-item> -->
-                <el-form-item v-if="ruleForm.paymentType == 2 || ruleForm.paymentType == 3" label="收取现金 :" prop="realPrice_1">
-                    <el-input @input="setRealPrice_1" style="width: 200px;" v-model="ruleForm.realPrice_1"></el-input>
-                    <span>元</span>
-                </el-form-item>
-                <el-form-item label="找零金额 :" v-if="ruleForm.paymentType == 2">
-                    ¥{{ ruleForm.small }}元
-                </el-form-item>
-                <el-form-item v-if="ruleForm.paymentType == 2 || ruleForm.paymentType == 3" label="实收金额 :" prop="realPrice">
-                    <el-input @input="setRealPrice" style="width: 200px;" v-model="ruleForm.realPrice"></el-input>
-                    <span>元</span>
-                </el-form-item>
-                <el-form-item label="订单备注 :" prop="remark">
-                    <el-input style="width: 400px;" type="textarea" :rows="2" maxlength="200" v-model="ruleForm.remark" show-word-limit></el-input>
-                </el-form-item>
-            </el-form>
-        </div>
-        <!--  支付过程 控制  -->
-        <div v-if="payStatus" class="increase-viewers-pay-status">
-            <div class="increase-viewers-pay-status-info" v-if="!loading">
-                <span style="font-weight: 600;font-size: 20px;">提示</span>
-                <span style="padding: 10px 0;">
-                    {{ payStatus==1 ? '生成订单失败!!!' : 
-                    payStatus==2 ? '生成订单生成成功,请点击调取扫码盒子' : 
-                    payStatus==4 ? '扫码支付失败!!!' :
-                    payStatus==5 ? '请出示付款码!!!' :
-                    payStatus==5.5 ? '扫码失败,请刷新付款码,再进行扫码!!!' :
-                    payStatus==6 ? '连接扫码器失败!!!' :
-                    payStatus==7 ? '用户支付失败或未支付,请重新连接支付!!!' :
-                    payStatus==8 ? '用户支付成功,请点击打印票!!!' :
-                    payStatus==9 ? '支付超时!!!' :
-                    payStatus==3 ? '现金支付记录入库失败,请重新提交' : '未知状态' }}
-                </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>
-                <!-- 扫码支付 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>
-                <!-- 打印 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,index) 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>
-            </div>
-        </div>
-    </div>
-    
-    <span slot="footer" class="dialog-footer">
-        <el-button @click="handleClose()">取 消</el-button>
-        <el-button v-if="!orderId&&!payStatus" :loading="loading" type="primary" @click="submitForm('ruleForm11')">确定支付</el-button>
-    </span>
-    </el-dialog>
-</template>
-<script>
-import { 
-  orderInfoSubmit,
-  gotoMicroPay,
-  gotoCashPay,
-  gotoCorporatePay,
-  gotoBalancePay,
-  gotoQuotaPay,
-  payQuery,
-  selectRegion,
-  orderInfoCancel,
-  factorAuth,
-  selectMarketTeamBySourceApi
- } from '@/api/windowTicketSales/ticketingSales'
- import { pageList as getPrintListApi } from "@/api/device/pda";
- import { printApi } from '@/api/windowTicketSales/ticketingCollection'
- const mathM = require('mathjs')
- const https = require('https');
- const axios = require('axios');
-  export default {
-    dicts: ['personnel_type'],
-    data() {
-      return {
-        loading: false,
-        loadingText: '',
-        dialogVisible: false,
-        actionIndex: false,
-        tableForm: {
-            name: '', // 姓名
-            mobile: '', // 电话
-            idcard: '', // 身份证
-            identity: '', // 观影人身份
-            remark: '', // 备注信息
-            salePrice: '', // 原价
-            realPrice: '', // 实收金额
-            seatId: '', // 座位ID
-            seatName: '', // 座位名称
-            seatType: '', // 座位类型
-        },
-        ruleForm: {
-            performId: "", // 剧目ID
-            retailId: "", // 分销ID
-            goodsList: [], // 商品列表
-            auditoriumId: "", // 演出厅ID
-            performTimeId: "1", // 场次时段ID
-            seatTypeId: "", // 座位类型ID
-            source: '', // 订单来源
-            purchaser: {},// 购票人信息
-            viewerList: [], // 观影人列表
-            orderIdOrQrCode: '',
-            paymentType: '', // 支付方式
-            small: '',// 找零
-            realPrice: '', // 实收金额
-        },
-        viewerList: [], // 观影人列表
-        rules: {
-            source: [
-                { required: true, message: '请选择用户来源', trigger: ['blur','change']},
-            ],
-            orderIdOrQrCode: [
-                { required: true, message: '请输入核销码/订单码', trigger: ['blur','change']},
-            ],
-            paymentType: [
-                { required: true, message: '请选择支付方式', trigger: ['blur','change']},
-            ],
-            realPrice: [
-                { required: true, message: '请输入实收金额', trigger: ['blur','change']},
-            ],
-            sourceRemark: [
-                { required: true, message: '请输入备注', trigger: ['blur','change']},
-            ],
-        },
-        moneyAll: '',
-        payment: '',
-        payStatus: null, // 支付状态
-        orderId: null,
-        websocket_connected: false, // 是否已连接
-        websocketCtrl: null,
-        websocketData: null,
-
-        idcardLoading: false,
-        payTime: null, // 支付等待时间
-        payTimeNum: 0,
-        printListId: null,
-        printList: [],
-
-        // 身份证校验 loading
-        factorAuthLoading: false,
-
-        ifRealUser: 0,  // 散客是否实名:0-否 1-是
-        ifRealTeam: 0,   // 团购是否实名:0否 1-是
-        oneMany: 1,   // 证件要求: 1一证一票,2一证多票
-        personnelNum: 0,   // 人员要求:0-表示不限制 其他数字表示限制人数
-      
-    
-        balance: null, // 授信额度
-        grantQuota: null, // 授信使用额度
-
-        code: null, // 支付code
-        codeTime: null // 检测是websocket是否还在连接
-    };
-      
-    },
-    methods: {
-        async initData(list,params){
-            try {
-                this.ifRealUser = params.ifRealUser  // 散客是否实名:0-否 1-是
-                this.ifRealTeam = params.ifRealTeam   // 团购是否实名:0否 1-是
-                this.oneMany = params.oneMany   // 证件要求: 1一证一票,2一证多票
-                this.personnelNum = params.personnelNum   // 人员要求:0-表示不限制 其他数字表示限制人数
-                this.websocketClear()
-                this.idcardLoading = false
-                this.ruleForm = {
-                    performId: "", // 剧目ID
-                    retailId: "", // 分销ID
-                    goodsList: [], // 商品列表
-                    auditoriumId: "", // 演出厅ID
-                    performTimeId: "", // 场次时段ID
-                    seatTypeId: "", // 座位类型ID
-                    source: '', // 订单来源
-                    purchaser: {},// 购票人信息
-                    viewerList: [], // 观影人列表
-                    orderIdOrQrCode: '',
-                    paymentType: '', // 支付方式
-                    small: '',// 实收金额
-                    realPrice: '', // 实收金额
-                    remark: '', // 订单备注
-                    sourceRemark: '', //  来源备注
-                }
-                this.payStatus = null
-                this.orderId = null
-                this.websocket_connected = false
-                this.dialogVisible = true
-                this.loading = true
-                this.actionIndex = null
-                this.viewerList = []
-                let perform = await this.selectRegionFun(params,list[0].seatTypeId)
-                console.log("perform===",perform)
-                // let perform = {
-                //     money: 1,
-                //     name: '普通票'
-                // }
-                let listCopy = []
-                let listCopy1 = []
-                list.forEach((item,index)=>{
-                    listCopy.push({
-                        id: index+1,
-                        name: '', // 姓名
-                        mobile: '', // 电话
-                        idcard: '', // 身份证
-                        identity: '', // 观影人身份
-                        remark: '', // 备注信息
-                        salePrice: this.oneMany == 2 || (this.oneMany == 1 && this.personnelNum != 0)  ? index == 0 ? perform.money  : 0 : perform.money, // 原价
-                        realPrice: this.oneMany == 2 || (this.oneMany == 1 && this.personnelNum != 0)  ? index == 0 ? perform.money  : 0 : perform.money, // 实收金额
-                        seatId: item.id, // 座位ID
-                        seatName: item.name?item.name:'暂无命名', // 座位名称
-                        seatType: perform.seatTypeId, // 座位类型
-                        seatTypeId: perform.seatTypeId,
-                        seatTypeName: perform.seatTypeName,
-                    })
-                })
-                //this.goodsList = 
-                this.viewerList = JSON.parse(JSON.stringify(listCopy))
-                this.setMoneyAll()
-                
-                console.log(this.viewerList)
-                this.loading = false
-                this.$nextTick(()=>{
-                    this.$refs.ruleForm11.clearValidate()
-                })
-            } catch (error) {
-                console.error("error====",error)
-            }
-            
-        },
-        /**  获取票务信息  */
-        async selectRegionFun(params,seatTypeId){
-            try {
-                this.loadingText = "获取票务信息中..."
-                let res = await selectRegion({
-                    "auditoriumId": params.auditoriumId, // 演艺厅ID
-                    "goodsId": params.goodsId, // 商品ID
-                    "performId": params.performId, // 上一界面节目ID
-                    "performTimeId": params.timeId, // 时段ID
-                    "retailId": "" // 分销ID
-                })
-                if(res.code == 200) {
-                    if(res.data.regionPriceList &&res.data.regionPriceList.length>0){
-                        //let obj = res.data.regionPriceList[0]
-                        let obj = {}
-                        res.data.regionPriceList.forEach((item,index)=>{
-                            if(seatTypeId == item.seatTypeId) {
-                                obj = item
-                            }
-                        }) 
-                        if(JSON.stringify(obj) != '{}'){
-                            this.ruleForm.performId = obj.performId
-                            this.ruleForm.goodsList = [
-                                {
-                                    goodsId: obj.goodsId,
-                                    salePeice: obj.salePrice,
-                                    saleNum: 1,
-                                }
-                            ]
-                            this.ruleForm.auditoriumId = obj.auditoriumId
-                            this.ruleForm.performId = obj.performId
-                            this.ruleForm.performTimeId = res.data.performTimeId
-                            this.ruleForm.seatTypeId = obj.seatTypeId
-                            return {
-                                money: obj.salePrice,
-                                //name: obj.goodsName,
-                                seatTypeId: obj.seatTypeId,
-                                seatTypeName: obj.seatTypeName,
-                            }
-                        }else {
-                            this.$message.error('存在座位未设置价格,请选择其他票!!!');
-                            this.loading = false
-                            this.dialogVisible = false
-                        }
-                        
-                    }else {
-                        this.$message.error('存在座位未设置价格,请选择其他票!!!');
-                        this.loading = false
-                        this.dialogVisible = false
-                    }
-                    console.log("res====",res)
-                }else {
-                    this.$message.error(res.msg);
-                    this.loading = false
-                    this.dialogVisible = false
-                }
-            } catch (error) {
-                console.error("error=====",error)
-                this.$message.error('价格查询出错');
-                this.loading = false
-                this.dialogVisible = false
-            }
-        },
-        /**  取消订单   */
-        async orderInfoCancelFun(type){
-            // let payStatus = this.payStatus
-            // this.payStatus = null
-            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.dialogVisible = false
-                        }else {
-                            this.payStatus = 9
-                            this.loading = false
-                        }
-                        
-                    }else {
-                        
-                    }
-                }).catch(()=>{
-                    this.$message.error('订单关闭失败!!!');
-                })
-            } catch (error) {
-                
-            }
-        },
-        /** 退出窗口 */
-        handleClose(done) {
-            // if(this.payStatus==8) {
-            //     this.$message.error('请daying');
-            //     return
-            // }
-            this.$confirm('确认关闭?')
-                .then(_ => {
-                    if(this.orderId){
-                        this.orderInfoCancelFun(true)
-                    }else {
-                        this.dialogVisible = false
-                    }
-                })
-                .catch(_ => {});
-        },
-        /**  保存个人信息 */
-        handleSeva(index, row) {    
-            if(!this.tableForm.name){
-                this.$message.error('请输入姓名!!!');
-                return
-            }
-            if(!this.tableForm.idcard){
-                this.$message.error('请输入身份证号!!!');
-                return 
-            }
-            if(this.tableForm.identity && this.tableForm.identity != 0){
-                if(!this.tableForm.remark){
-                    this.$message.error('请输入备注!!!');
-                    return 
-                }
-            }
-        
-            //this.factorAuthFun(index,this.tableForm)
-            if(this.oneMany == 2 && index==0) {
-                this.$set(this.viewerList,index,JSON.parse(JSON.stringify(this.tableForm)))
-                let list = JSON.parse(JSON.stringify(this.viewerList))
-                list.forEach((item,index)=>{
-                    item.name = this.tableForm.name
-                    item.idcard = this.tableForm.idcard
-                })
-                this.viewerList = list
-            }else {
-                this.$set(this.viewerList,index,JSON.parse(JSON.stringify(this.tableForm)))
-            }
-            this.actionIndex = null
-            this.setMoneyAll()
-        },
-        /**  校验 身份证 */
-        async factorAuthFun(index, obj){
-            try {
-                this.factorAuthLoading = true
-                let res = await factorAuth({
-                    "name": obj.name,
-                    "idcard": obj.idcard
-                })
-                if(res.code == 200){
-                    this.factorAuthLoading = false
-                    if(res.data.status != 1) {
-                        this.$message.error(res.data.errReason);
-                    }else {
-                        this.$set(this.viewerList,index,JSON.parse(JSON.stringify(this.tableForm)))
-                        this.actionIndex = null
-                        this.setMoneyAll()
-                    }
-                }else {
-                    this.$message.error(res.msg);
-                    this.factorAuthLoading = false
-                }
-            } catch (error) {
-                this.$message.error(error);
-                this.factorAuthLoading = false
-            }
-        },
-        handleEdit(index, row) {
-            this.actionIndex = row.id
-            this.tableForm = JSON.parse(JSON.stringify(row))
-            
-            console.log(index, row);
-        },
-        handleDelete(index, row) {
-            console.log(index, row);
-        },
-        setMoneyAll(){
-            let moneyAll = 0
-            this.viewerList.forEach((item,index) => {
-                console.log("item.realPrice====",item.realPrice)
-                if(item.realPrice && !isNaN(Number(item.realPrice))) {
-                    moneyAll = mathM.format(Number(moneyAll) + Number(item.realPrice),10) 
-                }
-            })
-            console.log("dsfsfdsf",moneyAll)
-            this.moneyAll = moneyAll? moneyAll: ''
-            this.$set(this.ruleForm,'realPrice',this.moneyAll)
-        },
-        setRealPrice(value) {
-            // if(value && !isNaN(value)) {
-            //     this.$set(this.ruleForm,'small',mathM.format(Number(value) - Number(this.moneyAll),10) )
-            // }
-            if(this.ruleForm.realPrice_1 && !isNaN(this.ruleForm.realPrice_1) && value && !isNaN(value)) {
-                this.$set(this.ruleForm,'small',mathM.format(Number(this.ruleForm.realPrice_1) - Number(value),10) )
-            }
-        },
-        setRealPrice_1(value) {
-            if(this.ruleForm.realPrice && !isNaN(this.ruleForm.realPrice) && value && !isNaN(value)) {
-                this.$set(this.ruleForm,'small',mathM.format(Number(value) - Number(this.ruleForm.realPrice),10) )
-            }
-        },
-        /**  检查是否存在空值 */
-        checkViewerList() {
-            let flog = false
-            for(let i = 0; i < this.viewerList.length; i++){
-                let obj = this.viewerList[i]
-                if(!obj.name){
-                    this.$message.error('请填写观影人姓名!!!');
-                    flog = true
-                    break;
-                }
-                if(!obj.idcard){
-                    this.$message.error('请填写观影人身份证号!!!');
-                    flog = true
-                    break; 
-                }
-                if(obj.identity && obj.identity != 0){
-                    if(!obj.remark){
-                        this.$message.error('请填写观影人备注!!!');
-                        flog = true
-                        break; 
-                    }
-                }
-            }
-            if(this.actionIndex){
-                this.$message.error('请先保存观影影人信息!!!');
-                flog = true
-            }
-            return flog
-        },
-        submitForm(formName) {
-            this.$refs[formName].validate((valid) => {
-            if (valid) {
-                if(this.ruleForm.paymentType == 4 && (!this.balance||this.balance<=0||this.balance < this.moneyAll)) {
-                    this.$message.error('团队账户余额不足!!!');
-                    return
-                }
-                if(this.ruleForm.paymentType == 5 && (!this.grantQuota||this.grantQuota<=0||this.grantQuota < this.moneyAll)) {
-                    this.$message.error('团队授信余额不足!!!');
-                    return
-                }
-                if(!this.checkViewerList()){
-                    this.orderInfoSubmitFun()
-                }
-            } else {
-                console.log('error submit!!');
-                return false;
-            }
-            });
-        },
-        resetForm(formName) {
-            this.$refs[formName].resetFields();
-        },
-        /**  生成订单  */
-        async orderInfoSubmitFun(){
-            this.loading = true
-            try {
-                this.orderId = null
-                this.loadingText = "生成订单中..."
-                let res = await orderInfoSubmit({
-                    ...this.ruleForm,
-                    viewerList: this.viewerList
-                })
-                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 {
-                                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 {
-                                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 {
-                                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 = null
-            this.websocketClear()
-            console.log('sdfdsfsd')
-            if (!this.websocket_connected) {
-                var host = "ws://localhost:2693";
-                this.websocketCtrl = new WebSocket(host,'ctrl');
-                this.websocketData = new WebSocket(host,'data');
-                this.websocketData.onopen = (evt) => {
-                    console.log('连接结果====',evt)
-                    this.loading = false
-                    this.payStatus = 5
-                    this.websocket_connected = true;
-                    this.websocket_open_state(evt);
-                }
-                this.websocketData.onerror = (evt) => {
-                    console.log('sdasdasd11111====',evt)
-                    this.payStatus = 6
-                    //this.vbar_open()
-                }
-                this.websocketData.onclose = (evt) => {
-                    console.log('关闭 ==== ',evt)
-                    // this.payStatus = 6
-                    //this.vbar_open()
-                }
-                this.websocketData.onmessage = (evt) => {
-                    console.log("接受消息====",evt)
-                    this.websocket_decode(evt.data);
-                }
-            }
-
-            //setTimeout(this.vbar_open(), 3000);
-        },
-        /**  连接结果 */
-        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 = "已连接";
-        },
-        //接收扫码结果处理
-        websocket_decode(code){
-            console.log("code=========",this.orderId , code)
-            if(this.orderId && (this.payStatus==5 ||this.payStatus == 5.5)  &&code) {
-                if(this.codeTime) {
-                    clearInterval(this.codeTime)
-                }
-                this.gotoMicroPayFun(this.orderId,code)
-            }else if(!code){
-                this.payStatus = 5.5
-            }
-        },
-        /** 关闭通讯 */
-        websocketClear(){
-            if(this.codeTime) {
-                clearInterval(this.codeTime)
-            }
-            if(this.websocketCtrl){
-                this.websocketCtrl.close()
-            }
-            if(this.websocketData){
-                this.websocketData.close()
-            }
-            this.websocket_connected = false
-        },
-        /**  读取身份证 */
-        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.dialogVisible = false
-            this.loading = false
-          }).catch(()=>{
-            this.loading = false
-            this.payStatus = 8
-            // this.dialogVisible = false
-            // this.loading = false
-          })
-          // 在 axios 请求时,选择性忽略 SSL
-          // const agent = new https.Agent({  
-          //   rejectUnauthorized: false
-          // });
-          // axios.post(
-          //   url, 
-          //   { httpsAgent: agent,...data }
-          //   ).then(()=>{
-          //   this.dialogVisible = false
-          //   this.loading = false
-          // })
-          // .catch(()=>{
-          //   this.dialogVisible = 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
-            }
-        }
-    }
-}
-</script>
-<style scoped lang="scss">
-.increase-viewers-box {
-    width: 100%;
-    height: calc( 100vh - 250px );
-    box-sizing: border-box;
-    overflow: hidden;
-    overflow-y: auto;
-    position: relative;
-}
-.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>

+ 12 - 5
src/views/windowTicketSales/model/increaseViewers copy 2.vue → src/views/windowTicketSales/model/increaseViewersNew.vue

@@ -535,6 +535,7 @@ import {
             this.$confirm('确认关闭?')
                 .then(_ => {
                     if(this.orderId){
+                        document.removeEventListener('keydown',this.keydownAdd);
                         this.orderInfoCancelFun(true)
                     }else {
                         this.dialogVisible = false
@@ -1011,12 +1012,13 @@ import {
         keydownAdd(e){
             console.log("e=====",e)
             console.log("this.code=====",this.code)
-            if( this.payStatus == 5 && e.code.indexOf('Digit') != -1 ) {
+            if( this.payStatus == 5 && e.key != 'Enter') {
                 this.code = this.code + e.key
             }
-            const regex = /^(%%%)\S+(%%%)$/;
-            if(regex.test(this.code)) {
-                let codeCopy = this.code.replace("%%%", "").replace("%%%", "")
+
+            if( e.key == 'Enter') {
+                document.removeEventListener('keydown',this.keydownAdd);
+                let codeCopy = this.code
                 this.payStatus == 5.5
                 this.code = ''
                 this.gotoMicroPayFun(this.orderId,codeCopy)
@@ -1177,7 +1179,12 @@ import {
                 this.grantQuota = null
             }
         }
-    }
+    },
+    beforeDestroy() {
+        // 组件销毁前执行的代码
+        console.log('组件即将销毁');
+        document.removeEventListener('keydown',this.keydownAdd);
+    },
 }
 </script>
 <style scoped lang="scss">

+ 2 - 1
src/views/windowTicketSales/ticketingSales.vue

@@ -203,7 +203,8 @@
   goodsPageList,
   getGoodsPerformApi
  } from '@/api/windowTicketSales/ticketingSales'
- import increaseViewers from "./model/increaseViewers"
+ //import increaseViewers from "./model/increaseViewers"
+ import increaseViewers from "./model/increaseViewersNew"
  import moment from "moment"
  import { pageList as getSeatType } from '@/api/seatTypeMr/seatTypeMr'
  import selectListMixin from "./mixins/selectList"