Files
lucky_shop/components/ns-goods-action-icon/ns-goods-action-icon.vue
2025-10-27 15:55:29 +08:00

147 lines
3.0 KiB
Vue

<template>
<view>
<block v-if="text == '客服'">
<!-- <ns-contact :niushop="chatParam" :send-message-title="sendData.title" :send-message-path="sendData.path" :send-message-img="sendData.img"> -->
<button hoverClass="none" openType="contact" sessionFrom="weapp" showMessageCard="true" class="action-icon-wrap" style="background: transparent;padding: 0;margin: 0;">
<view class="iconfont color-title" :class="icon"></view>
<text>{{ text }}</text>
<view class="corner-mark color-base-bg" v-if="cornerMark.length" :style="{ background: cornerMarkBg+'!important', color: cornerMarkColor }">{{ cornerMark }}</view>
</button>
<!-- </ns-contact> -->
</block>
<block v-else>
<view class="action-icon-wrap" @click="clickEvent">
<view class="iconfont " :class="icon"></view>
<text>{{ text }}</text>
<view class="corner-mark color-base-bg" :class="{'max' : parseInt(cornerMark)>99}" v-if="cornerMark.length" :style="{ background: cornerMarkBg+'!important', color: cornerMarkColor }">{{ cornerMark > 99 ? '99+' : cornerMark }}</view>
</view>
</block>
</view>
</template>
<script>
import nsContact from '@/components/ns-contact/ns-contact.vue';
export default {
name: 'ns-goods-action-icon',
props: {
// 商品底部icon导航icon图标
icon: {
type: String,
default: ''
},
// 商品底部icon导航文字
text: {
type: String,
default: ''
},
// 角标文字
cornerMark: {
type: String,
default: ''
},
// 角标背景色
cornerMarkBg: {
type: String,
default: ''
},
// 角标文字颜色
cornerMarkColor: {
type: String,
default: '#fff'
},
// 开放能力
openType: {
type: String,
default: ''
},
// 发送内容 openType="contact"时有效
sendData: {
type: Object,
default: function() {
return {
title: '',
path: '',
img: ''
};
}
},
chatParam: {
type: Object,
default: function(){
return {}
}
}
},
components:{
nsContact
},
methods: {
clickEvent() {
this.$emit('click');
}
}
};
</script>
<style lang="scss">
.action-icon-wrap {
display: flex;
flex-direction: column;
justify-content: center;
height: 100rpx;
min-width: 90rpx;
text-align: center;
position: relative;
margin-right: 6rpx;
}
.action-icon-wrap button {
width: 100%;
height: 100%;
position: absolute;
border: none;
z-index: 1;
padding: 0;
margin: 0;
background: none;
top: 0;
left: 0;
opacity: 0;
}
.action-icon-wrap button::after {
border: none !important;
}
.action-icon-wrap .iconfont {
margin: 0 auto 10rpx;
line-height: 1;
font-size: 40rpx;
}
.action-icon-wrap .corner-mark {
position: absolute;
z-index: 99;
font-size: $font-size-activity-tag;
top: 4rpx;
right: 12rpx;
color: #fff;
display: flex;
justify-content: center;
align-items: center;
width: 24rpx;
height: 24rpx;
padding: 6rpx;
border-radius: 50%;
&.max{
right:-4rpx;
width: 40rpx;
border-radius: 24rpx;
}
}
.action-icon-wrap text {
font-size: $font-size-tag;
line-height: 1;
}
</style>