123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- <template><page-meta :root-font-size="fontSize+'px'"></page-meta>
- <member-base :show="false"><view class="div ui-cart-wrapper">
- <!-- header -->
- <v-cart-header
- v-if="isLoaded"
- ref="header"
- :issShowTabbar="type"
- :isEmpty="isEmpty"
- ></v-cart-header>
- <view class="div">
- <!-- list -->
- <v-cart-list
- v-if="!(isLoaded && isEmpty)"
- ref="list"
- :issShowTabbar="type"
- :isCheckedAll="isFinish"
- ></v-cart-list>
- <!-- footer -->
- <v-cart-footer
- v-if="isLoaded"
- :issShowTabbar="type"
- :isCheckedAll="isFinish"
- :isStatus="isStatus"
- :isDisabled="isDisabled"
- :totalPrice="totalPrice"
- :totalAmount="totalAmount"
- :cartId="cartId"
- ></v-cart-footer>
- </view>
- <view v-if="isLoaded && isEmpty" class="div empty-cart">
- <view class="p" v-if="isOnline">您的购物车还是空的</view>
- <view class="p" v-if="!isOnline">登录后即可查看购物车中的商品</view>
- <text class="span" @click="goHome()" v-if="isOnline">随便逛逛</text>
- <text class="span" @click="goSingin()" v-if="!isOnline">去登录</text>
- </view>
- </view></member-base>
- </template>
- <script>
- import {getFontSize} from '@/util/common'
- import MemberBase from '../MemberBase'
- import cartHeader from './child/CartHeader'
- import cartList from './child/CartList'
- import cartFooter from './child/CartFooter'
- // import cartPromos from './child/Promos'
- import { mapState, mapMutations } from 'vuex'
- export default {
- data () {
- return {
- totalPrice: 0,
- totalAmount: 0,
- cartId: '',
- type: 0, // 判断是否显示购物车底部的tabbar 1 : 显示 0 不显示
- isFinish: false, // 编辑 false - 编辑~完成 true - 完成~编辑 false
- isStatus: true, // 是否默认选中底部的全选按钮
- isDisabled: false,
- isshowpromos: true, // 是否显示促销信息
- target: '', // 设置高度的element元素
- isEmpty: false,
- isLoaded: false
- }
- },
- computed: {
- fontSize(){
- return getFontSize()
- },
- ...mapState({
- isOnline: state => state.member.isOnline
- })
- },
- created () {
- uni.showLoading({ title: '加载中' })
- this.isSignin()
- // 监听是否改变购物车列表选中的状态
- uni.$on('change-list-selected', data => {
- // data.isFinish ? 表示是完成状态,1,列表默认全不选中 2,促销信息不显示, 3,改变列表的高度 : 编辑状态 1,列表默认全选中 2,促销信息显示, 3,改变列表的高度
- if (!this.isEmpty) {
- this.isFinish = data.isFinish
- if (data.isFinish) {
- this.isshowpromos = false
- this.$refs.list.addChecked(false, this.isFinish)
- } else {
- this.isshowpromos = true
- this.$refs.list.addChecked(true, this.isFinish)
- }
- this.$refs.list.renderCart()
- }
- })
- // 监听是否更新购物车列表
- uni.$on('update-cart-list', data => {
- if (data.isdelete) {
- this.$refs.list.deleteSelected()
- }
- })
- // 监听是否获取购物车促销信息
- uni.$on('get-promos-data', data => {
- // this.$refs.promos.getCartPromos(data);
- })
- // 监听选中的购物车
- uni.$on('calcu-cart-data', data => {
- this.totalPrice = data.totalPrice
- this.totalAmount = data.totalAmount
- this.cartId = data.cartId
- })
- // 监听购物车底部全选按钮是否选中
- uni.$on('cart-bottom-status', data => {
- // data.isCheckAll ? true 1,显示促销信息, 2,重新计算列表的高度: false 1.隐藏促销信息, 2,重新计算列表的高度
- if (data.isCheckAll && !this.isFinish) {
- this.isshowpromos = true
- } else {
- this.isshowpromos = false
- }
- this.$refs.list.addChecked(data.isCheckAll, this.isFinish)
- this.$refs.list.renderCart()
- })
- // 监听列表一个个选中底部全选按钮默认选中
- uni.$on('change-footer-status', status => {
- this.isStatus = status
- })
- uni.$on('change-footer-disabled', status => {
- this.isDisabled = status
- })
- uni.$on('list-is-empty', data => {
- uni.hideLoading()
- this.isLoaded = true
- if (data.length > 0) {
- this.isEmpty = false
- } else {
- this.isEmpty = true
- }
- })
- },
- mounted () {
- },
- beforeDestroy: function () {
- uni.$off('change-list-selected')
- uni.$off('update-cart-list')
- uni.$off('get-promos-data')
- uni.$off('calcu-cart-data')
- uni.$off('cart-bottom-status')
- uni.$off('change-footer-status')
- uni.$off('change-footer-disabled')
- uni.$off('list-is-empty')
- },
- components:{
- MemberBase,
- 'v-cart-header': cartHeader,
- 'v-cart-list': cartList,
- 'v-cart-footer': cartFooter
- // 'v-cart-promos': cartPromos,
- },
- methods: {
- /*
- * isSignin: 是否登录
- */
- isSignin () {
- if (this.isOnline) {
- this.isEmpty = false
- } else {
- this.isEmpty = true
- }
- },
- /*
- * goHome: 跳转到首页
- */
- goHome () {
- uni.navigateTo({url:'/pages/home/index/Index'})
- },
- goSingin () {
- uni.navigateTo({url:'/pages/home/memberlogin/Login'})
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- .ui-cart-wrapper {
- }
- .empty-cart {
- padding-top: 11.2rem;
- text-align: center;
- .img {
- width: 3.75rem;
- height: 3.75rem;
- }
- .p {
- font-size:$h2;
- color: #333;
- line-height: 1.1rem;
- padding: 1.3rem 0 2rem 0;
- }
- .span {
- font-size:$h2;
- color: rgba(255, 255, 255, 1);
- height: 2.2rem;
- background: $primaryColor;
- border-radius: 0.15rem;
- line-height: 2.2rem;
- display: inline-block;
- width: 10rem;
- }
- }
- </style>
|