@scrolltolower="outerToLowerHandler"
>
<view class="detail-imgs">
<view class="no-img" v-if="nearShop.imgs == null || nearShop.imgs.length === 0">
<image src="/static/images/noimg.png"/>
</view>
<swiper v-else circular :indicator-dots="true" :autoplay="true" :interval="5000" :duration="500">
<swiper-item v-for="(content,index) in nearShop.imgs" :key="index">
<image :src="content.url" @click="previewImage(index)"/>
</swiper-item>
</swiper>
</view>
<view class="content">
<!-- 商户信息 -->
<view class="merchant-info">
<view class="name">{{ nearShop.name }}</view>
<view class="open-time">开放时间:{{ nearShop.businessHoursStart + '-' + nearShop.businessHoursEnd }}</view>
</view>
<!-- 地址信息 -->
<view class="address-info">
<view class="address">
<view class="journey">距离我的位置有25.7公里</view>
<view class="specific-address tui-ellipsis">{{ nearShop.address }}</view>
</view>
<view class="map">
<image src="/pagesNls/static/imgs/marker.png" />
<text>地图</text>
</view>
<image src="/pagesNls/static/imgs/phone-icon.png" />
</view>
</view>
<!-- 房间信息 -->
<view class="room-info">
<tui-tabs tabs="tabs" currentTab="currentTab" zIndex="1" sliderHeight="48"
sliderWidth="156"
sliderBgColor="#3A8BE6"
sliderRadius="48rpx"
bottom="8"
selectedColor="#fff"
color="#333"
@change="changeHandler"
></tui-tabs>
<!-- 互动区域 -->
<swiper
class="content-swiper" current="currentTab" duration="300" @change="swiperChangeHandler"
>
<!-- 选房 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
<RoomItem v-for="item in 10" :key="item" />
</view>
</scroll-view>
</swiper-item>
<!-- 服务 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
111
</view>
</scroll-view>
</swiper-item>
<!-- 简介 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
<rich-text :nodes="formatRichText(nearShop.remark)"></rich-text>
</view>
</scroll-view>
</swiper-item>
<!-- 评价 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
aaa
</view>
</scroll-view>
</swiper-item>
</swiper>
</view>
<!-- 图片预览 -->
<tui-gallery :urls="urls" :current="currentIndex" :show="show" @hide="show = false"></tui-gallery>
</scroll-view>
</template>
<script>
import { recordStatVisit } from '@/common/api.js';
import RoomItem from './components/RoomItem.vue';
import { debounce } from '../../components/common/tui-utils/tui-utils';
export default {
components: {
RoomItem
},
data() {
return {
outerScroll: true,
innerScroll: false,
clientHeight: 0,
outerTimer: null,
innerTimer: null,
nearShop: {
"address":"安徽省黄山市黟县西递镇西递西香园客栈西递古村落",
"businessHoursEnd":"23:59",
"businessHoursStart":"00:00",
"businessStatus":"IN_BUSINESS",
"businessStatusText":"营业中",
"communityIds":null,
"communityInfos":null,
"contactName":"1",
"contactTel":"15095227799",
"createTime":"2025-01-14 17:39:35",
"createUserId":100170,
"createUserInfo":null,
"deleteTime":null,
"discountRule":"",
"discountStatus":null,
"discountStatusText":"未知",
"entryStatus":"ESTABLISHED",
"entryStatusText":"已入驻",
"fmImgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/138c1f01-d8ef-41a7-827c-e027c0c8713b.jpg"
}
],
"gdInfo":{
"id":341023103200,
"level":5,
"name":"西递村委会",
"parent":{
"id":341023103000,
"level":4,
"name":"西递镇",
"parent":{
"id":341023000000,
"level":3,
"name":"黟县",
"parent":{
"id":341000000000,
"level":2,
"name":"黄山市",
"parent":{
"id":340000000000,
"level":1,
"name":"安徽省",
"parent":null,
"parentId":0,
"status":1
},
"parentId":340000000000,
"status":1
},
"parentId":341000000000,
"status":1
},
"parentId":341023000000,
"status":1
},
"parentId":341023103000,
"status":1
},
"governmentDistrictId":341023103200,
"hotline":"18255962666",
"id":100052,
"imgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/5bd6f7a6-fdfe-49fa-b568-33d64f1195e0.jpg"
},
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/d00bc01a-528b-4c5a-b8ea-f82fa9cb43f1.jpg"
},
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/9f8f4f29-f9aa-402b-8d93-9d7dde912440.jpg"
}
],
"latitude":29.901661,
"longitude":117.993477,
"name":"泊心云舍·明经园(黄山黟县西递古村店)",
"notice":"<p><strong>订房必读</strong>:<br/>到达提示:<br/>酒店位于景区内,进入酒店需购买景区门票,请提前联系酒店确认景区营业时间及门票购买事宜。</p><p></p><p><strong>入离时间:</strong><br/><strong>入住时间: 14:00后</strong><br/><strong>退房时间: 12:00前</strong></p><p></p><p><strong>接待提示</strong><br/><strong>年龄限制</strong><br/>入住办理人需年满18岁<br/><strong>可接待人群</strong><br/>接待来自任何国家/地区的客人</p><p><br/><strong>前台服务</strong><br/>前台营业时间:24小时营业</p><p></p><p><strong>宠物</strong><br/>不可携带宠物</p><p>服务型动物<br/>不可携带服务型动物</p><p></p><p><strong>早餐</strong><br/>餐食类型:西式、中式<br/>餐食形式:<br/>自助餐,¥128每份 每天07:30-10:00开放</p><p></p><p><strong>预订提示</strong><br/>订单需等酒店或供应商确认后生效,订单确认结果以平台短信、邮件或app通知为准。</p><p>收费说明<br/>住宿方不收取押金</p><p></p><p><strong>客房使用</strong><br/><strong>商业拍摄</strong><br/>允许商业拍摄<br/><strong>做饭</strong><br/>不允许做饭<br/><strong>派对</strong><br/>允许举办派对/活动</p><p></p><p><strong>支付方式</strong><br/></p><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/111_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/113_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/141_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/14_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/6_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/7_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap\"><img class=\"media-wrap image-wrap\" src=\"https://pages.c-ctrip.com/hotels/creditcard/8_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><p></p><p><strong>儿童及加床</strong><br/>欢迎携带儿童入住</p><p><br/><strong>婴儿床及加床政策</strong><br/>所有房型不可加床、不提供婴儿床<br/>年龄床铺费用</p><p>6岁及以下使用现有床铺<span style=\"color:#06875a\">免费</span></p><p>7-14岁使用现有床铺¥ 388/人·晚</p><p>15-17岁使用现有床铺¥ 688/人·晚</p><p></p><p><strong>儿童早餐</strong><br/>年龄费用6岁及以下<span style=\"color:#06875a\">免费</span></p><p>7-14岁¥ 68/人</p><p>15-17岁¥ 128/人</p>",
"ownerPartnerId":100032,
"ownerPartnerInfo":{
"id":100032,
"name":"泊心云舍",
"shortName":"泊心云舍"
},
"partnerId":100004,
"qrCodeImg":"nlsshop/2025/01/38cf88af-a869-46e8-aa79-96384153e27c.png",
"qrCodeImgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/01/38cf88af-a869-46e8-aa79-96384153e27c.png"
}
],
"recommendationType":"NORMAL",
"recommendationTypeText":"普通",
"remark":"<p></p><div class=\"media-wrap image-wrap\"><img class=\"media-wrap image-wrap\" src=\"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/9b19b425-7ee8-4b30-a959-ec5544719025.jpg\"/></div><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">西递泊心云舍·明经园坐落于黄山脚下西递古村落内牌坊广场、明经湖畔,开门即见近500年历史的胡文光刺史牌</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">坊,登上观景平台便可将西递古村尽收眼底。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">明经园是西递村保留下来的百年古宅之一,由五个徽派风格院落组成,其中三栋为明清古宅,清雅复古,步步是景。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">每间主卧命名均化用徽州文化元素并融入房间设计。选用慕思床垫、富安娜埃及棉床品、意大利进口MPE乳胶枕、原装进口资生堂洗浴用品,并有全新竹纤维浴巾毛巾、全新亚麻拖鞋、精致的桃木梳,供每一位家人专属使用并可随身带走。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">院内设有集餐厅、咖啡厅、清吧于一体的独栋建筑——泊心餚,让您足不出户即可享受美味佳肴。</span></span></span></p>",
"shopType":4,
"shopTypeText":"民宿",
"shortName":"泊心云舍·明经园",
"status":"ENABLE",
"statusText":"启用",
"tags":"餐厅 行李寄存 无线WIFI 24小时前台",
"tagsList":[
"餐厅",
"行李寄存",
"无线WIFI",
"24小时前台"
],
"updateTime":"2025-03-17 14:27:30"
},
currentIndex: 0,
show: false,
currentTab: 0,
tabs: [
{ name: "选房" },
{ name: "服务" },
{ name: "简介" },
{ name: "评价" },
]
}
},
computed: {
urls () {
if(this.nearShop){
return this.nearShop.imgs.map(item => ({
src: item.url,
desc: item.name || ''
}))
}
return []
}
},
onLoad: function(options) {
const q = options.q
uni.setNavigationBarTitle({
title: this.nearShop.name,
});
// var that = this;
// const eventChannel = this.getOpenerEventChannel();
// eventChannel.on('nearShop', function(nearShop) {
// that.nearShop = nearShop;
// that.nearShop.remark = that.formatRichText(nearShop.remark);
// uni.setNavigationBarTitle({
// title: nearShop.name,
// });
// recordStatVisit({
// relationalId: nearShop.id,
// relationalType: 'NLS_SHOP',
// residentId: getApp().globalData.currentUserResident != null ? getApp().globalData.currentUserResident.id : 0,
// });
// });
},
onReady(){
this.getViewportHeight()
},
methods: {
toTelGJ() {
if(this.nearShop.hotline){
uni.makePhoneCall({
phoneNumber: this.nearShop.hotline.replace(/[^\d]/g,"") // 替换非数字字符
});
}
},
formatRichText(html) {
let newContent= html.replace(/\<img/gi, '<img style="max-width:100%;height:auto;display:block;"');
// 替换空白p
newContent = newContent.replace('<p></p>', '<p style="padding-bottom:1em"></p>')
return newContent;
},
previewImage(index){
this.currentIndex = index
this.show = true
},
changeHandler(e){
this.currentTab = e.index
},
swiperChangeHandler(e){
this.currentTab = e.detail.current
},
outerToLowerHandler(){
// console.log('toLower-x')
// clearTimeout(this.outerTimer)
// this.outerTimer = 'EXIT'
// setTimeout(() => {
// this.outerTimer = null
// }, 400)
// this.innerScroll = true
},
outerScrollHandler(e){
console.log(e,e.detail.scrollTop, 'e-x')
// if(this.outerTimer === 'EXIT'){
// // scroll 触发的时机不确定,这里是用来终止的
// return
// }
// clearTimeout(this.outerTimer)
// this.outerTimer = setTimeout(() => {
// console.log(e, 'e-x')
// if(e.detail.scrollHeight - this.clientHeight > e.detail.scrollTop){
// this.innerScroll = false
// }
// }, 300);
},
innerToUpperHandler(){
clearTimeout(this.innerTimer)
this.innerTimer = 'EXIT'
setTimeout(() => {
this.innerTimer = null
}, 400);
this.outerScroll = true
},
innerScrollHandler(e){
if(this.innerTimer === 'EXIT'){
return
}
clearTimeout(this.innerTimer)
this.innerTimer = setTimeout(() => {
console.log(e, 'inner-x')
if(e.detail.scrollTop > 0){
this.outerScroll = false
}
}, 300);
},
// 获取可视区域高度(兼容小程序和APP)
getViewportHeight() {
this.clientHeight = uni.getSystemInfoSync().windowHeight
}
}
}
</script>
<style lang="scss" scoped>
.container-wrapper{
font-size: 28rpx;
height: 100%;
.detail-imgs{
width: 100%;
height: 492rpx;
.no-img, swiper{
height: 100%;
}
image{
width: 100%;
height: 100%;
}
}
.content{
padding: 32rpx 26rpx 40rpx;
line-height: 42rpx;
background-color: #fff;
margin-bottom: 18rpx;
.merchant-info{
margin-bottom: 30rpx;
.name{
font-size: 32rpx;
font-weight: bold;
}
}
.address-info{
background-color: #E9F0F8;
border-radius: 8rpx;
display: flex;
padding: 24rpx 30rpx 24rpx 20rpx;
align-items: center;
.address{
flex-grow: 1;
overflow: hidden;
.specific-address{
color: #909090;
}
}
.map{
color: #909090;
padding: 0 36rpx;
margin-right: 32rpx;
display: flex;
flex-direction: column;
flex-shrink: 0;
align-items: center;
border-right: 1px solid #D0CECE;
image{
width: 38rpx;
height: 48rpx;
}
}
image{
width: 52rpx;
height: 52rpx;
flex-shrink: 0;
}
}
}
.room-info{
display: flex;
flex-direction: column;
height: 100vh;
.content-swiper{
padding: 0 26rpx 0;
background-color: #fff;
flex: 1;
scroll-view{
height: 100%;
.swiper-item-wrapper{
padding-bottom: 32rpx;
}
}
}
}
}
</style>
0 个回复