-
69package-lock.json
-
23src/pages.json
-
6src/pages/index/index.vue
-
BINsrc/static/images/icon/index/tab_10.png
-
BINsrc/static/images/icon/retail/add.png
-
BINsrc/static/images/icon/retail/back.png
-
BINsrc/static/images/icon/retail/cart.png
-
BINsrc/static/images/icon/retail/dropDown.png
-
BINsrc/static/images/icon/retail/historySearchDelete.png
-
BINsrc/static/images/icon/retail/home.png
-
BINsrc/static/images/icon/retail/search.png
-
BINsrc/static/images/icon/retail/searchClear.png
-
BINsrc/static/images/icon/retail/sub.png
-
236src/subpackage/retail/components/hover_cart_list/hover_cart_list.vue
-
7src/subpackage/retail/js/retail_api.js
-
10src/subpackage/retail/js/retail_server.js
-
20src/subpackage/retail/js/tools.js
-
447src/subpackage/retail/pages/confirm_goods/confirm_goods.vue
-
901src/subpackage/retail/pages/index/index.vue
-
239src/subpackage/retail/pages/search/search.vue
-
BINsrc/subpackage/retail/static/images/add.png
-
BINsrc/subpackage/retail/static/images/back.png
-
BINsrc/subpackage/retail/static/images/cart.png
-
BINsrc/subpackage/retail/static/images/dropDown.png
-
BINsrc/subpackage/retail/static/images/historySearchDelete.png
-
BINsrc/subpackage/retail/static/images/home.png
-
BINsrc/subpackage/retail/static/images/search.png
-
BINsrc/subpackage/retail/static/images/searchClear.png
After Width: 52 | Height: 52 | Size: 470 B |
After Width: 36 | Height: 36 | Size: 314 B |
After Width: 32 | Height: 32 | Size: 241 B |
After Width: 84 | Height: 84 | Size: 2.0 KiB |
After Width: 18 | Height: 18 | Size: 185 B |
After Width: 36 | Height: 36 | Size: 365 B |
After Width: 36 | Height: 36 | Size: 364 B |
After Width: 40 | Height: 40 | Size: 372 B |
After Width: 32 | Height: 32 | Size: 356 B |
After Width: 40 | Height: 40 | Size: 380 B |
@ -0,0 +1,236 @@ |
|||
<template> |
|||
<view v-if="isShowCartList" class="hover-cart-list"> |
|||
<view></view> |
|||
<view class="hover-cart-list-dialog" :style="{ height:cartListDialogHeight }"> |
|||
<view class="hover-cart-list-dialog-title"> |
|||
<view>商品名称</view> |
|||
<view>售价</view> |
|||
<view>数量</view> |
|||
</view> |
|||
<scroll-view class="hover-cart-list-dialog-content" :style="{ height:cartListHeight }" :scroll-top="0" :scroll-y="cartListScroll"> |
|||
<view class="hover-cart-list-dialog-content-for" :style="{ borderBottom:cartListItemBorderBottom }" v-for="item in cartList" :key="item.id"> |
|||
<view class="hover-cart-list-dialog-content-col1"> |
|||
<view>{{ item.name }}</view> |
|||
<view>{{ item.spec }}</view> |
|||
</view> |
|||
<view class="hover-cart-list-dialog-content-col2"> |
|||
<input type="digit" :value="item.price" @confirm="cartInputConfirm($event, item.id)" @blur="cartInputConfirm($event, item.id)" /> |
|||
<view>元</view> |
|||
</view> |
|||
<view class="hover-cart-list-dialog-content-col3"> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/sub.png" @click="cartCountClick('sub', item.id)"></image> |
|||
<view>{{ item.count }}</view> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/add.png" @click="cartCountClick('add', item.id)"></image> |
|||
</view> |
|||
</view> |
|||
</scroll-view> |
|||
</view> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
props: [ |
|||
"isShowCartList", "cartList", "cartListScroll", |
|||
"cartListHeight", "cartListDialogHeight", "cartListItemBorderBottom" |
|||
], |
|||
|
|||
data() { |
|||
return { |
|||
|
|||
} |
|||
}, |
|||
onLoad() { |
|||
|
|||
}, |
|||
methods: { |
|||
// 购物车输入确认 |
|||
cartInputConfirm(event, id) { |
|||
// 修改购物车列表对应的价格 |
|||
let value = parseFloat(event.detail.value).toFixed(2); |
|||
for (let i = 0; i < this.cartList.length; ++i) { |
|||
if (this.cartList[i].id == id) { |
|||
this.$emit("update:cartInputConfirm", value, i); |
|||
} |
|||
} |
|||
}, |
|||
|
|||
// 购物车列表数量选项触发 |
|||
cartCountClick(type, id) { |
|||
// 找点击的对应商品 |
|||
let item = null; |
|||
for (let i = 0; i < this.cartList.length; ++i) { |
|||
if (this.cartList[i].id == id) { |
|||
// item = this.cartList[i]; |
|||
this.$emit("update:cartCountClick", type, i); |
|||
break; |
|||
} |
|||
} |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss"> |
|||
.hover-cart-list { |
|||
width: 100vw; |
|||
height: 100vh; |
|||
position: absolute; |
|||
left: 0rpx; |
|||
top: 0rpx; |
|||
|
|||
>view { |
|||
&:first-child { |
|||
width: 100%; |
|||
height: 100%; |
|||
position: absolute; |
|||
left: 0rpx; |
|||
bottom: 0rpx; |
|||
bottom: calc( 108rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
bottom: calc( 108rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
|
|||
background-color: rgba(0,0,0,0.5); |
|||
} |
|||
} |
|||
|
|||
.hover-cart-list-dialog { |
|||
display: flex; |
|||
flex-direction: column; |
|||
justify-content: center; |
|||
align-items: center; |
|||
position: fixed; |
|||
bottom: 0rpx; |
|||
bottom: calc( 108rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
bottom: calc( 108rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
width: 100%; |
|||
height: 878rpx; |
|||
background-color: rgb(255,255,255); |
|||
border-top-left-radius: 30rpx; |
|||
border-top-right-radius: 30rpx; |
|||
|
|||
.hover-cart-list-dialog-title { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
width: 100%; |
|||
height: 120rpx; |
|||
text-align: center; |
|||
padding-left: 34rpx; |
|||
padding-right: 36rpx; |
|||
|
|||
>view { |
|||
font-size: 32rpx; |
|||
color: rgb(51,51,51); |
|||
|
|||
&:first-child { |
|||
width: 258rpx; |
|||
|
|||
} |
|||
&:nth-child(2) { |
|||
width: 166rpx; |
|||
} |
|||
&:nth-child(3) { |
|||
width: 126rpx; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.hover-cart-list-dialog-content { |
|||
display: flex; |
|||
flex-direction: column; |
|||
justify-content: center; |
|||
align-items: center; |
|||
flex-grow: 1; |
|||
height: 758rpx; |
|||
padding-left: 34rpx; |
|||
padding-right: 36rpx; |
|||
|
|||
.hover-cart-list-dialog-content-for { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: flex-start; |
|||
flex-grow: 1; |
|||
height: 114rpx; |
|||
border-bottom: 1rpx solid rgb(216,216,216); |
|||
margin-top: 30rpx; |
|||
|
|||
.hover-cart-list-dialog-content-col1 { |
|||
// display: flex; |
|||
flex-direction: column; |
|||
justify-content: flex-start; |
|||
align-items: center; |
|||
width: 258rpx; |
|||
|
|||
>view { |
|||
overflow: hidden; |
|||
word-break: nowrap; |
|||
text-overflow: ellipsis; /* 超出部分省略号 */ |
|||
display: -webkit-box; /** 对象作为伸缩盒子模型显示 **/ |
|||
-webkit-box-orient: vertical; /** 设置或检索伸缩盒对象的子元素的排列方式 **/ |
|||
-webkit-line-clamp: 1; /** 显示的行数 **/ |
|||
|
|||
&:first-child { |
|||
font-size: 28rpx; |
|||
color: rgb(51,51,51); |
|||
margin-bottom: 8rpx; |
|||
} |
|||
&:nth-child(2) { |
|||
font-size: 24rpx; |
|||
color: rgb(154,154,157); |
|||
} |
|||
} |
|||
} |
|||
|
|||
.hover-cart-list-dialog-content-col2 { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
color: rgb(51,51,51); |
|||
font-size: 28rpx; |
|||
text-align: center; |
|||
width: 166rpx; |
|||
|
|||
>input { |
|||
width: 132rpx; |
|||
height: 48rpx; |
|||
border: 2rpx solid rgb(216,216,216); |
|||
border-radius: 4rpx; |
|||
} |
|||
>view { |
|||
margin-left: 6rpx; |
|||
} |
|||
} |
|||
|
|||
.hover-cart-list-dialog-content-col3 { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
width: 126rpx; |
|||
|
|||
>image { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
|
|||
&:first-child { |
|||
|
|||
} |
|||
&:nth-child(3) { |
|||
|
|||
} |
|||
} |
|||
>view { |
|||
margin-left: 12rpx; |
|||
margin-right: 12rpx; |
|||
color: rgb(51,51,51); |
|||
font-size: 28rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</style> |
@ -0,0 +1,7 @@ |
|||
import { ORIGIN } from '../../../js/api'; |
|||
|
|||
export const RETAIL_API = { |
|||
stadiumList:`${ORIGIN}/stadium/list`, // 店铺列表
|
|||
} |
|||
|
|||
export default RETAIL_API; |
@ -0,0 +1,10 @@ |
|||
import { Server } from '../../../js/server'; |
|||
|
|||
class RetailServer extends Server { |
|||
constructor(props){ |
|||
super(props) |
|||
} |
|||
} |
|||
|
|||
|
|||
export default new RetailServer(); |
@ -0,0 +1,20 @@ |
|||
|
|||
export const tools = { |
|||
// px转rpx
|
|||
px2rpx: function(px) { |
|||
return (px / (uni.upx2px(px) / px)); |
|||
}, |
|||
|
|||
// 获取新的数据对象
|
|||
getNewObj: function(old) { |
|||
let newObj = {}; |
|||
|
|||
for (let key in old) { |
|||
newObj[key] = old[key]; |
|||
} |
|||
|
|||
return newObj; |
|||
}, |
|||
} |
|||
|
|||
export default tools; |
@ -0,0 +1,447 @@ |
|||
<template> |
|||
<view class="cg-container"> |
|||
<view class="final-cart-list"> |
|||
<view class="final-cart-list-dialog-title"> |
|||
<view>商品名称</view> |
|||
<view>售价</view> |
|||
<view>数量</view> |
|||
</view> |
|||
<scroll-view class="final-cart-list-dialog-content" :scroll-top="0" :scroll-y="cartListScroll" :style="{ height:cartListFinalHeight, paddingBottom:cartListFinalPaddingBottom }"> |
|||
<view class="final-cart-list-dialog-content-for" :style="{ borderBottom:item.borderBottom }" v-for="item in cartListFinal" :key="item.id"> |
|||
<view class="final-cart-list-dialog-content-col1"> |
|||
<view>{{ item.name }}</view> |
|||
<view>{{ item.spec }}</view> |
|||
</view> |
|||
<view class="final-cart-list-dialog-content-col2"> |
|||
<input v-if="isEdited" type="digit" :value="item.price" @confirm="cartInputConfirm($event, item.id)" @blur="cartInputConfirm($event, item.id)" /> |
|||
<view v-if="!isEdited">{{item.price}}</view> |
|||
<view>元</view> |
|||
</view> |
|||
<view class="final-cart-list-dialog-content-col3"> |
|||
<image v-if="isEdited" mode="aspectFit" src="/static/images/icon/retail/sub.png" @click="cartCountClick('sub', item.id)"></image> |
|||
<view>{{ item.count }}</view> |
|||
<image v-if="isEdited" mode="aspectFit" src="/static/images/icon/retail/add.png" @click="cartCountClick('add', item.id)"></image> |
|||
</view> |
|||
</view> |
|||
</scroll-view> |
|||
</view> |
|||
|
|||
<view class="cg-footer"> |
|||
<view> |
|||
<view class="cg-footer-price"> |
|||
<view>合计:</view> |
|||
<view><text>¥</text>{{ totalPrice }}</view> |
|||
</view> |
|||
|
|||
<view class="cg-footer-btn"> |
|||
<view class="cg-footer-btn-reedit" v-if="!isEdited" @click="cartReedit"><button>重新编辑</button></view> |
|||
<view class="cg-footer-btn-confirm" @click="cartConfirm"><button>{{cartConfirmText}}</button></view> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import util from '../../../../utils/util.js'; |
|||
import tools from '../../js/tools'; |
|||
import retailServer from '../../js/retail_server'; |
|||
import retailApi from '../../js/retail_api'; |
|||
|
|||
export default { |
|||
data() { |
|||
return { |
|||
isEdited: false, // 是否处于编辑模式 |
|||
cartListFinal: [], // 购物车最终列表数据 |
|||
totalPrice: 0, // 最终价格 |
|||
cartConfirmText: "收款出库", // 收款出库 || 确认 |
|||
cartListScroll: false, // 购物车列表是否能滚动 |
|||
cartListFinalHeight: "0rpx", // 最终显示的列表高度 |
|||
cartListFinalPaddingBottom: "0rpx", // 根据是否是异形屏来设置 |
|||
} |
|||
}, |
|||
onLoad(option) { |
|||
let data = JSON.parse(decodeURIComponent(option.data)); |
|||
|
|||
this.cartListFinal = []; |
|||
for (let i = 0; i < data.cartListFinal.length; ++i) { |
|||
this.cartListFinal.push(tools.getNewObj(data.cartListFinal[i])); |
|||
this.cartListFinal[i]["borderBottom"] = "1rpx solid rgb(216,216,216)"; |
|||
} |
|||
|
|||
// 最后一项默认不显示边框 |
|||
this.cartListFinal[this.cartListFinal.length - 1]["borderBottom"] = "0rpx solid rgb(216,216,216)"; |
|||
this.fixMainHeight(); // 适配主内容高度 |
|||
this.calcTotalPrice(); // 计算总价 |
|||
|
|||
util.showLoad(); |
|||
setTimeout(util.hideLoad, 1000); |
|||
}, |
|||
methods: { |
|||
// 重新编辑 |
|||
cartReedit() { |
|||
this.isEdited = true; |
|||
this.cartConfirmText = "确认"; |
|||
}, |
|||
|
|||
// 确认 || 收款出库 |
|||
cartConfirm() { |
|||
if (this.cartConfirmText == "确认") { |
|||
this.isEdited = false; |
|||
this.cartConfirmText = "收款出库"; |
|||
return; |
|||
} |
|||
|
|||
uni.navigateBack({ |
|||
delta: 1 |
|||
}); |
|||
}, |
|||
|
|||
// 购物车输入确认 |
|||
cartInputConfirm(event, id) { |
|||
// 修改购物车列表对应的价格 |
|||
let value = parseFloat(event.detail.value).toFixed(2); |
|||
for (let i = 0; i < this.cartListFinal.length; ++i) { |
|||
if (this.cartListFinal[i].id == id) { |
|||
this.cartListFinal[i].price = value; |
|||
} |
|||
} |
|||
|
|||
this.calcTotalPrice(); // 计算总价 |
|||
}, |
|||
|
|||
// 购物车列表数量选项触发 |
|||
cartCountClick(type, id) { |
|||
// 找点击的对应商品 |
|||
let item = null; |
|||
for (let i = 0; i < this.cartListFinal.length; ++i) { |
|||
if (this.cartListFinal[i].id == id) { |
|||
item = this.cartListFinal[i]; |
|||
break; |
|||
} |
|||
} |
|||
|
|||
if (item) { |
|||
switch (type) { |
|||
case "add": { |
|||
item.count += 1; |
|||
} break; |
|||
case "sub": { |
|||
if (item.count <= 0) { |
|||
return; |
|||
} |
|||
|
|||
item.count -= 1; |
|||
} break; |
|||
} |
|||
|
|||
this.calcTotalPrice(); // 计算总价 |
|||
} |
|||
}, |
|||
|
|||
// 计算总价 |
|||
calcTotalPrice() { |
|||
let price = 0.0; |
|||
|
|||
for (let i = 0; i < this.cartListFinal.length; ++i) { |
|||
price += (this.cartListFinal[i].count * this.cartListFinal[i].price); |
|||
} |
|||
|
|||
this.totalPrice = price.toFixed(2); |
|||
}, |
|||
|
|||
// 适配主内容高度 |
|||
fixMainHeight() { |
|||
let _this = this; |
|||
uni.getSystemInfo({ |
|||
success: res => { |
|||
console.log(res); |
|||
let sumHeight = res.windowHeight; // 获取可用的总高度 |
|||
|
|||
// // 看看当前滚动框是否超出这个高度 |
|||
let query = uni.createSelectorQuery().select(".cg-footer"); |
|||
query.boundingClientRect(data => { |
|||
sumHeight = sumHeight - data.height - uni.upx2px(90); // 可用高度减去footer 再减去顶部标题项 |
|||
let contentHeight = sumHeight; |
|||
|
|||
query = uni.createSelectorQuery().select(".final-cart-list-dialog-content-for"); |
|||
query.boundingClientRect(data => { |
|||
let itemSize = (data.height + uni.upx2px(30)); // 30是margin |
|||
let limitCount = Math.floor(contentHeight / itemSize); |
|||
|
|||
let height = _this.cartListFinal.length >= limitCount ? contentHeight : _this.cartListFinal.length * itemSize; |
|||
_this.cartListFinalHeight = `${tools.px2rpx(height)}rpx`; |
|||
|
|||
// 可以滚动,并且设置safeArea,大于等于44的为iphoneX及以上 |
|||
if (height >= contentHeight) { |
|||
_this.cartListScroll = true; |
|||
_this.cartListFinalPaddingBottom = `${res.safeArea.top >= 44 ? tools.px2rpx(res.safeArea.top) : 0}rpx`; |
|||
} |
|||
}).exec(); |
|||
}).exec(); |
|||
} |
|||
}); |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss"> |
|||
page { |
|||
// background-color: rgb(237,237,245); |
|||
background-color: rgb(255,255,255); |
|||
} |
|||
|
|||
.cg-container { |
|||
display: flex; |
|||
flex-direction: column; |
|||
width: 100vw; |
|||
height: 100vh; |
|||
padding-bottom: 0rpx; |
|||
padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
// border: 1px solid red; |
|||
|
|||
.final-cart-list { |
|||
display: flex; |
|||
flex-direction: column; |
|||
// width: 100%; |
|||
// height: 100%; |
|||
flex-grow: 1; |
|||
background-color: rgb(237,237,245); |
|||
|
|||
.final-cart-list-dialog-title { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
width: 100%; |
|||
height: 90rpx; |
|||
text-align: center; |
|||
padding-left: 34rpx; |
|||
padding-right: 36rpx; |
|||
background-color: rgb(255,255,255); |
|||
|
|||
>view { |
|||
font-size: 32rpx; |
|||
color: rgb(51,51,51); |
|||
|
|||
&:first-child { |
|||
width: 258rpx; |
|||
|
|||
} |
|||
&:nth-child(2) { |
|||
width: 166rpx; |
|||
} |
|||
&:nth-child(3) { |
|||
width: 126rpx; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.final-cart-list-dialog-content { |
|||
display: flex; |
|||
flex-direction: column; |
|||
justify-content: center; |
|||
align-items: flex-start; |
|||
// flex-grow: 1; |
|||
// height: 428rpx; |
|||
padding-left: 34rpx; |
|||
padding-right: 36rpx; |
|||
background-color: rgb(255,255,255); |
|||
// padding-bottom: 0rpx; |
|||
// padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
// padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
|
|||
.final-cart-list-dialog-content-for { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: flex-start; |
|||
// flex-grow: 1; |
|||
height: 114rpx; |
|||
border-bottom: 1rpx solid rgb(216,216,216); |
|||
background-color: rgb(255,255,255); |
|||
margin-top: 30rpx; |
|||
|
|||
.final-cart-list-dialog-content-col1 { |
|||
// display: flex; |
|||
flex-direction: column; |
|||
justify-content: flex-start; |
|||
align-items: center; |
|||
width: 258rpx; |
|||
|
|||
>view { |
|||
overflow: hidden; |
|||
word-break: nowrap; |
|||
text-overflow: ellipsis; /* 超出部分省略号 */ |
|||
display: -webkit-box; /** 对象作为伸缩盒子模型显示 **/ |
|||
-webkit-box-orient: vertical; /** 设置或检索伸缩盒对象的子元素的排列方式 **/ |
|||
-webkit-line-clamp: 1; /** 显示的行数 **/ |
|||
|
|||
&:first-child { |
|||
font-size: 28rpx; |
|||
color: rgb(51,51,51); |
|||
margin-bottom: 8rpx; |
|||
} |
|||
&:nth-child(2) { |
|||
font-size: 24rpx; |
|||
color: rgb(154,154,157); |
|||
} |
|||
} |
|||
} |
|||
|
|||
.final-cart-list-dialog-content-col2 { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
color: rgb(51,51,51); |
|||
font-size: 28rpx; |
|||
text-align: center; |
|||
width: 166rpx; |
|||
|
|||
>input { |
|||
width: 132rpx; |
|||
height: 48rpx; |
|||
border: 2rpx solid rgb(216,216,216); |
|||
border-radius: 4rpx; |
|||
} |
|||
>view { |
|||
&:first-child { |
|||
|
|||
} |
|||
&:nth-child(2) { |
|||
margin-left: 6rpx; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.final-cart-list-dialog-content-col3 { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
width: 126rpx; |
|||
|
|||
>image { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
|
|||
&:first-child { |
|||
|
|||
} |
|||
&:nth-child(3) { |
|||
|
|||
} |
|||
} |
|||
>view { |
|||
margin-left: 12rpx; |
|||
margin-right: 12rpx; |
|||
color: rgb(51,51,51); |
|||
font-size: 28rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
.cg-footer { |
|||
display: flex; |
|||
flex-direction: column; |
|||
justify-content: center; |
|||
align-items: flex-start; |
|||
// flex-grow: 1; |
|||
// opacity: 0.3; |
|||
|
|||
position: fixed; |
|||
// bottom: 0rpx; |
|||
bottom: calc( 0rpx + constant(safe-area-inset-bottom)); |
|||
bottom: calc( 0rpx + env(safe-area-inset-bottom)); |
|||
// padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
// padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
width: 100%; |
|||
height: 188rpx; |
|||
// border: 1rpx solid blue; |
|||
background-color: rgb(255,255,255); |
|||
|
|||
>view { |
|||
display: flex; |
|||
flex-direction: column; |
|||
// justify-content: flex-end; |
|||
align-items: flex-start; |
|||
width: 100%; |
|||
height: 100%; |
|||
|
|||
.cg-footer-price { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: flex-end; |
|||
align-items: center; |
|||
height: 88rpx; |
|||
width: 100%; |
|||
padding-right: 40rpx; |
|||
|
|||
>view { |
|||
&:first-child { |
|||
font-size: 24rpx; |
|||
} |
|||
&:nth-child(2) { |
|||
color: rgb(255,135,61); |
|||
font-size: 32rpx; |
|||
|
|||
>text { |
|||
font-size: 24rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
.cg-footer-btn { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: flex-end; |
|||
align-items: center; |
|||
height: 88rpx; |
|||
width: 100%; |
|||
padding-right: 24rpx; |
|||
font-size: 32rpx; |
|||
|
|||
> view { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
} |
|||
|
|||
.cg-footer-btn-reedit { |
|||
>button { |
|||
width: 242rpx; |
|||
height: 88rpx; |
|||
line-height: 88rpx; |
|||
border-radius: 44rpx; |
|||
padding: 0 0; |
|||
color: rgb(0,152,116); |
|||
background-color: rgb(255,255,255); |
|||
border: 2rpx solid rgb(0,152,116); |
|||
margin-right: 20rpx; |
|||
} |
|||
} |
|||
|
|||
.cg-footer-btn-confirm { |
|||
>button { |
|||
width: 242rpx; |
|||
height: 88rpx; |
|||
line-height: 88rpx; |
|||
border-radius: 44rpx; |
|||
padding: 0 0; |
|||
color: rgb(255,255,255); |
|||
background-color: rgb(0,152,116); |
|||
border: 2rpx solid rgb(0,152,116); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</style> |
@ -0,0 +1,901 @@ |
|||
<template> |
|||
<view class="container"> |
|||
<view class="header"> |
|||
<picker |
|||
@change="curStoreChange" |
|||
mode="selector" |
|||
range-key="name" |
|||
:range="curStoreList" |
|||
value="0" |
|||
> |
|||
<view class="header-store-selecter"> |
|||
<image class="header-store-selecter-left-img" mode="aspectFit" src="/static/images/icon/retail/home.png"></image> |
|||
<!-- <input id="cur-store-input-node" placeholder="请选择门店" :value="curStore.name" disabled /> --> |
|||
<view class="header-store-selecter-name">{{ curStore.name ? curStore.name : '' }}</view> |
|||
<image class="header-store-selecter-right-img" mode="aspectFit" src="/static/images/icon/retail/dropDown.png"></image> |
|||
</view> |
|||
</picker> |
|||
<view class="header-search-row"> |
|||
<view @click="searchTrigger"> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/search.png"></image> |
|||
<input |
|||
type="text" |
|||
placeholder="请输入商品名称" |
|||
disabled |
|||
/> |
|||
</view> |
|||
<button @click="searchTrigger">搜索</button> |
|||
</view> |
|||
</view> |
|||
|
|||
<view class="main" :style="{ height:mainHeight }"> |
|||
<scroll-view class="main-left" :scroll-top="categoryScrollTop" scroll-y="true" @scroll="categoryOnScroll"> |
|||
<view class="main-left-list" v-if="item.isSearch" v-for="item in goodsInfo" :key="item.id"> |
|||
<button plain=true @click="mainCategoryClick(item.id)" :style="{ color:item.style.color, backgroundColor:item.style.backgroundColor }">{{ item.categoryName }}</button> |
|||
</view> |
|||
</scroll-view> |
|||
<scroll-view class="main-right" scroll-top="0" scroll-y="true" v-if="scrollItem.isShow" v-for="scrollItem in goodsInfo" :key="scrollItem.id"> |
|||
<view class="main-right-list" v-for="item in scrollItem.goodsData" :key="item.id"> |
|||
<view>{{ item.name }}</view> |
|||
<view>{{ item.spec }}</view> |
|||
|
|||
<view class="main-right-list-price-count"> |
|||
<view class="main-right-list-price-row"> |
|||
<view><text>¥</text>{{ item.price }}</view> |
|||
</view> |
|||
|
|||
<view class="main-right-list-count-row"> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/sub.png" @click="mainCountClick('sub', scrollItem.id, item.id)"></image> |
|||
<view>{{ item.count }}</view> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/add.png" @click="mainCountClick('add', scrollItem.id, item.id)"></image> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</scroll-view> |
|||
</view> |
|||
|
|||
<hoverCartList |
|||
:isShowCartList="isShowCartList" :cartList="cartList" :cartListScroll="cartListScroll" |
|||
:cartListHeight="cartListHeight" :cartListDialogHeight="cartListDialogHeight" :cartListItemBorderBottom="cartListItemBorderBottom" |
|||
@update:cartInputConfirm="cartInputConfirm" @update:cartCountClick="cartCountClick" |
|||
> |
|||
</hoverCartList> |
|||
|
|||
<view class="footer"> |
|||
<view> |
|||
<view class="footer-price"> |
|||
<view @click="cartClick"> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/cart.png"></image> |
|||
<view v-if="(totalCount>0 && !isShowCartList) ? true:false">{{ totalCount }}</view> |
|||
<view v-if="(cartTotalCount>0 && isShowCartList) ? true:false">{{ cartTotalCount }}</view> |
|||
</view> |
|||
<view>合计:</view> |
|||
<view v-if="!isShowCartList"><text>¥</text>{{ totalPrice }}</view> |
|||
<view v-if="isShowCartList"><text>¥</text>{{ cartTotalPrice }}</view> |
|||
</view> |
|||
<view class="footer-confirm"> |
|||
<button @click="cartConfirm">确认</button> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
import util from '../../../../utils/util.js'; |
|||
import tools from '../../js/tools'; |
|||
import retailServer from '../../js/retail_server'; |
|||
import retailApi from '../../js/retail_api'; |
|||
import hoverCartList from '../../components/hover_cart_list/hover_cart_list'; |
|||
|
|||
export default { |
|||
components: { |
|||
'hoverCartList': hoverCartList |
|||
}, |
|||
data(){ |
|||
return { |
|||
categoryBtnStyle: { // 分类按钮样式 |
|||
default: { "color":"rgb(154,154,157)", "backgroundColor":"rgba(0,0,0,0)" }, |
|||
click: { "color":"rgb(0,152,116)", "backgroundColor":"rgb(205,235,228)" }, |
|||
}, |
|||
categoryScrollTop: 0, // 分类滚动值 |
|||
categoryOldScrollTop: 0, // 分类滚动旧值 |
|||
categoryIndex: 1, // 分类索引值,默认第一项是搜索,过滤掉,直接从第二项开始计算 |
|||
|
|||
// curStoreList: [{ id: '', name: '请选择门店'}], // 当前门店列表 |
|||
curStoreList: [], // 当前门店列表 |
|||
curStore: {}, // 当前门店 |
|||
goodsInfo: [], // 商品信息 |
|||
mainHeight: "0rpx", // 主内容高度 |
|||
totalPrice: 0, // 总价 |
|||
totalCount: 0, // 总量 |
|||
cartTotalPrice: 0, // 购物车总价 |
|||
cartTotalCount: 0, // 购物车总量 |
|||
|
|||
cartList: [], // 购物车列表 |
|||
cartListFinal: [], // 购物车最终列表数据 |
|||
isShowCartList: false, // 是否显示购物车列表 |
|||
cartListScroll: true, // 购物车列表是否滚动 |
|||
cartListHeight: "0rpx", // 购物车列表高度,根据数量来改变高度 |
|||
cartListDialogHeight: "0rpx", // 购物车列表对话框高度,根据数量来改变高度 |
|||
cartListItemBorderBottom: "1rpx solid rgb(216,216,216)", // 列表数量大于1才会显示border |
|||
} |
|||
}, |
|||
onLoad() { |
|||
this.deleteSearchLocal(); // 删除本地的历史搜索 |
|||
this.getStoreList(); // 获取店铺列表 |
|||
this.getGoodsInfo(); // 获取商品信息 |
|||
this.fixMainHeight(); // 适配主内容高度 |
|||
}, |
|||
onShow() { |
|||
this.getSearchLocal(); // 获取本地的历史搜索 |
|||
}, |
|||
methods: { |
|||
// 分类列表滚动监听 |
|||
categoryOnScroll(e) { |
|||
this.categoryOldScrollTop = e.detail.scrollTop; |
|||
}, |
|||
// 分类列表回到顶部 |
|||
categoryGoTop(e) { |
|||
let _this = this; |
|||
_this.categoryScrollTop = _this.categoryOldScrollTop; |
|||
_this.$nextTick(function() { |
|||
_this.categoryScrollTop = 0; |
|||
}); |
|||
}, |
|||
|
|||
// 设置搜索数据 默认列表第一项是存放搜索数据 |
|||
setSearchData(data) { |
|||
util.showLoad(); |
|||
setTimeout(util.hideLoad, 1000); |
|||
|
|||
this.goodsInfo[0].goodsData = []; |
|||
let random = Math.floor(Math.random() * 5 + 1); |
|||
console.log(random); |
|||
|
|||
let tempData = []; |
|||
for (let i = 0; i < this.goodsInfo[random].goodsData.length; ++i) { |
|||
tempData.push(tools.getNewObj(this.goodsInfo[random].goodsData[i])); |
|||
} |
|||
|
|||
let conectData = [] |
|||
for (let i = 1; i < this.goodsInfo.length; ++i) { |
|||
conectData = [ ...conectData, ...this.goodsInfo[i].goodsData ]; |
|||
} |
|||
|
|||
for (let i = 0; i < tempData.length; ++i) { |
|||
for (let j = 0; j < conectData.length; ++j) { |
|||
if (tempData[i].id == conectData[j].id) { |
|||
this.goodsInfo[0].goodsData.push(conectData[j]); |
|||
} |
|||
} |
|||
} |
|||
|
|||
this.categoryGoTop(); // 每次搜索后,分类列表都要滚动到顶部 |
|||
this.goodsInfo[0].isSearch = true; |
|||
this.mainCategoryClick(this.goodsInfo[0].id); |
|||
}, |
|||
|
|||
// 获取本地的历史搜索 |
|||
getSearchLocal() { |
|||
let _this = this; |
|||
|
|||
uni.getStorage({ |
|||
key: 'searchData', |
|||
success: function (res) { |
|||
console.log(res.data); |
|||
_this.setSearchData(res.data); // 设置搜索数据 |
|||
_this.deleteSearchLocal(); // 删除本地的历史搜索 |
|||
}, |
|||
fail: function(err) { |
|||
console.log(err); |
|||
_this.deleteSearchLocal(); // 删除本地的历史搜索 |
|||
}, |
|||
}); |
|||
}, |
|||
|
|||
// 删除本地的历史搜索 |
|||
deleteSearchLocal() { |
|||
this.searchData = null; |
|||
|
|||
uni.removeStorage({ |
|||
key: 'searchData', |
|||
success: function (res) { |
|||
console.log('success'); |
|||
} |
|||
}); |
|||
}, |
|||
|
|||
// 触发搜索 |
|||
searchTrigger() { |
|||
uni.navigateTo({ |
|||
url: '/subpackage/retail/pages/search/search' |
|||
}); |
|||
}, |
|||
|
|||
// 购物车输入确认 |
|||
cartInputConfirm(value, i) { |
|||
this.cartList[i].price = value; |
|||
this.calcCartTotalPriceAndCount(); // 计算购物车总价跟总量 |
|||
}, |
|||
|
|||
// 计算购物车总价跟总量 |
|||
calcCartTotalPriceAndCount() { |
|||
let price = 0.0; |
|||
let count = 0; |
|||
|
|||
for (let i = 0; i < this.cartList.length; ++i) { |
|||
price += (this.cartList[i].count * this.cartList[i].price); |
|||
count += this.cartList[i].count; |
|||
} |
|||
|
|||
this.cartTotalPrice = price.toFixed(2); |
|||
this.cartTotalCount = count; |
|||
}, |
|||
|
|||
// 购物车列表数量选项触发 |
|||
cartCountClick(type, i) { |
|||
switch (type) { |
|||
case "add": { |
|||
this.cartList[i].count += 1; |
|||
} break; |
|||
case "sub": { |
|||
if (this.cartList[i].count <= 0) { |
|||
return; |
|||
} |
|||
|
|||
this.cartList[i].count -= 1; |
|||
} break; |
|||
} |
|||
|
|||
this.calcCartTotalPriceAndCount(); // 计算购物车总价跟总量 |
|||
}, |
|||
|
|||
// 获取购物车列表的最终数据 |
|||
getCartListFinalData() { |
|||
let arr = []; |
|||
|
|||
for (let i = 0; i < this.cartList.length; ++i) { |
|||
if (this.cartList[i].count) { |
|||
arr.push(tools.getNewObj(this.cartList[i])); |
|||
} |
|||
} |
|||
|
|||
return arr; |
|||
}, |
|||
|
|||
// 购物车确认 |
|||
cartConfirm() { |
|||
this.cartListFinal = this.getCartListFinalData(); |
|||
|
|||
// 有数据,那么需要跳到确定页面 |
|||
if (this.cartListFinal.length) { |
|||
this.isShowCartList = false; |
|||
|
|||
let data = { |
|||
cartListFinal: this.cartListFinal, |
|||
}; |
|||
uni.navigateTo({ |
|||
url: `/subpackage/retail/pages/confirm_goods/confirm_goods?data=${encodeURIComponent(JSON.stringify(data))}` |
|||
}); |
|||
} |
|||
else { |
|||
uni.showToast({ |
|||
title: "购物车无数据!", |
|||
icon: "none" |
|||
}); |
|||
} |
|||
}, |
|||
|
|||
// 加入购物车列表 |
|||
addToCartList() { |
|||
this.cartList = []; |
|||
|
|||
// 计算购物车列表 |
|||
for (let i = this.categoryIndex; i < this.goodsInfo.length; ++i) { |
|||
for (let j = 0; j < this.goodsInfo[i].goodsData.length; ++j) { |
|||
if (this.goodsInfo[i].goodsData[j].count) { |
|||
this.cartList.push(tools.getNewObj(this.goodsInfo[i].goodsData[j])); |
|||
} |
|||
} |
|||
} |
|||
}, |
|||
|
|||
// 购物车点击 |
|||
cartClick() { |
|||
if (this.isShowCartList) { |
|||
this.isShowCartList = false; |
|||
} |
|||
else { |
|||
this.addToCartList(); // 将主页数据加入到购物车列表 |
|||
|
|||
// 根据数量改变列表高度 |
|||
let num = this.cartList.length; |
|||
this.cartListScroll = false; |
|||
if (this.cartList.length > 5) { |
|||
num = 5; |
|||
this.cartListScroll = true; |
|||
} |
|||
|
|||
// 只有一条数据就不会显示border |
|||
if (this.cartList.length <= 1) { |
|||
this.cartListItemBorderBottom = "0rpx solid rgb(216,216,216)"; |
|||
} |
|||
else { |
|||
this.cartListItemBorderBottom = "1rpx solid rgb(216,216,216)"; |
|||
} |
|||
|
|||
this.cartListHeight = `${151.6 * num}rpx`; |
|||
this.cartListDialogHeight = `${(878 - 758) + 151.6 * num}rpx`; |
|||
this.isShowCartList = true; |
|||
|
|||
this.calcCartTotalPriceAndCount(); // 计算购物车总价跟总量 |
|||
} |
|||
}, |
|||
|
|||
// 适配主内容高度 |
|||
fixMainHeight() { |
|||
let _this = this; |
|||
uni.getSystemInfo({ |
|||
success: res => { |
|||
console.log(res); |
|||
let sumHeight = res.windowHeight; // 获取可用的总高度 |
|||
let query = uni.createSelectorQuery().select(".header"); |
|||
|
|||
query.boundingClientRect(data => { |
|||
sumHeight -= data.height; |
|||
query = uni.createSelectorQuery().select(".footer"); |
|||
|
|||
query.boundingClientRect(data => { |
|||
sumHeight -= data.height; |
|||
_this.mainHeight = `${tools.px2rpx(sumHeight)}rpx`; |
|||
}).exec(); |
|||
}).exec(); |
|||
} |
|||
}); |
|||
}, |
|||
|
|||
// 计算总价跟总量 |
|||
calcTotalPriceAndCount() { |
|||
let price = 0.0; |
|||
let count = 0; |
|||
|
|||
for (let i = this.categoryIndex; i < this.goodsInfo.length; ++i) { |
|||
for (let j = 0; j < this.goodsInfo[i].goodsData.length; ++j) { |
|||
price += (this.goodsInfo[i].goodsData[j].count * this.goodsInfo[i].goodsData[j].price); |
|||
count += this.goodsInfo[i].goodsData[j].count; |
|||
} |
|||
} |
|||
|
|||
this.totalPrice = price.toFixed(2); |
|||
this.totalCount = count; |
|||
this.cartTotalPrice = this.totalPrice; |
|||
this.cartTotalCount = this.totalCount; |
|||
}, |
|||
|
|||
// 主页数量选项触发 |
|||
mainCountClick(type, id, goodsId) { |
|||
// 找点击的对应分类 |
|||
let item = null; |
|||
for (let i = 0; i < this.goodsInfo.length; ++i) { |
|||
if (this.goodsInfo[i].id == id) { |
|||
item = this.goodsInfo[i]; |
|||
break; |
|||
} |
|||
} |
|||
|
|||
// 分类有了,继续找该分类下的商品id |
|||
let goodsItem = null; |
|||
if (item) { |
|||
for (let i = 0; i < item.goodsData.length; ++i) { |
|||
if (item.goodsData[i].id == goodsId) { |
|||
goodsItem = item.goodsData[i]; |
|||
break; |
|||
} |
|||
} |
|||
} |
|||
|
|||
if (goodsItem) { |
|||
switch (type) { |
|||
case "add": { |
|||
goodsItem.count += 1; |
|||
} break; |
|||
case "sub": { |
|||
if (goodsItem.count <= 0) { |
|||
return; |
|||
} |
|||
|
|||
goodsItem.count -= 1; |
|||
} break; |
|||
} |
|||
|
|||
this.calcTotalPriceAndCount(); // 计算总价跟总量 |
|||
this.addToCartList(); // 将主页数据加入到购物车列表 |
|||
} |
|||
}, |
|||
|
|||
// 主页分类选项触发 |
|||
mainCategoryClick(id) { |
|||
// 将所有按钮恢复默认状态,点击的按钮则是另外的状态 |
|||
let item = null; |
|||
for (let i = 0; i < this.goodsInfo.length; ++i) { |
|||
this.goodsInfo[i].style = this.categoryBtnStyle.default; |
|||
this.goodsInfo[i].isShow = false; |
|||
|
|||
if (this.goodsInfo[i].id == id) { |
|||
item = this.goodsInfo[i]; |
|||
} |
|||
} |
|||
|
|||
if (item) { |
|||
item.style = this.categoryBtnStyle.click; |
|||
item.isShow = true; |
|||
} |
|||
}, |
|||
|
|||
// 获取商品信息 |
|||
getGoodsInfo() { |
|||
let _this = this; |
|||
|
|||
util.showLoad(); |
|||
setTimeout(util.hideLoad, 1000); |
|||
|
|||
_this.goodsInfo = []; |
|||
let categoryName = ""; |
|||
for (let i = 0; i < 20; ++i) { |
|||
categoryName = i <= 0 ? "搜索" : "分类"; |
|||
|
|||
_this.goodsInfo.push({ |
|||
id: i + 1, |
|||
isSearch: true, |
|||
isShow: false, |
|||
categoryName: `${categoryName}${i + 1}`, |
|||
style: _this.categoryBtnStyle.default, |
|||
goodsData: [ |
|||
{ |
|||
id: 1 + Math.random(), |
|||
name: `柠檬味维他奶原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "250ml 300ml 350ml", |
|||
price: 3.5, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 2 + Math.random(), |
|||
name: `原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "150ml 200ml 100ml", |
|||
price: 300.2, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 3 + Math.random(), |
|||
name: `豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "50ml 100ml 150ml", |
|||
price: 18, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 4 + Math.random(), |
|||
name: `原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "150ml 200ml 100ml", |
|||
price: 300.2, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 5 + Math.random(), |
|||
name: `豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "50ml 100ml 150ml", |
|||
price: 18, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 6 + Math.random(), |
|||
name: `原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "150ml 200ml 100ml", |
|||
price: 300.2, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 7 + Math.random(), |
|||
name: `豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "50ml 100ml 150ml", |
|||
price: 18, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 8 + Math.random(), |
|||
name: `原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "150ml 200ml 100ml", |
|||
price: 300.2, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 9 + Math.random(), |
|||
name: `豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "50ml 100ml 150ml", |
|||
price: 18, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 10 + Math.random(), |
|||
name: `原味豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "150ml 200ml 100ml", |
|||
price: 300.2, |
|||
count: 0, |
|||
}, |
|||
{ |
|||
id: 11 + Math.random(), |
|||
name: `豆奶${Math.floor(Math.random() * 20)}`, |
|||
spec: "50ml 100ml 150ml", |
|||
price: 18, |
|||
count: 0, |
|||
} |
|||
] |
|||
}); |
|||
} |
|||
|
|||
_this.goodsInfo[0].isSearch = false; |
|||
_this.goodsInfo[0].goodsData = []; |
|||
_this.goodsInfo[1].style = _this.categoryBtnStyle.click; |
|||
_this.goodsInfo[1].isShow = true; |
|||
}, |
|||
|
|||
// 店铺列表 |
|||
getStoreList() { |
|||
let _this = this; |
|||
return retailServer.get({ |
|||
url: retailApi.stadiumList, |
|||
data: {}, |
|||
failMsg: '加载店铺失败!' |
|||
}).then(res => { |
|||
let _list = res.list || []; |
|||
_this.curStoreList = [..._this.curStoreList, ..._list]; |
|||
_this.curStore = _this.curStoreList[0] || {}; |
|||
}); |
|||
}, |
|||
|
|||
// 当前店铺变化 |
|||
curStoreChange(e) { |
|||
let _this = this; |
|||
let curStoreList = _this.curStoreList; |
|||
_this.curStore = curStoreList[e.detail.value] || {}; |
|||
_this.$nextTick(function() { |
|||
_this.getGoodsInfo(); // 获取商品信息 |
|||
}); |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss"> |
|||
@function toDouble($value) { |
|||
@return $value * 2; |
|||
} |
|||
|
|||
page { |
|||
// background-color: rgb(237,237,245); |
|||
background-color: rgb(255,255,255); |
|||
} |
|||
|
|||
.container { |
|||
display: flex; |
|||
flex-direction: column; |
|||
width: 100vw; |
|||
height: 100vh; |
|||
padding-bottom: 0rpx; |
|||
padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
|
|||
.header { |
|||
height: 230rpx; |
|||
// border: 1rpx solid red; |
|||
display: flex; |
|||
flex-direction: column; |
|||
background-color: rgb(237,237,245); |
|||
|
|||
.header-store-selecter { |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
padding-left: 38rpx; |
|||
|
|||
& { |
|||
position: relative; |
|||
height: 78rpx; |
|||
line-height: 78rpx; |
|||
} |
|||
|
|||
.header-store-selecter-name { |
|||
height: 78rpx; |
|||
line-height: 78rpx; |
|||
fotn-size: 16rpx; |
|||
margin-left: 12rpx; |
|||
margin-right: 14rpx; |
|||
color: rgb(51,51,51); |
|||
} |
|||
.header-store-selecter-left-img { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
} |
|||
.header-store-selecter-right-img { |
|||
width: 18rpx; |
|||
height: 18rpx; |
|||
} |
|||
} |
|||
|
|||
.header-search-row { |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: center; |
|||
height: 152rpx; |
|||
background-color: rgb(255,255,255); |
|||
border-top-left-radius: 40rpx; |
|||
border-top-right-radius: 40rpx; |
|||
|
|||
>view { |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: space-between; |
|||
flex-grow: 1; |
|||
height: 92rpx; |
|||
border-radius: 10rpx; |
|||
background-color: rgb(242,242,247); |
|||
margin-left: 24rpx; |
|||
padding-left: 20rpx; |
|||
padding-right: 20rpx; |
|||
|
|||
>input { |
|||
flex-grow: 1; |
|||
height: 100%; |
|||
font-size: 32rpx; |
|||
} |
|||
>image{ |
|||
flex-shrink: 0; |
|||
margin-right: 20rpx; |
|||
width: 40rpx; |
|||
height: 40rpx; |
|||
} |
|||
} |
|||
>button { |
|||
flex-shrink: 0; |
|||
margin-left: 20rpx; |
|||
margin-right: 20rpx; |
|||
width: 100rpx; |
|||
height: 62rpx; |
|||
line-height: 62rpx; |
|||
font-size: 32rpx; |
|||
color: rgb(255,255,255); |
|||
background-color: rgb(6,147,137); |
|||
border-radius: 10rpx; |
|||
white-space: nowrap; |
|||
padding: 0 0; |
|||
} |
|||
} |
|||
} |
|||
|
|||
.main { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
// border: 1rpx solid green; |
|||
position: relative; |
|||
background-color: rgb(237,237,245); |
|||
padding-top: 24rpx; |
|||
// padding-bottom: 18rpx; |
|||
padding-bottom: calc( 18rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
padding-bottom: calc( 18rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
|
|||
.main-left { |
|||
width: 180rpx; |
|||
margin-right: 12rpx; |
|||
background-color: rgb(255,255,255); |
|||
border-top-right-radius: 30rpx; |
|||
|
|||
.main-left-list { |
|||
display: flex; |
|||
flex-direction: column; |
|||
|
|||
> button { |
|||
width: 100%; |
|||
height: 92rpx; |
|||
line-height: 92rpx; |
|||
border-radius: 0rpx; |
|||
border-top-right-radius: 30rpx; |
|||
border: 0rpx; |
|||
color: rgb(154,154,157); |
|||
background-color: rgba(0,0,0,0); |
|||
font-size: 25rpx; |
|||
} |
|||
} |
|||
} |
|||
.main-right { |
|||
width: 558rpx; |
|||
background-color: rgb(255,255,255); |
|||
border-top-left-radius: 30rpx; |
|||
display: flex; |
|||
flex-direction: column; |
|||
padding-left: 36rpx; |
|||
// padding-right: 48rpx; |
|||
|
|||
.main-right-list { |
|||
border-bottom: 1rpx solid rgb(237,237,245); |
|||
display: flex; |
|||
flex-direction: column; |
|||
padding-top: 24rpx; |
|||
padding-bottom: 24rpx; |
|||
|
|||
>view { |
|||
&:first-child { |
|||
font-size: 28rpx; |
|||
} |
|||
&:nth-child(2) { |
|||
margin-top: 8rpx; |
|||
margin-bottom: 14rpx; |
|||
font-size: 24rpx; |
|||
color: rgb(154,154,157); |
|||
} |
|||
} |
|||
|
|||
.main-right-list-price-count { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
// border: 1rpx solid green; |
|||
|
|||
.main-right-list-price-row { |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
color: rgb(255,135,61); |
|||
|
|||
>view { |
|||
&:first-child { |
|||
font-size: 32rpx; |
|||
line-height: 32rpx; |
|||
|
|||
>text { |
|||
font-size: 24rpx; |
|||
line-height: 24rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
.main-right-list-count-row { |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
padding-right: 48rpx; |
|||
|
|||
>image { |
|||
&:first-child { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
} |
|||
&:nth-child(3) { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
} |
|||
} |
|||
>view { |
|||
margin-left: 12rpx; |
|||
margin-right: 12rpx; |
|||
color: rgb(51,51,51); |
|||
font-size: 28rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
.footer { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
|
|||
position: fixed; |
|||
// bottom: 0rpx; |
|||
bottom: calc( 0rpx + constant(safe-area-inset-bottom)); |
|||
bottom: calc( 0rpx + env(safe-area-inset-bottom)); |
|||
// padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
// padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
width: 100%; |
|||
height: 108rpx; |
|||
// border: 1rpx solid blue; |
|||
background-color: rgb(255,255,255); |
|||
|
|||
>view { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
flex-grow: 1; |
|||
// border: 1px solid red; |
|||
// margin-top: 24rpx; |
|||
|
|||
.footer-price { |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
margin-left: 36rpx; |
|||
|
|||
>view { |
|||
&:first-child { |
|||
position: relative; |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
// border: 1rpx solid green; |
|||
|
|||
>image { |
|||
width: 84rpx; |
|||
height: 84rpx; |
|||
} |
|||
|
|||
>view { |
|||
position: absolute; |
|||
top: 0rpx; |
|||
right: 0rpx; |
|||
color: rgb(255,255,255); |
|||
background-color: rgb(230,0,18); |
|||
font-size: 20rpx; |
|||
border-radius: 100%; |
|||
width: 40rpx; |
|||
height: 40rpx; |
|||
line-height: 40rpx; |
|||
text-align: center; |
|||
} |
|||
} |
|||
&:nth-child(2) { |
|||
margin-left: 10rpx; |
|||
font-size: 24rpx; |
|||
line-height: 24rpx; |
|||
} |
|||
&:nth-child(3) { |
|||
font-size: 32rpx; |
|||
line-height: 32rpx; |
|||
color: rgb(255,135,61); |
|||
|
|||
>text { |
|||
font-size: 24rpx; |
|||
line-height: 24rpx; |
|||
} |
|||
} |
|||
&:nth-child(4) { |
|||
font-size: 32rpx; |
|||
line-height: 32rpx; |
|||
color: rgb(255,135,61); |
|||
|
|||
>text { |
|||
font-size: 24rpx; |
|||
line-height: 24rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
.footer-confirm { |
|||
display: flex; |
|||
flex-direction: row; |
|||
align-items: center; |
|||
margin-right: 24rpx; |
|||
|
|||
>button { |
|||
flex-shrink: 0; |
|||
width: 240rpx; |
|||
height: 88rpx; |
|||
line-height: 88rpx; |
|||
color: rgb(255,255,255); |
|||
font-size: 32rpx; |
|||
border: 0rpx; |
|||
border-radius: 44rpx; |
|||
background-color: rgb(0,152,116); |
|||
white-space: nowrap; |
|||
padding: 0 0; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</style> |
@ -0,0 +1,239 @@ |
|||
<template> |
|||
<view class="search-container"> |
|||
<view class="search-row"> |
|||
<view> |
|||
<image mode="aspectFit" src="/static/images/icon/retail/search.png"></image> |
|||
<input |
|||
type="text" |
|||
placeholder="请输入商品名称" |
|||
v-model="searchText" |
|||
focus="true" |
|||
/> |
|||
<image @click="searchClear" mode="aspectFit" src="/static/images/icon/retail/searchClear.png"></image> |
|||
</view> |
|||
<button @click="searchTrigger(searchText)">搜索</button> |
|||
</view> |
|||
|
|||
<view class="history-search"> |
|||
<view> |
|||
<view>历史搜索</view> |
|||
<image @click="searchHistoryDelete" mode="aspectFit" src="/static/images/icon/retail/historySearchDelete.png"></image> |
|||
</view> |
|||
<view> |
|||
<view v-for="item in historyList" :key="item.id" @click="searchTrigger(item.text)">{{ item.text }}</view> |
|||
</view> |
|||
</view> |
|||
</view> |
|||
</template> |
|||
|
|||
<script> |
|||
export default { |
|||
data() { |
|||
return { |
|||
searchText: "", // 搜索文本 |
|||
historyList: [], // 历史列表 |
|||
} |
|||
}, |
|||
onLoad() { |
|||
this.getSearchHistory(); // 获取搜索历史 |
|||
}, |
|||
methods: { |
|||
// 删除历史搜索 |
|||
searchHistoryDelete() { |
|||
if (this.historyList.length <= 0) { |
|||
uni.showToast({ |
|||
title: "暂无历史数据!", |
|||
icon: "none" |
|||
}) |
|||
|
|||
return; |
|||
} |
|||
|
|||
let _this = this; |
|||
uni.showModal({ |
|||
content: '确人删除全部历史记录?', |
|||
success: function (res) { |
|||
if (res.confirm) { |
|||
console.log('用户点击确定'); |
|||
|
|||
_this.historyList = []; |
|||
} |
|||
else if (res.cancel) { |
|||
console.log('用户点击取消'); |
|||
} |
|||
} |
|||
}); |
|||
}, |
|||
|
|||
// 清除搜索文本 |
|||
searchClear() { |
|||
this.searchText = ""; |
|||
}, |
|||
|
|||
// 触发搜索 |
|||
searchTrigger(text) { |
|||
if (!text) { |
|||
uni.showToast({ |
|||
title: "请输入商品名称!", |
|||
icon: "none" |
|||
}); |
|||
|
|||
return; |
|||
} |
|||
|
|||
// 存本地数据,返回上一页后用来搜索数据 |
|||
let _this = this; |
|||
uni.setStorage({ |
|||
key: 'searchData', |
|||
data: { |
|||
list: [], // 返回的是一个搜索列表 |
|||
}, |
|||
success: function() { |
|||
console.log('success'); |
|||
|
|||
// 有数据的话就返回到上一页面,加载对应数据 |
|||
uni.navigateBack({ |
|||
delta: 1 |
|||
}); |
|||
}, |
|||
fail: function(err) { |
|||
console.log(err); |
|||
}, |
|||
}); |
|||
}, |
|||
|
|||
// 获取搜索历史 |
|||
getSearchHistory() { |
|||
for (let i = 0; i < 20; ++i) { |
|||
this.historyList.push({ |
|||
id: i + 1, |
|||
text: "历史" + i |
|||
}); |
|||
} |
|||
}, |
|||
} |
|||
} |
|||
</script> |
|||
|
|||
<style lang="scss"> |
|||
.search-container { |
|||
display: flex; |
|||
flex-direction: column; |
|||
width: 100vw; |
|||
height: 100vh; |
|||
padding-bottom: 0rpx; |
|||
padding-bottom: calc( 0rpx + constant(safe-area-inset-bottom)); /* 兼容 iOS < 11.2 */ |
|||
padding-bottom: calc( 0rpx + env(safe-area-inset-bottom)); /* 兼容 iOS >= 11.2 */ |
|||
|
|||
.search-row { |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: center; |
|||
height: 152rpx; |
|||
background-color: rgb(255,255,255); |
|||
|
|||
>view { |
|||
display: flex; |
|||
align-items: center; |
|||
justify-content: space-between; |
|||
flex-grow: 1; |
|||
height: 92rpx; |
|||
border-radius: 10rpx; |
|||
background-color: rgb(242,242,247); |
|||
margin-left: 24rpx; |
|||
padding-left: 20rpx; |
|||
padding-right: 20rpx; |
|||
|
|||
>input { |
|||
flex-grow: 1; |
|||
height: 100%; |
|||
font-size: 32rpx; |
|||
} |
|||
>image{ |
|||
flex-shrink: 0; |
|||
|
|||
&:first-child { |
|||
width: 40rpx; |
|||
height: 40rpx; |
|||
margin-right: 20rpx; |
|||
} |
|||
&:nth-child(3) { |
|||
width: 32rpx; |
|||
height: 32rpx; |
|||
margin-left: 20rpx; |
|||
} |
|||
} |
|||
} |
|||
>button { |
|||
flex-shrink: 0; |
|||
margin-left: 20rpx; |
|||
margin-right: 20rpx; |
|||
width: 100rpx; |
|||
height: 62rpx; |
|||
line-height: 62rpx; |
|||
font-size: 32rpx; |
|||
color: rgb(255,255,255); |
|||
background-color: rgb(6,147,137); |
|||
border-radius: 10rpx; |
|||
white-space: nowrap; |
|||
padding: 0 0; |
|||
} |
|||
} |
|||
|
|||
.history-search { |
|||
display: flex; |
|||
flex-direction: column; |
|||
justify-content: center; |
|||
align-items: center; |
|||
background-color: white; |
|||
padding-top: 26rpx; |
|||
padding-left: 26rpx; |
|||
|
|||
>view { |
|||
width: 100%; |
|||
|
|||
&:first-child { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: space-between; |
|||
align-items: center; |
|||
margin-bottom: 26rpx; |
|||
|
|||
>view { |
|||
font-size: 32rpx; |
|||
font-weight: bold; |
|||
} |
|||
|
|||
>image { |
|||
width: 36rpx; |
|||
height: 36rpx; |
|||
margin-right: 26rpx; |
|||
} |
|||
} |
|||
&:nth-child(2) { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: flex-start; |
|||
align-items: center; |
|||
flex-wrap: wrap; |
|||
|
|||
>view { |
|||
display: flex; |
|||
flex-direction: row; |
|||
justify-content: center; |
|||
align-items: center; |
|||
height: 66rpx; |
|||
font-size: 28rpx; |
|||
color: rgb(193,193,199); |
|||
background-color: rgb(242,242,247); |
|||
border-radius: 32rpx; |
|||
padding-left: 30rpx; |
|||
padding-right: 30rpx; |
|||
margin-right: 26rpx; |
|||
margin-bottom: 26rpx; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
|||
</style> |
After Width: 36 | Height: 36 | Size: 314 B |
After Width: 32 | Height: 32 | Size: 241 B |
After Width: 84 | Height: 84 | Size: 2.0 KiB |
After Width: 18 | Height: 18 | Size: 185 B |
After Width: 36 | Height: 36 | Size: 365 B |
After Width: 36 | Height: 36 | Size: 364 B |
After Width: 40 | Height: 40 | Size: 372 B |
After Width: 32 | Height: 32 | Size: 356 B |