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.

326 lines
7.1 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<template>
<view class="category " :class="['theme', themeObj.name]">
<!-- 搜索 -->
<!-- #ifdef APP-PLUS -->
<div class="status-bar" :style="{height:statusBarHeight+'px'}"></div>
<!-- #endif -->
<view class="search">
<search class="w-100"></search>
</view>
<view class="VerticalBox">
<scroll-view class="VerticalNav nav" scroll-y scroll-with-animation
:scroll-top="verticalNavTop" style="height:calc(100vh - 140px)">
<view class="cu-item text-sm"
:class="index==tabCur?'text-green cur':''"
v-for="(categoryType_item,index) in categoryType" :key="index" @tap="TabSelect"
:data-id="index">
{{categoryType_item.name}}
</view>
</scroll-view>
<scroll-view class="padding-sm" scroll-y scroll-with-animation style="width: calc(100% - 110px); height:calc(100vh - 140px)"
:scroll-into-view="'main-'+mainCur" @scroll="VerticalMain">
<view class="type_head">
<view class="type_head_item text-center text-xs"
v-for="(type,index) in subPoiCategories"
:class="type.id==tabTypeCur?'type_head_item_cur':''"
@tap="TabTypeSelect" :key="index":data-id="type.id">
<view class="">{{type.name}}</view>
</view>
</view>
<view class="type_good">
<goodList :has-token="hasToken" style="width: 100%; background-color: #FFFFFF;" :propsList = "cateGood" ></goodList>
</view>
</scroll-view>
</view>
</view>
</template>
<script>
import { getGoodsList } from '@/api/index.js'
import search from "../../commponent/public/search";
import goodList from '../../commponent/home/goodList';
import jsonData from "../../../json.js"
import { getCart, getToken } from '@/utils/auth';
import { setTabBarBadge } from '@/utils/util.js'
var app = getApp();
export default {
data() {
return {
mainCur: 0,
tabCur: 0,
categoryType:[], //分类
verticalNavTop: 0,
subPoiCategories:[], //二级分类
tabTypeCur:0, //二级分类选中id
cateGood:[],
bottoms: '100',
showHeader: false, //判断当前终端是APP还是h5
classLevel: true, //控制显示分类菜单 true二级分类菜单 false三级分类菜单
current: "",
scrollTop: "",
statusBarHeight: 20,
currentTwo: 0,
currentThere: 0,
_goods: [],
hasToken: true,
themeObj: app.globalData.themeObj
};
},
components: {
search,
goodList
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function(options) {
// #ifdef APP-PLUS
this.showHeader = true //在APP端对样式进行调整
this.bottoms = '0' //在APP下 规格弹窗的位置发生变化
// #endif
this.getGoodsList()
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady: function() {},
/**
* 生命周期函数--监听页面显示
*/
onShow: function() {
if (getToken()) {
this.hasToken = true
const carts = getCart()
setTabBarBadge(carts.length)
} else {
uni.navigateTo({
url: '/pages/login/index1'
})
this.hasToken = false
setTabBarBadge(0)
}
this.themeObj = app.globalData.themeObj
},
/**
* 生命周期函数--监听页面隐藏
*/
onHide: function() {},
/**
* 生命周期函数--监听页面卸载
*/
onUnload: function() {},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh: function() {},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom: function() {},
/**
* 用户点击右上角分享
*/
onShareAppMessage: function() {},
methods: {
getGoodsList() {
const s = [
{
"rule": "eq",
"type": "string",
"dictCode": "",
"val": "1",
"field": "ifSale"
}
]
const params = {
pageNo:1,
pageSize: 100,
superQueryParams: encodeURI(JSON.stringify(s)),
superQueryMatchType: 'and'
}
getGoodsList(params).then(res => {
const result = res.result.records.reduce((c,v) => {
c[v.category] = c[v.category] || []
c[v.category].push(v)
return c
}, {})
const data = Object.keys(result).map((v, index) => {
return {
name: v,
id: index,
children: result[v],
"leaf": 0,
"type": 100,
"subPoiCategories": []
}
})
this._goods = data
this.categoryType = data
this.subPoiCategories = []
this.cateGood = data[this.tabCur].children
})
},
TabSelect(e) {
this.tabCur = e.currentTarget.dataset.id;
this.mainCur = e.currentTarget.dataset.id;
this.verticalNavTop = (e.currentTarget.dataset.id - 1) * 50;
this.subPoiCategories = []
this.cateGood = this._goods[this.tabCur].children
},
TabTypeSelect(e) {
this.tabTypeCur = e.currentTarget.dataset.id;
},
VerticalMain(e) {
// #ifdef MP-ALIPAY
return false //支付宝小程序暂时不支持双向联动
// #endif
let that = this;
let tabHeight = 0;
if (this.load) {
for (let i = 0; i < this.categoryType.length; i++) {
let view = uni.createSelectorQuery().select("#main-" + this.categoryType[i].id);
view.fields({
size: true
}, data => {
this.categoryType[i].top = tabHeight;
tabHeight = tabHeight + data.height;
this.categoryType[i].bottom = tabHeight;
}).exec();
}
this.load = false
}
let scrollTop = e.detail.scrollTop + 10;
for (let i = 0; i < this.categoryType.length; i++) {
if (scrollTop > this.categoryType[i].top && scrollTop < this.categoryType[i].bottom) {
this.verticalNavTop = (this.categoryType[i].id - 1) * 50
this.tabCur = this.categoryType[i].id
console.log(scrollTop)
return false
}
}
}
}
};
</script>
<style scoped lang="scss">
.fixed {
position: fixed;
z-index: 99;
}
.VerticalNav.nav {
width: 200upx;
white-space: initial;
background-color: #f1f1f1;
}
.VerticalNav.nav .cu-item {
width: 100%;
text-align: center;
background-color: #f1f1f1 ;
margin: 0;
border: none;
height: 50px;
position: relative;
}
.VerticalNav.nav .cu-item.cur {
background-color: #fff;
}
.VerticalNav.nav .cu-item.cur::after {
content: "";
width: 8upx;
height: 50upx;
border-radius: 0 10upx 10upx 0 ;
position: absolute;
background-color: #4BDA4D;
top: 0;
left: 0;
bottom: 0;
margin: auto;
}
.VerticalBox {
display: flex;
}
.VerticalMain {
background-color: #fff;
flex: 1;
}
.category {
background-color: #ffffff;
position: fixed;
width: 100%;
height: 100%;
box-sizing: border-box;
top: 0;
bottom: 0;
z-index: 10;
}
.search {
height: 70px;
padding: 10upx 10upx;
padding-left: 10upx;
overflow: hidden;
display: flex;
align-items: center;
justify-content: space-between;
}
.type_head{
display: grid;
grid-template-columns: repeat(3,33.33%);
grid-gap: 10rpx;
}
.type_head_item{
line-height: 65rpx;
color: #000000;
background-color: #F5F6F7;
border-radius: 15rpx;
}
.type_head_item_cur{
line-height: 65rpx;
color: #1E9C3D;
background-color: #E4FCDE;
border-radius: 15rpx;
}
</style>