Browse Source

add black ls api

feat-230721
刘嘉炜 2 years ago
parent
commit
acb2f6b8d2
  1. 2
      src/subpackage/blacklist/js/api.js
  2. 137
      src/subpackage/blacklist/pages/abnormal_list/abnormal_list.vue

2
src/subpackage/blacklist/js/api.js

@ -3,6 +3,8 @@ import { ORIGIN } from '../../../js/api';
export const BLACKLIST_API = { export const BLACKLIST_API = {
stadiumList:`${ORIGIN}/admin/stadium/list`, // 店铺列表 stadiumList:`${ORIGIN}/admin/stadium/list`, // 店铺列表
identifyRecords:`${ORIGIN}/admin/stadium/identify/records`, // 疑似逃票的记录 identifyRecords:`${ORIGIN}/admin/stadium/identify/records`, // 疑似逃票的记录
blacklistAdd:`${ORIGIN}/admin/user/blacklist/add`, // 黑名单添加-后台
blacklistRemove:`${ORIGIN}/admin/user/blacklist/remove`, // 黑名单移除-后台
} }

137
src/subpackage/blacklist/pages/abnormal_list/abnormal_list.vue

@ -5,7 +5,7 @@
<picker :range="stadiumLs" range-key="name" @change="stadiumChange"> <picker :range="stadiumLs" range-key="name" @change="stadiumChange">
<view class="asc-frame"> <view class="asc-frame">
<view class="af-content"> <view class="af-content">
<view class="ac-txt">{{ selectStadium.name || '全部' }}</view>
<view :class="[ 'ac-txt', selectStadium.name?'select':'' ]">{{ selectStadium.name || '全部' }}</view>
<image class="ac-icon" mode="aspectFit" src="/subpackage/blacklist/static/images/arrow.png"></image> <image class="ac-icon" mode="aspectFit" src="/subpackage/blacklist/static/images/arrow.png"></image>
</view> </view>
</view> </view>
@ -20,29 +20,40 @@
</picker> </picker>
</view> </view>
<view class="al-list"> <view class="al-list">
<view class="al-item" v-for="i in 5" :key="i">
<view class="al-title">欧轩智能羽毛球馆(永泰店)</view>
<view class="al-item" v-for="(e, i) in blackLs" :key="i">
<view class="al-title">{{ e.extension.stadium_name || '-' }}</view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">订单编号20195175645666</view>
<view class="ai-tag">租场</view>
<view class="ai-txt">订单编号{{ e.order_no || '-' }}</view>
<view class="ai-tag">{{ e.type || '-' }}</view>
</view> </view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">用户信息183165538周大强</view>
<view class="ai-txt">用户信息{{ e.extension.mobile || '-' }}{{ e.extension.nickname || '-' }}</view>
</view> </view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">核销码200801108978</view>
<view class="ai-txt">核销码{{ e.verify_code || '-' }}</view>
</view> </view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">验证方式扫码器验证(pad)</view>
<view class="ai-txt">验证方式{{ e.verify_desc || '-' }}</view>
</view> </view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">核销时间2021-05-17 11:12:58</view>
<view class="ai-txt">核销时间{{ e.verify_leave_time || '-' }}</view>
</view> </view>
<view class="ai-line"> <view class="ai-line">
<view class="ai-txt">抓拍图片</view> <view class="ai-txt">抓拍图片</view>
<view class="ai-img"></view>
<view class="ai-img">
<image
v-if="e.evidence_img"
@click="previewImg(e.evidence_img || '')"
mode="aspectFit"
:src="e.evidence_img || ''"
></image>
</view> </view>
<view :class="['ai-btn', i%2 ==0?'red':'']" @click="operateBtn">移出黑名单</view>
</view>
<view
v-if="e.in_black_list === 1 || e.in_black_list === 0"
:class="['ai-btn', e.in_black_list === 1?'red':'']"
@click="operateBtn(e, i)"
>{{e.in_black_list === 1?'移出黑名单':'加入黑名单'}}</view>
</view> </view>
</view> </view>
@ -59,6 +70,8 @@ export default {
stadiumLs: [], stadiumLs: [],
selectStadium: {}, selectStadium: {},
curDate: '', curDate: '',
blackLs: [],
page: 1
} }
}, },
async onLoad(options){ async onLoad(options){
@ -73,41 +86,119 @@ export default {
console.warn('get records ls err --->', err); console.warn('get records ls err --->', err);
} }
}, },
onReachBottom(){
let { selectStadium, curDate, page } = this;
this.getRecords({
brand_id: selectStadium.brand_id,
stadium_id: selectStadium.id,
verify_time: curDate,
page: ++page
})
},
methods: { methods: {
previewImg(url){
uni.previewImage({ urls: [url] })
},
getRecords({ getRecords({
authority = 'wx',
authority = 'wx', // 便
brand_id = 63, brand_id = 63,
stadium_id = '', stadium_id = '',
page = 1, page = 1,
page_size = 15,
page_size = 10,
verify_time = '' verify_time = ''
}){ }){
util.showLoad();
server.get({ server.get({
url: BLACKLIST_API.identifyRecords, url: BLACKLIST_API.identifyRecords,
data: { data: {
authority, brand_id, page, page_size, authority, brand_id, page, page_size,
stadium_id, verify_time
stadium_id: stadium_id || '', verify_time
}, },
failMsg: '加载列表失败!' failMsg: '加载列表失败!'
}) })
.then(res => { .then(res => {
console.warn('getRecords->', res);
util.hideLoad();
let _ls = res.list || [];
if(page ===1)return this.blackLs = _ls;
if(!_ls.length)return util.showNone('没有更多数据!');
this.page = page;
this.blackLs = [ ...this.blackLs, ..._ls ];
}) })
}, },
dateChange(e){ dateChange(e){
this.curDate = e.detail.value || '-'
let { selectStadium } = this;
let _date = e.detail.value || '-'
this.curDate = _date;
this.page = 1;
this.blackLs = [];
this.getRecords({
brand_id: selectStadium.brand_id,
stadium_id: selectStadium.id,
verify_time: _date,
})
}, },
stadiumChange(e){ stadiumChange(e){
let { stadiumLs } = this;
this.selectStadium = stadiumLs[e.detail.value]
let { stadiumLs, curDate } = this;
let _curStadium = stadiumLs[e.detail.value] || {};
this.selectStadium = _curStadium;
this.page = 1;
this.blackLs = [];
this.getRecords({
brand_id: _curStadium.brand_id,
stadium_id: _curStadium.id,
verify_time: curDate,
})
}, },
operateBtn(){
operateBtn(e, idx){
let _status = e.in_black_list || ''
let _qry = {
uid: e.user_id,
brand_id: e.brand_id,
idx: idx,
status: _status,
}
if(_status == 0)return this.modalToDo({ qry: _qry, content: '确定将该用户拉入黑名单吗?确定后用户将不能再进入小程序' });
if(_status === 1)return this.modalToDo({ qry: _qry, content: '确定移出黑名单吗?' });
},
modalToDo({ qry, content }){
util.showModal({ util.showModal({
title: '提示', title: '提示',
content: '确定将该用户拉入黑名单吗?确定后用户将不能再进入小程序',
content: content,
showCancel: true, showCancel: true,
success: mRes => {
if(mRes.confirm)this.blackLsOpt(qry);
}
}) })
}, },
blackLsOpt: util.debounce(function({ uid, brand_id, idx, status}){
let _url = '';
if(status == 0)_url = BLACKLIST_API.blacklistAdd;
if(status == 1)_url = BLACKLIST_API.blacklistRemove;
util.showLoad();
server.get({
url: _url,
data: {
id: uid,
brand_id,
},
isDefaultGet: false
})
.then(res=>{
util.hideLoad();
if(res.data.code == 0){
util.showNone('操作成功!');
let _blackLs = this.blackLs || [];
_blackLs[idx].in_black_list = status == 0 ? 1 : 0;
this.blackLs = _blackLs;
setTimeout(_=>this.$forceUpdate(), 1200);
}else{
util.showNone(res.data.message || '操作失败!稍后重试');
}
})
}, 300, true),
// //
getStoreList({ getStoreList({
page=1, page=1,
@ -125,7 +216,7 @@ export default {
}) })
.then(res=>{ .then(res=>{
let _list = res.list || []; let _list = res.list || [];
_list.unshift({ name: '全部', id: 0 })
_list.unshift({ name: '全部', id: '' })
this.stadiumLs = _list; this.stadiumLs = _list;
return _list return _list
}) })
@ -163,6 +254,9 @@ export default {
@include textHide(1); @include textHide(1);
font-size: 28upx; font-size: 28upx;
color: #9c9c9f; color: #9c9c9f;
&.select{
color: #1A1A1A;
}
} }
.ac-icon{ .ac-icon{
flex-shrink: 0; flex-shrink: 0;
@ -228,7 +322,6 @@ export default {
height: 180upx; height: 180upx;
overflow: hidden; overflow: hidden;
border-radius: 6upx; border-radius: 6upx;
background-color: skyblue;
>image{ >image{
width: 100%; width: 100%;
height: 100%; height: 100%;

Loading…
Cancel
Save