member.vue 3.45 KB
<template>
  <div class="box">
    <el-breadcrumb class="mt20 mb20" :separator-icon="ArrowRight">
      <el-breadcrumb-item :to="{ path: '/' }">
        <el-icon>
          <HomeFilled/>
        </el-icon>
        首页
      </el-breadcrumb-item>
      <el-breadcrumb-item :to="{path:'/nationalTeam/index'}">国家队</el-breadcrumb-item>
      <el-breadcrumb-item>荣誉墙</el-breadcrumb-item>
    </el-breadcrumb>
  </div>
  <div class="flexBody box">
    <el-tabs v-model="activeName" tab-position="left" @tab-change="changeTab">
      <el-tab-pane v-for="(n,index) in list" :name="index">
        <template #label>
          <span class="custom-tabs-label">
            <span class="tabFont">{{ n.name }}</span>
          </span>
        </template>
      </el-tab-pane>
    </el-tabs>
    <el-row class="JsmemberList" :gutter="40">
      <el-col v-for="m in memberList" :lg="6" :md="8" :sm="12">
        <div class="item" @click="goLeaderInfo(m.id,m.playerLabelStr)">
          <div class="imgbox"><img :src="fillImgUrl_webSite(m.picUrl)"></div>
          <h3>{{ m.realName }}</h3>
          <!--<p v-for="p in m.remark?.split(',')">{{ p }}</p>-->
          <!--<p v-html="m.remark"></p>-->
        </div>
      </el-col>
      <el-col v-if="memberList?.length==0" :span="24">
        <el-empty description="暂无队员"/>
      </el-col>

    </el-row>

  </div>
  <div class="pc-page-box" v-if="total>8">
    <PaginationPc v-model:page="query.pageNum" v-model:limit="query.pageSize" :total="total" @pagination="getList"/>
  </div>
</template>

<script setup>
import { ArrowRight } from '@element-plus/icons-vue'
import { onMounted, ref } from 'vue'
import { getTeammate } from '@/apiPc/webSite'
import { useRouter } from 'vue-router'

const router = useRouter()
const activeName = ref(0)
const memberList = ref([])
const query = ref({
  pageSize: 12,
  pageNum: 1,
  label: 0
})
const total = ref(0)
const list = ref([
  { name: '全部队员', value: '' },
  { name: '国际级运动健将', value: '0' },
  { name: '运动健将', value: '1' },
  { name: '一级运动员', value: '2' },
  { name: '二级运动员', value: '3' },
  { name: '三级运动员', value: '4' }
])
const nowTab = ref({})
onMounted(() => {
  nowTab.value = list.value[0]
  init()
})
const init = () => {
  getTeammate(query.value).then(res => {
    memberList.value = res.data
    changeTab(0)
  })
}
const changeTab = (n) => {
  nowTab.value = list.value[n]
  query.value.label = list.value[n]?.value
  getList()
}

function getList() {
  getTeammate(query.value).then(res => {
    memberList.value = res.rows
    total.value = res.total
  })
}

function goLeaderInfo(id, name) {
  router.push({
    path: `/about/leader/${id}`,
    query: {
      name: encodeURIComponent(name),
      from: 'nationalTeam'
    }
  })
}
</script>

<style scoped lang="scss">

.custom-tabs-label {
  display: flex;
  align-items: center;
}

:deep(.el-tabs--left .el-tabs__item.is-left) {
  margin: 0 0 20px;
}

:deep(.el-tabs--left .el-tabs__active-bar.is-left) {
  left: 0 !important;
  right: auto !important;
}

:deep(.el-tabs--left .el-tabs__nav-wrap.is-left::after) {
  display: none;
}

:deep(.el-tabs__item.is-active) {
  font-size: 15px;
  background: #fff;
}

:deep(.el-tabs--left) {;
}

:deep(.el-tabs--left .el-tabs__header.is-left) {
  min-width: 200px;
  padding: 30px 0 30px 30px;
  height: 70vh;
  margin: 0;
  background: #f6f6f5
}

.tabFont {
  margin-left: 20px;
}

.el-tabs {
  min-width: 260px
}

.flexBody {
  display: flex
}
</style>