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.
116 lines
3.1 KiB
116 lines
3.1 KiB
<template>
|
|
<view>
|
|
<view class='sign-record'>
|
|
<view class='list' v-for="(item,index) in signList" :key="index">
|
|
<view class='item'>
|
|
<view class='data'>{{item.month}}</view>
|
|
<view class='listn'>
|
|
<view class='itemn acea-row row-between-wrapper' v-for="(itemn,indexn) in item.list" :key="indexn">
|
|
<view>
|
|
<view class='name line1'>{{$t(itemn.title)}}</view>
|
|
<view>{{itemn.add_time}}</view>
|
|
</view>
|
|
<view class='num'>+{{itemn.number}}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view class='loadingicon acea-row row-center-wrapper' v-if="signList.length > 0">
|
|
<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadtitle}}
|
|
</view>
|
|
<view v-if="signList.length == 0"><emptyPage :title="$t(`暂无签到记录~`)"></emptyPage></view>
|
|
</view>
|
|
<!-- #ifdef MP -->
|
|
<!-- <authorize @onLoadFun="onLoadFun" :isAuto="isAuto" :isShowAuth="isShowAuth" @authColse="authColse"></authorize> -->
|
|
<!-- #endif -->
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import { getSignMonthList } from '@/api/user.js';
|
|
import { toLogin } from '@/libs/login.js';
|
|
import { mapGetters } from "vuex";
|
|
import emptyPage from '@/components/emptyPage';
|
|
// #ifdef MP
|
|
import authorize from '@/components/Authorize';
|
|
// #endif
|
|
export default {
|
|
components: {
|
|
emptyPage,
|
|
// #ifdef MP
|
|
authorize
|
|
// #endif
|
|
},
|
|
data() {
|
|
return {
|
|
loading:false,
|
|
loadend:false,
|
|
loadtitle:this.$t(`加载更多`),
|
|
page:1,
|
|
limit:8,
|
|
signList:[],
|
|
isAuto: false, //没有授权的不会自动授权
|
|
isShowAuth: false //是否隐藏授权
|
|
};
|
|
},
|
|
computed: mapGetters(['isLogin']),
|
|
watch:{
|
|
isLogin:{
|
|
handler:function(newV,oldV){
|
|
if(newV){
|
|
this.getSignMoneList();
|
|
}
|
|
},
|
|
deep:true
|
|
}
|
|
},
|
|
onLoad(){
|
|
if(this.isLogin){
|
|
this.getSignMoneList();
|
|
}else{
|
|
toLogin();
|
|
}
|
|
},
|
|
onReachBottom: function () {
|
|
this.getSignMoneList();
|
|
},
|
|
methods: {
|
|
/**
|
|
*
|
|
* 授权回调
|
|
*/
|
|
onLoadFun:function(){
|
|
this.getSignMoneList();
|
|
},
|
|
// 授权关闭
|
|
authColse:function(e){
|
|
this.isShowAuth = e
|
|
},
|
|
/**
|
|
* 获取签到记录列表
|
|
*/
|
|
getSignMoneList:function(){
|
|
let that=this;
|
|
if(that.loading) return;
|
|
if(that.loadend) return;
|
|
that.loading = true;
|
|
that.loadtitle = "";
|
|
getSignMonthList({ page: that.page, limit: that.limit }).then(res=>{
|
|
let list = res.data;
|
|
let loadend = list.length < that.limit;
|
|
that.signList = that.$util.SplitArray(list, that.signList);
|
|
that.$set(that,'signList',that.signList);
|
|
that.loadend = loadend;
|
|
that.loading = false;
|
|
that.loadtitle = loadend ? that.$t(`我也是有底线的`) : that.$t(`加载更多`);
|
|
}).catch(err=>{
|
|
that.loading = false;
|
|
that.loadtitle = that.$t(`加载更多`);
|
|
});
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
</style>
|
|
|