| 
									
										
										
										
											2025-10-16 17:07:47 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  | 	<view class="category-container"> | 
					
						
							|  |  |  | 		<u-navbar id="uNavbarId" title="商品详情" :background="{background: 'transparent' }" :border-bottom="false" | 
					
						
							|  |  |  | 			back-icon-color="#000" title-color="#000"> | 
					
						
							|  |  |  | 			<template v-slot:right> | 
					
						
							|  |  |  | 				<image class="collection" src="/static/icon/Settings.png" mode=""></image> | 
					
						
							|  |  |  | 			</template> | 
					
						
							|  |  |  | 		</u-navbar> | 
					
						
							|  |  |  | 		<scroll-view scroll-y="true" :style="'height:'+scrollHeight+'px'"> | 
					
						
							|  |  |  | 			<view class="scroll-view"> | 
					
						
							|  |  |  | 				<view class="menu-level1"> | 
					
						
							|  |  |  | 					<view class="text" :class="{'active': currentCate==index}" v-for="(item, index) in categoryList"
 | 
					
						
							|  |  |  | 						@click="handleChangeCategory(index)"> | 
					
						
							|  |  |  | 						{{item.name}} | 
					
						
							|  |  |  | 					</view> | 
					
						
							|  |  |  | 				</view> | 
					
						
							|  |  |  | 				<view class="menu-level2" v-if="categoryList[currentCate]?.relative.length!=0"> | 
					
						
							| 
									
										
										
										
											2025-10-23 13:49:19 +08:00
										 |  |  | 					<view class="menu-item" v-for="item in categoryList[currentCate]?.relative" @click="handleSearchCategory(item)"> | 
					
						
							| 
									
										
										
										
											2025-10-16 17:07:47 +08:00
										 |  |  | 						<u-image v-if="item.img" :fade="false" :src="getImageUrl(item.img)" :width="iconWidth"
 | 
					
						
							|  |  |  | 							mode="widthFix"></u-image> | 
					
						
							|  |  |  | 						<view class="menu-text"> | 
					
						
							|  |  |  | 							{{item.name}} | 
					
						
							|  |  |  | 						</view> | 
					
						
							|  |  |  | 					</view> | 
					
						
							|  |  |  | 				</view> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				<view class="mall-list"> | 
					
						
							|  |  |  | 					<u-waterfall v-model="mallList" ref="mallListRef"> | 
					
						
							|  |  |  | 						<template v-slot:left="{leftList}"> | 
					
						
							|  |  |  | 							<view class="mall-item u-m-r-10" v-for="(item, index) in leftList" :key="index"
 | 
					
						
							|  |  |  | 								@click="handleCheck(item)"> | 
					
						
							|  |  |  | 								<u-lazy-load threshold="-450" border-radius="10" :image="getImageUrl(item.image)" | 
					
						
							|  |  |  | 									:index="index"></u-lazy-load> | 
					
						
							|  |  |  | 								<view class="mall-title u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									{{item.name}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<del class="u-m-l-5 u-m-r-5" style="white-space: nowrap;">¥{{item.price}}</del> | 
					
						
							|  |  |  | 								<view class="mall-price u-m-l-5 u-m-r-5" v-if="RDType(item.payment_methods)"> | 
					
						
							|  |  |  | 									<image src="/static/icon/rongdou.png" class="icon" mode=""></image> | 
					
						
							|  |  |  | 									{{item.rongdou_price}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-price u-m-l-5 u-m-r-5" v-if="pointsType(item.payment_methods)"> | 
					
						
							|  |  |  | 									<u-icon name="integral"></u-icon> | 
					
						
							|  |  |  | 									{{item.points_price}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-tag u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									<view class="mall-tag-text" v-if="RDType(item.payment_methods)"> | 
					
						
							|  |  |  | 										融豆 | 
					
						
							|  |  |  | 									</view> | 
					
						
							|  |  |  | 									<view class="mall-tag-owner" v-if="pointsType(item.payment_methods)"> | 
					
						
							|  |  |  | 										积分 | 
					
						
							|  |  |  | 									</view> | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-shop u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									{{item.category}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 							</view> | 
					
						
							|  |  |  | 						</template> | 
					
						
							|  |  |  | 						<template v-slot:right="{rightList}"> | 
					
						
							|  |  |  | 							<view class="mall-item u-m-l-10" v-for="(item, index) in rightList" :key="index"
 | 
					
						
							|  |  |  | 								@click="handleCheck(item)"> | 
					
						
							|  |  |  | 								<u-lazy-load threshold="-450" border-radius="10" :image="getImageUrl(item.image)" | 
					
						
							|  |  |  | 									:index="index"></u-lazy-load> | 
					
						
							|  |  |  | 								<view class="mall-title u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									{{item.name}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<del class="u-m-l-5 u-m-r-5" style="white-space: nowrap;">¥{{item.price}}</del> | 
					
						
							|  |  |  | 								<view class="mall-price u-m-l-5 u-m-r-5" v-if="RDType(item.payment_methods)"> | 
					
						
							|  |  |  | 									<image src="/static/icon/rongdou.png" class="icon" mode=""></image> | 
					
						
							|  |  |  | 									{{item.rongdou_price}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-price u-m-l-5 u-m-r-5" v-if="pointsType(item.payment_methods)"> | 
					
						
							|  |  |  | 									<u-icon name="integral"></u-icon> | 
					
						
							|  |  |  | 									{{item.points_price}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-tag u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									<view class="mall-tag-text" v-if="RDType(item.payment_methods)"> | 
					
						
							|  |  |  | 										融豆 | 
					
						
							|  |  |  | 									</view> | 
					
						
							|  |  |  | 									<view class="mall-tag-owner" v-if="pointsType(item.payment_methods)"> | 
					
						
							|  |  |  | 										积分 | 
					
						
							|  |  |  | 									</view> | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 								<view class="mall-shop u-m-l-5 u-m-r-5"> | 
					
						
							|  |  |  | 									{{item.category}} | 
					
						
							|  |  |  | 								</view> | 
					
						
							|  |  |  | 							</view> | 
					
						
							|  |  |  | 						</template> | 
					
						
							|  |  |  | 					</u-waterfall> | 
					
						
							|  |  |  | 					<u-loadmore margin-top="20" :status="loadStatus"></u-loadmore> | 
					
						
							|  |  |  | 				</view> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			</view> | 
					
						
							|  |  |  | 		</scroll-view> | 
					
						
							|  |  |  | 	</view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script setup lang="ts"> | 
					
						
							|  |  |  | 	import { | 
					
						
							|  |  |  | 		ref, onMounted, getCurrentInstance | 
					
						
							|  |  |  | 	} from 'vue'; | 
					
						
							|  |  |  | 	import { mallAPI } from '../../api/mall'; | 
					
						
							|  |  |  | 	import { getImageUrl } from '../../util/common'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const instance = getCurrentInstance(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const currentCate = ref(0) | 
					
						
							|  |  |  | 	const categoryList = ref([]) | 
					
						
							|  |  |  | 	const iconWidth = "65%" | 
					
						
							|  |  |  | 	const loadCategory = () => { | 
					
						
							|  |  |  | 		mallAPI.getCategory().then(res => { | 
					
						
							|  |  |  | 			categoryList.value = res.data | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const handleChangeCategory = (index) => { | 
					
						
							|  |  |  | 		currentCate.value = index | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2025-10-23 13:49:19 +08:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	const handleSearchCategory = (item) => { | 
					
						
							|  |  |  | 		 uni.navigateTo({ | 
					
						
							|  |  |  | 		 	url: '/pages/home/mallSearch?cate=' + item.name | 
					
						
							|  |  |  | 		 }) | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2025-10-16 17:07:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	const params = ref({ | 
					
						
							|  |  |  | 		keyword: '', | 
					
						
							|  |  |  | 		page: 1, | 
					
						
							|  |  |  | 		limit: 5, | 
					
						
							|  |  |  | 		category: '' | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	const mallList = ref([]) | 
					
						
							|  |  |  | 	const mallListRef = ref() | 
					
						
							|  |  |  | 	const loadStatus = ref('loadmore') // nomore
 | 
					
						
							|  |  |  | 	const maxPage = ref(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// 积分兑换
 | 
					
						
							|  |  |  | 	const pointsType = (val : any) => { | 
					
						
							|  |  |  | 		if (val && val.indexOf("points") >= 0) return true | 
					
						
							|  |  |  | 		return false | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	// 融豆兑换
 | 
					
						
							|  |  |  | 	const RDType = (val : any) => { | 
					
						
							|  |  |  | 		if (val && val.indexOf("rongdou") >= 0) return true | 
					
						
							|  |  |  | 		return false | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// 加载数据
 | 
					
						
							|  |  |  | 	const loadMallData = () => { | 
					
						
							|  |  |  | 		if (loadStatus.value == 'nomore') return | 
					
						
							|  |  |  | 		mallAPI.getMallList(params.value).then((res) => { | 
					
						
							|  |  |  | 			mallList.value = mallList.value.concat(res.data.products) | 
					
						
							|  |  |  | 			maxPage.value = res.data.pagination.pages | 
					
						
							|  |  |  | 			params.value.page++ | 
					
						
							|  |  |  | 			if (maxPage.value < params.value.page) { | 
					
						
							|  |  |  | 				loadStatus.value = 'nomore' | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const handleCheck = (item : any) => { | 
					
						
							|  |  |  | 		uni.navigateTo({ | 
					
						
							|  |  |  | 			url: '/pages/home/mallDetail?id=' + item.id | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const scrollHeight = ref(0) | 
					
						
							|  |  |  | 	const loadHeight = () => { | 
					
						
							|  |  |  | 		uni.getSystemInfo({ | 
					
						
							|  |  |  | 			success(res) { | 
					
						
							|  |  |  | 				let screenHeight = res.screenHeight | 
					
						
							|  |  |  | 				uni.createSelectorQuery().in(instance.proxy).select("#uNavbarId").boundingClientRect((data : any) => { | 
					
						
							|  |  |  | 					scrollHeight.value = screenHeight - data.height | 
					
						
							|  |  |  | 				}).exec() | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	onMounted(() => { | 
					
						
							|  |  |  | 		loadHeight() | 
					
						
							|  |  |  | 		loadCategory() | 
					
						
							|  |  |  | 		loadMallData() | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | 	.category-container { | 
					
						
							|  |  |  | 		width: 100%; | 
					
						
							|  |  |  | 		height: 100vh; | 
					
						
							|  |  |  | 		background: #B9D5FF; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.collection { | 
					
						
							|  |  |  | 			width: 48rpx; | 
					
						
							|  |  |  | 			height: 48rpx; | 
					
						
							|  |  |  | 			margin-right: 24rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.scroll-view { | 
					
						
							|  |  |  | 			.menu-level1 { | 
					
						
							|  |  |  | 				display: flex; | 
					
						
							|  |  |  | 				white-space: nowrap; | 
					
						
							|  |  |  | 				overflow: hidden; | 
					
						
							|  |  |  | 				overflow-x: scroll; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				leading-trim: NONE; | 
					
						
							|  |  |  | 				line-height: 100%; | 
					
						
							|  |  |  | 				letter-spacing: -2%; | 
					
						
							|  |  |  | 				font-family: Work Sans; | 
					
						
							|  |  |  | 				font-weight: 600; | 
					
						
							|  |  |  | 				font-style: SemiBold; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				.text { | 
					
						
							|  |  |  | 					margin: 22rpx; | 
					
						
							|  |  |  | 					font-family: Work Sans; | 
					
						
							|  |  |  | 					font-weight: 600; | 
					
						
							|  |  |  | 					font-style: SemiBold; | 
					
						
							|  |  |  | 					font-size: 14px; | 
					
						
							|  |  |  | 					color: #F5F8FF; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				.active { | 
					
						
							|  |  |  | 					font-size: 16px; | 
					
						
							|  |  |  | 					color: var(--wz, #2938E0); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			.menu-level2 { | 
					
						
							|  |  |  | 				background: #F5F8FF; | 
					
						
							|  |  |  | 				// background: #FFFFFF80;
 | 
					
						
							|  |  |  | 				padding: 20rpx 0 0 0; | 
					
						
							|  |  |  | 				border-radius: 20rpx; | 
					
						
							|  |  |  | 				display: flex; | 
					
						
							|  |  |  | 				flex-wrap: wrap; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				.menu-item { | 
					
						
							|  |  |  | 					display: flex; | 
					
						
							|  |  |  | 					flex-direction: column; | 
					
						
							|  |  |  | 					align-items: center; | 
					
						
							|  |  |  | 					width: 20%; | 
					
						
							|  |  |  | 					margin-bottom: 20rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					.menu-text { | 
					
						
							|  |  |  | 						font-family: Work Sans; | 
					
						
							|  |  |  | 						font-weight: 400; | 
					
						
							|  |  |  | 						font-style: Regular; | 
					
						
							|  |  |  | 						font-size: 24rpx; | 
					
						
							|  |  |  | 						leading-trim: NONE; | 
					
						
							|  |  |  | 						line-height: 100%; | 
					
						
							|  |  |  | 						letter-spacing: -2%; | 
					
						
							|  |  |  | 						color: #2B2B2B; | 
					
						
							|  |  |  | 						margin-top: 10rpx; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// 商城列表
 | 
					
						
							|  |  |  | 			.mall-list { | 
					
						
							|  |  |  | 				margin-top: 20rpx; | 
					
						
							|  |  |  | 				padding: 0 20rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				.mall-item { | 
					
						
							|  |  |  | 					border-radius: 16rpx; | 
					
						
							|  |  |  | 					background: #F0F5FF; | 
					
						
							|  |  |  | 					position: relative; | 
					
						
							|  |  |  | 					margin-top: 20rpx; | 
					
						
							|  |  |  | 					box-shadow: 0px 4px 4px 0px #00000040; | 
					
						
							|  |  |  | 					padding-bottom: 10rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					.mall-title { | 
					
						
							|  |  |  | 						font-size: 30rpx; | 
					
						
							|  |  |  | 						margin-top: 10rpx; | 
					
						
							|  |  |  | 						color: $u-main-color; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					.mall-price { | 
					
						
							|  |  |  | 						font-size: 30rpx; | 
					
						
							|  |  |  | 						color: $u-type-error; | 
					
						
							|  |  |  | 						margin-top: 10rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						.icon { | 
					
						
							|  |  |  | 							height: 30rpx; | 
					
						
							|  |  |  | 							width: 30rpx; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					.mall-tag { | 
					
						
							|  |  |  | 						display: flex; | 
					
						
							|  |  |  | 						margin-top: 5px; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						.mall-tag-owner { | 
					
						
							|  |  |  | 							background-color: $u-type-error; | 
					
						
							|  |  |  | 							color: #FFFFFF; | 
					
						
							|  |  |  | 							display: flex; | 
					
						
							|  |  |  | 							align-items: center; | 
					
						
							|  |  |  | 							padding: 4rpx 14rpx; | 
					
						
							|  |  |  | 							border-radius: 50rpx; | 
					
						
							|  |  |  | 							font-size: 20rpx; | 
					
						
							|  |  |  | 							line-height: 1; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 						.mall-tag-text { | 
					
						
							|  |  |  | 							margin-right: 10px; | 
					
						
							|  |  |  | 							border: 1px solid $u-type-primary; | 
					
						
							|  |  |  | 							color: $u-type-primary; | 
					
						
							|  |  |  | 							border-radius: 50rpx; | 
					
						
							|  |  |  | 							line-height: 1; | 
					
						
							|  |  |  | 							padding: 4rpx 14rpx; | 
					
						
							|  |  |  | 							display: flex; | 
					
						
							|  |  |  | 							align-items: center; | 
					
						
							|  |  |  | 							border-radius: 50rpx; | 
					
						
							|  |  |  | 							font-size: 20rpx; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					.mall-shop { | 
					
						
							|  |  |  | 						font-size: 22rpx; | 
					
						
							|  |  |  | 						color: $u-tips-color; | 
					
						
							|  |  |  | 						margin-top: 5px; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </style> |