1 |
- import{d as q,$ as L,am as j,h as A,V as _,an as D,ao as F,a as t,I as m,G as B,H as U,j as r,E as k,x as w,C as E}from"./vendor.138103cd.js";/* empty css *//* empty css *//* empty css *//* empty css *//* empty css */import{i as h}from"./icon_teacher.40b6f077.js";import{r as b,s as S}from"./index.1773970e.js";const T="_headImg_l5yqu_1",V="_tabs_l5yqu_4",N="_tabContent_l5yqu_27",R="_itemContent_l5yqu_34",$="_item_l5yqu_34",M="_left_l5yqu_45",H="_center_l5yqu_50",O="_right_l5yqu_53",G="_fraction_l5yqu_57",P="_time_l5yqu_62",z="_user_l5yqu_73",J="_name_l5yqu_76",K="_tag_l5yqu_81",Q="_activeUser_l5yqu_92",W="_avator_l5yqu_105",X="_btn_l5yqu_110",Y="_num_l5yqu_116";var e={headImg:T,tabs:V,tabContent:N,itemContent:R,item:$,left:M,center:H,right:O,fraction:G,time:P,user:z,name:J,tag:K,activeUser:Q,avator:W,btn:X,num:Y},Z="./assets/icon-trophy.61957a4c.png",tt="./assets/icon-emtry.76ea3a6a.png";function et(c){return typeof c=="function"||Object.prototype.toString.call(c)==="[object Object]"&&!w(c)}var lt=q({name:"leaderboard",setup(){const c=L(),I=j(),i=A({tabIndex:0,musicList:[]}),x=async()=>{try{const{data:{activityMusicVoList:s,shareUrl:a}}=await b.post(`/api-student/open/activity/info/${c.query.id}`);Array.isArray(s)&&(i.musicList=s.map(n=>(n.rankingList=[],n.loaded=!1,n))),y.value=a}catch{}},p=async()=>{if(!i.musicList[i.tabIndex].loaded)try{const{data:s}=await b.get("/api-student/open/activityEvaluationRecord/queryRankingList",{params:{activityPlanId:c.query.id,activityEvaluationId:i.musicList[i.tabIndex].evaluationId,limit:10}});Array.isArray(s.rankingList)&&(i.musicList[i.tabIndex].rankingList=s.rankingList,i.musicList[i.tabIndex].loaded=!0)}catch{}},y=_(),g=_(!1),f=_(42),C=()=>{I.back()};D(async()=>{await x(),await p()});const u=F(()=>{var l,d;if(!i.musicList[i.tabIndex])return{};const s=S.user.data;if(!s.userId)return{};const a=i.musicList[i.tabIndex],n=(l=a==null?void 0:a.rankingList)==null?void 0:l.find(v=>v.userId==s.userId);let o=(d=a==null?void 0:a.rankingList)==null?void 0:d.findIndex(v=>v.userId==s.userId);return o=o>-1?o+1:0,{join:a.join,score:a.score,isTop:!!n,heardUrl:s.heardUrl,username:s.username,userId:s.userId,step:o}});return()=>{let s;return t("div",{class:e.leaderboard},[t("div",{class:e.container},[t("div",{class:e.headImg},[t(m,{width:"100%",fit:"cover",src:y.value,onLoad:a=>{f.value=a.target.height,g.value=!0}},null)]),g.value&&t(B,{active:i.tabIndex,"onUpdate:active":a=>i.tabIndex=a,class:e.tabs,animated:!0,swipeable:!0,titleInactiveColor:"#fff",titleActiveColor:"rgba(224,146,144,1)",onChange:a=>p()},et(s=i.musicList.map(a=>t(U,{title:a.musicSheetName},{default:()=>[t("div",{class:e.tabContent,style:{height:`calc(100vh - ${f.value}px)`}},[t("div",{class:e.itemContent},[t("div",{class:e.item},[t("div",{class:e.left},[r("\u6392\u540D")]),t("div",{class:e.center},[r("\u6635\u79F0")]),t("div",{class:e.right},[r("\u8BC4\u5206")])]),a.rankingList.map((n,o)=>{const l=(o+1).toString().padStart(2,"0"),d=(n.joinDate+"").split(" ")[0];return t("div",{class:e.item},[t("div",{class:e.left},[o==0?t(m,{src:Z},null):l]),t("div",{class:e.center},[t(m,{width:"34px",height:"34px",fit:"cover",round:!0,src:n.userAvatar||h},null),t("div",{class:e.user},[t("div",{class:e.name},[n.username]),t("div",{class:e.tag},[t("span",null,[n.userSubject])])])]),t("div",{class:e.right},[t("div",{class:e.fraction},[n.score,r("\u5206")]),t("div",{class:e.time},[d])])])}),!a.rankingList.length&&t(k,{image:tt,description:"\u8BE5\u66F2\u76EE\u6682\u65E0\u6392\u540D\u5594\uFF5E"},null)])])]})))?s:{default:()=>[s]}),u.value.userId&&t("div",{class:e.activeUser},[t(E,{center:!0,title:u.value.username},{icon:()=>t(m,{class:e.avator,fit:"cover",round:!0,src:u.value.heardUrl||h},null),label:()=>u.value.join?u.value.isTop?t("div",null,[r("\u60A8\u7684\u8BC4\u6D4B\u5DF2\u4E0A\u699C! \u5F53\u524D\u6392\u540D"),t("span",{style:{color:"#FA6400"}},[" ",u.value.step])]):t("div",null,[r("\u60A8\u7684\u8BC4\u6D4B\u6682\u672A\u4E0A\u699C\uFF0C\u5FEB\u53BB"),t("span",{style:{color:"#FA6400"},onClick:()=>C()},[r("\u6311\u6218")]),r("\u5427\uFF01")]):t("div",null,[r("\u60A8\u5C1A\u672A\u62A5\u540D\u53C2\u8D5B")]),value:()=>{if(u.value.join)return t("span",{class:e.num},[u.value.score,r("\u5206")])}})])])])}}});export{lt as default};
|