web-retail-h5/components/area-product-list/index.vue

254 lines
5.7 KiB
Vue

<template>
<view class="area-product-list">
<view class="area-header">
<view class="header-bg"></view>
<text class="area-title">{{ title }}</text>
<u-button
v-if="list.length > 0"
type="primary"
size="mini"
shape="circle"
:custom-style="{
background: '#ffffff',
border: 'none',
position: 'relative',
zIndex: 1,
height: '46rpx',
lineHeight: '46rpx',
width: 'fit-content',
padding: '0 12rpx',
margin: '0',
}"
@click="goToMore"
>
<view class="more-btn-content">
<text class="more-text">更多</text>
<u-icon name="arrow-right" color="#005bac" size="14"></u-icon>
</view>
</u-button>
</view>
<view class="product-container">
<view
class="product-item"
v-for="item in list"
:key="item.pkWares"
@click="handleProductClick(item)"
>
<image :src="item.cover1" class="product-image" mode="aspectFill" />
<view class="product-info">
<view class="product-name">{{ item.waresName }}</view>
<view class="product-price-row">
<view class="product-price">
{{ formatPrice(item.waresPrice) }}
</view>
<u-button
v-if="false"
type="primary"
size="mini"
shape="circle"
:custom-style="{
background: '#005bac',
margin: '0px',
width: '48rpx',
height: '48rpx',
minWidth: '48rpx',
}"
@click.native.stop="handleAddToCart(item)"
>
<u-icon name="plus" color="#ffffff" size="12"></u-icon>
</u-button>
</view>
</view>
</view>
</view>
</view>
</template>
<script>
import { numberToCurrencyNo, isLocal, isLocaled } from '@/util/numberToCurrency'
import { addShopping } from '@/config/goods'
export default {
props: {
title: {
type: String,
default: '热销专区',
},
list: {
type: Array,
default: () => [
{
pkWares: 17024,
cover1:
'https://bd-qd.oss-cn-beijing.aliyuncs.com/test_01/20250406/c2aea04b-174d-4703-acab-c52d928371bd.jpg',
waresCode: 'HZSLXSJ2',
waresPrice: '6000.0000',
specialArea: 25,
isSale: 0,
preSaleStatus: 0,
},
{
pkWares: 17041,
cover1:
'https://bd-qd.oss-cn-beijing.aliyuncs.com/test_01/20250406/c2aea04b-174d-4703-acab-c52d928371bd.jpg',
waresCode: 'HZSLXSJ1',
waresPrice: '2000.0000',
specialArea: 25,
isSale: 0,
preSaleStatus: 0,
},
{
pkWares: 17042,
cover1:
'https://bd-qd.oss-cn-beijing.aliyuncs.com/test_01/20250406/c2aea04b-174d-4703-acab-c52d928371bd.jpg',
waresCode: 'HZSLXSJ3',
waresPrice: '3999.0000',
specialArea: 25,
isSale: 0,
preSaleStatus: 0,
},
],
},
specialAreaId: {
type: [Number, String],
default: '25',
},
},
methods: {
isLocaled,
formatPrice(price) {
// 使用numberToCurrencyNo和isLocal函数来格式化价格
return isLocal(numberToCurrencyNo(price))
},
goToMore() {
// 跳转到专区详情页面
uni.navigateTo({
url: `/pages/specialArea/index?id=${this.specialAreaId}`,
})
},
handleProductClick(item) {
// 商品点击事件,可根据需求实现跳转或其他逻辑
this.$emit('product-click', item)
},
handleAddToCart(item) {
const params = {
pkCountry: this.pkCountry,
specialArea: item.specialArea,
number: 1,
waresCode: item.waresCode,
productGroup: item.productGroup,
}
addShopping(params).then(res => {
if (res.code == 200) {
uni.showToast({
title: '购物车添加成功',
icon: 'success',
mask: true,
})
this.$store.dispatch("getCarLength");
}
})
},
},
}
</script>
<style lang="scss" scoped>
.area-product-list {
background-color: #ffffff;
padding: 20rpx;
padding-top: 0;
border-radius: 16rpx;
margin-bottom: 24rpx;
position: relative;
}
.area-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 24rpx;
position: relative;
padding: 20rpx 0;
height: 46rpx;
}
.header-bg {
position: absolute;
top: 0;
left: -20rpx;
right: -20rpx;
height: 100%;
background: linear-gradient(to bottom, #add8e6, #ffffff);
z-index: 0;
border-top-left-radius: 8px;
border-top-right-radius: 8px;
}
.area-title {
font-size: 32rpx;
font-weight: bold;
color: #333333;
position: relative;
z-index: 1;
}
.more-btn-content {
display: flex;
align-items: center;
justify-content: center;
height: 100%;
flex-grow: 0;
}
.more-text {
font-size: 24rpx;
color: #005bac;
margin-right: 4rpx;
}
.product-container {
display: flex;
flex-wrap: wrap;
margin: 0 -10rpx;
}
.product-item {
width: 33.33%;
padding: 0 10rpx;
box-sizing: border-box;
}
.product-image {
width: 100%;
height: 200rpx;
border-radius: 8rpx;
background-color: #f5f5f5;
}
.product-info {
margin-top: 12rpx;
position: relative;
}
.product-name {
font-size: 28rpx;
color: #333;
margin-bottom: 8rpx;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.product-price-row {
display: flex;
justify-content: space-between;
align-items: center;
.product-price {
font-size: 24rpx;
font-weight: bold;
color: #005bac;
}
}
</style>