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.
414 lines
9.7 KiB
414 lines
9.7 KiB
<template>
|
|
<view class='productSort copy-data' :style="{height:pageHeight}">
|
|
<!-- #ifdef APP-PLUS || MP -->
|
|
<!-- <view class="sys-head" :style="{height:sysHeight}"></view> -->
|
|
<!-- #endif -->
|
|
<view class='header acea-row row-center-wrapper'>
|
|
<view class='acea-row row-between-wrapper input'>
|
|
<text class='iconfont icon-sousuo'></text>
|
|
<input type='text' :placeholder="$t('搜索商品名称')" @confirm="searchSubmitValue" confirm-type='search'
|
|
name="search" placeholder-class='placeholder'></input>
|
|
</view>
|
|
</view>
|
|
<view class="scroll-box">
|
|
<view class='aside'>
|
|
<scroll-view scroll-y="true" scroll-with-animation='true' style="height: calc(100% - 100rpx)">
|
|
<view class='item acea-row row-center-wrapper' :class='index==navActive?"on":""'
|
|
v-for="(item,index) in productList" :key="index" @click='tap(index,"b"+index)'>
|
|
<text>{{$t(item.cate_name)}}</text>
|
|
</view>
|
|
<!-- #ifdef APP-PLUS -->
|
|
<view class="item" v-if="newData.status && newData.status.status"></view>
|
|
<!-- #endif -->
|
|
</scroll-view>
|
|
</view>
|
|
|
|
|
|
<view class='conter'>
|
|
<scroll-view scroll-y="true" :scroll-into-view="toView" @scroll="scroll" scroll-with-animation='true'
|
|
style="height: 100%;" class="conterScroll">
|
|
<block v-for="(item,index) in productList" :key="index">
|
|
<view class='listw' :id="'b'+index">
|
|
<view class='title acea-row row-center-wrapper'>
|
|
<view class='line'></view>
|
|
<view class='name'>{{$t(item.cate_name)}}</view>
|
|
<view class='line'></view>
|
|
</view>
|
|
<view class='list acea-row'>
|
|
<navigator hover-class='none'
|
|
:url='"/pages/goods/goods_list/index?cid="+item.id+"&title="+item.cate_name'
|
|
class='item acea-row row-column row-middle'>
|
|
<view class='picture'>
|
|
<easy-loadimage mode="widthFix" :image-src="item.pic || defimg">
|
|
</easy-loadimage>
|
|
<!-- <image src="/static/images/sort-img.png" v-else></image> -->
|
|
</view>
|
|
<view class='name line1'>{{$t(`全部商品`)}}</view>
|
|
</navigator>
|
|
<block v-for="(itemn,indexn) in item.children" :key="indexn">
|
|
<navigator hover-class='none'
|
|
:url='"/pages/goods/goods_list/index?sid="+itemn.id+"&title="+itemn.cate_name'
|
|
class='item acea-row row-column row-middle'>
|
|
<view class='picture'>
|
|
<easy-loadimage mode="widthFix" :image-src="itemn.pic"></easy-loadimage>
|
|
<!-- <image src="/static/images/sort-img.png" v-else></image> -->
|
|
</view>
|
|
<view class='name line1'>{{$t(itemn.cate_name)}}</view>
|
|
</navigator>
|
|
</block>
|
|
</view>
|
|
</view>
|
|
</block>
|
|
<view :style='"height:"+(height-300)+"rpx;"' v-if="number<15"></view>
|
|
</scroll-view>
|
|
</view>
|
|
</view>
|
|
<tabBar v-if="!is_diy" :pagePath="'/pages/goods_cate/goods_cate'"></tabBar>
|
|
<pageFooter v-else></pageFooter>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
let sysHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
|
|
import {
|
|
getCategoryList
|
|
} from '@/api/store.js';
|
|
import {
|
|
mapState,
|
|
mapGetters
|
|
} from "vuex"
|
|
import {
|
|
getNavigation
|
|
} from '@/api/public.js'
|
|
import pageFooter from '@/components/pageFooter/index.vue'
|
|
import tabBar from "@/pages/index/visualization/components/tabBar.vue";
|
|
const app = getApp();
|
|
export default {
|
|
components: {
|
|
pageFooter,
|
|
tabBar
|
|
},
|
|
data() {
|
|
return {
|
|
defimg: require('@/static/images/all_cat.png'),
|
|
navlist: [],
|
|
productList: [],
|
|
navActive: 0,
|
|
number: "",
|
|
is_diy: uni.getStorageSync('is_diy'),
|
|
height: 0,
|
|
hightArr: [],
|
|
toView: "",
|
|
tabbarH: 0,
|
|
footH: 0,
|
|
windowHeight: 0,
|
|
newData: {},
|
|
activeRouter: '',
|
|
pageHeight: '100%',
|
|
sysHeight: sysHeight,
|
|
// #ifdef APP-PLUS
|
|
pageHeight: app.globalData.windowHeight,
|
|
// #endif
|
|
lock: false
|
|
}
|
|
},
|
|
computed: {
|
|
...mapState({
|
|
cartNum: state => state.indexData.cartNum
|
|
})
|
|
},
|
|
mounted() {
|
|
let that = this
|
|
// #ifdef H5
|
|
uni.getSystemInfo({
|
|
success: function(res) {
|
|
that.pageHeight = res.windowHeight + 'px'
|
|
}
|
|
});
|
|
// #endif
|
|
let routes = getCurrentPages();
|
|
let curRoute = routes[routes.length - 1].route
|
|
this.activeRouter = '/' + curRoute
|
|
!that.productList.length && this.getAllCategory(1);
|
|
uni.$on('uploadCatData', () => {
|
|
this.getAllCategory(1);
|
|
})
|
|
},
|
|
methods: {
|
|
getNav() {
|
|
getNavigation().then(res => {
|
|
this.newData = res.data
|
|
})
|
|
},
|
|
goRouter(item) {
|
|
var pages = getCurrentPages();
|
|
var page = (pages[pages.length - 1]).$page.fullPath;
|
|
if (item.link == page) return
|
|
uni.switchTab({
|
|
url: item.link,
|
|
fail(err) {
|
|
uni.redirectTo({
|
|
url: item.link
|
|
})
|
|
}
|
|
})
|
|
},
|
|
footHeight(data) {
|
|
this.footH = data
|
|
},
|
|
infoScroll: function() {
|
|
let that = this;
|
|
let len = that.productList.length;
|
|
this.number = that.productList[len - 1].children.length;
|
|
//设置商品列表高度
|
|
uni.getSystemInfo({
|
|
success: function(res) {
|
|
that.height = (res.windowHeight) * (750 / res.windowWidth) - 98;
|
|
},
|
|
});
|
|
let height = 0;
|
|
let hightArr = [];
|
|
for (let i = 0; i < len; i++) {
|
|
//获取元素所在位置
|
|
let query = uni.createSelectorQuery().in(this);
|
|
let idView = "#b" + i;
|
|
query.select(idView).boundingClientRect();
|
|
query.exec(function(res) {
|
|
let top = res[0].top;
|
|
hightArr.push(top);
|
|
that.hightArr = hightArr
|
|
});
|
|
};
|
|
},
|
|
tap: function(index, id) {
|
|
this.toView = id;
|
|
this.navActive = index;
|
|
this.$set(this, 'lock', true);
|
|
uni.$emit('scroll');
|
|
},
|
|
getAllCategory: function(type) {
|
|
let that = this;
|
|
if (type || !uni.getStorageSync('CAT1_DATA')) {
|
|
getCategoryList().then(res => {
|
|
uni.setStorageSync('CAT1_DATA', res.data)
|
|
that.productList = res.data;
|
|
that.$nextTick(res => {
|
|
that.infoScroll();
|
|
})
|
|
})
|
|
} else {
|
|
that.productList = uni.getStorageSync('CAT1_DATA')
|
|
that.$nextTick(res => {
|
|
that.infoScroll();
|
|
})
|
|
}
|
|
},
|
|
scroll: function(e) {
|
|
let scrollTop = e.detail.scrollTop;
|
|
let scrollArr = this.hightArr;
|
|
if (this.lock) {
|
|
this.$set(this, 'lock', false);
|
|
return;
|
|
}
|
|
for (let i = 0; i < scrollArr.length; i++) {
|
|
if (scrollTop >= 0 && scrollTop < scrollArr[1] - scrollArr[0]) {
|
|
this.navActive = 0
|
|
} else if (scrollTop >= scrollArr[i] - scrollArr[0] && scrollTop < scrollArr[i + 1] - scrollArr[
|
|
0]) {
|
|
this.navActive = i
|
|
} else if (scrollTop >= scrollArr[scrollArr.length - 1] - scrollArr[0]) {
|
|
this.navActive = scrollArr.length - 1
|
|
}
|
|
}
|
|
uni.$emit('scroll');
|
|
},
|
|
searchSubmitValue: function(e) {
|
|
if (this.$util.trim(e.detail.value).length > 0)
|
|
uni.navigateTo({
|
|
url: '/pages/goods/goods_list/index?searchValue=' + e.detail.value
|
|
})
|
|
else
|
|
return this.$util.Tips({
|
|
title: this.$t(`搜索商品名称`)
|
|
});
|
|
},
|
|
}
|
|
}
|
|
</script>
|
|
<style scoped lang="scss">
|
|
/deep/uni-scroll-view {
|
|
padding-bottom: 0 !important;
|
|
}
|
|
|
|
.sys-title {
|
|
z-index: 10;
|
|
position: relative;
|
|
height: 40px;
|
|
line-height: 40px;
|
|
font-size: 30rpx;
|
|
color: #333;
|
|
background-color: #fff;
|
|
// #ifdef APP-PLUS
|
|
text-align: center;
|
|
// #endif
|
|
// #ifdef MP
|
|
text-align: left;
|
|
padding-left: 30rpx;
|
|
// #endif
|
|
}
|
|
|
|
.sys-head {
|
|
background-color: #fff;
|
|
}
|
|
|
|
.productSort {
|
|
display: flex;
|
|
flex-direction: column;
|
|
//#ifdef MP
|
|
height: calc(100vh - var(--window-top)) !important;
|
|
//#endif
|
|
//#ifndef MP
|
|
height: 100vh //#endif
|
|
}
|
|
|
|
.productSort .header {
|
|
width: 100%;
|
|
height: 96rpx;
|
|
background-color: #fff;
|
|
border-bottom: 1rpx solid #f5f5f5;
|
|
}
|
|
|
|
.productSort .header .input {
|
|
width: 700rpx;
|
|
height: 60rpx;
|
|
background-color: #f5f5f5;
|
|
border-radius: 50rpx;
|
|
box-sizing: border-box;
|
|
padding: 0 25rpx;
|
|
}
|
|
|
|
.productSort .header .input .iconfont {
|
|
font-size: 35rpx;
|
|
color: #555;
|
|
}
|
|
|
|
.productSort .header .input .placeholder {
|
|
color: #999;
|
|
}
|
|
|
|
.productSort .header .input input {
|
|
font-size: 26rpx;
|
|
height: 100%;
|
|
width: 597rpx;
|
|
}
|
|
|
|
.productSort .scroll-box {
|
|
flex: 1;
|
|
overflow: hidden;
|
|
display: flex;
|
|
}
|
|
|
|
// #ifndef MP
|
|
uni-scroll-view {
|
|
padding-bottom: 100rpx;
|
|
}
|
|
|
|
// #endif
|
|
|
|
.productSort .aside {
|
|
width: 180rpx;
|
|
height: 100%;
|
|
overflow: hidden;
|
|
background-color: #f7f7f7;
|
|
}
|
|
|
|
.productSort .aside .item {
|
|
height: 100rpx;
|
|
width: 100%;
|
|
font-size: 26rpx;
|
|
color: #424242;
|
|
text-align: center;
|
|
}
|
|
|
|
.productSort .aside .item.on {
|
|
background-color: #fff;
|
|
border-left: 4rpx solid var(--view-theme);
|
|
width: 100%;
|
|
color: var(--view-theme);
|
|
font-weight: bold;
|
|
}
|
|
|
|
.productSort .conter {
|
|
flex: 1;
|
|
height: 100%;
|
|
overflow: hidden;
|
|
padding: 0 14rpx;
|
|
background-color: #fff;
|
|
position: relative;
|
|
padding-bottom: 200rpx;
|
|
}
|
|
|
|
.productSort .conter .listw {
|
|
padding-top: 20rpx;
|
|
}
|
|
|
|
.productSort .conter .listw .title {
|
|
height: 90rpx;
|
|
}
|
|
|
|
.productSort .conter .listw .title .line {
|
|
width: 100rpx;
|
|
height: 2rpx;
|
|
background-color: #f0f0f0;
|
|
}
|
|
|
|
.productSort .conter .listw .title .name {
|
|
font-size: 28rpx;
|
|
color: #333;
|
|
margin: 0 30rpx;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.productSort .conter .list {
|
|
flex-wrap: wrap;
|
|
}
|
|
|
|
.productSort .conter .list .item {
|
|
width: 177rpx;
|
|
margin-top: 26rpx;
|
|
}
|
|
|
|
.productSort .conter .list .item .picture {
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
border-radius: 50%;
|
|
}
|
|
|
|
// .productSort .conter .list .item .picture image {
|
|
// width: 100%;
|
|
// height: 100%;
|
|
// border-radius: 50%;
|
|
// }
|
|
|
|
.productSort .conter .list .item .picture {
|
|
|
|
/deep/,
|
|
/deep/image,
|
|
/deep/.easy-loadimage,
|
|
/deep/uni-image {
|
|
|
|
width: 120rpx;
|
|
height: 120rpx;
|
|
border-radius: 50%;
|
|
}
|
|
}
|
|
|
|
.productSort .conter .list .item .name {
|
|
font-size: 24rpx;
|
|
color: #333;
|
|
height: 56rpx;
|
|
line-height: 56rpx;
|
|
width: 120rpx;
|
|
text-align: center;
|
|
}
|
|
</style>
|
|
|