donateList.vue 4.41 KB
<!--
 * @Author: hookehuyr hookehuyr@gmail.com
 * @Date: 2022-05-30 13:51:47
 * @LastEditors: hookehuyr hookehuyr@gmail.com
 * @LastEditTime: 2022-06-25 12:21:31
 * @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 ? 'heightLow' : '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>
        <flower-icon type="right" :qty="kgInfo.kg_total" align="text-bottom" font-size="1.25rem" color="#713610" />
      </van-col>
    </van-row>
  </div>
  <van-list v-model:loading="loading" :finished="finished" :finished-text="finishedTextStatus ? '没有更多了' : ''"
    @load="onLoad">
    <template v-for="(item, key) in donateList" :key="key">
      <div class="van-hairline--bottom">
        <van-row style="padding: 0.5rem 1rem;">
          <van-col span="4">
            <van-image round width="3rem" height="3rem" :src="item.avatar ? item.avatar : icon_avatar" />
          </van-col>
          <van-col span="14">
            <div class="name-info global-center">
              <p>{{ item.name }}</p>
              <p style="color: #C5C5C5;">{{ item.donate_time }}</p>
            </div>
          </van-col>
          <van-col span="6" style="color: #222222; text-align: right; font-size: 1rem;">
            <flower-icon type="right" :qty="item.qty" align="top" color="#222222" />
          </van-col>
        </van-row>
      </div>
    </template>
  </van-list>
  <van-empty v-if="emptyStatus" class="custom-image" :image="no_image" description="暂无明细" />
</template>

<script setup>
import { onMounted, ref } from 'vue'
import { useRoute } from 'vue-router'
import { useTitle } from '@/utils/generatePackage.js'
//import { } from '@/utils/generateModules.js'
import { icon_avatar, no_image, icon_flower, icon_logo } from '@/utils/generateIcons.js'
//import { } from '@/composables'
import { kgDonateListAPI } from '@/api/C/kg.js'
import FlowerIcon from '@/components/FlowerIcon'

const $route = useRoute()
useTitle($route.meta.title);

const kgInfo = ref({});
const kg_id = $route.query.kg_id;
const donateList = 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);

const onLoad = async () => {
  const { data } = await kgDonateListAPI({ kg_id, limit: limit.value, offset: offset.value });
  kgInfo.value = data;
  // 有空格分割name
  if (kgInfo.value.kg_name.indexOf(' ') > -1) {
    kgInfo.value.multi_name = kgInfo.value.kg_name.split(' ');
  }
  donateList.value = [...donateList.value, ...data.donate_list];
  offset.value = donateList.value.length;
  loading.value = false;
  // 数据全部加载完成
  if (!data.donate_list.length) {
    // 加载状态结束
    finished.value = true;
  }
  if (!donateList.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>