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.
1749 lines
42 KiB
1749 lines
42 KiB
3 months ago
|
<template>
|
||
|
<!-- 商品分类第三种布局样式 -->
|
||
|
<view class="goodCate acea-row row-column">
|
||
|
<view v-show="scrollTop" :style="{ height: headerHeight+'px' }"></view>
|
||
|
<view :class="{ fixed: scrollTop }" class="mp-header" id="mp-header">
|
||
|
<view class="sys-head" :style="{ height: sysHeight+'px' }"></view>
|
||
|
<view class="serch-box" style="height: 43px;">
|
||
|
<view class="serch-wrapper acea-row row-middle">
|
||
|
<view class="menu_box flex-center opac">
|
||
|
<image src="@/static/img/back_icon.png" class="w-32 h-32" @tap="backTap"></image>
|
||
|
<text class="menu_line"></text>
|
||
|
<image src="@/static/img/menu_icon.png" class="w-32 h-32" @tap="moreNav"></image>
|
||
|
</view>
|
||
|
<navigator open-type="navigateBack" hover-class="none">
|
||
|
<text class="iconfont icon-fanhui2"></text>
|
||
|
</navigator>
|
||
|
<navigator url="/pages/goods/goods_search/index" class="input acea-row row-middle" hover-class="none">
|
||
|
<text class="iconfont icon-ic_search"></text>
|
||
|
请输入商品名称
|
||
|
</navigator>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<!-- 门店地址详情 -->
|
||
|
<view class="store-address">
|
||
|
<view class="address acea-row row-middle">
|
||
|
<view class="name line1">{{info.name || '暂无门店'}}</view>
|
||
|
<view class="tips">本单到店{{info.delivery_type == 2 ? '自提' : '配送'}}</view>
|
||
|
</view>
|
||
|
<view class="distance acea-row">
|
||
|
<text class="iconfont icon-ic_location51"></text>
|
||
|
<view class="text">门店距您{{info.range||0}}km|{{info.address}}{{info.detailed_address}}</view>
|
||
|
</view>
|
||
|
<view class="time acea-row">
|
||
|
<text class="iconfont icon-icon_clock"></text>
|
||
|
<view class="text">营业时间:{{info.day_time || '-'}}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="category acea-row" v-if="diyCategory.level == 3">
|
||
|
<scroll-view scroll-x="true" class="scroll-view">
|
||
|
<view class="item" :class="{ on: navOneActive == index }" v-for="(item,index) in categoryList" :key="item.id" @click="tapNavOne(item,index)">
|
||
|
<view class="img-box">
|
||
|
<image :src="item.pic" class="img"></image>
|
||
|
</view>
|
||
|
<view class="title">{{item.cate_name}}</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
<view class="btn acea-row row-column row-center row-middle" @click="oneDrawerOpen">
|
||
|
<view class="">全</view>
|
||
|
<view class="">部</view>
|
||
|
<image class="w-28 h-28 block mt-8" src="@/static/img/all_pic.png"></image>
|
||
|
<image src="../static/shade.png" class="img"></image>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="conter acea-row" id="conter">
|
||
|
<view class="aside-box">
|
||
|
<scroll-view scroll-y="true" class="aside" :class="{ fixed: scrollTop && (conterTop - scrollTop <= headerHeight) }" :style="{ top: headerHeight+'px' }">
|
||
|
<view class='item acea-row row-center-wrapper' :class='index==navActive?"on":""' v-for="(item,index) in categoryErList" :key="index" @click="tapNav(item,index)">
|
||
|
<text>{{item.cate_name}}</text>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
</view>
|
||
|
<view class="wrapper">
|
||
|
<view class="bgcolor-box">
|
||
|
<view class="bgcolor acea-row" :class="{ fixed: scrollTop && (conterTop - scrollTop <= headerHeight) }" :style="{ top: headerHeight+'px' }">
|
||
|
<view class="longTab acea-row row-middle">
|
||
|
<scroll-view scroll-x="true" style="white-space: nowrap;" scroll-with-animation :scroll-left="tabLeft" show-scrollbar="true">
|
||
|
<view class="longItem" :style='"width:"+isWidth+"px"' :class="index===tabClick?'click':''" v-for="(item,index) in categoryThreeList" :key="index"
|
||
|
@click="longClick(index)">
|
||
|
<view class="inner">{{item.cate_name}}</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
</view>
|
||
|
<view class="openList">
|
||
|
<view class="btn" @click="openTap">
|
||
|
<text class="iconfont icon-ic_downarrow"></text>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<!--商品列表 -->
|
||
|
<goodClass :tempArr="tempArr" :isLogin="isLogin" @gocartduo="goCartDuo" @gocartdan="goCartDan" @ChangeCartNumDan="ChangeCartNumDan" @detail="goDetail"></goodClass>
|
||
|
<view class='loadingicon acea-row row-center-wrapper'>
|
||
|
<text class='loading iconfont icon-jiazai' :hidden='loading==false'></text>{{loadTitle}}
|
||
|
</view>
|
||
|
<view class="safe-area-inset-bottom"></view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="footer">
|
||
|
<view class="inner-box" :class="{ open: footerOpen }">
|
||
|
<view class="inner acea-row row-between row-middle">
|
||
|
<BaseMoney :money="totalPrice" symbolSize="32" integerSize="48" decimalSize="32" color="#FFFFFF"></BaseMoney>
|
||
|
<view class="btn" @click="subOrder">选好了</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="cartIcon" @click="getCartLists">
|
||
|
<uni-badge :text="cartNum" absolute="rightTop" :offset="[6, 4]" :custom-style="{background: 'var(--view-theme)'}">
|
||
|
<view class="image-wrap">
|
||
|
<image src="@/static/img/cart_pic.png" class="image"></image>
|
||
|
</view>
|
||
|
</uni-badge>
|
||
|
</view>
|
||
|
</view>
|
||
|
<!-- 分类购物车下拉列表 -->
|
||
|
<cartList :cartData="cartData" :isFooter='isFooter' :cartNums='cartNum' @closeList="closeList" @ChangeCartNumDan="ChangeCartList" @ChangeSubDel="ChangeSubDel"
|
||
|
@ChangeOneDel="ChangeOneDel"></cartList>
|
||
|
<!-- 产品属性组件 -->
|
||
|
<productWindow :attr="attr" :isShow='1' :iSplus='1' :iScart='1' :type="2" @myevent="onMyEvent" @ChangeAttr="ChangeAttr" @ChangeCartNum="ChangeCartNumDuo" @attrVal="attrVal"
|
||
|
@iptCartNum="iptCartNum" @goCat="goCatNum" :is_vip="is_vip" id='product-window'></productWindow>
|
||
|
<homeList :navH="46 + sysHeight" :currentPage="currentPage" :sysHeight="sysHeight" :openNavList="diyProduct.navList"></homeList>
|
||
|
<tuiDrawer :visible="!iSlong" mode="top" backgroundColor="transparent" @close="closeTap">
|
||
|
<view class="downTab acea-row row-column">
|
||
|
<!-- #ifdef MP -->
|
||
|
<view :style="{height: getHeight.barTop+'px'}"></view>
|
||
|
<view :style="{height: getHeight.barHeight+'px'}"></view>
|
||
|
<!-- #endif -->
|
||
|
<view class="title acea-row row-between-wrapper">
|
||
|
<view>{{categoryTitle}}</view>
|
||
|
</view>
|
||
|
<scroll-view scroll-y="true" class="scroll-view">
|
||
|
<view class="children">
|
||
|
<view class="acea-row row-middle">
|
||
|
<view class="item line1" :class="index===tabClick?'click':''" v-for="(item,index) in categoryThreeList" :key="index" @click="longClick(index,item)">
|
||
|
<view class="inner">{{item.cate_name}}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
<view class="btn acea-row row-center-wrapper" @click="closeTap">点击收起<text class="iconfont icon-ic_uparrow"></text></view>
|
||
|
</view>
|
||
|
</tuiDrawer>
|
||
|
<tuiDrawer :visible="oneVisible" mode="top" backgroundColor="transparent" @close="oneDrawerClose">
|
||
|
<view class="category-dialog">
|
||
|
<!-- #ifdef MP -->
|
||
|
<view :style="{height: getHeight.barTop+'px'}"></view>
|
||
|
<view :style="{height: getHeight.barHeight+'px'}"></view>
|
||
|
<!-- #endif -->
|
||
|
<scroll-view scroll-y="true" class="scroll-view">
|
||
|
<view class="acea-row">
|
||
|
<view class="item" :class="{ on: navOneActive == index }" v-for="(item,index) in categoryList" :key="item.id" @click="tapNavOne(item,index)">
|
||
|
<view class="img-box">
|
||
|
<image :src="item.pic" class="img"></image>
|
||
|
</view>
|
||
|
<view class="title">{{item.cate_name}}</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</scroll-view>
|
||
|
<view class="btn acea-row row-center-wrapper" @click="oneDrawerClose">
|
||
|
点击收起<text class="iconfont icon-ic_uparrow"></text>
|
||
|
</view>
|
||
|
</view>
|
||
|
</tuiDrawer>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
let sysHeight = uni.getSystemInfoSync().statusBarHeight;
|
||
|
|
||
|
import {
|
||
|
vcartList,
|
||
|
getCartCounts,
|
||
|
cartDel
|
||
|
} from '@/api/order.js';
|
||
|
import {
|
||
|
getCategoryList,
|
||
|
getAttr,
|
||
|
postCartNum,
|
||
|
getCollageCart,
|
||
|
addCollageCart,
|
||
|
getCollageCount,
|
||
|
emptyCollagePartake,
|
||
|
} from '@/api/store.js';
|
||
|
import {
|
||
|
getProducts,
|
||
|
getCustomerList,
|
||
|
getStoreCategory,
|
||
|
getStoreBrand
|
||
|
} from '@/api/new_store.js';
|
||
|
import productWindow from '@/components/productWindow/index';
|
||
|
import goodClass from '@/components/goodClass';
|
||
|
import cartList from '@/components/cartList';
|
||
|
import homeList from '@/components/homeList/index.vue';
|
||
|
import tuiDrawer from '@/components/tui-drawer/tui-drawer.vue';
|
||
|
import {
|
||
|
mapGetters
|
||
|
} from 'vuex';
|
||
|
import {
|
||
|
goShopDetail
|
||
|
} from '@/libs/order.js';
|
||
|
import {
|
||
|
toLogin
|
||
|
} from '@/libs/login.js';
|
||
|
export default {
|
||
|
computed: {
|
||
|
...mapGetters(['isLogin', 'uid', 'diyProduct', 'diyCategory'])
|
||
|
},
|
||
|
components: {
|
||
|
productWindow,
|
||
|
goodClass,
|
||
|
cartList,
|
||
|
homeList,
|
||
|
tuiDrawer,
|
||
|
},
|
||
|
props: {
|
||
|
isFooter: {
|
||
|
type: Boolean,
|
||
|
default: false
|
||
|
},
|
||
|
info: {
|
||
|
type: Object,
|
||
|
default: {}
|
||
|
},
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
getHeight: this.$util.getWXStatusHeight(),
|
||
|
deliveryList: [{
|
||
|
name: '自提',
|
||
|
key: 2
|
||
|
},
|
||
|
{
|
||
|
name: '配送',
|
||
|
key: 1
|
||
|
},
|
||
|
],
|
||
|
switchNum: 1,
|
||
|
sysHeight: sysHeight,
|
||
|
categoryList: [],
|
||
|
navOneActive: 0,
|
||
|
navActive: 0,
|
||
|
categoryTitle: '',
|
||
|
categoryErList: [],
|
||
|
categoryThreeList: [],
|
||
|
tabLeft: 0,
|
||
|
isWidth: 0, //每个导航栏占位
|
||
|
tabClick: 0, //导航栏被点击
|
||
|
iSlong: true,
|
||
|
tempArr: [],
|
||
|
loading: false,
|
||
|
loadend: false,
|
||
|
loadTitle: '加载更多',
|
||
|
page: 1,
|
||
|
limit: 10,
|
||
|
cid: 0, //一级分类
|
||
|
sid: 0, //二级分类
|
||
|
tid: 0, //三级分类
|
||
|
delivery_type: 3, // 配送方式
|
||
|
isAuto: false, //没有授权的不会自动授权
|
||
|
isShowAuth: false, //是否隐藏授权
|
||
|
attr: {
|
||
|
cartAttr: false,
|
||
|
productAttr: [],
|
||
|
productSelect: {}
|
||
|
},
|
||
|
productValue: [],
|
||
|
attrValue: '', //已选属性
|
||
|
storeName: '', //多属性产品名称
|
||
|
id: 0,
|
||
|
cartData: {
|
||
|
cartList: [],
|
||
|
iScart: false
|
||
|
},
|
||
|
totalPrice: 0.00,
|
||
|
lengthCart: 0,
|
||
|
is_vip: 0, //是否是会员
|
||
|
cart_num: 0,
|
||
|
storeInfo: {},
|
||
|
cartNum: 0,
|
||
|
footerOpen: false,
|
||
|
currentPage: false,
|
||
|
oneVisible: false,
|
||
|
headerHeight: 0,
|
||
|
conterTop: 0,
|
||
|
scrollTop: 0,
|
||
|
}
|
||
|
},
|
||
|
watch: {
|
||
|
info(newValue, oldValue) {
|
||
|
this.switchNum = newValue.delivery_type == 3 ? 1 : newValue.delivery_type
|
||
|
this.$nextTick(() => {
|
||
|
const query = uni.createSelectorQuery().in(this);
|
||
|
query
|
||
|
.select("#mp-header")
|
||
|
.boundingClientRect((data) => {
|
||
|
this.headerHeight = data.height;
|
||
|
})
|
||
|
.exec();
|
||
|
query
|
||
|
.select("#conter")
|
||
|
.boundingClientRect((data) => {
|
||
|
this.conterTop = data.top;
|
||
|
})
|
||
|
.exec();
|
||
|
});
|
||
|
},
|
||
|
},
|
||
|
mounted() {
|
||
|
let that = this;
|
||
|
// 获取设备宽度
|
||
|
uni.getSystemInfo({
|
||
|
success(e) {
|
||
|
that.isWidth = e.windowWidth / 5
|
||
|
}
|
||
|
});
|
||
|
// 页面滚动
|
||
|
uni.$on('onPageScroll', (scrollTop) => {
|
||
|
this.scrollTop = scrollTop;
|
||
|
this.footerOpen = false;
|
||
|
});
|
||
|
// 页面滚动到底部
|
||
|
uni.$on('onReachBottom', () => {
|
||
|
this.getProducts();
|
||
|
});
|
||
|
},
|
||
|
methods: {
|
||
|
// 授权回调
|
||
|
onLoadFun() {
|
||
|
setTimeout(function() {
|
||
|
this.isShowAuth = false;
|
||
|
}, 10)
|
||
|
},
|
||
|
// 授权关闭
|
||
|
authColse: function(e) {
|
||
|
this.isShowAuth = e
|
||
|
},
|
||
|
updateFun(e) {
|
||
|
if (e.cartNum) {
|
||
|
this.tempArr.forEach((item) => {
|
||
|
if (item.id == e.id) {
|
||
|
item.cart_num = e.cartNum
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
// 商品列表
|
||
|
getProducts() {
|
||
|
let that = this;
|
||
|
if (that.loadend) return;
|
||
|
if (that.loading) return;
|
||
|
that.loading = true;
|
||
|
getProducts({
|
||
|
page: that.page,
|
||
|
limit: that.limit,
|
||
|
type: 1,
|
||
|
cid: that.cid,
|
||
|
sid: that.sid,
|
||
|
tid: that.tid,
|
||
|
store_id: that.info.id,
|
||
|
delivery_type: that.info.delivery_type,
|
||
|
collate_code_id: that.info.collage_id
|
||
|
}).then(res => {
|
||
|
let list = res.data,
|
||
|
loadend = list.length < that.limit;
|
||
|
that.tempArr = that.$util.SplitArray(list, that.tempArr);
|
||
|
that.$set(that, 'tempArr', that.tempArr);
|
||
|
that.loading = false;
|
||
|
that.loadend = loadend;
|
||
|
that.loadTitle = loadend ? "没有更多内容啦~" : "加载更多";
|
||
|
that.page = that.page + 1;
|
||
|
}).catch(err => {
|
||
|
that.loading = false;
|
||
|
that.loadTitle = '加载更多'
|
||
|
});
|
||
|
},
|
||
|
// 切换自提方式
|
||
|
swithFn(num) {
|
||
|
switch (num) {
|
||
|
case 1:
|
||
|
this.switchNum = 1
|
||
|
this.delivery_type = '3'
|
||
|
break;
|
||
|
case 2:
|
||
|
this.switchNum = 2
|
||
|
this.delivery_type = '2'
|
||
|
break;
|
||
|
}
|
||
|
this.page = 1;
|
||
|
this.loadend = false;
|
||
|
this.tempArr = []
|
||
|
this.getProducts()
|
||
|
},
|
||
|
// 生成订单;
|
||
|
subOrder: function() {
|
||
|
uni.navigateBack();
|
||
|
},
|
||
|
// 计算总价;
|
||
|
getTotalPrice: function() {
|
||
|
let that = this,
|
||
|
list = that.cartData.cartList,
|
||
|
totalPrice = 0.00;
|
||
|
list.forEach(item => {
|
||
|
totalPrice = that.$util.$h.Add(totalPrice, that.$util.$h.Mul(item.cart_num, item.truePrice));
|
||
|
})
|
||
|
that.$set(that, 'totalPrice', totalPrice);
|
||
|
},
|
||
|
ChangeSubDel: function(event) {
|
||
|
emptyCollagePartake({
|
||
|
collage_id: this.info.collage_id
|
||
|
}).then(res => {
|
||
|
this.$util.Tips({
|
||
|
title: '清空成功',
|
||
|
success: () => {
|
||
|
this.cartData.iScart = false
|
||
|
this.getCartNum();
|
||
|
for (let i = 0; i < this.tempArr.length; i++) {
|
||
|
if (!this.tempArr[i].cart_num) {
|
||
|
continue;
|
||
|
}
|
||
|
this.tempArr[i].cart_num = 0;
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
// let that = this,
|
||
|
// list = that.cartData.cartList,
|
||
|
// ids = [],
|
||
|
// storeId = uni.getStorageSync('user_store_id');
|
||
|
// list.forEach(item => {
|
||
|
// ids.push(item.id)
|
||
|
// });
|
||
|
// cartDel(ids.join(","),storeId).then(res => {
|
||
|
// that.$set(that.cartData, 'cartList', []);
|
||
|
// that.cartData.iScart = false;
|
||
|
// that.totalPrice = 0.00;
|
||
|
// that.page = 1;
|
||
|
// that.loadend = false;
|
||
|
// that.tempArr = [];
|
||
|
// that.getProducts();
|
||
|
// that.getCartNum();
|
||
|
// })
|
||
|
},
|
||
|
ChangeOneDel: function(id, index) {
|
||
|
let that = this,
|
||
|
list = that.cartData.cartList,
|
||
|
storeId = uni.getStorageSync('user_store_id');
|
||
|
cartDel(id.toString(), storeId).then(res => {
|
||
|
list.splice(index, 1);
|
||
|
if (!list.length) {
|
||
|
that.cartData.iScart = false;
|
||
|
that.page = 1;
|
||
|
that.loadend = false;
|
||
|
that.tempArr = [];
|
||
|
that.getProducts();
|
||
|
};
|
||
|
that.getCartNum();
|
||
|
})
|
||
|
},
|
||
|
getCartLists() {
|
||
|
if (this.footerOpen) {
|
||
|
this.getCartList();
|
||
|
} else {
|
||
|
this.footerOpen = true;
|
||
|
}
|
||
|
},
|
||
|
// 获取购物车商品列表
|
||
|
getCartList(iSshow) {
|
||
|
let that = this;
|
||
|
let data = {
|
||
|
store_id: that.info.id,
|
||
|
collage_id: that.info.collage_id,
|
||
|
};
|
||
|
getCollageCart(data).then(res => {
|
||
|
that.$set(that.cartData, 'cartList', res.data);
|
||
|
if (res.data.length) {
|
||
|
that.$set(that.cartData, 'iScart', iSshow ? false : !that.cartData.iScart);
|
||
|
} else {
|
||
|
that.$set(that.cartData, 'iScart', false);
|
||
|
}
|
||
|
that.getTotalPrice();
|
||
|
});
|
||
|
},
|
||
|
// 关闭购物车弹窗
|
||
|
closeList(e) {
|
||
|
this.$set(this.cartData, 'iScart', e);
|
||
|
},
|
||
|
getCartNum: function() {
|
||
|
getCollageCount({
|
||
|
store_id: this.info.id,
|
||
|
collage_id: this.info.collage_id
|
||
|
}).then(res => {
|
||
|
this.cartNum = res.data.count;
|
||
|
});
|
||
|
},
|
||
|
onMyEvent: function() {
|
||
|
this.$set(this.attr, 'cartAttr', false);
|
||
|
},
|
||
|
/**
|
||
|
* 默认选中属性
|
||
|
*
|
||
|
*/
|
||
|
DefaultSelect: function() {
|
||
|
let productAttr = this.attr.productAttr;
|
||
|
let value = [];
|
||
|
for (let key in this.productValue) {
|
||
|
if (this.productValue[key].stock > 0) {
|
||
|
value = this.attr.productAttr.length ? key.split(",") : [];
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
for (let i = 0; i < productAttr.length; i++) {
|
||
|
this.$set(productAttr[i], "index", value[i]);
|
||
|
}
|
||
|
//sort();排序函数:数字-英文-汉字;
|
||
|
let productSelect = this.productValue[value.join(",")];
|
||
|
if (productSelect && productAttr.length) {
|
||
|
this.$set(
|
||
|
this.attr.productSelect,
|
||
|
"store_name",
|
||
|
this.storeName
|
||
|
);
|
||
|
this.$set(this.attr.productSelect, "image", productSelect.image);
|
||
|
this.$set(this.attr.productSelect, "price", productSelect.price);
|
||
|
this.$set(this.attr.productSelect, "stock", productSelect.stock);
|
||
|
this.$set(this.attr.productSelect, "unique", productSelect.unique);
|
||
|
this.$set(this.attr.productSelect, "cart_num", 1);
|
||
|
this.$set(this.attr.productSelect, 'vip_price', productSelect.vip_price);
|
||
|
this.$set(this, "attrValue", value.join(","));
|
||
|
} else if (!productSelect && productAttr.length) {
|
||
|
this.$set(
|
||
|
this.attr.productSelect,
|
||
|
"store_name",
|
||
|
this.storeName
|
||
|
);
|
||
|
this.$set(this.attr.productSelect, "image", this.storeInfo.image);
|
||
|
this.$set(this.attr.productSelect, "price", this.storeInfo.price);
|
||
|
this.$set(this.attr.productSelect, "stock", 0);
|
||
|
this.$set(this.attr.productSelect, "unique", "");
|
||
|
this.$set(this.attr.productSelect, "cart_num", 0);
|
||
|
this.$set(this, "attrValue", "");
|
||
|
this.$set(this.attr.productSelect, 'vip_price', this.storeInfo.vip_price);
|
||
|
} else if (!productSelect && !productAttr.length) {
|
||
|
this.$set(
|
||
|
this.attr.productSelect,
|
||
|
"store_name",
|
||
|
this.storeName
|
||
|
);
|
||
|
this.$set(this.attr.productSelect, "image", this.storeInfo.image);
|
||
|
this.$set(this.attr.productSelect, "price", this.storeInfo.price);
|
||
|
this.$set(this.attr.productSelect, "stock", this.storeInfo.stock);
|
||
|
this.$set(
|
||
|
this.attr.productSelect,
|
||
|
"unique",
|
||
|
this.storeInfo.unique || ""
|
||
|
);
|
||
|
this.$set(this.attr.productSelect, "cart_num", 1);
|
||
|
this.$set(this, "attrValue", "");
|
||
|
this.$set(this.attr.productSelect, 'vip_price', this.storeInfo.vip_price);
|
||
|
}
|
||
|
},
|
||
|
/**
|
||
|
* 属性变动赋值
|
||
|
*
|
||
|
*/
|
||
|
ChangeAttr: function(res) {
|
||
|
let productSelect = this.productValue[res];
|
||
|
if (productSelect && productSelect.stock > 0) {
|
||
|
this.$set(this.attr.productSelect, "image", productSelect.image);
|
||
|
this.$set(this.attr.productSelect, "price", productSelect.price);
|
||
|
this.$set(this.attr.productSelect, "stock", productSelect.stock);
|
||
|
this.$set(this.attr.productSelect, "unique", productSelect.unique);
|
||
|
this.$set(this.attr.productSelect, 'vip_price', productSelect.vip_price);
|
||
|
this.$set(this.attr.productSelect, "cart_num", 1);
|
||
|
this.$set(this, "attrValue", res);
|
||
|
} else if (productSelect && productSelect.stock == 0) {
|
||
|
this.$set(this.attr.productSelect, "image", productSelect.image);
|
||
|
this.$set(this.attr.productSelect, "price", productSelect.price);
|
||
|
this.$set(this.attr.productSelect, "stock", 0);
|
||
|
this.$set(this.attr.productSelect, "unique", "");
|
||
|
this.$set(this.attr.productSelect, 'vip_price', productSelect.vip_price);
|
||
|
this.$set(this.attr.productSelect, "cart_num", 0);
|
||
|
this.$set(this, "attrValue", "");
|
||
|
} else {
|
||
|
this.$set(this.attr.productSelect, "image", this.storeInfo.image);
|
||
|
this.$set(this.attr.productSelect, "price", this.storeInfo.price);
|
||
|
this.$set(this.attr.productSelect, "stock", 0);
|
||
|
this.$set(this.attr.productSelect, "unique", "");
|
||
|
this.$set(this.attr.productSelect, 'vip_price', this.storeInfo.vip_price);
|
||
|
this.$set(this.attr.productSelect, "cart_num", 0);
|
||
|
this.$set(this, "attrValue", "");
|
||
|
}
|
||
|
},
|
||
|
attrVal(val) {
|
||
|
this.$set(this.attr.productAttr[val.indexw], 'index', this.attr.productAttr[val.indexw].attr_values[val
|
||
|
.indexn]);
|
||
|
},
|
||
|
/**
|
||
|
* 购物车手动填写
|
||
|
*
|
||
|
*/
|
||
|
iptCartNum: function(e) {
|
||
|
this.$set(this.attr.productSelect, 'cart_num', e);
|
||
|
},
|
||
|
// 点击默认单属性购物车
|
||
|
goCartDan(item, index) {
|
||
|
if (!this.isLogin) {
|
||
|
this.getIsLogin();
|
||
|
} else {
|
||
|
this.tempArr[index].cart_num = 1;
|
||
|
this.$set(this, 'tempArr', this.tempArr);
|
||
|
this.goCat(0, item.id, 1);
|
||
|
}
|
||
|
},
|
||
|
// 改变单属性购物车
|
||
|
ChangeCartNumDan(changeValue, index, item) {
|
||
|
let num = this.tempArr[index];
|
||
|
let stock = this.tempArr[index].stock;
|
||
|
this.ChangeCartNum(changeValue, num, stock, 0, item.id);
|
||
|
},
|
||
|
// 改变多属性购物车
|
||
|
ChangeCartNumDuo(changeValue) {
|
||
|
//获取当前变动属性
|
||
|
let productSelect = this.productValue[this.attrValue];
|
||
|
//如果没有属性,赋值给商品默认库存
|
||
|
if (productSelect === undefined && !this.attr.productAttr.length)
|
||
|
productSelect = this.attr.productSelect;
|
||
|
//无属性值即库存为0;不存在加减;
|
||
|
if (productSelect === undefined) return;
|
||
|
let stock = productSelect.stock || 0;
|
||
|
let num = this.attr.productSelect;
|
||
|
this.ChangeCartNum(changeValue, num, stock, 1, this.id);
|
||
|
},
|
||
|
// 已经加入购物车时的购物加减;
|
||
|
ChangeCartList(changeValue, index) {
|
||
|
let list = this.cartData.cartList;
|
||
|
let num = list[index];
|
||
|
let stock = list[index].trueStock;
|
||
|
this.ChangeCartNum(changeValue, num, stock, 0, num.product_id, index, 1);
|
||
|
if (!list.length) {
|
||
|
this.cartData.iScart = false;
|
||
|
this.page = 1;
|
||
|
this.loadend = false;
|
||
|
this.tempArr = [];
|
||
|
this.getProducts();
|
||
|
}
|
||
|
},
|
||
|
// 购物车加减计算函数
|
||
|
ChangeCartNum(changeValue, num, stock, isDuo, id, index, cart) {
|
||
|
if (changeValue) {
|
||
|
num.cart_num++;
|
||
|
if (num.cart_num > stock) {
|
||
|
if (isDuo) {
|
||
|
this.$set(this.attr.productSelect, "cart_num", stock ? stock : 1);
|
||
|
this.$set(this, "cart_num", stock ? stock : 1);
|
||
|
} else {
|
||
|
num.cart_num = stock ? stock : 0;
|
||
|
this.$set(this, 'tempArr', this.tempArr);
|
||
|
this.$set(this.cartData, 'cartList', this.cartData.cartList);
|
||
|
}
|
||
|
return this.$util.Tips({
|
||
|
title: "该产品没有更多库存了"
|
||
|
});
|
||
|
} else {
|
||
|
if (!isDuo) {
|
||
|
if (cart) {
|
||
|
this.goCat(0, id, 1, 1, num.product_attr_unique);
|
||
|
this.getTotalPrice();
|
||
|
this.tempArr.forEach((item) => {
|
||
|
if (item.id == id) {
|
||
|
item.cart_num++;
|
||
|
}
|
||
|
})
|
||
|
} else {
|
||
|
this.goCat(0, id, 1);
|
||
|
}
|
||
|
} else {
|
||
|
this.tempArr.forEach((item) => {
|
||
|
if (item.id == id) {
|
||
|
item.cart_num++;
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
} else {
|
||
|
num.cart_num--;
|
||
|
if (num.cart_num == 0) {
|
||
|
this.cartData.cartList.splice(index, 1);
|
||
|
if (isDuo) {
|
||
|
this.$set(this.attr.productSelect, "cart_num", 1);
|
||
|
this.$set(this, "cart_num", 1);
|
||
|
}
|
||
|
}
|
||
|
if (num.cart_num < 0) {
|
||
|
if (isDuo) {
|
||
|
this.$set(this.attr.productSelect, "cart_num", 1);
|
||
|
this.$set(this, "cart_num", 1);
|
||
|
} else {
|
||
|
num.cart_num = 0;
|
||
|
this.$set(this, 'tempArr', this.tempArr);
|
||
|
this.$set(this.cartData, 'cartList', this.cartData.cartList);
|
||
|
}
|
||
|
} else {
|
||
|
if (!isDuo) {
|
||
|
if (cart) {
|
||
|
this.goCat(0, id, 0, 1, num.product_attr_unique);
|
||
|
this.getTotalPrice();
|
||
|
this.tempArr.forEach((item) => {
|
||
|
if (item.id == id) {
|
||
|
item.cart_num--;
|
||
|
}
|
||
|
})
|
||
|
} else {
|
||
|
this.goCat(0, id, 0);
|
||
|
}
|
||
|
} else {
|
||
|
this.tempArr.forEach((item) => {
|
||
|
if (item.id == id) {
|
||
|
item.cart_num--;
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
// 多规格加入购物车;
|
||
|
goCatNum() {
|
||
|
this.goCat(1, this.id, 1);
|
||
|
},
|
||
|
/*
|
||
|
* 加入购物车
|
||
|
*/
|
||
|
goCat: function(duo, id, type, cart, unique) {
|
||
|
let that = this;
|
||
|
if (duo) {
|
||
|
let productSelect = that.productValue[this.attrValue];
|
||
|
//如果有属性,没有选择,提示用户选择
|
||
|
if (
|
||
|
that.attr.productAttr.length &&
|
||
|
productSelect === undefined
|
||
|
)
|
||
|
return that.$util.Tips({
|
||
|
title: "产品库存不足,请选择其它属性"
|
||
|
});
|
||
|
}
|
||
|
let q = {
|
||
|
productId: id,
|
||
|
cartNum: duo ? that.attr.productSelect.cart_num : 1,
|
||
|
collageId: this.info.collage_id,
|
||
|
storeId: this.info.id,
|
||
|
uniqueId: duo ? that.attr.productSelect.unique : cart ? unique : "",
|
||
|
isAdd: type
|
||
|
};
|
||
|
addCollageCart(q).then(res => {
|
||
|
if (duo) {
|
||
|
that.attr.cartAttr = false;
|
||
|
that.$util.Tips({
|
||
|
title: "添加购物车成功"
|
||
|
});
|
||
|
that.tempArr.forEach((item, index) => {
|
||
|
if (item.id == that.id) {
|
||
|
let arrtStock = that.attr.productSelect.stock
|
||
|
let objNum = parseInt(item.cart_num) + parseInt(that.attr.productSelect.cart_num);
|
||
|
item.cart_num = objNum > arrtStock ? arrtStock : objNum
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
that.getCartNum();
|
||
|
if (!cart) {
|
||
|
that.getCartList(1);
|
||
|
}
|
||
|
}).catch(err => {
|
||
|
that.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
});;
|
||
|
// postCartNum(q)
|
||
|
// .then(function(res) {
|
||
|
// if (duo) {
|
||
|
// that.attr.cartAttr = false;
|
||
|
// that.$util.Tips({
|
||
|
// title: "添加购物车成功"
|
||
|
// });
|
||
|
// // that.page = 1;
|
||
|
// // that.loadend = false;
|
||
|
// that.tempArr.forEach((item, index) => {
|
||
|
// if (item.id == that.id) {
|
||
|
// let arrtStock = that.attr.productSelect.stock
|
||
|
// let objNum = parseInt(item.cart_num) + parseInt(that.attr.productSelect.cart_num);
|
||
|
// item.cart_num = objNum > arrtStock ? arrtStock : objNum
|
||
|
// }
|
||
|
// })
|
||
|
// // that.productslist();
|
||
|
// }
|
||
|
// that.getCartNum();
|
||
|
// if (!cart) {
|
||
|
// that.getCartList(1);
|
||
|
// }
|
||
|
// })
|
||
|
// .catch(err => {
|
||
|
// return that.$util.Tips({
|
||
|
// title: err
|
||
|
// });
|
||
|
// });
|
||
|
},
|
||
|
goCartDuo(item) {
|
||
|
if (!this.isLogin) {
|
||
|
this.getIsLogin();
|
||
|
} else {
|
||
|
// uni.showLoading({
|
||
|
// title: '加载中'
|
||
|
// });
|
||
|
this.storeName = item.store_name;
|
||
|
this.getAttrs(item.id);
|
||
|
this.$set(this, 'id', item.id);
|
||
|
this.$set(this.attr, 'cartAttr', true);
|
||
|
}
|
||
|
},
|
||
|
getIsLogin() {
|
||
|
toLogin();
|
||
|
},
|
||
|
// 商品详情接口;
|
||
|
getAttrs(id) {
|
||
|
let that = this;
|
||
|
getAttr(id, 0).then(res => {
|
||
|
// uni.hideLoading();
|
||
|
that.$set(that.attr, 'productAttr', res.data.productAttr);
|
||
|
that.$set(that, 'productValue', res.data.productValue);
|
||
|
that.$set(that, 'is_vip', res.data.storeInfo.is_vip);
|
||
|
that.$set(that, 'storeInfo', res.data.storeInfo);
|
||
|
that.DefaultSelect();
|
||
|
})
|
||
|
},
|
||
|
// 去详情页
|
||
|
goDetail(item) {
|
||
|
goShopDetail(item, this.uid).then(res => {
|
||
|
uni.navigateTo({
|
||
|
url: `/pages/goods_details/index?id=${item.id}&fromType=1`
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
openTap() {
|
||
|
this.iSlong = false
|
||
|
},
|
||
|
closeTap() {
|
||
|
this.iSlong = true
|
||
|
},
|
||
|
// 分类数据
|
||
|
getAllCategory: function() {
|
||
|
let that = this;
|
||
|
getStoreCategory().then(res => {
|
||
|
let data = res.data;
|
||
|
// data.forEach(item => {
|
||
|
// item.children.unshift({
|
||
|
// 'id': 0,
|
||
|
// 'cate_name': '全部商品'
|
||
|
// })
|
||
|
// })
|
||
|
that.categoryTitle = data[0].cate_name;
|
||
|
that.cid = data[0].id;
|
||
|
that.sid = 0;
|
||
|
that.navActive = 0;
|
||
|
that.tabClick = 0;
|
||
|
that.categoryList = data;
|
||
|
if (this.diyCategory.level == 2) {
|
||
|
that.categoryErList = that.categoryList;
|
||
|
} else {
|
||
|
that.categoryErList = that.categoryList[0].children || [];
|
||
|
}
|
||
|
that.categoryThreeList = that.categoryErList[0].children || [];
|
||
|
// that.categoryErList = res.data[0].children ? res.data[0].children : [];
|
||
|
that.page = 1;
|
||
|
that.loadend = false;
|
||
|
that.tempArr = [];
|
||
|
that.getProducts();
|
||
|
})
|
||
|
},
|
||
|
tapNav(item, index) {
|
||
|
uni.pageScrollTo({
|
||
|
duration: 0,
|
||
|
scrollTop: 0
|
||
|
})
|
||
|
// let list = this.categoryList[index];
|
||
|
let list = this.categoryErList[index];
|
||
|
this.navActive = index;
|
||
|
this.categoryTitle = list.cate_name;
|
||
|
// this.categoryErList = item.children ? item.children : [];
|
||
|
this.categoryThreeList = item.children || [];
|
||
|
this.tabClick = 0;
|
||
|
this.tabLeft = 0;
|
||
|
if (this.diyCategory.level == 2) {
|
||
|
this.cid = list.id;
|
||
|
this.sid = 0;
|
||
|
} else {
|
||
|
this.sid = list.id;
|
||
|
}
|
||
|
if (!this.categoryThreeList[0] || this.categoryThreeList[0].id) {
|
||
|
this.categoryThreeList.unshift({
|
||
|
cate_name: '全部商品',
|
||
|
id: 0
|
||
|
});
|
||
|
}
|
||
|
this.tid = 0;
|
||
|
this.page = 1;
|
||
|
this.loadend = false;
|
||
|
this.tempArr = [];
|
||
|
this.getProducts();
|
||
|
},
|
||
|
// 导航栏点击
|
||
|
longClick(index) {
|
||
|
if (this.categoryThreeList.length > 3) {
|
||
|
this.tabLeft = (index - 1) * (this.isWidth + 6) //设置下划线位置
|
||
|
};
|
||
|
this.tabClick = index; //设置导航点击了哪一个
|
||
|
this.iSlong = true;
|
||
|
// this.sid = this.categoryThreeList[index].id;
|
||
|
if (this.diyCategory.level == 2) {
|
||
|
this.sid = this.categoryThreeList[index].id;
|
||
|
this.tid = 0;
|
||
|
} else {
|
||
|
this.tid = this.categoryThreeList[index].id;
|
||
|
}
|
||
|
this.page = 1;
|
||
|
this.loadend = false;
|
||
|
this.tempArr = [];
|
||
|
this.getProducts();
|
||
|
},
|
||
|
goodsListScroll() {
|
||
|
this.footerOpen = false;
|
||
|
},
|
||
|
moreNav() {
|
||
|
this.currentPage = !this.currentPage
|
||
|
},
|
||
|
backTap() {
|
||
|
let pages = getCurrentPages(); // 获取当前打开过的页面路由数,
|
||
|
if (pages.length > 1) {
|
||
|
uni.navigateBack()
|
||
|
} else {
|
||
|
uni.switchTab({
|
||
|
url: '/pages/index/index'
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
tapNavOne(item, index) {
|
||
|
this.navOneActive = index;
|
||
|
this.navActive = 0;
|
||
|
this.tabClick = 0;
|
||
|
this.categoryErList = item.children;
|
||
|
this.categoryThreeList = this.categoryErList[0].children || [];
|
||
|
if (!this.categoryThreeList[0] || this.categoryThreeList[0].id) {
|
||
|
this.categoryThreeList.unshift({
|
||
|
cate_name: '全部商品',
|
||
|
id: 0
|
||
|
});
|
||
|
}
|
||
|
this.categoryTitle = item.cate_name;
|
||
|
this.cid = item.id;
|
||
|
this.sid = item.children[0] ? item.children[0].id : 0;
|
||
|
this.tid = 0;
|
||
|
this.page = 1;
|
||
|
this.loadend = false;
|
||
|
this.tempArr = [];
|
||
|
this.getProducts();
|
||
|
},
|
||
|
oneDrawerOpen() {
|
||
|
this.oneVisible = true;
|
||
|
},
|
||
|
oneDrawerClose() {
|
||
|
this.oneVisible = false;
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss">
|
||
|
.safe-area-inset-bottom {
|
||
|
height: constant(safe-area-inset-bottom);
|
||
|
height: env(safe-area-inset-bottom);
|
||
|
}
|
||
|
|
||
|
/* #ifdef MP || APP-PLUS */
|
||
|
.mp-header {
|
||
|
background: #FFFFFF;
|
||
|
top: 0;
|
||
|
right: 0;
|
||
|
left: 0;
|
||
|
z-index: 10;
|
||
|
|
||
|
.serch-wrapper {
|
||
|
height: 100%;
|
||
|
/* #ifdef MP */
|
||
|
padding: 0 220rpx 0 30rpx;
|
||
|
/* #endif */
|
||
|
/* #ifdef APP-PLUS */
|
||
|
padding: 0 50rpx 0 40rpx;
|
||
|
|
||
|
/* #endif */
|
||
|
.input {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
height: 58rpx;
|
||
|
padding-left: 32rpx;
|
||
|
margin: 0 0 0 18rpx;
|
||
|
background: #F5F5F5;
|
||
|
color: #999999;
|
||
|
font-size: 24rpx;
|
||
|
/* #ifdef MP */
|
||
|
width: 70%;
|
||
|
/* #endif */
|
||
|
/* #ifdef APP-PLUS */
|
||
|
width: 100%;
|
||
|
/* #endif */
|
||
|
border-radius: 29rpx;
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 24rpx;
|
||
|
margin-right: 18rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* #endif */
|
||
|
page {
|
||
|
background-color: #fff;
|
||
|
}
|
||
|
|
||
|
/deep/.product-window.joinCart {
|
||
|
z-index: 999;
|
||
|
}
|
||
|
|
||
|
::-webkit-scrollbar {
|
||
|
width: 0;
|
||
|
height: 0;
|
||
|
color: transparent;
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
.goodCate {
|
||
|
flex-wrap: nowrap;
|
||
|
min-height: 100vh;
|
||
|
|
||
|
/deep/.mask {
|
||
|
z-index: 99;
|
||
|
}
|
||
|
|
||
|
/deep/.attrProduct {
|
||
|
.mask {
|
||
|
z-index: 100;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.header {
|
||
|
position: fixed;
|
||
|
background-color: #fff;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
width: 100%;
|
||
|
z-index: 99;
|
||
|
border-bottom: 1px solid #F0F0F0;
|
||
|
/* #ifdef H5 */
|
||
|
padding-top: 20rpx;
|
||
|
/* #endif */
|
||
|
|
||
|
.pageIndex {
|
||
|
width: 68rpx;
|
||
|
height: 68rpx;
|
||
|
border-radius: 50%;
|
||
|
background-color: #F7F7F7;
|
||
|
|
||
|
.iconfont {
|
||
|
color: #666666;
|
||
|
font-size: 30rpx;
|
||
|
}
|
||
|
|
||
|
// image{
|
||
|
// width: 29rpx;
|
||
|
// height: 30rpx;
|
||
|
// }
|
||
|
}
|
||
|
|
||
|
.search {
|
||
|
width: 690rpx;
|
||
|
height: 68rpx;
|
||
|
border-radius: 36rpx;
|
||
|
background-color: #F7F7F7;
|
||
|
font-size: 26rpx;
|
||
|
color: #cccccc;
|
||
|
padding: 0 30rpx;
|
||
|
box-sizing: border-box;
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 30rpx;
|
||
|
margin-right: 18rpx;
|
||
|
color: #666666;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.conter {
|
||
|
flex-wrap: nowrap;
|
||
|
flex: 1;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.aside-box {
|
||
|
width: 168rpx;
|
||
|
}
|
||
|
|
||
|
.aside {
|
||
|
top: 0;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
z-index: 10;
|
||
|
width: 168rpx;
|
||
|
height: 100%;
|
||
|
background: #F5F5F5;
|
||
|
|
||
|
.item {
|
||
|
height: 100rpx;
|
||
|
font-size: 26rpx;
|
||
|
color: #666666;
|
||
|
|
||
|
&.on {
|
||
|
background: #FFFFFF;
|
||
|
color: var(--view-theme);
|
||
|
font-weight: 500;
|
||
|
font-size: 28rpx;
|
||
|
position: relative;
|
||
|
|
||
|
&::after {
|
||
|
content: "";
|
||
|
position: absolute;
|
||
|
width: 6rpx;
|
||
|
height: 48rpx;
|
||
|
background: var(--view-theme);
|
||
|
border-radius: 0 4rpx 4rpx 0;
|
||
|
left: 0
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.wrapper {
|
||
|
flex: 1;
|
||
|
flex-wrap: nowrap;
|
||
|
min-width: 0;
|
||
|
|
||
|
.bgcolor-box {
|
||
|
height: 104rpx;
|
||
|
}
|
||
|
|
||
|
.bgcolor {
|
||
|
flex-wrap: nowrap;
|
||
|
height: 104rpx;
|
||
|
background: #FFFFFF;
|
||
|
top: 0;
|
||
|
right: 0;
|
||
|
left: 168rpx;
|
||
|
z-index: 10;
|
||
|
}
|
||
|
|
||
|
.mask {
|
||
|
z-index: 9;
|
||
|
}
|
||
|
|
||
|
.longTab {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
|
||
|
.longItem {
|
||
|
display: inline-block;
|
||
|
border-radius: 28rpx;
|
||
|
margin-left: 16rpx;
|
||
|
background: #F5F5F5;
|
||
|
vertical-align: middle;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 54rpx;
|
||
|
color: #333333;
|
||
|
|
||
|
.inner {
|
||
|
height: 56rpx;
|
||
|
border: 1rpx solid transparent;
|
||
|
border-radius: 28rpx;
|
||
|
transform: rotateZ(360deg);
|
||
|
}
|
||
|
|
||
|
&.click {
|
||
|
background: var(--view-theme);
|
||
|
color: var(--view-theme);
|
||
|
|
||
|
.inner {
|
||
|
background: rgba(255, 255, 255, 0.9);
|
||
|
background-clip: content-box;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.underlineBox {
|
||
|
height: 3px;
|
||
|
width: 20%;
|
||
|
display: flex;
|
||
|
align-content: center;
|
||
|
justify-content: center;
|
||
|
transition: .5s;
|
||
|
|
||
|
.underline {
|
||
|
width: 33rpx;
|
||
|
height: 4rpx;
|
||
|
background-color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.openList {
|
||
|
width: 92rpx;
|
||
|
text-align: center;
|
||
|
line-height: 104rpx;
|
||
|
|
||
|
.btn {
|
||
|
display: inline-block;
|
||
|
width: 56rpx;
|
||
|
height: 56rpx;
|
||
|
border-radius: 50%;
|
||
|
background: #F5F5F5;
|
||
|
line-height: 56rpx;
|
||
|
}
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 32rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.goodsList {
|
||
|
margin-top: 0rpx;
|
||
|
padding: 0 30rpx 0 20rpx;
|
||
|
|
||
|
/deep/.item {
|
||
|
margin-bottom: 33rpx !important;
|
||
|
|
||
|
.text {
|
||
|
font-size: 26rpx;
|
||
|
}
|
||
|
|
||
|
.bottom {
|
||
|
.sales {
|
||
|
.money {
|
||
|
font-size: 34rpx;
|
||
|
|
||
|
text {
|
||
|
font-size: 26rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.cart {
|
||
|
.pictrue {
|
||
|
width: 50rpx;
|
||
|
height: 50rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.goodsListWrap {}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.store-address {
|
||
|
position: relative;
|
||
|
padding: 20rpx 20rpx 30rpx 32rpx;
|
||
|
|
||
|
.address {
|
||
|
font-size: 32rpx;
|
||
|
font-weight: 500;
|
||
|
color: #333333;
|
||
|
|
||
|
.name {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
font-weight: 500;
|
||
|
font-size: 30rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.tips {
|
||
|
font-size: 24rpx;
|
||
|
color: var(--view-theme);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.distance {
|
||
|
margin-top: 20rpx;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 30rpx;
|
||
|
color: #666666;
|
||
|
|
||
|
.iconfont {
|
||
|
margin-right: 8rpx;
|
||
|
font-size: 22rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.time {
|
||
|
margin-top: 14rpx;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 30rpx;
|
||
|
color: #666666;
|
||
|
|
||
|
.iconfont {
|
||
|
margin-right: 8rpx;
|
||
|
font-size: 22rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.text {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.footer {
|
||
|
position: fixed;
|
||
|
right: 20rpx;
|
||
|
left: 20rpx;
|
||
|
bottom: 36rpx;
|
||
|
bottom: calc(36rpx + constant(safe-area-inset-bottom)); ///兼容 IOS<11.2/
|
||
|
bottom: calc(36rpx + env(safe-area-inset-bottom)); ///兼容 IOS>11.2/
|
||
|
z-index: 101;
|
||
|
|
||
|
.cartIcon {
|
||
|
position: absolute;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
width: 96rpx;
|
||
|
height: 96rpx;
|
||
|
border-radius: 48rpx;
|
||
|
background: linear-gradient(-90deg, var(--view-gradient), var(--view-theme));
|
||
|
box-shadow: 0rpx 0rpx 20rpx 0rpx rgba(0, 0, 0, 0.1);
|
||
|
|
||
|
.image-wrap {
|
||
|
width: 96rpx;
|
||
|
height: 96rpx;
|
||
|
border-radius: 48rpx;
|
||
|
text-align: center;
|
||
|
line-height: 96rpx;
|
||
|
}
|
||
|
|
||
|
.image {
|
||
|
width: 54rpx;
|
||
|
height: 54rpx;
|
||
|
vertical-align: middle;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.inner-box {
|
||
|
position: absolute;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
width: 96rpx;
|
||
|
height: 96rpx;
|
||
|
border-radius: 48rpx;
|
||
|
overflow: hidden;
|
||
|
transition: 0.3s;
|
||
|
|
||
|
&.open {
|
||
|
width: 100%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.inner {
|
||
|
flex-wrap: nowrap;
|
||
|
height: 96rpx;
|
||
|
padding: 0 12rpx 0 128rpx;
|
||
|
border-radius: 48rpx;
|
||
|
background: #333333;
|
||
|
}
|
||
|
|
||
|
.btn {
|
||
|
width: 186rpx;
|
||
|
height: 72rpx;
|
||
|
padding: 0 32rpx;
|
||
|
background: linear-gradient(-90deg, var(--view-gradient) 0%, var(--view-theme) 100%);
|
||
|
border-radius: 36rpx;
|
||
|
text-align: center;
|
||
|
font-weight: 500;
|
||
|
font-size: 26rpx;
|
||
|
line-height: 72rpx;
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.group-btn {
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
width: 140rpx;
|
||
|
height: 64rpx;
|
||
|
border: 1rpx solid #DDDDDD;
|
||
|
border-radius: 32rpx;
|
||
|
font-weight: 500;
|
||
|
font-size: 26rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.dialog {
|
||
|
position: fixed;
|
||
|
right: 0;
|
||
|
bottom: 0;
|
||
|
left: 0;
|
||
|
z-index: 101;
|
||
|
padding: 36rpx 40rpx 40rpx;
|
||
|
border-radius: 12rpx 12rpx 0 0;
|
||
|
background-color: #FFFFFF;
|
||
|
transform: translateY(100%);
|
||
|
transition: 0.3s;
|
||
|
|
||
|
&.active {
|
||
|
transform: translateY(0);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.dialog-head {
|
||
|
display: flex;
|
||
|
|
||
|
.button {
|
||
|
flex: 1;
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
height: 138rpx;
|
||
|
border: 4rpx solid #DDDDDD;
|
||
|
border-radius: 12rpx;
|
||
|
font-weight: 500;
|
||
|
font-size: 32rpx;
|
||
|
color: #333333;
|
||
|
cursor: pointer;
|
||
|
|
||
|
+.button {
|
||
|
margin-left: 46rpx;
|
||
|
}
|
||
|
|
||
|
&.active {
|
||
|
border: 4rpx solid var(--view-theme);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.dialog-body {
|
||
|
margin-top: 60rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #999999;
|
||
|
|
||
|
.dialog-body-main {
|
||
|
display: flex;
|
||
|
align-items: center;
|
||
|
margin-top: 32rpx;
|
||
|
}
|
||
|
|
||
|
.dialog-body-left {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
margin-right: 20rpx;
|
||
|
}
|
||
|
|
||
|
.dialog-body-right {
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
width: 140rpx;
|
||
|
height: 46rpx;
|
||
|
border: 2rpx solid #DDDDDD;
|
||
|
border-radius: 23rpx;
|
||
|
font-size: 22rpx;
|
||
|
color: #666666;
|
||
|
cursor: pointer;
|
||
|
}
|
||
|
|
||
|
.dialog-body-name {
|
||
|
font-weight: 500;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 1;
|
||
|
color: #333333;
|
||
|
|
||
|
.tag {
|
||
|
margin-left: 14rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #888888;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.dialog-body-info {
|
||
|
margin-top: 28rpx;
|
||
|
|
||
|
.item {
|
||
|
display: flex;
|
||
|
font-size: 22rpx;
|
||
|
line-height: 1.5;
|
||
|
color: #888888;
|
||
|
|
||
|
+.item {
|
||
|
margin-top: 20rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.dialog-foot {
|
||
|
display: flex;
|
||
|
margin-top: 78rpx;
|
||
|
|
||
|
.button {
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: center;
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
height: 92rpx;
|
||
|
border-radius: 46rpx;
|
||
|
background-color: #EEEEEE;
|
||
|
font-size: 30rpx;
|
||
|
color: #666666;
|
||
|
cursor: pointer;
|
||
|
|
||
|
+.button {
|
||
|
margin-left: 46rpx;
|
||
|
}
|
||
|
|
||
|
&.primary {
|
||
|
background-color: var(--view-theme);
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.downTab {
|
||
|
flex-wrap: nowrap;
|
||
|
max-height: 820rpx;
|
||
|
border-radius: 0rpx 0rpx 32rpx 32rpx;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.title {
|
||
|
padding: 32rpx 0 24rpx 30rpx;
|
||
|
font-size: 32rpx;
|
||
|
line-height: 44rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.scroll-view {
|
||
|
flex: 1;
|
||
|
min-height: 0;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
.children {
|
||
|
padding: 0 0 8rpx 30rpx;
|
||
|
margin: 0 -24rpx 0 0;
|
||
|
|
||
|
.item {
|
||
|
width: 154rpx;
|
||
|
height: 56rpx;
|
||
|
border-radius: 28rpx;
|
||
|
margin: 0 24rpx 24rpx 0;
|
||
|
background: #F5F5F5;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 56rpx;
|
||
|
color: #333333;
|
||
|
|
||
|
.inner {
|
||
|
width: 154rpx;
|
||
|
height: 56rpx;
|
||
|
border: 1rpx solid transparent;
|
||
|
border-radius: 28rpx;
|
||
|
background-clip: content-box;
|
||
|
transform: rotateZ(360deg);
|
||
|
}
|
||
|
|
||
|
&.click {
|
||
|
background: var(--view-theme);
|
||
|
color: var(--view-theme);
|
||
|
|
||
|
.inner {
|
||
|
background-color: rgba(255, 255, 255, 0.9);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.btn {
|
||
|
height: 80rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #999999;
|
||
|
|
||
|
.iconfont {
|
||
|
margin-left: 4rpx;
|
||
|
font-size: 24rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.menu_box {
|
||
|
width: 154rpx;
|
||
|
height: 58rpx;
|
||
|
border-radius: 29rpx;
|
||
|
z-index: 970;
|
||
|
}
|
||
|
|
||
|
.opac {
|
||
|
background-color: rgba(255, 255, 255, 0.6);
|
||
|
border: 1rpx solid rgba(0, 0, 0, 0.1);
|
||
|
justify-content: space-evenly;
|
||
|
}
|
||
|
|
||
|
.menu_line {
|
||
|
width: 1px;
|
||
|
height: 30rpx;
|
||
|
background: #B3B3B3;
|
||
|
}
|
||
|
|
||
|
.category {
|
||
|
flex-wrap: nowrap;
|
||
|
border-bottom: 1rpx solid #EEEEEE;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.scroll-view {
|
||
|
flex: 1;
|
||
|
min-width: 0;
|
||
|
padding-left: 20rpx;
|
||
|
white-space: nowrap;
|
||
|
|
||
|
.item {
|
||
|
display: inline-block;
|
||
|
padding: 24rpx 0;
|
||
|
margin-right: 8rpx;
|
||
|
vertical-align: middle;
|
||
|
|
||
|
&.on {
|
||
|
.img-box {
|
||
|
border-color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.title {
|
||
|
background: linear-gradient(90deg, var(--view-gradient) 0%, var(--view-theme) 100%);
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.img-box {
|
||
|
width: 104rpx;
|
||
|
height: 104rpx;
|
||
|
padding: 6rpx;
|
||
|
border: 3rpx solid transparent;
|
||
|
border-radius: 50%;
|
||
|
margin: 0 auto;
|
||
|
}
|
||
|
|
||
|
.img {
|
||
|
width: 92rpx;
|
||
|
height: 92rpx;
|
||
|
border-radius: 50%;
|
||
|
}
|
||
|
|
||
|
.title {
|
||
|
width: 120rpx;
|
||
|
height: 40rpx;
|
||
|
border-radius: 20rpx;
|
||
|
margin-top: 8rpx;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.btn {
|
||
|
position: relative;
|
||
|
flex-wrap: nowrap;
|
||
|
width: 72rpx;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 34rpx;
|
||
|
color: #333333;
|
||
|
|
||
|
.img {
|
||
|
position: absolute;
|
||
|
top: 0;
|
||
|
left: 0;
|
||
|
width: 22rpx;
|
||
|
height: 100%;
|
||
|
transform: translateX(-50%);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.category-dialog {
|
||
|
border-radius: 0rpx 0rpx 32rpx 32rpx;
|
||
|
background: #FFFFFF;
|
||
|
|
||
|
.scroll-view {
|
||
|
max-height: 724rpx;
|
||
|
padding-left: 32rpx;
|
||
|
}
|
||
|
|
||
|
.item {
|
||
|
margin: 0 22rpx 26rpx 0;
|
||
|
|
||
|
&.on {
|
||
|
.img-box {
|
||
|
border-color: var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.title {
|
||
|
background: linear-gradient(90deg, var(--view-gradient) 0%, var(--view-theme) 100%);
|
||
|
color: #FFFFFF;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.img-box {
|
||
|
width: 104rpx;
|
||
|
height: 104rpx;
|
||
|
padding: 6rpx;
|
||
|
border: 3rpx solid transparent;
|
||
|
border-radius: 50%;
|
||
|
margin: 0 auto;
|
||
|
}
|
||
|
|
||
|
.img {
|
||
|
width: 92rpx;
|
||
|
height: 92rpx;
|
||
|
border-radius: 50%;
|
||
|
}
|
||
|
|
||
|
.title {
|
||
|
width: 120rpx;
|
||
|
height: 40rpx;
|
||
|
border-radius: 20rpx;
|
||
|
margin-top: 8rpx;
|
||
|
text-align: center;
|
||
|
font-size: 24rpx;
|
||
|
line-height: 40rpx;
|
||
|
color: #333333;
|
||
|
}
|
||
|
|
||
|
.btn {
|
||
|
flex-wrap: nowrap;
|
||
|
height: 80rpx;
|
||
|
font-size: 24rpx;
|
||
|
color: #999999;
|
||
|
|
||
|
.iconfont {
|
||
|
margin-left: 4rpx;
|
||
|
font-size: 24rpx;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|