You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
251 lines
9.5 KiB
251 lines
9.5 KiB
11 months ago
|
{extend name="public/container"}
|
||
|
{block name="head_top"}
|
||
|
<style>
|
||
|
.layui-input-block button {
|
||
|
border: 1px solid rgba(0, 0, 0, 0.1);
|
||
|
}
|
||
|
|
||
|
.layui-card-body {
|
||
|
padding-left: 10px;
|
||
|
padding-right: 10px;
|
||
|
}
|
||
|
|
||
|
.layui-card-body p.layuiadmin-big-font {
|
||
|
font-size: 36px;
|
||
|
color: #666;
|
||
|
line-height: 36px;
|
||
|
padding: 5px 0 10px;
|
||
|
overflow: hidden;
|
||
|
text-overflow: ellipsis;
|
||
|
word-break: break-all;
|
||
|
white-space: nowrap;
|
||
|
}
|
||
|
|
||
|
.layui-fluid .layui-row . {
|
||
|
position: absolute;
|
||
|
right: 15px;
|
||
|
}
|
||
|
|
||
|
.layuiadmin-badge {
|
||
|
top: 50%;
|
||
|
margin-top: -9px;
|
||
|
color: #01AAED;
|
||
|
}
|
||
|
|
||
|
.layuiadmin-span-color i {
|
||
|
padding-left: 5px;
|
||
|
}
|
||
|
|
||
|
.layui-card.card {
|
||
|
border: 2px solid #F2F2F2;
|
||
|
border-radius: 2%;
|
||
|
}
|
||
|
|
||
|
.layui-card.checkcard {
|
||
|
border: 2px solid #F47822;
|
||
|
border-radius: 5px;
|
||
|
}
|
||
|
|
||
|
.block-rigit button {
|
||
|
width: 100px;
|
||
|
letter-spacing: .5em;
|
||
|
line-height: 28px;
|
||
|
}
|
||
|
|
||
|
.layui-form-item {
|
||
|
margin-bottom: .5rem;
|
||
|
}
|
||
|
|
||
|
.layui-form-item .code {
|
||
|
width: 15rem;
|
||
|
}
|
||
|
|
||
|
.layui-form-item .code img {
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
}
|
||
|
</style>
|
||
|
<script src="{__PLUG_PATH}echarts.common.min.js"></script>
|
||
|
{/block}
|
||
|
{block name="content"}
|
||
|
<div class="layui-fluid" id="app" v-cloak>
|
||
|
<div class="layui-row layui-col-space15">
|
||
|
<div class="layui-card">
|
||
|
<div class="layui-card-header">
|
||
|
购买服务
|
||
|
</div>
|
||
|
<div class="layui-tab layui-tab-brief" lay-filter="tab">
|
||
|
<ul class="layui-tab-title">
|
||
|
<li lay-id="list" class="layui-this" @click="changeMealType('sms')">短信
|
||
|
</li>
|
||
|
<li lay-id="list" @click="changeMealType('expr_query')">物流查询
|
||
|
</li>
|
||
|
</ul>
|
||
|
</div>
|
||
|
<div class="layui-row">
|
||
|
<div class="layui-card-body layui-col-space10">
|
||
|
<div class="layui-col-sm1 layui-col-md2" v-if="priceList.length" v-for="(item,index) in priceList"
|
||
|
@click="checkMeal(item,index)">
|
||
|
<div class="layui-card" :class="param == index ? 'checkcard' : 'card'">
|
||
|
<div class="layui-card-body" style="padding: 27px 15px 0;">
|
||
|
<p style="text-align: center;color: #F47822;font-size: 30px;line-height: 30px;">{{item.num }}条</p>
|
||
|
</div>
|
||
|
<div class="layui-card-header">
|
||
|
<p style="text-align: center;color: #C2C5BE;font-size: 16px;">¥{{ item.price }}</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-row layui-col-space15">
|
||
|
<div class="layui-card" v-show="checked">
|
||
|
<div class="layui-card-header">
|
||
|
立即支付
|
||
|
</div>
|
||
|
<div class="layui-card-body">
|
||
|
<div class="layui-row">
|
||
|
<form class="layui-form" action="">
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">短信账户:</label>
|
||
|
<div class="layui-input-block">
|
||
|
<span style="font-size: 24px;line-height: 33px;">{$info['account']}</span>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">支付方式:</label>
|
||
|
<div class="layui-input-block">
|
||
|
<button type="button" class="layui-btn" :class="payType == 'weixin'? 'layui-btn-normal' : 'layui-btn-primary'" @click="changeType('weixin')">微信支付
|
||
|
</button>
|
||
|
<!-- <button type="button" class="layui-btn" :class="payType == 'alipay'? 'layui-btn-normal' : 'layui-btn-primary'" @click="changeType('alipay')">支付宝-->
|
||
|
<!-- </button>-->
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">充值条数:</label>
|
||
|
<div class="layui-input-block">
|
||
|
<span style="font-size: 24px;line-height: 33px;">{{ checked.num }} 条</span>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">支付金额:</label>
|
||
|
<div class="layui-input-block">
|
||
|
<p style="line-height: 33px;font-size: 16px;color: #F47822;">¥{{ checked.price }}</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item" v-show="code.code_show">
|
||
|
<div class="layui-input-block code" >
|
||
|
<div id="qrcode" style="width:100px; height:100px; margin-top:15px;"></div>
|
||
|
</div>
|
||
|
<div class="layui-input-block">
|
||
|
<span>
|
||
|
支付码过期时间:{{code.invalid}}
|
||
|
</span>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item" v-show="!code.code_show">
|
||
|
<span>您尚未开通短信服务,请先开启<a href="{:Url('setting.systemPlat/sms_open')}" style="color: rgb(244, 120, 34);font-size: 20px;">开通服务</a></span>
|
||
|
</div>
|
||
|
</form>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<script src="{__ADMIN_PATH}js/layuiList.js"></script>
|
||
|
<script src="{__ADMIN_PATH}js/qrcode.js"></script>
|
||
|
<script>
|
||
|
require(['vue'], function (Vue) {
|
||
|
new Vue({
|
||
|
el: "#app",
|
||
|
data: {
|
||
|
type: 'sms',
|
||
|
number: 0,
|
||
|
send_total: 0,
|
||
|
option: {},
|
||
|
status: '',
|
||
|
data: '',
|
||
|
title: '全部商品',
|
||
|
myChart: {},
|
||
|
showtime: false,
|
||
|
priceList: [],
|
||
|
checked: false,
|
||
|
param: '',
|
||
|
payType: 'weixin',
|
||
|
code: '',
|
||
|
qrcode: ''
|
||
|
},
|
||
|
watch: {
|
||
|
"param": function (newVal) {
|
||
|
let that = this;
|
||
|
that.checked = that.priceList[newVal];
|
||
|
that.param = newVal;
|
||
|
that.getCode();
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
checkMeal: function (item, index) {
|
||
|
this.param = index;
|
||
|
},
|
||
|
changeMealType: function (val) {
|
||
|
if (val != this.type) {
|
||
|
this.type = val;
|
||
|
this.getLackList();
|
||
|
|
||
|
}
|
||
|
},
|
||
|
getLackList: function () {
|
||
|
var that = this;
|
||
|
var index = layList.layer.load(2, {shade: [0.3, '#fff']});
|
||
|
layList.baseGet(layList.Url({a: 'get_meal', p: {type: that.type}}), function (res) {
|
||
|
layList.layer.close(index);
|
||
|
that.priceList = res.data.data;
|
||
|
if (that.priceList.length > 0) {
|
||
|
that.checked = res.data.data[0];
|
||
|
that.param = 0;
|
||
|
}
|
||
|
that.getCode();
|
||
|
}, function (err) {
|
||
|
layList.layer.close(index);
|
||
|
});
|
||
|
},
|
||
|
changeType: function (val) {
|
||
|
if (val != this.payType) {
|
||
|
this.payType = val;
|
||
|
this.getCode();
|
||
|
}
|
||
|
},
|
||
|
getCode: function () {
|
||
|
let that = this;
|
||
|
let index = layList.layer.load(2, {shade: [0.3, '#fff']});
|
||
|
layList.basePost(layList.Url({a: 'pay'}), {
|
||
|
type: that.checked.type,
|
||
|
num: that.checked.num,
|
||
|
price: that.checked.price,
|
||
|
meal_id: that.checked.id,
|
||
|
pay_type: that.payType
|
||
|
}, function (res) {
|
||
|
layList.layer.close(index);
|
||
|
that.code = res.data;
|
||
|
that.qrcode.makeCode(res.data.qr_code);
|
||
|
}, function (err) {
|
||
|
layList.layer.close(index);
|
||
|
});
|
||
|
},
|
||
|
|
||
|
},
|
||
|
mounted: function () {
|
||
|
this.getLackList();
|
||
|
this.$nextTick(function () {
|
||
|
this.qrcode = new QRCode(document.getElementById("qrcode"), {
|
||
|
width : 100,
|
||
|
height : 100
|
||
|
});
|
||
|
})
|
||
|
}
|
||
|
});
|
||
|
})
|
||
|
</script>
|
||
|
{/block}
|