rankList.vue 5.17 KB
<!--
 * @Author: hookehuyr hookehuyr@gmail.com
 * @Date: 2022-05-30 13:51:47
 * @LastEditors: hookehuyr hookehuyr@gmail.com
 * @LastEditTime: 2022-06-09 16:12:51
 * @FilePath: /tswj/src/views/client/donateList.vue
 * @Description: 幼儿园儿童捐赠金额排行榜
-->
<template>
  <div class="wrapper">
    <van-row>
      <van-col span="20" style="padding: 1rem 0.5rem 1rem 0;">
        <div :class="[kgInfo.multi_name ? 'heightHigh' : 'heightLow', 'kg-name']">
          <van-row align="center" justify="center" style="position: relative; top: 50%; transform: translateY(-50%);">
            <van-col span="4">
              <van-image round width="3.5rem" height="3.5rem" :src="kgInfo.kg_logo ? kgInfo.kg_logo : icon_logo" style="vertical-align: text-bottom;" />
            </van-col>
            <van-col span="20">
              <div v-if="kgInfo.multi_name" style="margin-left: 1.5rem;">
                <p>{{ kgInfo.multi_name[0] }}</p>
                <p>{{ kgInfo.multi_name[1] }}</p>
              </div>
              <p v-else style="margin-left: 1.5rem;">
                {{ kgInfo.kg_name }}
              </p>
            </van-col>
          </van-row>
        </div>
      </van-col>
      <van-col>
        <div class="flower">
          <van-icon :name="icon_flower" color="#c5c5c5" size="1.25rem" style="vertical-align: bottom;" />&nbsp;{{ kgInfo.kg_total }}
        </div>
      </van-col>
    </van-row>
  </div>
  <van-list v-model:loading="loading" :finished="finished" :finished-text="finishedTextStatus ? '没有更多了' : ''" :immediate-check="false" @load="onLoad">
    <div v-for="(rank, indexKey) in donateRankList" :key="indexKey" class="van-hairline--bottom">
      <van-row style="padding: 0.5rem;">
        <van-col span="2">
          <div v-if="indexKey < 3" class="glob-center">
            <van-icon v-if="indexKey === 0" :name="icon_ranking1" size="1.75rem" />
            <van-icon v-if="indexKey === 1" :name="icon_ranking2" size="1.75rem" />
            <van-icon v-if="indexKey === 2" :name="icon_ranking3" size="1.75rem" />
          </div>
          <div v-else class="glob-center" style="text-align: center; color: #84909F;">{{ indexKey + 1 }}&nbsp;</div>
        </van-col>
        <van-col span="4">
          <van-image round width="3rem" height="3rem" :src="rank.perf_avatar ? rank.perf_avatar : icon_avatar" />
        </van-col>
        <van-col span="14">
          <div class="name-info glob-center">
            <p>{{ rank.perf_name }}</p>
          </div>
        </van-col>
        <van-col span="4" style="text-align: right; font-size: 1rem;">
          <div class="glob-center" style="color: #222222;">
            <van-icon style="vertical-align: top;" size="1.25rem" :name="icon_flower" />
            <span>&nbsp;{{ rank.qty }}</span>
          </div>
        </van-col>
      </van-row>
    </div>
  </van-list>
  <van-empty v-if="emptyStatus" class="custom-image" :image="no_image" description="暂无明细" />
</template>

<script setup>
import { ref, onMounted } from 'vue'
import { useRoute } from 'vue-router'
import { useTitle } from '@/utils/generatePackage.js'
//import { } from '@/utils/generateModules.js'
import { icon_avatar, icon_ranking1, icon_ranking2, icon_ranking3, icon_flower, icon_logo, no_image } from '@/utils/generateIcons.js'
//import { } from '@/composables'
import { kgDonateRankAPI } from '@/api/C/kg.js'
const $route = useRoute();
useTitle($route.meta.title);

const kgInfo = ref({});
const kg_id = $route.query.kg_id;
const donateRankList = ref([])
const loading = ref(false)
const finished = ref(false)
const limit = ref(10)
const offset = ref(0)
const finishedTextStatus = ref(false);
const emptyStatus = ref(false);

onMounted(async () => {
  const { data } = await kgDonateRankAPI({ kg_id, limit: limit.value, offset: offset.value });
  kgInfo.value = data;
  donateRankList.value = data.rank_list;
  offset.value = donateRankList.value.length;
  // 有空格分割name
  if (kgInfo.value.kg_name.indexOf(' ') > -1) {
    kgInfo.value.multi_name = kgInfo.value.kg_name.split(' ');
  }
})


const onLoad = async () => {
  const { data } = await kgDonateRankAPI({ kg_id, limit: limit.value, offset: offset.value });
  donateRankList.value = [...donateRankList.value, ...data.rank_list];
  offset.value = donateRankList.value.length;
  loading.value = false;
  // 数据全部加载完成
  if (!data.rank_list.length) {
    // 加载状态结束
    finished.value = true;
  }
  if (!donateRankList.value.length) {
    finishedTextStatus.value = false;
    emptyStatus.value = true;
  } else {
    emptyStatus.value = false;
  }
}
</script>

<style lang="less" scoped>
.wrapper {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  background-color: #F7F7F7;
  position: relative;

  .rank {
    position: relative;

    .avatar {
      position: absolute;
      top: 0;
      left: 20%;
    }

    .text {
      position: absolute;
      top: 0.5rem;
      left: 40%;
      color: #84909F;
    }
  }

  .flower {
    text-align: center;
    position: absolute;
    top: 40%;
    right: 0.5rem;
    color: #713610;
    font-size: 1.25rem;
  }

  .kg-name {
    position: relative;
    height: 3rem;
  }

  .heightLow {
    height: 3rem;
  }

  .heightHigh {
    height: 6rem;
  }
}
</style>