You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2 lines
8.7 KiB

import{d as e,e as l,f as a,w as s,W as t,j as u,k as i,q as c,v as n,t as r,u as o,n as d,X as v,B as f,F as p,C as _,Y as g,H as m,Z as h,y,z as k,x as b,a6 as w,G as x,E as j,J as $,_ as S,T as C,s as F,$ as z,a0 as N,a1 as R,a2 as q,a3 as A}from"./index-BBl9NF8i.js";import{l as I}from"./content.DVkGYAJC.js";import{h as T,f as B}from"./geo.BHVFNtB7.js";import{u as E,t as G,g as H,m as J,a as W}from"./tip.CRDnOkzn.js";import{_ as X}from"./_plugin-vue_export-helper.BCo6x5W8.js";const Y=X(e({__name:"detail",setup(e){const X={science_venue:"科技场馆类",education_research:"教育科研类",agriculture:"“三农”类",enterprise:"企业类",nature_resource:"自然资源类",other:"其他类"},Y={free:"免费",paid:"收费"};function Z(e,l){let a=e.replace("#","").trim();if(3===a.length&&(a=a.split("").map(e=>e+e).join("")),6!==a.length)return`rgba(5, 201, 172, ${l})`;const s=parseInt(a,16);return`rgba(${s>>16&255},${s>>8&255},${255&s},${l})`}function D(e){if(!e||"string"!=typeof e)return"";const l="max-width:100%;height:auto;display:block;vertical-align:top;";return e.replace(/<img\b([\s\S]*?)(\/>|>)/gi,(e,a,s)=>{const t=String(a).trim();if(/style\s*=/i.test(t))return/max-width\s*:/i.test(t)?e:e.replace(/style\s*=\s*(["'])([\s\S]*?)\1/i,(e,a,s)=>/max-width/i.test(s)?e:`style=${a}${s};${l}${a}`);return`<img ${t} style="${l}"${"/>"===s?" />":">"}`})}function K(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function L(e){if(!e||!String(e).trim())return!1;return String(e).replace(/<[^>]+>/g," ").replace(/&nbsp;/gi," ").replace(/\s+/g," ").trim().length>0}const M=l(null),O=l(!0),P=l(!0),Q=l(!0),U=l(!1),V=l(!1),ee=l(!1),le=l("--"),ae=l(null),se=a(()=>{const e=M.value;return e?Array.isArray(e.carousel)&&e.carousel.length?e.carousel:e.cover_image?[{type:"image",url:e.cover_image}]:[]:[]}),te=a(()=>{var e;const l=null==(e=M.value)?void 0:e.reservation_notice;if(null==l||""===l)return"";const a=String(l);let s="";if(/<[a-z][\s\S]*>/i.test(a))s=D(a);else{s=`<div style="white-space:pre-wrap;font-size:13px;color:#4e5969;line-height:1.65;">${K(a)}</div>`}return L(s)?s:""});const ue=a(()=>{var e;return function(e){if(null==e||""===e)return"";const l=String(e);let a="";a=/<[a-z][\s\S]*>/i.test(l)?D(l):`<div style="white-space:pre-wrap;font-size:14px;color:#4e5969;line-height:1.65;">${K(l)}</div>`;return L(a)?a:""}(null==(e=M.value)?void 0:e.study_courses)}),ie=a(()=>{var e;const l=null==(e=M.value)?void 0:e.detail_html;if(!l)return"";const a=D(String(l));return L(a)?a:""}),ce=a(()=>{var e;const l=(null==(e=M.value)?void 0:e.venue_type_color)||"#05c9ac";return{color:l,backgroundColor:Z(l,.14),border:`1px solid ${Z(l,.35)}`}});function ne(){const e=M.value;if(!(null==e?void 0:e.lat)||!(null==e?void 0:e.lng)||!ae.value)return void(le.value="--");const l=T(ae.value.lat,ae.value.lng,Number(e.lat),Number(e.lng));le.value=B(l)}function re(){var e,l,a,s;const t=Number((null==(e=M.value)?void 0:e.lat)||0),u=Number((null==(l=M.value)?void 0:l.lng)||0);t&&u?z({latitude:t,longitude:u,name:(null==(a=M.value)?void 0:a.name)||"场馆",address:(null==(s=M.value)?void 0:s.address)||""}):F({title:"暂无导航坐标",icon:"none"})}return s(M,()=>{ne()}),s([ie,ue,te],()=>{O.value=!0,P.value=!0,Q.value=!0,N(()=>{setTimeout(()=>{var e;const l=null==(e=R())?void 0:e.proxy,a=q();l&&a.in(l);const s=A(180);a.select(".judge-intro").boundingClientRect(),a.select(".judge-courses").boundingClientRect(),a.select(".judge-notice").boundingClientRect(),a.exec(e=>{const[l,a,t]=e||[];U.value=!!(l&&l.height&&l.height>s+1),V.value=!!(a&&a.height&&a.height>s+1),ee.value=!!(t&&t.height&&t.height>s+1)})},120)})}),t(async e=>{const l=Number((null==e?void 0:e.id)||0);l&&(M.value=await I(l),c({type:"gcj02",success:e=>{ae.value={lat:e.latitude,lng:e.longitude},ne()},fail:()=>{le.value="--"}}))}),(e,l)=>{const a=m,s=h,t=g,c=v,F=n,z=b,N=S,R=d,q=C;return r(),u(F,{class:"page"},{default:i(()=>[o(R,{"scroll-y":"",class:"scroll"},{default:i(()=>[o(F,{class:"hero"},{default:i(()=>[se.value.length?(r(),u(c,{key:0,class:"hero-swiper",circular:"","indicator-dots":se.value.length>1,"indicator-active-color":"#05c9ac","indicator-color":"rgba(255,255,255,0.45)"},{default:i(()=>[(r(!0),f(p,null,_(se.value,(e,l)=>(r(),u(t,{key:"s-"+l,class:"swiper-item"},{default:i(()=>["video"!==e.type?(r(),u(a,{key:0,class:"slide-media",src:e.url,mode:"aspectFill"},null,8,["src"])):(r(),u(s,{key:1,class:"slide-media slide-video",src:e.url,controls:"","object-fit":"cover","show-center-play-btn":!0},null,8,["src"]))]),_:2},1024))),128))]),_:1},8,["indicator-dots"])):(r(),u(F,{key:1,class:"hero-placeholder"})),o(F,{class:"live-badge"},{default:i(()=>{var e;return[y(" 当前馆内人数:"+k((null==(e=M.value)?void 0:e.live_people_count)??0)+"人 ",1)]}),_:1})]),_:1}),o(F,{class:"main-card"},{default:i(()=>{var e,s,t,c,n,d;return[o(z,{class:"venue-name"},{default:i(()=>{var e;return[y(k((null==(e=M.value)?void 0:e.name)||"-"),1)]}),_:1}),(null==(e=M.value)?void 0:e.venue_type)||(null==(s=M.value)?void 0:s.ticket_type)||(null==(t=M.value)?void 0:t.district)?(r(),u(F,{key:0,class:"chip-row"},{default:i(()=>{var e,l,a;return[(null==(e=M.value)?void 0:e.venue_type)?(r(),u(z,{key:0,class:"chip",style:w(ce.value)},{default:i(()=>{return[y(k((e=M.value.venue_type,e?X[e]||e:"")),1)];var e}),_:1},8,["style"])):x("",!0),(null==(l=M.value)?void 0:l.ticket_type)?(r(),u(z,{key:1,class:j(["chip","paid"===M.value.ticket_type?"chip-paid":"chip-free"])},{default:i(()=>{return[y(k((e=M.value.ticket_type,e?Y[e]||e:"")),1)];var e}),_:1},8,["class"])):x("",!0),(null==(a=M.value)?void 0:a.district)?(r(),u(z,{key:2,class:"chip chip-district"},{default:i(()=>[y(k(M.value.district),1)]),_:1})):x("",!0)]}),_:1})):x("",!0),(null==(c=M.value)?void 0:c.unit_name)?(r(),u(F,{key:1,class:"info-row"},{default:i(()=>[o(a,{class:"info-ico",src:$(E),mode:"aspectFit"},null,8,["src"]),o(F,{class:"info-text-col"},{default:i(()=>[o(z,{class:"info-text"},{default:i(()=>[y("所属单位:"+k(M.value.unit_name),1)]),_:1})]),_:1})]),_:1})):x("",!0),(null==(n=M.value)?void 0:n.open_time)?(r(),u(F,{key:2,class:"info-row"},{default:i(()=>[o(a,{class:"info-ico",src:$(G),mode:"aspectFit"},null,8,["src"]),o(F,{class:"info-text-col"},{default:i(()=>[o(z,{class:"info-text"},{default:i(()=>[y("开放时间:"+k(M.value.open_time),1)]),_:1})]),_:1})]),_:1})):x("",!0),o(F,{class:"info-row"},{default:i(()=>[o(a,{class:"info-ico",src:$(H),mode:"aspectFit"},null,8,["src"]),o(F,{class:"info-text-col"},{default:i(()=>[o(z,{class:"info-text"},{default:i(()=>[y("距离:"+k(le.value),1)]),_:1})]),_:1})]),_:1}),(null==(d=M.value)?void 0:d.address)?(r(),u(F,{key:3,class:"info-row"},{default:i(()=>[o(a,{class:"info-ico",src:$(J),mode:"aspectFit"},null,8,["src"]),o(F,{class:"info-text-col"},{default:i(()=>[o(z,{class:"info-text"},{default:i(()=>[y("具体地址:"+k(M.value.address),1)]),_:1})]),_:1})]),_:1})):x("",!0),te.value?(r(),u(F,{key:4,class:"notice-block"},{default:i(()=>[o(F,{class:"sec-title-row notice-head-row"},{default:i(()=>[o(F,{class:"notice-head-left"},{default:i(()=>[o(a,{class:"info-ico",src:$(W),mode:"aspectFit"},null,8,["src"]),o(z,{class:"notice-label"},{default:i(()=>[y("预约须知")]),_:1})]),_:1}),ee.value?(r(),u(z,{key:0,class:"expand-link",onClick:l[0]||(l[0]=e=>Q.value=!Q.value)},{default:i(()=>[y(k(Q.value?"收起":"展开"),1)]),_:1})):x("",!0)]),_:1}),o(F,{class:j(["notice-block-body judge-notice",{"is-collapsed":ee.value&&!Q.value}])},{default:i(()=>[o(N,{class:"notice-inline-rich",nodes:te.value},null,8,["nodes"])]),_:1},8,["class"])]),_:1})):x("",!0)]}),_:1}),ie.value?(r(),u(F,{key:0,class:"intro-card"},{default:i(()=>[o(F,{class:"sec-title-row"},{default:i(()=>[o(z,{class:"sec-title"},{default:i(()=>[y("场馆介绍")]),_:1}),U.value?(r(),u(z,{key:0,class:"expand-link",onClick:l[1]||(l[1]=e=>O.value=!O.value)},{default:i(()=>[y(k(O.value?"收起":"展开"),1)]),_:1})):x("",!0)]),_:1}),o(F,{class:j(["intro-rich-wrap judge-intro",{"is-collapsed":U.value&&!O.value}])},{default:i(()=>[o(N,{class:"intro-rich",nodes:ie.value},null,8,["nodes"])]),_:1},8,["class"])]),_:1})):x("",!0),ue.value?(r(),u(F,{key:1,class:"courses-card"},{default:i(()=>[o(F,{class:"sec-title-row"},{default:i(()=>[o(z,{class:"sec-title"},{default:i(()=>[y("研学课程")]),_:1}),V.value?(r(),u(z,{key:0,class:"expand-link",onClick:l[2]||(l[2]=e=>P.value=!P.value)},{default:i(()=>[y(k(P.value?"收起":"展开"),1)]),_:1})):x("",!0)]),_:1}),o(F,{class:j(["courses-rich-wrap judge-courses",{"is-collapsed":V.value&&!P.value}])},{default:i(()=>[o(N,{class:"courses-rich",nodes:ue.value},null,8,["nodes"])]),_:1},8,["class"])]),_:1})):x("",!0),o(F,{class:"safe-bottom"})]),_:1}),o(F,{class:"action-bar"},{default:i(()=>[o(q,{class:"btn primary",onClick:re},{default:i(()=>[y("一键导航")]),_:1})]),_:1})]),_:1})}}}),[["__scopeId","data-v-6c083375"]]);export{Y as default};