|
|
import{C as e,Ct as t,D as n,E as r,G as i,I as a,Qt as ee,S as o,T as s,X as te,Y as c,at as l,b as u,ht as d,m as f,ot as p,q as m,rt as h,tn as g,y as _,z as ne}from"./vue.runtime.esm-bundler-DUiYyeqQ.js";import{C as v,S as re,_ as y,b as ie,s as b,u as ae,x as oe}from"./index-j1gM0XLI.js";import{t as se}from"./usePageLoad-DFTLo_Lv.js";import{u as ce}from"./assets-BATlskhA.js";import{t as le}from"./TeacherDetailDialog-vyw-G-Ds.js";import{n as ue}from"./teacherStar-DhP_EdY6.js";import{i as de,n as fe,o as pe,r as me}from"./tiandituMap-B5qXv89S.js";/* empty css */var he={class:`dashboard-page executive-dashboard`},ge={key:0,class:`radar-top-grid`},x={class:`radar-kpi`},S={class:`kpi-icon`},C={class:`radar-kpi`},w={class:`kpi-icon`},T={class:`radar-kpi`},E={class:`kpi-icon`},D={class:`radar-kpi`},O={class:`kpi-icon`},k={class:`radar-map-card`},A={class:`radar-main`},j={class:`radar-map-container-wrap`},M={key:0,class:`radar-map-placeholder`},N={key:1,class:`radar-map-placeholder`},P={class:`radar-side`},F={class:`radar-side-head`},I={key:0,class:`radar-side-count`},L={class:`radar-side-body`},_e={key:0,class:`radar-empty-panel`},ve={class:`radar-teacher-avatar`},ye=[`onClick`],be={class:`stars`},xe={class:`radar-empty-panel`},Se={key:0,class:`radar-view-summary`},Ce={class:`radar-bottom-grid`},we={class:`radar-info-card`},Te={class:`radar-school-list`},Ee={class:`radar-info-card`},De={class:`radar-field-list`},Oe={class:`radar-field-bar`},ke={key:0,class:`empty-hint`},R=b(n({__name:`index`,setup(n){let b=d(!1),R=d(!1),z=d(``),B=d(null),V=d(null),H=d(!1),U=d(null),W=d(null),G=null,K=[],q=_(()=>B.value?.summary),Ae=_(()=>B.value?.quality||[]),J=_(()=>B.value?.research_fields||[]),je=_(()=>Math.max(...J.value.map(e=>e.percent),1));function Me(e,t){return e?e.length>t?`${e.slice(0,t)}…`:e:``}function Ne(e){return ue(e.star_level_item?.value,e.star_level_item?.label)}function Y(e){U.value=e,H.value=!0}function X(e){V.value=e,Pe()}function Pe(){let e=V.value?.id??null;for(let{overlay:t,schoolId:n}of K)t.setActive?.(n===e)}async function Z(){b.value=!0;try{B.value=await ce(),V.value&&=B.value.schools.find(e=>e.id===V.value?.id)||null,await a(),await Q()}finally{b.value=!1}}async function Q(){if(!W.value)return;if(z.value=``,!de()){z.value=`未配置天地图 Key(VITE_TIANDITU_TK)`;return}let e=B.value?.schools||[];if(!e.length){$();return}R.value=!0;try{let t=await pe();$();let n=W.value;n.innerHTML=``,G=new t.Map(n),G.enableScrollWheelZoom(),K=[];let r=V.value?.id??null;for(let n of e){let e=me(t,{name:n.name,longitude:n.longitude,latitude:n.latitude},r===n.id);G.addOverLay(e),e.addEventListener(`click`,()=>X(n)),K.push({overlay:e,schoolId:n.id})}fe(G,t)}catch(e){let t=e instanceof Error?e.message:`地图初始化失败`;z.value=t.includes(`脚本`)||t.includes(`SDK`)?`${t}。若 Key 已配置域名白名单,请使用 https://slake.ali251.langye.net 访问(本地可在 hosts 绑定该域名后访问 http://slake.ali251.langye.net:5173)`:t,$()}finally{R.value=!1}}function $(){if(G){for(let{overlay:e}of K)try{G.removeOverLay(e)}catch{}G.clearOverLays?.()}K=[],G=null}return h(()=>B.value?.schools.length,()=>{B.value&&!b.value&&a(()=>Q())}),se(Z),ne($),(n,a)=>{let d=c(`el-icon`),h=c(`el-button`),_=te(`loading`);return p((i(),e(`div`,he,[a[18]||=u(`div`,{class:`page-head`},[u(`h1`,{class:`radar-page-title`},`高校雷达网地图`)],-1),q.value?(i(),e(`div`,ge,[u(`div`,x,[u(`span`,S,[r(d,null,{default:l(()=>[r(t(ie))]),_:1})]),a[1]||=u(`span`,null,[s(`已覆盖高校`),u(`em`,null,`已配置经纬度的高校`)],-1),u(`strong`,null,g(q.value.covered_schools),1)]),u(`div`,C,[u(`span`,w,[r(d,null,{default:l(()=>[r(t(v))]),_:1})]),a[2]||=u(`span`,null,[s(`关联老师`),u(`em`,null,`地图点位老师总数`)],-1),u(`strong`,null,g(q.value.map_teachers),1)]),u(`div`,T,[u(`span`,E,[r(d,null,{default:l(()=>[r(t(re))]),_:1})]),a[3]||=u(`span`,null,[s(`五星老师`),u(`em`,null,`高价值合作对象`)],-1),u(`strong`,null,g(q.value.five_star_teachers),1)]),u(`div`,D,[u(`span`,O,[r(d,null,{default:l(()=>[r(t(y))]),_:1})]),a[4]||=u(`span`,null,[s(`待补坐标`),u(`em`,null,`高校坐标待完善`)],-1),u(`strong`,null,g(q.value.pending_coords),1)])])):o(``,!0),u(`section`,k,[a[15]||=u(`div`,{class:`radar-map-toolbar`},[u(`h2`,null,`高校分布`),u(`span`,{class:`toolbar-hint`},`以苏州为中心展示,点击圆点或学校名称查看高校详情`)],-1),u(`div`,A,[u(`div`,j,[z.value?(i(),e(`div`,M,[r(d,{size:24},{default:l(()=>[r(t(ae))]),_:1}),a[5]||=u(`strong`,null,`地图暂不可用`,-1),u(`span`,null,g(z.value),1)])):!B.value?.schools.length&&!R.value?(i(),e(`div`,N,[r(d,{size:24},{default:l(()=>[r(t(y))]),_:1}),a[6]||=u(`strong`,null,`暂无地图点位`,-1),a[7]||=u(`span`,null,`请先在「高校坐标库」维护经纬度。`,-1)])):p((i(),e(`div`,{key:2,ref_key:`mapContainerRef`,ref:W,class:`radar-map-container`},null,512)),[[_,R.value]])]),u(`aside`,P,[u(`div`,F,[u(`h3`,null,g(V.value?.name||`高校详情`),1),V.value?(i(),e(`span`,I,[r(d,null,{default:l(()=>[r(t(v))]),_:1}),s(` `+g(V.value.teachers_count)+` 位 `,1)])):o(``,!0)]),u(`div`,L,[V.value?(i(),e(f,{key:0},[V.value.teachers.length?o(``,!0):(i(),e(`div`,_e,[r(d,{size:20},{default:l(()=>[r(t(v))]),_:1}),a[8]||=u(`strong`,null,`暂无关联老师`,-1),a[9]||=u(`span`,null,`该校已在地图上展示,可在老师库中关联高校后在此查看老师列表。`,-1)])),(i(!0),e(f,null,m(V.value.teachers,n=>(i(),e(`div`,{key:n.id,class:`radar-teacher-card`},[u(`span`,ve,[r(d,null,{default:l(()=>[r(t(v))]),_:1})]),u(`span`,null,[u(`button`,{type:`button`,class:`radar-teacher-name`,onClick:e=>Y(n.id)},g(n.name),9,ye),u(`em`,null,g(Me(n.research_direction,16)),1),u(`i`,be,g(Ne(n)),1)]),r(h,{size:`small`,plain:``,onClick:e=>Y(n.id)},{default:l(()=>[...a[10]||=[s(`详情`,-1)]]),_:1},8,[`onClick`])]))),128))],64)):(i(),e(f,{key:1},[u(`div`,xe,[r(d,{size:20},{default:l(()=>[r(t(oe))]),_:1}),a[11]||=u(`strong`,null,`选择高校点位`,-1),a[12]||=u(`span`,null,`点击地图上的高校圆点,右侧会显示该校信息及关联老师列表。`,-1)]),q.value?(i(),e(`div`,Se,[a[13]||=u(`span`,null,`当前视图点位`,-1),u(`strong`,null,g(q.value.visible_points),1),a[14]||=u(`span`,null,`最高星级老师`,-1),u(`strong`,null,g(q.value.max_star)+` 星`,1)])):o(``,!0)],64))])])])]),u(`div`,Ce,[u(`section`,we,[a[16]||=u(`h2`,null,`数据质量`,-1),u(`div`,Te,[(i(!0),e(f,null,m(Ae.value,t=>(i(),e(`div`,{key:t.label,class:`radar-school-row`},[u(`span`,null,[s(g(t.label),1),u(`em`,null,g(t.detail),1)])]))),128))])]),u(`section`,Ee,[a[17]||=u(`h2`,null,`研究方向分布`,-1),u(`div`,De,[(i(!0),e(f,null,m(J.value,t=>(i(),e(`div`,{key:t.label,class:`radar-field-row`},[u(`span`,null,[s(g(t.label)+` `,1),u(`em`,null,g(t.count)+` 位老师`,1),u(`div`,Oe,[u(`i`,{style:ee({width:`${Math.round(t.percent/je.value*100)}%`})},null,4)])]),u(`strong`,null,g(t.percent)+`%`,1)]))),128)),J.value.length?o(``,!0):(i(),e(`p`,ke,`暂无研究方向统计数据`))])])]),r(le,{modelValue:H.value,"onUpdate:modelValue":a[0]||=e=>H.value=e,"teacher-id":U.value,readonly:``,onSaved:Z},null,8,[`modelValue`,`teacher-id`])])),[[_,b.value]])}}}),[[`__scopeId`,`data-v-7543633c`]]);export{R as default}; |