Commit 6e9a3492b5d73533e0dd4a8eae84a114df835889
1 parent
943f9186
江阴支付
Showing
8 changed files
with
615 additions
and
107 deletions
src/assets/images/loseIcon.png
0 → 100644
4.98 KB
src/assets/images/successIcon.png
0 → 100644
6.08 KB
src/router/index.js
| ... | ... | @@ -25,6 +25,17 @@ export default new Router({ |
| 25 | 25 | name: 'parkRecord', |
| 26 | 26 | component: () => import("@/views/parkPay/parkRecord.vue") |
| 27 | 27 | }, |
| 28 | + | |
| 29 | + { | |
| 30 | + path: '/coupon', | |
| 31 | + name: 'coupon', | |
| 32 | + component: () => import("@/views/parkPay/coupon.vue") | |
| 33 | + }, | |
| 34 | + { | |
| 35 | + path: '/couponPay', | |
| 36 | + name: 'couponPay', | |
| 37 | + component: () => import("@/views/parkPay/couponPay.vue") | |
| 38 | + }, | |
| 28 | 39 | { |
| 29 | 40 | path: '/plateNumber', |
| 30 | 41 | name: 'plateNumber', |
| ... | ... | @@ -37,6 +48,8 @@ export default new Router({ |
| 37 | 48 | component: () => import("@/views/parkPay/orderPay.vue") |
| 38 | 49 | }, |
| 39 | 50 | |
| 51 | + | |
| 52 | + | |
| 40 | 53 | // //---------------- 个人页面导航 |
| 41 | 54 | // { |
| 42 | 55 | // path: '/selfNav', | ... | ... |
src/utils/request.js
| ... | ... | @@ -5,7 +5,7 @@ import axios from 'axios' |
| 5 | 5 | const service = axios.create({ |
| 6 | 6 | // https://dev.renniting.cn/pay/ 赤峰测试 |
| 7 | 7 | // http://pay.service.renniting.cn/ 赤峰 |
| 8 | - baseURL: 'http://pay.service.renniting.cn/', // url = base url + request url | |
| 8 | + baseURL: 'https://pay.jycrtc.com/', // url = base url + request url | |
| 9 | 9 | // withCredentials: true, // send cookies when cross-domain requests |
| 10 | 10 | timeout: 6000 // request timeout |
| 11 | 11 | }) | ... | ... |
src/utils/utils.js
| ... | ... | @@ -139,22 +139,15 @@ export default { |
| 139 | 139 | return '1' |
| 140 | 140 | } |
| 141 | 141 | }, |
| 142 | - // 0eca8f5373ca4866aec2f8e9d9367104 老的id | |
| 143 | - // 14318527b13840c2a4af63fef52c2d6e 老的签名 | |
| 144 | 142 | |
| 145 | - // ud8yq5tv0inxupc05xfeau39jywlqoj2 新的id | |
| 146 | - // ny1u72b6k374sg379z0kqjgfxe2ycnpw 新的签名 | |
| 147 | 143 | |
| 148 | - myVarAppid:'65grtq5tv0wewec05xfeau39jyghhjm',// 公共请求Appid | |
| 144 | + myVarAppid:'0eca8f5373ca4866aec2f8e9d9367104',// 公共请求Appid | |
| 149 | 145 | |
| 150 | 146 | myDeviceInfo: 'BC0703A4-AFB0-4B51-9089-9B7487C0CC6E', // 公共请求设备信息 |
| 151 | 147 | |
| 152 | - myVxAppId: 'wx2af2bab90d433c86', | |
| 153 | - // 测试环境 微信赤峰 appid wxff4cebaedbf4f886 | |
| 154 | - // 微信赤峰 appid wx2af2bab90d433c86 | |
| 155 | - // 黄石 appid wxa1a66cc7d263afe6 | |
| 148 | + myVxAppId: 'wxfdc1af620d3ab750', | |
| 156 | 149 | |
| 157 | - myOrgId: '10003', // 归属地 赤峰id 10003 黄石 10079 | |
| 150 | + myOrgId: '10107', // | |
| 158 | 151 | |
| 159 | 152 | myGetSign: function (objb) { // 获取签名 |
| 160 | 153 | var compare = function (obj1, obj2) { |
| ... | ... | @@ -169,13 +162,13 @@ export default { |
| 169 | 162 | } |
| 170 | 163 | } |
| 171 | 164 | objb.sort(compare); |
| 172 | - var strmd5 = 'dfdf2b6k37r5y79z0kqjgfxe2wet3434'; | |
| 165 | + var strmd5 = '14318527b13840c2a4af63fef52c2d6e'; | |
| 173 | 166 | for(var i=0;i<objb.length;i++){ |
| 174 | 167 | if(objb[i].value != null&&objb[i].value != ''){ |
| 175 | 168 | strmd5 += objb[i].keyname+objb[i].value; |
| 176 | 169 | } |
| 177 | 170 | } |
| 178 | - strmd5 += 'dfdf2b6k37r5y79z0kqjgfxe2wet3434'; | |
| 171 | + strmd5 += '14318527b13840c2a4af63fef52c2d6e'; | |
| 179 | 172 | // console.log('strmd5-------->'+strmd5); |
| 180 | 173 | strmd5 = md5(strmd5); |
| 181 | 174 | strmd5=strmd5.toUpperCase(); | ... | ... |
src/views/parkPay/coupon.vue
0 → 100644
| 1 | +<template> | |
| 2 | + <div> | |
| 3 | + <img :src="successiconUrl" alt="" style="margin: 10px auto;width: 64px;height: 64px;"> | |
| 4 | + <div style="padding: 10px 30px 50px"> | |
| 5 | + <p>尊敬的车主您好:</p> | |
| 6 | + <p>尊敬的车主您好:</p> | |
| 7 | + <p>尊敬的车主您好:</p> | |
| 8 | + </div> | |
| 9 | + <div style="padding: 0 20px"> | |
| 10 | + <mt-button size="large" type="primary" @click="toPay" style="margin-bottom: 20px;">去支付</mt-button> | |
| 11 | + <mt-button size="large" type="danger" @click="toBackPage">返回</mt-button> | |
| 12 | + </div> | |
| 13 | + | |
| 14 | + </div> | |
| 15 | +</template> | |
| 16 | + | |
| 17 | +<script> | |
| 18 | +export default { | |
| 19 | + name: "coupon", | |
| 20 | + data(){ | |
| 21 | + return{ | |
| 22 | + successiconUrl:require('../../assets/images/successIcon.png'), | |
| 23 | + loseiconUrl:require('../../assets/images/loseIcon.png'), | |
| 24 | + } | |
| 25 | + }, | |
| 26 | + methods:{ | |
| 27 | + toPay(){ | |
| 28 | + this.$router.push({ | |
| 29 | + path:'couponPay' | |
| 30 | + }) | |
| 31 | + }, | |
| 32 | + toBackPage(){ | |
| 33 | + this.$router.back() | |
| 34 | + } | |
| 35 | + } | |
| 36 | +}; | |
| 37 | +</script> | |
| 38 | + | |
| 39 | +<style scoped> | |
| 40 | + | |
| 41 | +</style> | ... | ... |
src/views/parkPay/couponPay.vue
0 → 100644
| 1 | +<template> | |
| 2 | + <div> | |
| 3 | + <div class="car-wrap"> | |
| 4 | + <div class="carBG" :class="carWrapBG | formateColor"> | |
| 5 | + <p class="carNumber">{{carNumber}}</p> | |
| 6 | + <p class="payFee">{{(arrearageActFee/100).toFixed(2)}}元</p> | |
| 7 | + </div> | |
| 8 | + </div> | |
| 9 | + | |
| 10 | + <ul class="fee-wrap"> | |
| 11 | + <li> | |
| 12 | + <span>停放车场</span> | |
| 13 | + <span>{{parkName}}</span> | |
| 14 | + </li> | |
| 15 | + <li> | |
| 16 | + <span>入场时间</span> | |
| 17 | + <span>{{parkInTime}}</span> | |
| 18 | + </li> | |
| 19 | + <li> | |
| 20 | + <span>出场时间</span> | |
| 21 | + <span>{{parkOutTime}}</span> | |
| 22 | + </li> | |
| 23 | + <li> | |
| 24 | + <span>停车时长</span> | |
| 25 | + <span>{{$utils.dateFormat(parkDuration)}}</span> | |
| 26 | + </li> | |
| 27 | + <li> | |
| 28 | + <span>应付金额</span> | |
| 29 | + <span> ¥{{(totalFee/100).toFixed(2)}}元</span> | |
| 30 | + </li> | |
| 31 | + <li> | |
| 32 | + <span>停车优惠</span> | |
| 33 | + <p> | |
| 34 | + ({{cardTypeFormat(carType)}}) <span style="color: #3cc51f">-20.00元</span> | |
| 35 | + </p> | |
| 36 | + </li> | |
| 37 | + <li> | |
| 38 | + <span>实际支付</span> | |
| 39 | + <span style="color: red"> ¥{{(unPayFee/100).toFixed(2)}}元</span> | |
| 40 | + </li> | |
| 41 | + </ul> | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + <div style="padding: 20px 18px"> | |
| 46 | + <div class="toPay" @click="toPay">{{clientBrowser}}支付</div> | |
| 47 | + </div> | |
| 48 | + | |
| 49 | + <div v-if="appOrderTimeout.length>0"> | |
| 50 | + <p class="tip"> | |
| 51 | + 温馨提示: | |
| 52 | + </p> | |
| 53 | + <p style="color: #666;padding: 0 18px;"> | |
| 54 | + {{appOrderTimeout}} | |
| 55 | + </p> | |
| 56 | + </div> | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + </div> | |
| 61 | +</template> | |
| 62 | + | |
| 63 | +<script> | |
| 64 | +// import CryptoJS from '../utils/AES.js' | |
| 65 | +// let Base64 = require('js-base64').Base64 | |
| 66 | +import { MessageBox } from 'mint-ui'; | |
| 67 | +import { aliPay, getOpenId, vxPayQuery, bankH5Pay, queryParkingRecordPageByCarNumbers } from '@/api/orderPay/orderPay' | |
| 68 | + | |
| 69 | +export default { | |
| 70 | + name: 'orderPay', | |
| 71 | + data() { | |
| 72 | + return { | |
| 73 | + carWrapBG: 0, | |
| 74 | + carNumber: '苏BB210V', | |
| 75 | + parkName:'', | |
| 76 | + parkInTime:'', | |
| 77 | + parkOutTime:'', | |
| 78 | + parkDuration:'', | |
| 79 | + carType:1, | |
| 80 | + arrearageActFee: 0, | |
| 81 | + arrearageDiscFee: 0, | |
| 82 | + arrearageActFee: 0, | |
| 83 | + totalFee:0,// 应付 | |
| 84 | + unPayFee:0,// 实付 | |
| 85 | + parkingData: [], // 在停数据 | |
| 86 | + historyList: [], // 历史欠费数据 | |
| 87 | + clientBrowser: '', // 客户端 | |
| 88 | + paySrcType: '', //支付的类型 101 是本次 103是历史欠费 | |
| 89 | + orderId: '', //支付的订单 | |
| 90 | + webAppCode: '', // 微信code | |
| 91 | + appOrderTimeout: '', // 超时描述 | |
| 92 | + } | |
| 93 | + }, | |
| 94 | + created() { | |
| 95 | + // this.carWrapBG = this.$route.query.carColor //车牌颜色 | |
| 96 | + // this.carNumber = this.$route.query.carNumber | |
| 97 | + // this.arrearageTotalFee = this.$route.query.arrearageTotalFee // 应收 | |
| 98 | + // this.arrearageDiscFee = this.$route.query.arrearageDiscFee // 优惠 | |
| 99 | + // this.arrearageActFee = this.$route.query.arrearageActFee // 实收 | |
| 100 | + this.clientBrowser = this.$utils.clientBrowser() //支付方式 | |
| 101 | + // this.paySrcType = this.$route.query.paySrcType // 实收 | |
| 102 | + // this.orderId = this.$route.query.ordeID | |
| 103 | + // console.log(this.orderId) | |
| 104 | + // this.appOrderTimeout = this.$route.query.appOrderTimeout | |
| 105 | + if (this.clientBrowser == "微信") { | |
| 106 | + this.webAppCode = this.getCode(); | |
| 107 | + } | |
| 108 | + | |
| 109 | + this.parkRecordList() | |
| 110 | + | |
| 111 | + }, | |
| 112 | + mounted(){ | |
| 113 | + | |
| 114 | + }, | |
| 115 | + methods: { | |
| 116 | + parkRecordList() { // 获取停车记录数据 | |
| 117 | + var salt = this.$utils.myCommonSalt(32); | |
| 118 | + var jsondata = { | |
| 119 | + app_id: this.$utils.myVarAppid, | |
| 120 | + deviceInfo: this.$utils.myDeviceInfo, | |
| 121 | + salt: salt, | |
| 122 | + sign_type: "md5", | |
| 123 | + pageNum: '1', | |
| 124 | + pageSize: '1000', | |
| 125 | + parkState: '10', | |
| 126 | + terminalSource: '3', | |
| 127 | + parkState:'10', | |
| 128 | + carNumber: this.carNumber, | |
| 129 | + carNumberColor: '0', | |
| 130 | + orgId: this.$utils.myOrgId, | |
| 131 | + | |
| 132 | + } | |
| 133 | + jsondata.sign = this.$utils.signObject(jsondata) | |
| 134 | + | |
| 135 | + // jsondata.sign = md5sign | |
| 136 | + console.log('停车记录传参 ' + JSON.stringify(jsondata)); | |
| 137 | + queryParkingRecordPageByCarNumbers(jsondata).then(response => { | |
| 138 | + console.log(response) | |
| 139 | + let res = response.data.dataList[0] | |
| 140 | + this.parkName = res.parkName | |
| 141 | + | |
| 142 | + this.parkInTime = res.parkInTime | |
| 143 | + this.parkOutTime = res.parkOutTime | |
| 144 | + this.parkDuration = res.parkDuration | |
| 145 | + this.carType = res.carType | |
| 146 | + | |
| 147 | + this.totalFee = res.totalFee | |
| 148 | + this.unPayFee = res.unPayFee | |
| 149 | + | |
| 150 | + }) | |
| 151 | + }, | |
| 152 | + getCode() { | |
| 153 | + var appID = this.$utils.myVxAppId; | |
| 154 | + var code = this.getUrlParam('code'); | |
| 155 | + var local = window.location.href; | |
| 156 | + if (code == null || code === '') { | |
| 157 | + window.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=' + appID + '&redirect_uri=' + encodeURIComponent(local) + '&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect' | |
| 158 | + } else { | |
| 159 | + return code; | |
| 160 | + } | |
| 161 | + }, | |
| 162 | + getUrlParam(name) { | |
| 163 | + var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)'); | |
| 164 | + var r = window.location.search.substr(1).match(reg) | |
| 165 | + if (r != null) return unescape(r[2]) | |
| 166 | + return null | |
| 167 | + }, | |
| 168 | + toPay() { | |
| 169 | + let me = this | |
| 170 | + let _order = [] | |
| 171 | + | |
| 172 | + console.log(this.orderId) | |
| 173 | + if (this.paySrcType == 103) { | |
| 174 | + this.orderId = JSON.parse(this.orderId) | |
| 175 | + this.orderId.forEach(item => { | |
| 176 | + _order.push({ | |
| 177 | + orderId: item | |
| 178 | + }) | |
| 179 | + }) | |
| 180 | + this.orderId = [] | |
| 181 | + this.orderId = _order | |
| 182 | + } | |
| 183 | + | |
| 184 | + | |
| 185 | + if (this.clientBrowser == '支付宝') { // 支付宝支付 | |
| 186 | + let me = this | |
| 187 | + var aliParams = {}; | |
| 188 | + aliParams.orderId = this.orderId; | |
| 189 | + aliParams.carNumber = this.carNumber; | |
| 190 | + aliParams.payType = 1;// 1:支付宝 2:微信 3:银联 10:H5 4微信公众号 | |
| 191 | + aliParams.terminalSource = 7;//请求端来源 1: 任你停 2:pda 3:微信公共号 7:H5扫码 10页面支付 | |
| 192 | + aliParams.paySrcType = this.paySrcType;//101停车支付 | |
| 193 | + aliParams.orgId = this.$utils.myOrgId | |
| 194 | + aliParams.backType = 2 | |
| 195 | + aliParams.recordArreaInfos = JSON.stringify(this.orderId); | |
| 196 | + console.log(aliParams) | |
| 197 | + aliPay(aliParams).then(response => { | |
| 198 | + console.log(response) | |
| 199 | + if (response.code == 0) {//进场 | |
| 200 | + document.write(response.data);//打开支付表单 | |
| 201 | + } else if(response.code == 1002){//其他情况如【该卡号场内已存在】 | |
| 202 | + console.log(response.message); | |
| 203 | + MessageBox.confirm('', { | |
| 204 | + message: response.message, | |
| 205 | + title: '温馨提示', | |
| 206 | + showCancelButton:false, | |
| 207 | + confirmButtonText: '确定', | |
| 208 | + }).then(action => { | |
| 209 | + if (action == 'confirm') { //确认的回调 | |
| 210 | + console.log('确定'); | |
| 211 | + this.$router.go(-1) | |
| 212 | + } | |
| 213 | + }).catch(err => { | |
| 214 | + if (err == 'cancel') { //取消的回调 | |
| 215 | + console.log('取消'); | |
| 216 | + } | |
| 217 | + }); | |
| 218 | + }else{ | |
| 219 | + alert(response.message) | |
| 220 | + } | |
| 221 | + | |
| 222 | + }) | |
| 223 | + } | |
| 224 | + | |
| 225 | + | |
| 226 | + if (this.clientBrowser == '微信') { // 微信支付 | |
| 227 | + let _openId = sessionStorage.getItem('openIdData') | |
| 228 | + if(_openId){ | |
| 229 | + me.vxPay(_openId, this.orderId) | |
| 230 | + }else{ | |
| 231 | + //第一步获取openid | |
| 232 | + var codeParams = { | |
| 233 | + code: this.webAppCode, | |
| 234 | + appId: this.$utils.myVxAppId | |
| 235 | + }; | |
| 236 | + getOpenId(codeParams).then(res => { | |
| 237 | + if (res.code == 0) { | |
| 238 | + me.vxPay(res.data, this.orderId) | |
| 239 | + sessionStorage.setItem('openIdData',res.data) | |
| 240 | + } else if (res.code == 40163) { //code been used, hints[重复code问题] | |
| 241 | + alert('请重新支付!重复code问题') | |
| 242 | + console.log(res.message); | |
| 243 | + } else { | |
| 244 | + alert('请重新支付') | |
| 245 | + } | |
| 246 | + }) | |
| 247 | + } | |
| 248 | + } | |
| 249 | + }, | |
| 250 | + vxPay(openIdData, orderIdData) { | |
| 251 | + let vm = this | |
| 252 | + var wxParams = {}; | |
| 253 | + wxParams.orderId = orderIdData; | |
| 254 | + wxParams.backType = 2, | |
| 255 | + wxParams.orgId = this.$utils.myOrgId, | |
| 256 | + wxParams.payType = 4;// 1:支付宝 2:微信 3:银联 10:H5 4微信公众号 | |
| 257 | + wxParams.terminalSource = 7;//请求端来源 1: 任你停 2:pda 3:微信公共号 7:H5扫码 10页面支付 | |
| 258 | + wxParams.carNumber = this.carNumber; | |
| 259 | + wxParams.paySrcType = this.paySrcType;//101停车支付 | |
| 260 | + wxParams.recordArreaInfos = JSON.stringify(orderIdData); | |
| 261 | + wxParams.openId = openIdData; | |
| 262 | + wxParams.appId = this.$utils.myVxAppId; | |
| 263 | + vxPayQuery(wxParams).then(res => { | |
| 264 | + if (res.code == 0) { // | |
| 265 | + if (res.data) { | |
| 266 | + var data = res.data; | |
| 267 | + console.log(JSON.stringify(data)); | |
| 268 | + if (typeof WeixinJSBridge === 'undefined') { // 微信浏览器内置对象。参考微信官方文档 | |
| 269 | + if (document.addEventListener) { | |
| 270 | + document.addEventListener('WeixinJSBridgeReady', vm.onBridgeReady(data), false) | |
| 271 | + } else if (document.attachEvent) { | |
| 272 | + document.attachEvent('WeixinJSBridgeReady', vm.onBridgeReady(data)) | |
| 273 | + document.attachEvent('onWeixinJSBridgeReady', vm.onBridgeReady(data)) | |
| 274 | + } | |
| 275 | + } else { | |
| 276 | + console.log('准备调用微信支付') | |
| 277 | + vm.onBridgeReady(data) | |
| 278 | + } | |
| 279 | + } else { | |
| 280 | + alert("没有找到返回值"); | |
| 281 | + } | |
| 282 | + } else if(res.code == 1002){//其他情况如【该卡号场内已存在】 | |
| 283 | + console.log(res.message); | |
| 284 | + MessageBox.confirm('', { | |
| 285 | + message: res.message, | |
| 286 | + title: '温馨提示', | |
| 287 | + showCancelButton:false, | |
| 288 | + confirmButtonText: '确定', | |
| 289 | + }).then(action => { | |
| 290 | + if (action == 'confirm') { //确认的回调 | |
| 291 | + console.log('确定'); | |
| 292 | + this.$router.go(-1) | |
| 293 | + } | |
| 294 | + }).catch(err => { | |
| 295 | + if (err == 'cancel') { //取消的回调 | |
| 296 | + console.log('取消'); | |
| 297 | + } | |
| 298 | + }); | |
| 299 | + }else{ | |
| 300 | + alert(res.message) | |
| 301 | + } | |
| 302 | + }) | |
| 303 | + }, | |
| 304 | + onBridgeReady(params) { | |
| 305 | + let me = this | |
| 306 | + console.log('调用微信支付WeixinJSBridge') | |
| 307 | + WeixinJSBridge.invoke( | |
| 308 | + 'getBrandWCPayRequest', params, | |
| 309 | + // | |
| 310 | + // 'getBrandWCPayRequest', { // 下面参数内容都是后台返回的 | |
| 311 | + // 'appId': data.appId, // 公众号名称,由商户传入 | |
| 312 | + // 'timeStamp': data.timeStamp, // 时间戳 | |
| 313 | + // 'nonceStr': data.nonceStr, // 随机串 | |
| 314 | + // 'package': data.package, // 预支付id | |
| 315 | + // 'signType': data.signType, // 微信签名方式 | |
| 316 | + // 'paySign': data.paySign // 微信签名 | |
| 317 | + // }, | |
| 318 | + function (res) { | |
| 319 | + // 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。 | |
| 320 | + if (res.err_msg === 'get_brand_wcpay_request:ok') { | |
| 321 | + console.log('成功') | |
| 322 | + var salt = me.$utils.myCommonSalt(32); | |
| 323 | + let wxparams = { | |
| 324 | + pageNum: 1, | |
| 325 | + pageSize: 10000, | |
| 326 | + parkState: 10, | |
| 327 | + terminalSource: 7, | |
| 328 | + carNumber: me.carNumber, | |
| 329 | + app_id: me.$utils.myVarAppid, | |
| 330 | + deviceInfo: me.$utils.myDeviceInfo, | |
| 331 | + salt: salt, | |
| 332 | + sign_type: "md5", | |
| 333 | + token:'', | |
| 334 | + } | |
| 335 | + wxparams.sign = me.$utils.signObject(wxparams) | |
| 336 | + queryParkingRecordPageByCarNumbers(wxparams).then(response => { | |
| 337 | + console.log(response) | |
| 338 | + me.parkList = response.data.dataList | |
| 339 | + | |
| 340 | + // alert(JSON.stringify(me.parkList)) | |
| 341 | + // alert(me.parkList.length) | |
| 342 | + if(me.parkList.length == 0){ | |
| 343 | + me.$router.push({ | |
| 344 | + path:'parkRecord', | |
| 345 | + query:{ | |
| 346 | + carNumber: me.carNumber, | |
| 347 | + carNumberColor: me.carWrapBG, | |
| 348 | + parkFlag: 0 // 0表示在停 1表示历史 | |
| 349 | + } | |
| 350 | + }) | |
| 351 | + | |
| 352 | + }else{ | |
| 353 | + me.parkingData = me.parkList.filter(item => { | |
| 354 | + return item.parkState == '10' | |
| 355 | + }) | |
| 356 | + console.log(me.parkingData) | |
| 357 | + me.historyList = me.parkList.filter(item => { | |
| 358 | + return item.parkState == '20' | |
| 359 | + }) | |
| 360 | + console.log(me.historyList) | |
| 361 | + | |
| 362 | + if(me.historyList.length>0){ | |
| 363 | + MessageBox.confirm('', { | |
| 364 | + message: '您当前有历史欠费 是否立即补缴?', | |
| 365 | + title: '温馨提示', | |
| 366 | + confirmButtonText: '去补缴', | |
| 367 | + cancelButtonText: '取消' | |
| 368 | + }).then(action => { | |
| 369 | + if (action == 'confirm') { //确认的回调 | |
| 370 | + console.log('确定'); | |
| 371 | + me.$router.push({ | |
| 372 | + path:'parkRecord', | |
| 373 | + query:{ | |
| 374 | + carNumber: me.carNumber, | |
| 375 | + carNumberColor: me.carWrapBG, | |
| 376 | + parkFlag: 1 // 0表示在停 1表示历史 | |
| 377 | + } | |
| 378 | + }) | |
| 379 | + } | |
| 380 | + }).catch(err => { | |
| 381 | + if (err == 'cancel') { //取消的回调 | |
| 382 | + console.log('取消'); | |
| 383 | + } | |
| 384 | + }); | |
| 385 | + }else{ | |
| 386 | + | |
| 387 | + if(me.paySrcType==101){ //缴费了本次 | |
| 388 | + me.$router.push({ | |
| 389 | + path:'parkRecord', | |
| 390 | + query:{ | |
| 391 | + carNumber: me.carNumber, | |
| 392 | + carNumberColor: me.carWrapBG, | |
| 393 | + parkFlag: 0 // 0表示在停 1表示历史 | |
| 394 | + } | |
| 395 | + }) | |
| 396 | + }else{ | |
| 397 | + MessageBox.confirm('', { | |
| 398 | + message: '您当前有在停订单 是否立即支付?', | |
| 399 | + title: '温馨提示', | |
| 400 | + confirmButtonText: '去支付', | |
| 401 | + cancelButtonText: '取消' | |
| 402 | + }).then(action => { | |
| 403 | + if (action == 'confirm') { //确认的回调 | |
| 404 | + console.log('确定'); | |
| 405 | + me.$router.push({ | |
| 406 | + path:'parkRecord', | |
| 407 | + query:{ | |
| 408 | + carNumber: me.carNumber, | |
| 409 | + carNumberColor: me.carWrapBG, | |
| 410 | + parkFlag: 0 // 0表示在停 1表示历史 | |
| 411 | + } | |
| 412 | + }) | |
| 413 | + } | |
| 414 | + }).catch(err => { | |
| 415 | + if (err == 'cancel') { //取消的回调 | |
| 416 | + console.log('取消'); | |
| 417 | + } | |
| 418 | + }); | |
| 419 | + } | |
| 420 | + | |
| 421 | + } | |
| 422 | + } | |
| 423 | + | |
| 424 | + | |
| 425 | + | |
| 426 | + }) | |
| 427 | + | |
| 428 | + | |
| 429 | + | |
| 430 | + } else { | |
| 431 | + console.log('失败') | |
| 432 | + alert('支付失败') | |
| 433 | + me.$router.go(-2); | |
| 434 | + } | |
| 435 | + } | |
| 436 | + ) | |
| 437 | + }, | |
| 438 | + cardTypeFormat : function(num){ | |
| 439 | + if(num == '1'){ | |
| 440 | + return '单次券' | |
| 441 | + } | |
| 442 | + if(num == 2){ | |
| 443 | + return '时长券' | |
| 444 | + } | |
| 445 | + if(num == 3){ | |
| 446 | + return '满减券' | |
| 447 | + } | |
| 448 | + if(num == 4){ | |
| 449 | + return '金额券' | |
| 450 | + } | |
| 451 | + if(num == 5){ | |
| 452 | + return '包天券' | |
| 453 | + } | |
| 454 | + if(num == 6){ | |
| 455 | + return '折扣券' | |
| 456 | + } | |
| 457 | + } | |
| 458 | + }, | |
| 459 | + filters: { | |
| 460 | + } | |
| 461 | +} | |
| 462 | +</script> | |
| 463 | + | |
| 464 | +<style scoped lang="scss"> | |
| 465 | + .car-wrap { | |
| 466 | + padding: 7px 7px; | |
| 467 | + background: #FFF; | |
| 468 | + } | |
| 469 | + | |
| 470 | + .carBG { | |
| 471 | + width: 100%; | |
| 472 | + height: 130px; | |
| 473 | + } | |
| 474 | + | |
| 475 | + .carBlue { | |
| 476 | + background: url("../../assets/images/blueBG.png") no-repeat; | |
| 477 | + background-size: 100% 100%; | |
| 478 | + } | |
| 479 | + | |
| 480 | + .carYellow { | |
| 481 | + background: url("../../assets/images/yellowBG.png") no-repeat; | |
| 482 | + background-size: 100% 100%; | |
| 483 | + } | |
| 484 | + | |
| 485 | + .carGreen { | |
| 486 | + background: url("../../assets/images/greenBG.png") no-repeat; | |
| 487 | + background-size: 100% 100%; | |
| 488 | + } | |
| 489 | + | |
| 490 | + .carWhite { | |
| 491 | + background: url("../../assets/images/whiteBG.png") no-repeat; | |
| 492 | + background-size: 100% 100%; | |
| 493 | + } | |
| 494 | + | |
| 495 | + .carBlack { | |
| 496 | + background: url("../../assets/images/blackBG.png") no-repeat; | |
| 497 | + background-size: 100% 100%; | |
| 498 | + } | |
| 499 | + | |
| 500 | + .carNumber { | |
| 501 | + padding: 20px 0 10px; | |
| 502 | + font-size: 30px; | |
| 503 | + color: #fff; | |
| 504 | + text-align: center; | |
| 505 | + } | |
| 506 | + | |
| 507 | + .payFee { | |
| 508 | + font-size: 24px; | |
| 509 | + color: #FF7B7B; | |
| 510 | + text-align: center; | |
| 511 | + } | |
| 512 | + | |
| 513 | + .fee-wrap { | |
| 514 | + background: #FFF; | |
| 515 | + padding: 0 18px; | |
| 516 | + > li { | |
| 517 | + display: flex; | |
| 518 | + justify-content: space-between; | |
| 519 | + height: 30px; | |
| 520 | + line-height: 30px; | |
| 521 | + border-bottom: 1px solid #EAEAEA; | |
| 522 | + &:last-child { | |
| 523 | + border-bottom: 0; | |
| 524 | + } | |
| 525 | + } | |
| 526 | + | |
| 527 | + } | |
| 528 | + | |
| 529 | + .toPay { | |
| 530 | + width: 100%; | |
| 531 | + height: 44px; | |
| 532 | + margin: 0 auto; | |
| 533 | + line-height: 44px; | |
| 534 | + text-align: center; | |
| 535 | + background: linear-gradient(180deg, #3885D9 0%, #4194EF 100%); | |
| 536 | + border-radius: 4px; | |
| 537 | + border: 1px solid #0D72E2; | |
| 538 | + font-size: 20px; | |
| 539 | + color: #FFF; | |
| 540 | + cursor: pointer; | |
| 541 | + } | |
| 542 | + | |
| 543 | + .tip { | |
| 544 | + padding-left: 40px; | |
| 545 | + background: url("../../assets/images/tip.png") no-repeat 18px center; | |
| 546 | + background-size: 16px 16px; | |
| 547 | + color: #666; | |
| 548 | + } | |
| 549 | +</style> | ... | ... |
src/views/parkPay/plateNumber.vue
| 1 | 1 | <template> |
| 2 | 2 | <div id="page"> |
| 3 | 3 | |
| 4 | - <div class="swiper-container" style="height: 260px"> | |
| 5 | - <div class="swiper-wrapper"> | |
| 6 | - <div class="swiper-slide" v-for="item in swiperData" :key="item.id" | |
| 7 | - :style="{backgroundImage:'url(' + item.url + ')'}" | |
| 8 | - @click="openImgUrl(item)" | |
| 9 | - ></div> | |
| 10 | - </div> | |
| 11 | - <!-- 如果需要分页器 --> | |
| 12 | - <div class="swiper-pagination"></div> | |
| 13 | 4 | |
| 14 | - <!-- 如果需要滚动条 --> | |
| 15 | - <!-- <div class="swiper-scrollbar"></div>--> | |
| 16 | - </div> | |
| 17 | 5 | |
| 18 | 6 | <div class="wrap"> |
| 19 | - <!--<p style="margin-bottom: 18px;margin-top: 18px;">请选择车牌颜色</p>--> | |
| 7 | + <p style="margin-bottom: 18px;margin-top: 18px;">请选择车牌颜色</p> | |
| 20 | 8 | |
| 21 | 9 | <ul class="color-choose"> |
| 22 | 10 | <li v-for="(i,index) in colorList" :key="i.name" @click="chooseColor(index)" |
| ... | ... | @@ -31,7 +19,7 @@ |
| 31 | 19 | |
| 32 | 20 | |
| 33 | 21 | <p style="margin-bottom: 18px;margin-top: 18px;"></p> |
| 34 | - <!--<p style="margin-bottom: 18px;margin-top: 18px;">请输入车牌号码</p>--> | |
| 22 | + <p style="margin-bottom: 18px;margin-top: 18px;">请输入车牌号码</p> | |
| 35 | 23 | <div class="num-box"> |
| 36 | 24 | <div class="num0" @click="clickFirstWrap()"> |
| 37 | 25 | <span>{{formData.num0}}</span> |
| ... | ... | @@ -74,18 +62,7 @@ |
| 74 | 62 | |
| 75 | 63 | |
| 76 | 64 | <div class="submit-box" @click="submitFn()"> |
| 77 | - 查询 | |
| 78 | - </div> | |
| 79 | - | |
| 80 | - <div> | |
| 81 | - <p style="margin-bottom: 18px;margin-top: 18px;">查询记录</p> | |
| 82 | - <ul class="bound-list" v-if="boundList.length>0"> | |
| 83 | - <li v-for="i in boundList" :key="i" @click="boundHandle(i)"> | |
| 84 | - <span>{{ i }}</span> | |
| 85 | - </li> | |
| 86 | - </ul> | |
| 87 | - <div v-else style="text-align: center;padding: 10px 0;">暂无查询记录</div> | |
| 88 | - <!--<div class="addCarNum"><span></span>添加车辆</div>--> | |
| 65 | + 领取 | |
| 89 | 66 | </div> |
| 90 | 67 | |
| 91 | 68 | |
| ... | ... | @@ -355,12 +332,10 @@ export default { |
| 355 | 332 | submitConfirm: false, |
| 356 | 333 | submitConfirmFalse: false, |
| 357 | 334 | submitConfirmText: '', |
| 358 | - swiperData: [], // 轮播数据 | |
| 359 | - boundList:[] // 历史记录 | |
| 360 | 335 | } |
| 361 | 336 | }, |
| 362 | 337 | created(){ |
| 363 | - this.initSWiper() | |
| 338 | + | |
| 364 | 339 | }, |
| 365 | 340 | mounted () { |
| 366 | 341 | // |
| ... | ... | @@ -375,54 +350,9 @@ export default { |
| 375 | 350 | // } |
| 376 | 351 | // } |
| 377 | 352 | |
| 378 | - this.boundList = JSON.parse(localStorage.getItem('parkRecordList')) ? JSON.parse(localStorage.getItem('parkRecordList')) : [] | |
| 379 | - console.log(this.boundList) | |
| 380 | 353 | }, |
| 381 | 354 | methods: { |
| 382 | - initSWiper() { | |
| 383 | - var salt = this.$utils.myCommonSalt(32) | |
| 384 | - var jsondata = { | |
| 385 | - app_id: this.$utils.myVarAppid, | |
| 386 | - deviceInfo: this.$utils.myDeviceInfo, | |
| 387 | - salt: salt, | |
| 388 | - sign_type: 'md5', | |
| 389 | - sign: '1', | |
| 390 | - orgId: this.$utils.myOrgId, | |
| 391 | - jumpType: '7' // 7 微信公众号 8小票 | |
| 392 | - }; | |
| 393 | - // jsondata = JSON.stringify(jsondata); | |
| 394 | - swiperQuery(jsondata).then(res => { | |
| 395 | - this.swiperData = res.data | |
| 396 | - console.log(this.swiperData) | |
| 397 | - new Swiper('.swiper-container', { | |
| 398 | - pagination: '.swiper-pagination', | |
| 399 | - paginationClickable: true, | |
| 400 | - centeredSlides: true, | |
| 401 | - notNextTick: true, | |
| 402 | - autoplay: 5000, | |
| 403 | - autoplayDisableOnInteraction: true, | |
| 404 | - | |
| 405 | - observer: true, //修改swiper自己或子元素时,自动初始化swiper | |
| 406 | - observeParents: true, //修改swiper的父元素时,自动初始化swiper | |
| 407 | - onSlideChangeStart: function (swiper) { | |
| 408 | - //console.log(swiper.activeIndex) | |
| 409 | - } | |
| 410 | - }) | |
| 411 | - }) | |
| 412 | - }, | |
| 413 | - openImgUrl(i) { // 点击图片跳转 | |
| 414 | - window.open(i.jumpUrl) | |
| 415 | - }, | |
| 416 | - boundHandle(i) { // 记录点击事件 | |
| 417 | - console.log(i) | |
| 418 | - this.$router.push({ | |
| 419 | - path:'parkRecord', | |
| 420 | - query:{ | |
| 421 | - carNumber:i, | |
| 422 | - carNumberColor: this.currentColor | |
| 423 | - } | |
| 424 | - }) | |
| 425 | - }, | |
| 355 | + | |
| 426 | 356 | chooseColor (index){ // 颜色选择 0:蓝牌;1:黄牌;2:白牌;3:黑牌;4:绿色 |
| 427 | 357 | this.currentColor = index |
| 428 | 358 | switch (this.currentColor) { |
| ... | ... | @@ -519,15 +449,7 @@ export default { |
| 519 | 449 | this.$emit('getPlateLicense',plateLicense) |
| 520 | 450 | console.log(plateLicense); |
| 521 | 451 | |
| 522 | - // boundList | |
| 523 | - if(this.boundList.indexOf(plateLicense) == -1 ){ | |
| 524 | - if(this.boundList.length == 3){ | |
| 525 | - this.boundList.pop() | |
| 526 | - } | |
| 527 | - this.boundList.unshift(plateLicense) | |
| 528 | - } | |
| 529 | - localStorage.setItem('parkRecordList',JSON.stringify(this.boundList)) | |
| 530 | - console.log(this.boundList) | |
| 452 | + | |
| 531 | 453 | |
| 532 | 454 | this.$router.push({ |
| 533 | 455 | path:'parkRecord', |
| ... | ... | @@ -631,16 +553,6 @@ export default { |
| 631 | 553 | </script> |
| 632 | 554 | <style lang="scss" scoped> |
| 633 | 555 | |
| 634 | - .swiper-container { | |
| 635 | - height: 206px; | |
| 636 | - } | |
| 637 | - | |
| 638 | - .swiper-slide { | |
| 639 | - /*width: 100%;*/ | |
| 640 | - height: 206px; | |
| 641 | - background-repeat: no-repeat; | |
| 642 | - background-size: 100% 100%; | |
| 643 | - } | |
| 644 | 556 | |
| 645 | 557 | .flex-items-center { |
| 646 | 558 | display: flex; | ... | ... |