123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- {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-col-sm6 layui-col-md3">
- <div class="layui-card">
- <div class="layui-card-header">
- 短信剩余条数
- <span class="layui-badge layuiadmin-badge layui-bg-blue">条</span>
- </div>
- <div class="layui-card-body">
- <p class="layuiadmin-big-font">{{number}}</p>
- </div>
- </div>
- </div>
- <div class="layui-col-sm6 layui-col-md3">
- <div class="layui-card">
- <div class="layui-card-header">
- 短信发送总条数
- <span class="layui-badge layuiadmin-badge layui-bg-cyan">条</span>
- </div>
- <div class="layui-card-body">
- <p class="layuiadmin-big-font">{{send_total}}</p>
- </div>
- </div>
- </div>
- </div>
- <div class="layui-row layui-col-space15">
- <div class="layui-card">
- <div class="layui-card-header">
- 选择套餐
- </div>
- <div class="layui-row">
- <div class="layui-card-body layui-col-space10">
- <div class="layui-col-sm1 layui-col-md2" 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">
- <button type="button" class="layui-btn" :class="payType == 'weixin'? 'layui-btn-normal' : 'layui-btn-primary'" @click="changeType('weixin')">微信支付</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">
- <div class="layui-input-block code">
- <img :src="code.code_url" alt="">
- </div>
- <div class="layui-input-block">
- <span>
- 支付码过期时间:{{code.invalid}}
- </span>
- </div>
- </div>
- </form>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- <script src="{__ADMIN_PATH}js/layuiList.js"></script>
- <script>
- require(['vue'],function(Vue){
- new Vue({
- el:"#app",
- data:{
- number:0,
- send_total:0,
- option:{},
- status:'',
- data:'',
- title:'全部商品',
- myChart:{},
- showtime:false,
- priceList:[],
- checked:false,
- param:'',
- payType: 'weixin',
- code: ''
- },
- 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;
- },
- info:function(){
- var that=this;
- var index=layList.layer.load(2,{shade: [0.3,'#fff']});
- layList.baseGet(layList.Url({a:'number'}),function (res){
- layList.layer.close(index);
- that.number = res.data.number;
- that.send_total = res.data.send_total;
- },function (err) {
- layList.layer.close(index);
- });
- },
- getLackList:function(){
- var that=this;
- var index=layList.layer.load(2,{shade: [0.3,'#fff']});
- layList.baseGet(layList.Url({a:'price'}),function (res){
- layList.layer.close(index);
- that.priceList = res.data;
- if(that.priceList.length > 0){
- that.checked = res.data[0];
- that.param = 0;
- }
- },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'}),{payType:that.payType,price:that.checked.price,mealId:that.checked.id},function (res){
- layList.layer.close(index);
- that.code = res.data;
- },function (err) {
- layList.layer.close(index);
- });
- },
- },
- mounted:function () {
- this.info();
- this.getLackList();
- }
- });
- })
- </script>
- {/block}
|