123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- <template>
- <view class="content">
- <view class="order-item">
- <view class="head dffd">
- <navigator url="/pages/user/funManage/recharge" class="rech fontsm dffs">
- 充值学豆
- <u-icon size="14" color="#fff" name="arrow-right"></u-icon>
- </navigator>
- <text class="white fontsm">已有学豆</text>
- <view class="mon">{{ userInfo.userInfo.bean || 0 }}</view>
- <view class="bot dffs">
- <image src="/static/img/pro/usicon.png" mode=""></image>
- 累积获得学豆
- <image src="/static/img/pro/usicon.png" mode=""></image>
- </view>
- </view>
- <view class="pageCon">
- <view class="pgConTitle">收支明细</view>
- <view class="listBox">
- <view v-for="(item, ind) in list" :key="ind" class="pgConBox bb">
- <view class="pgConTop dfsb">
- <text class="elli">{{ item.content }}</text>
- <text :class="[item.check == 1 ? 'red' : 'green', 'mon']">{{ item.money }}</text>
- </view>
- <view class="pgConBot dfsb">
- <text>{{ item.create_time }}</text>
- <text class="">余额: {{ item.after_money }}</text>
- </view>
- </view>
- </view>
- <view class="nodata" v-if="list.length < 1"><u-empty icon-size="200" text="还没有记录哦" mode="list"></u-empty></view>
- </view>
- </view>
- </view>
- </template>
- <script>
- import { mapState, mapActions } from 'vuex';
- export default {
- computed: {
- ...mapState({ userInfo: state => state.userInfo })
- },
- data() {
- return {
- list: [],
- status: 'more',
- page: 1,
- pagenum: 10
- };
- },
- async onLoad(options) {
- await this.loadData();
- },
- onReachBottom() {
- if (this.status == 'nomore') return;
- this.page = ++this.page;
- this.loadData();
- },
- methods: {
- //获取订单列表
- loadData() {
- // flag Number 类型: 1=余额 2=学豆
- this.$api
- .request('user/getMoneyLog', {
- flag: 2,
- page: this.page,
- limit: this.pagenum
- })
- .then(data => {
- if (data.code == 200) {
- this.list = this.list.concat(data.data.list);
- this.status = 'more';
- if (data.data.list.length < this.limit) {
- this.status = 'nomore';
- }
- } else {
- this.$api.toast(data.msg);
- }
- })
- .catch(function(error) {
- console.log(error);
- });
- }
- }
- };
- </script>
- <style lang="scss">
- .content {
- }
- .order-item {
- margin: 0rpx 6rpx;
- .head {
- background: url()
- no-repeat;
- background-size: 100% 100%;
- height: 264rpx;
- padding: 40rpx 30rpx;
- align-items: center;
- .rech {
- color: #fff;
- align-self: flex-end;
- }
- .mon {
- margin-top: 20rpx;
- font-size: 60rpx;
- font-family: PingFangSC-Semibold, PingFang SC;
- font-weight: 600;
- color: #ffffff;
- line-height: 84rpx;
- }
- .bot {
- color: #fff;
- font-size: 18rpx;
- image {
- width: 13rpx;
- height: 13rpx;
- margin: 0 12rpx;
- }
- }
- }
- .pageCon {
- margin-top: 45rpx;
- .pgConTitle {
- padding: 0 30rpx;
- font-size: 36rpx;
- line-height: 44rpx;
- font-family: PingFangSC-Medium, PingFang SC;
- font-weight: 500;
- color: #333333;
- }
- .listBox {
- padding: 0 30rpx;
- .pgConBox {
- padding: 30rpx 0;
- .pgConTop {
- align-items: flex-start;
- .elli {
- margin-right: 5rpx;
- flex: 1;
- }
- text {
- font-size: 30rpx;
- }
- .mon {
- font-size: 36rpx;
- font-family: DIN-Medium, DIN;
- font-weight: 500;
- }
- }
- .pgConBot {
- margin-top: 20rpx;
- text {
- color: $textgrey;
- font-size: 26rpx;
- line-height: 36rpx;
- }
- }
- }
- }
- }
- }
- </style>
|