235 lines
6.0 KiB
Vue
235 lines
6.0 KiB
Vue
<template>
|
||
<view>
|
||
<!-- md卡片:竖向,一行放两个,图上内容下 -->
|
||
<view v-if="size === 'md'" class="md-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick">
|
||
<view class="icon-box ss-flex">
|
||
<image class="icon" :src="state.liveStatus[data.status].img"></image>
|
||
<view class="title ss-m-l-16">{{ state.liveStatus[data.status].title }}</view>
|
||
</view>
|
||
<img class="md-img-box" :src="sheep.$url.cdn(data.feeds_img)" referrerpolicy="no-referrer" />
|
||
<view class="md-goods-content">
|
||
<view class="md-goods-title ss-line-1" :style="[{ color: titleColor }]">
|
||
{{ data.name }}
|
||
</view>
|
||
<view class="md-goods-subtitle ss-m-t-14 ss-line-1" :style="[{ color: subTitleColor }]">
|
||
主播:{{ data.anchor_name }}
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- sl卡片:竖向型,一行放一个,图片上内容下边 -->
|
||
<view v-if="size === 'sl'" class="sl-goods-card ss-flex-col" :style="[elStyles]" @tap="onClick">
|
||
<view class="icon-box ss-flex">
|
||
<image class="icon" :src="state.liveStatus[data.status].img"></image>
|
||
<view class="title ss-m-l-16">{{ state.liveStatus[data.status].title }}</view>
|
||
</view>
|
||
<img class="sl-img-box" :src="sheep.$url.cdn(data.feeds_img)" referrerpolicy="no-referrer" />
|
||
<view class="sl-goods-content">
|
||
<view class="sl-goods-title ss-line-1" :style="[{ color: titleColor }]">
|
||
{{ data.name }}
|
||
</view>
|
||
<view class="sl-goods-subtitle ss-m-t-14 ss-line-1" :style="[{ color: subTitleColor }]">
|
||
主播:{{ data.anchor_name }}
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
<script setup>
|
||
import { computed, reactive } from 'vue';
|
||
import sheep from '@/sheep';
|
||
/**
|
||
* 直播卡片
|
||
*
|
||
* @property {String} img - 图片
|
||
* @property {String} title - 标题
|
||
* @property {Number} titleWidth = 0 - 标题宽度,默认0,单位rpx
|
||
* @property {String} skuText - 规格
|
||
* @property {String | Number} score - 积分
|
||
* @property {String | Number} price - 价格
|
||
* @property {String | Number} originalPrice - 单购价
|
||
* @property {String} priceColor - 价格颜色
|
||
* @property {Number | String} num - 数量
|
||
*
|
||
*/
|
||
const props = defineProps({
|
||
goodsFields: {
|
||
type: [Array, Object],
|
||
default() {
|
||
return {};
|
||
},
|
||
},
|
||
tagStyle: {
|
||
type: Object,
|
||
default: {},
|
||
},
|
||
data: {
|
||
type: Object,
|
||
default: {},
|
||
},
|
||
size: {
|
||
type: String,
|
||
default: 'sl',
|
||
},
|
||
background: {
|
||
type: String,
|
||
default: '',
|
||
},
|
||
topRadius: {
|
||
type: Number,
|
||
default: 0,
|
||
},
|
||
bottomRadius: {
|
||
type: Number,
|
||
default: 0,
|
||
},
|
||
titleColor: {
|
||
type: String,
|
||
default: '#333',
|
||
},
|
||
subTitleColor: {
|
||
type: String,
|
||
default: '#999999',
|
||
},
|
||
});
|
||
// 组件样式
|
||
const elStyles = computed(() => {
|
||
return {
|
||
background: props.background,
|
||
'border-top-left-radius': props.topRadius + 'px',
|
||
'border-top-right-radius': props.topRadius + 'px',
|
||
'border-bottom-left-radius': props.bottomRadius + 'px',
|
||
'border-bottom-right-radius': props.bottomRadius + 'px',
|
||
};
|
||
});
|
||
const state = reactive({
|
||
liveStatus: {
|
||
101: {
|
||
img: sheep.$url.static('/static/img/shop/app/mplive/living.png'),
|
||
title: '直播中',
|
||
},
|
||
102: {
|
||
img: sheep.$url.static('/static/img/shop/app/mplive/start.png'),
|
||
title: '未开始',
|
||
},
|
||
103: {
|
||
img: sheep.$url.static('/static/img/shop/app/mplive/ended.png'),
|
||
title: '已结束',
|
||
},
|
||
},
|
||
});
|
||
const emits = defineEmits(['click', 'getHeight']);
|
||
const onClick = () => {
|
||
emits('click');
|
||
};
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
// md
|
||
.md-goods-card {
|
||
overflow: hidden;
|
||
width: 100%;
|
||
height: 424rpx;
|
||
position: relative;
|
||
z-index: 1;
|
||
background-color: $white;
|
||
.icon-box {
|
||
position: absolute;
|
||
left: 20rpx;
|
||
top: 10rpx;
|
||
width: 136rpx;
|
||
height: 40rpx;
|
||
background: rgba(#000000, 0.5);
|
||
border-radius: 20rpx;
|
||
z-index: 1;
|
||
.icon {
|
||
width: 40rpx;
|
||
height: 40rpx;
|
||
border-radius: 20rpx 0px 20rpx 20rpx;
|
||
}
|
||
.title {
|
||
font-size: 24rpx;
|
||
font-weight: 500;
|
||
color: #ffffff;
|
||
}
|
||
}
|
||
.md-goods-content {
|
||
position: absolute;
|
||
left: 0;
|
||
bottom: 0;
|
||
padding: 20rpx;
|
||
width: 100%;
|
||
background: linear-gradient(360deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.02) 100%);
|
||
}
|
||
|
||
.md-img-box {
|
||
width: 100%;
|
||
height: 100%;
|
||
object-fit: cover;
|
||
}
|
||
|
||
.md-goods-title {
|
||
font-size: 26rpx;
|
||
color: #333;
|
||
width: 100%;
|
||
}
|
||
.md-goods-subtitle {
|
||
font-size: 24rpx;
|
||
font-weight: 400;
|
||
color: #999999;
|
||
}
|
||
}
|
||
.sl-goods-card {
|
||
overflow: hidden;
|
||
position: relative;
|
||
z-index: 1;
|
||
width: 100%;
|
||
height: 400rpx;
|
||
background-color: $white;
|
||
.icon-box {
|
||
position: absolute;
|
||
left: 20rpx;
|
||
top: 10rpx;
|
||
width: 136rpx;
|
||
height: 40rpx;
|
||
background: rgba(#000000, 0.5);
|
||
border-radius: 20rpx;
|
||
z-index: 1;
|
||
.icon {
|
||
width: 40rpx;
|
||
height: 40rpx;
|
||
border-radius: 20rpx 0px 20rpx 20rpx;
|
||
}
|
||
.title {
|
||
font-size: 24rpx;
|
||
font-weight: 500;
|
||
color: #ffffff;
|
||
}
|
||
}
|
||
.sl-goods-content {
|
||
position: absolute;
|
||
left: 0;
|
||
bottom: 0;
|
||
padding: 20rpx;
|
||
width: 100%;
|
||
background: linear-gradient(360deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.02) 100%);
|
||
}
|
||
|
||
.sl-img-box {
|
||
width: 100%;
|
||
height: 100%;
|
||
object-fit: cover;
|
||
}
|
||
|
||
.sl-goods-title {
|
||
font-size: 26rpx;
|
||
color: #333;
|
||
width: 100%;
|
||
}
|
||
.sl-goods-subtitle {
|
||
font-size: 24rpx;
|
||
font-weight: 400;
|
||
color: #999999;
|
||
}
|
||
}
|
||
</style>
|