You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
400 lines
11 KiB
400 lines
11 KiB
3 months ago
|
<template>
|
||
|
<!-- 搜索框 -->
|
||
|
<!-- #ifdef H5 -->
|
||
|
<view class="header" :style="[headerStyle]">
|
||
|
<view class="serch-wrapper acea-row row-middle" :style="[serchWrapperStyle,txtPosition]">
|
||
|
<view class="logo skeleton-rect" v-if="styleConfig == 0 && styleTypeConfig == 2 && logoConfig">
|
||
|
<image :src="logoConfig" mode="heightFix"></image>
|
||
|
</view>
|
||
|
<view class="title" :style="[txtStyle]" v-if="titleConfig && (styleConfig==1 || (styleConfig==0 && styleTypeConfig == 0))" @click="goLink">{{ titleConfig }}</view>
|
||
|
<view class="map" :style="[txtStyle]" v-if="styleConfig==2 || (styleConfig==0 && styleTypeConfig == 1)">
|
||
|
<text class="iconfont icon-ic_location51" v-if="fixConfig !=0"></text>
|
||
|
<text v-if="styleConfig===2 && fixConfig == 1">{{addressInfos}}</text>
|
||
|
<text v-if="styleConfig===2 && fixConfig == 0">{{storeName.slice(0,7) || '选择门店'}}</text>
|
||
|
<text v-if="styleConfig===0 && fixConfig == 1">{{addressInfo}}</text>
|
||
|
<text v-if="styleConfig===0 && fixConfig == 0">{{storeName.slice(0,4) || '选择门店'}}</text>
|
||
|
<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</view>
|
||
|
<navigator v-if="styleConfig===0" url="/pages/goods/goods_search/index" class="input acea-row row-middle skeleton-rect" hover-class="none">
|
||
|
<view class="search acea-row row-middle" :style="[searchStyle]">
|
||
|
<text class="iconfont icon-ic_search"></text>
|
||
|
<swiper v-if="hotWords.length" :autoplay="true" :interval="3000" :duration="1000" :vertical="true" :circular="true" class="swiper"
|
||
|
:style="{ color: dataConfig.hotWordsColor.color[0].item }">
|
||
|
<swiper-item v-for="(item, index) in hotWords" :key="index">
|
||
|
{{ item.val }}
|
||
|
</swiper-item>
|
||
|
</swiper>
|
||
|
<text v-else>{{ dataConfig.tipConfig.value }}</text>
|
||
|
</view>
|
||
|
</navigator>
|
||
|
</view>
|
||
|
</view>
|
||
|
<!-- #endif -->
|
||
|
<!-- #ifdef MP || APP-PLUS -->
|
||
|
<view>
|
||
|
<view class="mp-header" :style="[headerStyle, { paddingRight: serchRight + 'px' }]">
|
||
|
<view class="sys-head" :style="{ height: statusBarHeight + 'px'}"></view>
|
||
|
<view class="serch-box" :style="[serchWrapperStyle, { height: serchHeight + 'px' }]">
|
||
|
<view class="serch-wrapper acea-row row-middle" :style="[txtPosition]">
|
||
|
<view class="logo skeleton-rect" v-if="styleConfig == 0 && styleTypeConfig == 2 && logoConfig">
|
||
|
<image :src="logoConfig" mode="heightFix"></image>
|
||
|
</view>
|
||
|
<view class="title" :style="[txtStyle]" v-if="titleConfig && (styleConfig==1 || (styleConfig==0 && styleTypeConfig == 0))" @click="goLink">{{ titleConfig }}</view>
|
||
|
<view class="map" :style="[txtStyle]" v-if="styleConfig==2 || (styleConfig==0 && styleTypeConfig == 1)" @click="chooseLocation">
|
||
|
<text class="iconfont icon-ic_location51" v-if="fixConfig !=0"></text>
|
||
|
<text v-if="styleConfig===2 && fixConfig == 1">{{addressInfos}}</text>
|
||
|
<text v-if="styleConfig===2 && fixConfig == 0">{{storeName.slice(0,7) || '选择门店'}}</text>
|
||
|
<text v-if="styleConfig===0 && fixConfig == 1">{{addressInfo}}</text>
|
||
|
<text v-if="styleConfig===0 && fixConfig == 0">{{storeName.slice(0,4) || '选择门店'}}</text>
|
||
|
<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</view>
|
||
|
<navigator v-if="styleConfig===0" url="/pages/goods/goods_search/index" class="input acea-row row-middle skeleton-rect" hover-class="none">
|
||
|
<view class="search acea-row row-middle" :style="[searchStyle]">
|
||
|
<text class="iconfont icon-ic_search"></text>
|
||
|
<swiper v-if="hotWords.length" :autoplay="true" :interval="3000" :duration="1000" :vertical="true" :circular="true" class="swiper"
|
||
|
:style="{ color: dataConfig.hotWordsColor.color[0].item }">
|
||
|
<swiper-item v-for="(item, index) in hotWords" :key="index">
|
||
|
{{ item.val }}
|
||
|
</swiper-item>
|
||
|
</swiper>
|
||
|
<text v-else>{{ dataConfig.tipConfig.value }}</text>
|
||
|
</view>
|
||
|
</navigator>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view :style="'height:'+(statusBarHeight+serchHeight)+'px;'"></view>
|
||
|
</view>
|
||
|
<!-- #endif -->
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
let statusBarHeight = uni.getSystemInfoSync().statusBarHeight;
|
||
|
import location from "@/mixins/location";
|
||
|
export default {
|
||
|
name: 'headerSerch',
|
||
|
props: {
|
||
|
dataConfig: {
|
||
|
type: Object,
|
||
|
default: () => {}
|
||
|
}
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
statusBarHeight: statusBarHeight,
|
||
|
marTop: 63,
|
||
|
styleConfig: this.dataConfig.styleConfig.tabVal,
|
||
|
styleTypeConfig:this.dataConfig.styleTypeConfig.tabVal,
|
||
|
bgColor: this.dataConfig.moduleColor.color,
|
||
|
titleConfig: this.dataConfig.titleConfig.value,
|
||
|
txtColor: this.dataConfig.txtColor.color[0].item,
|
||
|
txtStyleConfig: this.dataConfig.txtStyleConfig.tabList[this.dataConfig.txtStyleConfig.tabVal].style,
|
||
|
txtSize: this.dataConfig.txtSize.val,
|
||
|
fixConfig: this.dataConfig.fixConfig.tabVal,
|
||
|
logoConfig: this.dataConfig.logoConfig.url,
|
||
|
txtFixConfig: this.dataConfig.txtFixConfig.tabVal,
|
||
|
boxStyle: '',
|
||
|
mbConfig: '',
|
||
|
hotWords: [],
|
||
|
prConfig: '',
|
||
|
tabVal: '',
|
||
|
radioVal: '',
|
||
|
textColor: '',
|
||
|
textStyle: '',
|
||
|
serchHeight: '',
|
||
|
serchRight: ''
|
||
|
};
|
||
|
},
|
||
|
computed: {
|
||
|
txtStyle() {
|
||
|
let num = 0
|
||
|
if(this.styleConfig==0 && this.styleTypeConfig != 2){
|
||
|
num = 30
|
||
|
}
|
||
|
return {
|
||
|
color:`${this.txtColor}`,
|
||
|
fontStyle:`${this.txtStyleConfig!='bold'?this.txtStyleConfig:''}`,
|
||
|
fontWeight:`${this.txtStyleConfig=='bold'?this.txtStyleConfig:''}`,
|
||
|
fontSize:`${this.txtSize*2}rpx`,
|
||
|
marginRight:`${num}rpx`
|
||
|
};
|
||
|
},
|
||
|
headerStyle() {
|
||
|
return {
|
||
|
padding: `${this.dataConfig.topConfig.val*2}rpx ${this.dataConfig.prConfig.val*2}rpx ${this.dataConfig.bottomConfig.val*2}rpx`,
|
||
|
background: this.dataConfig.bottomBgColor.color[0].item,
|
||
|
};
|
||
|
},
|
||
|
serchWrapperStyle() {
|
||
|
let borderRadius = [];
|
||
|
if (this.dataConfig.fillet.type) {
|
||
|
for (let i = 0; i < this.dataConfig.fillet.valList.length; i++) {
|
||
|
borderRadius.push(`${this.dataConfig.fillet.valList[i].val*2}rpx`);
|
||
|
}
|
||
|
} else {
|
||
|
for (let i = 0; i < 4; i++) {
|
||
|
borderRadius.push(`${this.dataConfig.fillet.val*2}rpx`);
|
||
|
}
|
||
|
}
|
||
|
return {
|
||
|
borderRadius: borderRadius.join(' '),
|
||
|
background: `linear-gradient(90deg, ${this.dataConfig.moduleColor.color[0].item} 0%, ${this.dataConfig.moduleColor.color[1].item} 100%)`,
|
||
|
};
|
||
|
},
|
||
|
txtPosition(){
|
||
|
return {
|
||
|
justifyContent:this.styleConfig !=0 && this.txtFixConfig===1?'center':this.styleConfig !=0 && this.txtFixConfig===2?'flex-end':'flex-start',
|
||
|
paddingLeft:this.styleConfig !=0 && this.txtFixConfig===1?this.serchRight+'px !important':0
|
||
|
}
|
||
|
},
|
||
|
searchStyle() {
|
||
|
return {
|
||
|
background: this.dataConfig.searchBoxColor.color[0].item,
|
||
|
color: this.dataConfig.tipColor.color[0].item,
|
||
|
justifyContent:this.txtFixConfig==0?'flex-start':this.txtFixConfig==2?'flex-end':'center'
|
||
|
};
|
||
|
},
|
||
|
},
|
||
|
mixins: [location],
|
||
|
mounted() {
|
||
|
let that = this;
|
||
|
that.hotWords = that.dataConfig.hotWords.list.filter(item => {
|
||
|
if (item.val) {
|
||
|
return item;
|
||
|
}
|
||
|
});
|
||
|
uni.setStorageSync('hotList', that.hotWords);
|
||
|
that.$store.commit('hotWords/setHotWord', that.hotWords);
|
||
|
// #ifdef MP || APP-PLUS
|
||
|
setTimeout(() => {
|
||
|
// 获取小程序头部高度
|
||
|
let info = uni.createSelectorQuery().in(this).select(".mp-header");
|
||
|
info.boundingClientRect(function(data) {
|
||
|
that.marTop = data.height
|
||
|
}).exec()
|
||
|
}, 100)
|
||
|
// #endif
|
||
|
// #ifdef MP
|
||
|
const {
|
||
|
windowWidth,
|
||
|
statusBarHeight,
|
||
|
} = uni.getSystemInfoSync();
|
||
|
const {
|
||
|
top,
|
||
|
left,
|
||
|
width,
|
||
|
height,
|
||
|
} = uni.getMenuButtonBoundingClientRect();
|
||
|
that.serchHeight = (top - statusBarHeight) * 2 + height;
|
||
|
that.serchRight = windowWidth - left;
|
||
|
// #endif
|
||
|
if(this.styleConfig===2 || (this.styleConfig===0 && this.styleTypeConfig === 1)){
|
||
|
this.selfLocation();
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
goLink() {
|
||
|
let url = this.dataConfig.linkConfig.value;
|
||
|
this.$util.JumpPath(url);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss" scoped>
|
||
|
.serch-wrapper {
|
||
|
|
||
|
&.center {
|
||
|
justify-content: center;
|
||
|
}
|
||
|
|
||
|
&.right {
|
||
|
justify-content: flex-end;
|
||
|
/* #ifdef MP */
|
||
|
padding-right: 185rpx !important;
|
||
|
/* #endif */
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.title {
|
||
|
margin-right: 30rpx;
|
||
|
font-weight: 400;
|
||
|
font-size: 30rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.map {
|
||
|
color: #fff;
|
||
|
font-size: 28rpx;
|
||
|
margin-right: 20rpx;
|
||
|
|
||
|
.info {
|
||
|
&.on {
|
||
|
max-width: 260rpx;
|
||
|
}
|
||
|
|
||
|
&.on1 {
|
||
|
max-width: 156rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 28rpx;
|
||
|
}
|
||
|
|
||
|
.icon-ic_rightarrow {
|
||
|
opacity: 0.8;
|
||
|
}
|
||
|
|
||
|
.icon-ic_location51{
|
||
|
margin-right: 6rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.header {
|
||
|
width: 100%;
|
||
|
// height: 100rpx;
|
||
|
// background: linear-gradient(90deg, $bg-star 50%, $bg-end 100%);
|
||
|
|
||
|
.serch-wrapper {
|
||
|
height: 96rpx;
|
||
|
padding: 18rpx 30rpx !important;
|
||
|
|
||
|
.logo {
|
||
|
height: 60rpx;
|
||
|
margin-right: 20rpx;
|
||
|
|
||
|
image {
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.input {
|
||
|
position: relative;
|
||
|
flex: 1;
|
||
|
|
||
|
.search {
|
||
|
flex: 1;
|
||
|
height: 60rpx;
|
||
|
padding: 0 32rpx;
|
||
|
border-radius: 30rpx;
|
||
|
background: #F5F5F5;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 32rpx;
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
margin-right: 16rpx;
|
||
|
font-size: 32rpx;
|
||
|
}
|
||
|
|
||
|
.swiper {
|
||
|
flex: 1;
|
||
|
height: 32rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* #ifdef MP || APP-PLUS */
|
||
|
.mp-header {
|
||
|
z-index: 30;
|
||
|
position: fixed;
|
||
|
left: 0;
|
||
|
top: 0;
|
||
|
width: 100%;
|
||
|
background: linear-gradient(90deg, $bg-star 50%, $bg-end 100%);
|
||
|
|
||
|
.serch-wrapper {
|
||
|
height: 100%;
|
||
|
/* #ifdef MP */
|
||
|
padding: 0 30rpx !important;
|
||
|
/* #endif */
|
||
|
/* #ifdef APP-PLUS */
|
||
|
padding: 0 50rpx 0 40rpx;
|
||
|
|
||
|
/* #endif */
|
||
|
.logo {
|
||
|
height: 60rpx;
|
||
|
margin-right: 20rpx;
|
||
|
|
||
|
image {
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.input {
|
||
|
position: relative;
|
||
|
flex: 1;
|
||
|
|
||
|
.search {
|
||
|
flex: 1;
|
||
|
height: 60rpx;
|
||
|
padding: 0 32rpx;
|
||
|
border-radius: 30rpx;
|
||
|
background: #F5F5F5;
|
||
|
font-size: 28rpx;
|
||
|
line-height: 32rpx;
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 32rpx;
|
||
|
margin-right: 18rpx;
|
||
|
}
|
||
|
|
||
|
.swiper {
|
||
|
flex: 1;
|
||
|
height: 32rpx;
|
||
|
}
|
||
|
|
||
|
.button {
|
||
|
position: absolute;
|
||
|
top: 4rpx;
|
||
|
right: 4rpx;
|
||
|
height: 52rpx;
|
||
|
padding: 0 24rpx;
|
||
|
border-radius: 26rpx;
|
||
|
background: var(--view-theme);
|
||
|
font-weight: 500;
|
||
|
line-height: 52rpx;
|
||
|
font-size: 22rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
|
||
|
.button2 {
|
||
|
margin-left: 20rpx;
|
||
|
font-size: 30rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
// 没有logo,直接搜索框
|
||
|
&.on {
|
||
|
/* #ifdef MP */
|
||
|
width: 70%;
|
||
|
/* #endif */
|
||
|
/* #ifdef APP-PLUS */
|
||
|
width: 100%;
|
||
|
/* #endif */
|
||
|
}
|
||
|
|
||
|
// 设置圆角
|
||
|
&.fillet {
|
||
|
border-radius: 29rpx;
|
||
|
}
|
||
|
|
||
|
// 文本框文字居中
|
||
|
&.row-center {
|
||
|
padding: 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* #endif */
|
||
|
.row-center uni-swiper-item, .row-center swiper-item{
|
||
|
text-align: center;
|
||
|
}
|
||
|
</style>
|