commit
						e635b91bb5
					
				|  | @ -90,6 +90,7 @@ | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "dayjs": "^1.11.7", |     "dayjs": "^1.11.7", | ||||||
|     "lodash": "^4.17.21", |     "lodash": "^4.17.21", | ||||||
|  |     "lodash-es": "^4.17.21", | ||||||
|     "luch-request": "^3.0.8", |     "luch-request": "^3.0.8", | ||||||
|     "pinia": "^2.0.33", |     "pinia": "^2.0.33", | ||||||
|     "pinia-plugin-persist-uni": "^1.2.0", |     "pinia-plugin-persist-uni": "^1.2.0", | ||||||
|  |  | ||||||
|  | @ -1,6 +1,11 @@ | ||||||
| <!-- 拼团订单的详情 --> | <!-- 拼团订单的详情 --> | ||||||
| <template> | <template> | ||||||
|   <s-layout title="拼团详情" class="detail-wrap" :navbar="state.data && !state.loading ? 'inner': 'normal'" :onShareAppMessage="shareInfo"> |   <s-layout | ||||||
|  |     title="拼团详情" | ||||||
|  |     class="detail-wrap" | ||||||
|  |     :navbar="state.data && !state.loading ? 'inner' : 'normal'" | ||||||
|  |     :onShareAppMessage="shareInfo" | ||||||
|  |   > | ||||||
|     <view v-if="state.loading"></view> |     <view v-if="state.loading"></view> | ||||||
|     <view v-if="state.data && !state.loading"> |     <view v-if="state.data && !state.loading"> | ||||||
|       <!-- 团长信息 + 活动信息 --> |       <!-- 团长信息 + 活动信息 --> | ||||||
|  | @ -22,7 +27,7 @@ | ||||||
|           priceColor="#E1212B" |           priceColor="#E1212B" | ||||||
|           @tap=" |           @tap=" | ||||||
|             sheep.$router.go('/pages/goods/groupon', { |             sheep.$router.go('/pages/goods/groupon', { | ||||||
|               id: state.data.headRecord.activityId |               id: state.data.headRecord.activityId, | ||||||
|             }) |             }) | ||||||
|           " |           " | ||||||
|           :style="[{ top: Number(statusBarHeight + 108) + 'rpx' }]" |           :style="[{ top: Number(statusBarHeight + 108) + 'rpx' }]" | ||||||
|  | @ -71,7 +76,9 @@ | ||||||
|           </view> |           </view> | ||||||
|           <view class="countdown-title ss-flex" v-else> |           <view class="countdown-title ss-flex" v-else> | ||||||
|             还差 |             还差 | ||||||
|             <view class="num">{{ state.data.headRecord.userSize - state.data.headRecord.userCount }}人</view> |             <view class="num" | ||||||
|  |               >{{ state.data.headRecord.userSize - state.data.headRecord.userCount }}人</view | ||||||
|  |             > | ||||||
|             拼团成功 |             拼团成功 | ||||||
|             <view class="ss-flex countdown-time"> |             <view class="ss-flex countdown-time"> | ||||||
|               <view class="countdown-h ss-flex ss-row-center">{{ endTime.h }}</view> |               <view class="countdown-h ss-flex ss-row-center">{{ endTime.h }}</view> | ||||||
|  | @ -109,7 +116,11 @@ | ||||||
|             </view> |             </view> | ||||||
|           </view> |           </view> | ||||||
|           <!-- 还有几个坑位 --> |           <!-- 还有几个坑位 --> | ||||||
|           <view class="default-avatar ss-m-r-24 ss-m-b-20" v-for="item in state.remainNumber" :key="item"> |           <view | ||||||
|  |             class="default-avatar ss-m-r-24 ss-m-b-20" | ||||||
|  |             v-for="item in state.remainNumber" | ||||||
|  |             :key="item" | ||||||
|  |           > | ||||||
|             <image |             <image | ||||||
|               :src="sheep.$url.static('/static/img/shop/avatar/unknown.png')" |               :src="sheep.$url.static('/static/img/shop/avatar/unknown.png')" | ||||||
|               class="avatar-img" |               class="avatar-img" | ||||||
|  | @ -154,11 +165,7 @@ | ||||||
|         </view> |         </view> | ||||||
|         <view v-else class="ss-flex ss-row-center"> |         <view v-else class="ss-flex ss-row-center"> | ||||||
|           <view v-if="state.data.orderId"> |           <view v-if="state.data.orderId"> | ||||||
|             <button |             <button class="ss-reset-button join-btn" :disabled="endTime.ms <= 0" @tap="onShare"> | ||||||
|               class="ss-reset-button join-btn" |  | ||||||
|               :disabled="endTime.ms <= 0" |  | ||||||
|               @tap="onShare" |  | ||||||
|             > |  | ||||||
|               邀请好友来拼团 |               邀请好友来拼团 | ||||||
|             </button> |             </button> | ||||||
|           </view> |           </view> | ||||||
|  | @ -198,8 +205,8 @@ | ||||||
|   import { onLoad } from '@dcloudio/uni-app'; |   import { onLoad } from '@dcloudio/uni-app'; | ||||||
|   import { useDurationTime } from '@/sheep/hooks/useGoods'; |   import { useDurationTime } from '@/sheep/hooks/useGoods'; | ||||||
|   import { showShareModal } from '@/sheep/hooks/useModal'; |   import { showShareModal } from '@/sheep/hooks/useModal'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import CombinationApi from "@/sheep/api/promotion/combination"; |   import CombinationApi from '@/sheep/api/promotion/combination'; | ||||||
| 
 | 
 | ||||||
|   const headerBg = sheep.$url.css('/static/img/shop/user/withdraw_bg.png'); |   const headerBg = sheep.$url.css('/static/img/shop/user/withdraw_bg.png'); | ||||||
|   const statusBarHeight = sheep.$platform.device.statusBarHeight * 2; |   const statusBarHeight = sheep.$platform.device.statusBarHeight * 2; | ||||||
|  | @ -295,7 +302,9 @@ | ||||||
|       state.remainNumber = remainNumber > 0 ? remainNumber : 0; |       state.remainNumber = remainNumber > 0 ? remainNumber : 0; | ||||||
| 
 | 
 | ||||||
|       // 获取活动信息 |       // 获取活动信息 | ||||||
|       const { data: activity } = await CombinationApi.getCombinationActivity(data.headRecord.activityId); |       const { data: activity } = await CombinationApi.getCombinationActivity( | ||||||
|  |         data.headRecord.activityId, | ||||||
|  |       ); | ||||||
|       state.activity = activity; |       state.activity = activity; | ||||||
|     } else { |     } else { | ||||||
|       state.data = null; |       state.data = null; | ||||||
|  | @ -316,8 +325,7 @@ | ||||||
|   .recharge-box { |   .recharge-box { | ||||||
|     position: relative; |     position: relative; | ||||||
|     margin-bottom: 120rpx; |     margin-bottom: 120rpx; | ||||||
|     background: v-bind(headerBg) center/750rpx 100% |     background: v-bind(headerBg) center/750rpx 100% no-repeat, | ||||||
|         no-repeat, |  | ||||||
|       linear-gradient(115deg, #f44739 0%, #ff6600 100%); |       linear-gradient(115deg, #f44739 0%, #ff6600 100%); | ||||||
|     border-radius: 0 0 5% 5%; |     border-radius: 0 0 5% 5%; | ||||||
|     height: 100rpx; |     height: 100rpx; | ||||||
|  |  | ||||||
|  | @ -24,9 +24,9 @@ | ||||||
|         </view> |         </view> | ||||||
|         <view class="border-bottom"> |         <view class="border-bottom"> | ||||||
|           <s-goods-item |           <s-goods-item | ||||||
|               :img="record.picUrl" |             :img="record.picUrl" | ||||||
|               :title="record.spuName" |             :title="record.spuName" | ||||||
|               :price="record.combinationPrice" |             :price="record.combinationPrice" | ||||||
|           > |           > | ||||||
|             <template #groupon> |             <template #groupon> | ||||||
|               <view class="ss-flex"> |               <view class="ss-flex"> | ||||||
|  | @ -67,8 +67,8 @@ | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import {formatOrderColor} from "@/sheep/hooks/useGoods"; |   import { formatOrderColor } from '@/sheep/hooks/useGoods'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|   import CombinationApi from '@/sheep/api/promotion/combination'; |   import CombinationApi from '@/sheep/api/promotion/combination'; | ||||||
| 
 | 
 | ||||||
|  | @ -121,7 +121,7 @@ | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list) |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | @ -63,7 +63,7 @@ | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import RewardActivityApi from '@/sheep/api/promotion/rewardActivity'; |   import RewardActivityApi from '@/sheep/api/promotion/rewardActivity'; | ||||||
|   import { formatRewardActivityRule } from '@/sheep/hooks/useGoods'; |   import { formatRewardActivityRule } from '@/sheep/hooks/useGoods'; | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
|  | @ -118,7 +118,7 @@ | ||||||
|     const { code, data } = await SpuApi.getSpuPage({ |     const { code, data } = await SpuApi.getSpuPage({ | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
|       ...params |       ...params, | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  |  | ||||||
|  | @ -32,7 +32,7 @@ | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
|   import { reactive, watch } from 'vue'; |   import { reactive, watch } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import GoodsItem from './goods.vue'; |   import GoodsItem from './goods.vue'; | ||||||
|   import OrderItem from './order.vue'; |   import OrderItem from './order.vue'; | ||||||
|   import OrderApi from '@/sheep/api/trade/order'; |   import OrderApi from '@/sheep/api/trade/order'; | ||||||
|  |  | ||||||
|  | @ -1,74 +1,90 @@ | ||||||
| <!-- 分销首页:明细列表  --> | <!-- 分销首页:明细列表  --> | ||||||
| <template> | <template> | ||||||
| 	<view class="distribution-log-wrap"> |   <view class="distribution-log-wrap"> | ||||||
| 		<view class="header-box"> |     <view class="header-box"> | ||||||
| 			<image class="header-bg" :src="sheep.$url.static('/static/img/shop/commission/title2.png')" /> |       <image class="header-bg" :src="sheep.$url.static('/static/img/shop/commission/title2.png')" /> | ||||||
| 			<view class="ss-flex header-title"> |       <view class="ss-flex header-title"> | ||||||
| 				<view class="title">实时动态</view> |         <view class="title">实时动态</view> | ||||||
| 				<text class="cicon-forward" /> |         <text class="cicon-forward" /> | ||||||
| 			</view> |       </view> | ||||||
| 		</view> |     </view> | ||||||
| 		<scroll-view scroll-y="true" @scrolltolower="loadmore" class="scroll-box log-scroll" |     <scroll-view | ||||||
| 			scroll-with-animation="true"> |       scroll-y="true" | ||||||
| 			<view v-if="state.pagination.list"> |       @scrolltolower="loadmore" | ||||||
| 				<view class="log-item-box ss-flex ss-row-between" v-for="item in state.pagination.list" :key="item.id"> |       class="scroll-box log-scroll" | ||||||
| 					<view class="log-item-wrap"> |       scroll-with-animation="true" | ||||||
| 						<view class="log-item ss-flex ss-ellipsis-1 ss-col-center"> |     > | ||||||
| 							<view class="ss-flex ss-col-center"> |       <view v-if="state.pagination.list"> | ||||||
| 								<image class="log-img" :src="sheep.$url.static('/static/img/shop/avatar/notice.png')" mode="aspectFill" /> |         <view | ||||||
| 							</view> |           class="log-item-box ss-flex ss-row-between" | ||||||
| 							<view class="log-text ss-ellipsis-1"> |           v-for="item in state.pagination.list" | ||||||
|  |           :key="item.id" | ||||||
|  |         > | ||||||
|  |           <view class="log-item-wrap"> | ||||||
|  |             <view class="log-item ss-flex ss-ellipsis-1 ss-col-center"> | ||||||
|  |               <view class="ss-flex ss-col-center"> | ||||||
|  |                 <image | ||||||
|  |                   class="log-img" | ||||||
|  |                   :src="sheep.$url.static('/static/img/shop/avatar/notice.png')" | ||||||
|  |                   mode="aspectFill" | ||||||
|  |                 /> | ||||||
|  |               </view> | ||||||
|  |               <view class="log-text ss-ellipsis-1"> | ||||||
|                 {{ item.title }} {{ fen2yuan(item.price) }} 元 |                 {{ item.title }} {{ fen2yuan(item.price) }} 元 | ||||||
|               </view> |               </view> | ||||||
| 						</view> |             </view> | ||||||
| 					</view> |           </view> | ||||||
| 					<text class="log-time">{{ dayjs(item.createTime).fromNow() }}</text> |           <text class="log-time">{{ dayjs(item.createTime).fromNow() }}</text> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 
 | 
 | ||||||
| 			<!-- 加载更多 --> |       <!-- 加载更多 --> | ||||||
| 			<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" color="#333333" |       <uni-load-more | ||||||
| 				@tap="loadmore" /> |         v-if="state.pagination.total > 0" | ||||||
| 		</scroll-view> |         :status="state.loadStatus" | ||||||
| 	</view> |         color="#333333" | ||||||
|  |         @tap="loadmore" | ||||||
|  |       /> | ||||||
|  |     </scroll-view> | ||||||
|  |   </view> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
| 	import dayjs from 'dayjs'; |   import dayjs from 'dayjs'; | ||||||
|   import BrokerageApi from '@/sheep/api/trade/brokerage'; |   import BrokerageApi from '@/sheep/api/trade/brokerage'; | ||||||
|   import { fen2yuan } from '../../../sheep/hooks/useGoods'; |   import { fen2yuan } from '../../../sheep/hooks/useGoods'; | ||||||
| 
 | 
 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		loadStatus: '', |     loadStatus: '', | ||||||
| 		pagination: { |     pagination: { | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 1, |       pageSize: 1, | ||||||
| 		}, |     }, | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	async function getLog() { |   async function getLog() { | ||||||
|     state.loadStatus = 'loading'; |     state.loadStatus = 'loading'; | ||||||
|     const { code, data } = await BrokerageApi.getBrokerageRecordPage({ |     const { code, data } = await BrokerageApi.getBrokerageRecordPage({ | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize |       pageSize: state.pagination.pageSize, | ||||||
| 		}); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list); |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	getLog(); |   getLog(); | ||||||
| 
 | 
 | ||||||
| 	// 加载更多 |   // 加载更多 | ||||||
| 	function loadmore() { |   function loadmore() { | ||||||
|     if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  | @ -78,88 +94,88 @@ | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.distribution-log-wrap { |   .distribution-log-wrap { | ||||||
| 		width: 690rpx; |     width: 690rpx; | ||||||
| 		margin: 0 auto; |     margin: 0 auto; | ||||||
| 		margin-bottom: 20rpx; |     margin-bottom: 20rpx; | ||||||
| 		border-radius: 12rpx; |     border-radius: 12rpx; | ||||||
| 		z-index: 3; |     z-index: 3; | ||||||
| 		position: relative; |     position: relative; | ||||||
| 
 | 
 | ||||||
| 		.header-box { |     .header-box { | ||||||
| 			width: 690rpx; |       width: 690rpx; | ||||||
| 			height: 76rpx; |       height: 76rpx; | ||||||
| 			position: relative; |       position: relative; | ||||||
| 
 | 
 | ||||||
| 			.header-bg { |       .header-bg { | ||||||
| 				width: 690rpx; |         width: 690rpx; | ||||||
| 				height: 76rpx; |         height: 76rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.header-title { |       .header-title { | ||||||
| 				position: absolute; |         position: absolute; | ||||||
| 				left: 20rpx; |         left: 20rpx; | ||||||
| 				top: 24rpx; |         top: 24rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.title { |       .title { | ||||||
| 				font-size: 28rpx; |         font-size: 28rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				color: #ffffff; |         color: #ffffff; | ||||||
| 				line-height: 30rpx; |         line-height: 30rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.cicon-forward { |       .cicon-forward { | ||||||
| 				font-size: 30rpx; |         font-size: 30rpx; | ||||||
| 				font-weight: 400; |         font-weight: 400; | ||||||
| 				color: #ffffff; |         color: #ffffff; | ||||||
| 				line-height: 30rpx; |         line-height: 30rpx; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.log-scroll { |     .log-scroll { | ||||||
| 			height: 600rpx; |       height: 600rpx; | ||||||
| 			background: #fdfae9; |       background: #fdfae9; | ||||||
| 			padding: 10rpx 20rpx 0; |       padding: 10rpx 20rpx 0; | ||||||
| 			box-sizing: border-box; |       box-sizing: border-box; | ||||||
| 			border-radius: 0 0 12rpx 12rpx; |       border-radius: 0 0 12rpx 12rpx; | ||||||
| 
 | 
 | ||||||
| 			.log-item-box { |       .log-item-box { | ||||||
| 				margin-bottom: 20rpx; |         margin-bottom: 20rpx; | ||||||
| 
 | 
 | ||||||
| 				.log-time { |         .log-time { | ||||||
| 					// margin-left: 30rpx; |           // margin-left: 30rpx; | ||||||
| 					text-align: right; |           text-align: right; | ||||||
| 					font-size: 24rpx; |           font-size: 24rpx; | ||||||
| 					font-family: OPPOSANS; |           font-family: OPPOSANS; | ||||||
| 					font-weight: 400; |           font-weight: 400; | ||||||
| 					color: #c4c4c4; |           color: #c4c4c4; | ||||||
| 				} |         } | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.loadmore-wrap { |       .loadmore-wrap { | ||||||
| 				// line-height: 80rpx; |         // line-height: 80rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.log-item { |       .log-item { | ||||||
| 				// background: rgba(#ffffff, 0.2); |         // background: rgba(#ffffff, 0.2); | ||||||
| 				border-radius: 24rpx; |         border-radius: 24rpx; | ||||||
| 				padding: 6rpx 20rpx 6rpx 12rpx; |         padding: 6rpx 20rpx 6rpx 12rpx; | ||||||
| 
 | 
 | ||||||
| 				.log-img { |         .log-img { | ||||||
| 					width: 40rpx; |           width: 40rpx; | ||||||
| 					height: 40rpx; |           height: 40rpx; | ||||||
| 					border-radius: 50%; |           border-radius: 50%; | ||||||
| 					margin-right: 10rpx; |           margin-right: 10rpx; | ||||||
| 				} |         } | ||||||
| 
 | 
 | ||||||
| 				.log-text { |         .log-text { | ||||||
| 					max-width: 480rpx; |           max-width: 480rpx; | ||||||
| 					font-size: 24rpx; |           font-size: 24rpx; | ||||||
| 					font-weight: 500; |           font-weight: 500; | ||||||
| 					color: #333333; |           color: #333333; | ||||||
| 				} |         } | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -14,12 +14,18 @@ | ||||||
|       > |       > | ||||||
|         <template #rightBottom> |         <template #rightBottom> | ||||||
|           <view class="ss-flex ss-row-between"> |           <view class="ss-flex ss-row-between"> | ||||||
|             <view class="commission-num" v-if="item.brokerageMinPrice === undefined">预计佣金:计算中</view> |             <view class="commission-num" v-if="item.brokerageMinPrice === undefined" | ||||||
|             <view class="commission-num" v-else-if="item.brokerageMinPrice === item.brokerageMaxPrice"> |               >预计佣金:计算中</view | ||||||
|  |             > | ||||||
|  |             <view | ||||||
|  |               class="commission-num" | ||||||
|  |               v-else-if="item.brokerageMinPrice === item.brokerageMaxPrice" | ||||||
|  |             > | ||||||
|               预计佣金:{{ fen2yuan(item.brokerageMinPrice) }} |               预计佣金:{{ fen2yuan(item.brokerageMinPrice) }} | ||||||
|             </view> |             </view> | ||||||
|             <view class="commission-num" v-else> |             <view class="commission-num" v-else> | ||||||
|               预计佣金:{{ fen2yuan(item.brokerageMinPrice) }} ~ {{ fen2yuan(item.brokerageMaxPrice) }} |               预计佣金:{{ fen2yuan(item.brokerageMinPrice) }} ~ | ||||||
|  |               {{ fen2yuan(item.brokerageMaxPrice) }} | ||||||
|             </view> |             </view> | ||||||
|             <button |             <button | ||||||
|               class="ss-reset-button share-btn ui-BG-Main-Gradient" |               class="ss-reset-button share-btn ui-BG-Main-Gradient" | ||||||
|  | @ -53,7 +59,7 @@ | ||||||
|   import $share from '@/sheep/platform/share'; |   import $share from '@/sheep/platform/share'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { showShareModal } from '@/sheep/hooks/useModal'; |   import { showShareModal } from '@/sheep/hooks/useModal'; | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
|   import BrokerageApi from '@/sheep/api/trade/brokerage'; |   import BrokerageApi from '@/sheep/api/trade/brokerage'; | ||||||
|  |  | ||||||
|  | @ -41,10 +41,7 @@ | ||||||
|           <view class="no-box ss-flex ss-col-center ss-row-between"> |           <view class="no-box ss-flex ss-col-center ss-row-between"> | ||||||
|             <text class="order-code">订单编号:{{ item.bizId }}</text> |             <text class="order-code">订单编号:{{ item.bizId }}</text> | ||||||
|             <text class="order-state"> |             <text class="order-state"> | ||||||
|               {{ |               {{ item.status === 0 ? '待结算' : item.status === 1 ? '已结算' : '已取消' }} | ||||||
|                 item.status === 0 ? '待结算' |  | ||||||
|                   : item.status === 1 ? '已结算' : '已取消' |  | ||||||
|               }} |  | ||||||
|               ( 佣金 {{ fen2yuan(item.price) }} 元 ) |               ( 佣金 {{ fen2yuan(item.price) }} 元 ) | ||||||
|             </text> |             </text> | ||||||
|           </view> |           </view> | ||||||
|  | @ -77,7 +74,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { onPageScroll } from '@dcloudio/uni-app'; |   import { onPageScroll } from '@dcloudio/uni-app'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|   import BrokerageApi from '@/sheep/api/trade/brokerage'; |   import BrokerageApi from '@/sheep/api/trade/brokerage'; | ||||||
|  |  | ||||||
|  | @ -235,7 +235,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { computed, reactive, ref } from 'vue'; |   import { computed, reactive, ref } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { onPageScroll } from '@dcloudio/uni-app'; |   import { onPageScroll } from '@dcloudio/uni-app'; | ||||||
|   import BrokerageApi from '@/sheep/api/trade/brokerage'; |   import BrokerageApi from '@/sheep/api/trade/brokerage'; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,196 +1,243 @@ | ||||||
| <!-- 分销 - 佣金明细 --> | <!-- 分销 - 佣金明细 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout class="wallet-wrap" title="佣金"> |   <s-layout class="wallet-wrap" title="佣金"> | ||||||
| 		<!-- 钱包卡片 --> |     <!-- 钱包卡片 --> | ||||||
| 		<view class="header-box ss-flex ss-row-center ss-col-center"> |     <view class="header-box ss-flex ss-row-center ss-col-center"> | ||||||
| 			<view class="card-box ui-BG-Main ui-Shadow-Main"> |       <view class="card-box ui-BG-Main ui-Shadow-Main"> | ||||||
| 				<view class="card-head ss-flex ss-col-center"> |         <view class="card-head ss-flex ss-col-center"> | ||||||
| 					<view class="card-title ss-m-r-10">当前佣金(元)</view> |           <view class="card-title ss-m-r-10">当前佣金(元)</view> | ||||||
| 					<view @tap="state.showMoney = !state.showMoney" class="ss-eye-icon" |           <view | ||||||
| 						:class="state.showMoney ? 'cicon-eye' : 'cicon-eye-off'" /> |             @tap="state.showMoney = !state.showMoney" | ||||||
| 				</view> |             class="ss-eye-icon" | ||||||
| 				<view class="ss-flex ss-row-between ss-col-center ss-m-t-30"> |             :class="state.showMoney ? 'cicon-eye' : 'cicon-eye-off'" | ||||||
| 					<view class="money-num">{{ state.showMoney ? fen2yuan(state.summary.withdrawPrice || 0) : '*****' }}</view> |           /> | ||||||
| 					<view class="ss-flex"> |         </view> | ||||||
| 						<view class="ss-m-r-20"> |         <view class="ss-flex ss-row-between ss-col-center ss-m-t-30"> | ||||||
| 							<button class="ss-reset-button withdraw-btn" @tap="sheep.$router.go('/pages/commission/withdraw')"> |           <view class="money-num">{{ | ||||||
| 								提现 |             state.showMoney ? fen2yuan(state.summary.withdrawPrice || 0) : '*****' | ||||||
| 							</button> |           }}</view> | ||||||
| 						</view> |           <view class="ss-flex"> | ||||||
| 						<button class="ss-reset-button balance-btn ss-m-l-20" @tap="state.showModal = true"> |             <view class="ss-m-r-20"> | ||||||
| 							转余额 |               <button | ||||||
| 						</button> |                 class="ss-reset-button withdraw-btn" | ||||||
| 					</view> |                 @tap="sheep.$router.go('/pages/commission/withdraw')" | ||||||
| 				</view> |               > | ||||||
|  |                 提现 | ||||||
|  |               </button> | ||||||
|  |             </view> | ||||||
|  |             <button class="ss-reset-button balance-btn ss-m-l-20" @tap="state.showModal = true"> | ||||||
|  |               转余额 | ||||||
|  |             </button> | ||||||
|  |           </view> | ||||||
|  |         </view> | ||||||
| 
 | 
 | ||||||
| 				<view class="ss-flex"> |         <view class="ss-flex"> | ||||||
| 					<view class="loading-money"> |           <view class="loading-money"> | ||||||
| 						<view class="loading-money-title">冻结佣金</view> |             <view class="loading-money-title">冻结佣金</view> | ||||||
| 						<view class="loading-money-num"> |             <view class="loading-money-num"> | ||||||
|               {{ state.showMoney ? fen2yuan(state.summary.frozenPrice || 0) : '*****' }} |               {{ state.showMoney ? fen2yuan(state.summary.frozenPrice || 0) : '*****' }} | ||||||
|             </view> |             </view> | ||||||
| 					</view> |           </view> | ||||||
| 					<view class="loading-money ss-m-l-100"> |           <view class="loading-money ss-m-l-100"> | ||||||
| 						<view class="loading-money-title">可提现佣金</view> |             <view class="loading-money-title">可提现佣金</view> | ||||||
| 						<view class="loading-money-num"> |             <view class="loading-money-num"> | ||||||
|               {{ state.showMoney ? fen2yuan(state.summary.brokeragePrice || 0) : '*****' }} |               {{ state.showMoney ? fen2yuan(state.summary.brokeragePrice || 0) : '*****' }} | ||||||
|             </view> |             </view> | ||||||
| 					</view> |           </view> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 		</view> |     </view> | ||||||
| 
 | 
 | ||||||
| 		<su-sticky> |     <su-sticky> | ||||||
| 			<!-- 统计 --> |       <!-- 统计 --> | ||||||
| 			<view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> |       <view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> | ||||||
| 				<uni-datetime-picker v-model="state.date" type="daterange" @change="onChangeTime" :end="state.today"> |         <uni-datetime-picker | ||||||
| 					<button class="ss-reset-button date-btn"> |           v-model="state.date" | ||||||
| 						<text>{{ dateFilterText }}</text> |           type="daterange" | ||||||
| 						<text class="cicon-drop-down ss-seldate-icon" /> |           @change="onChangeTime" | ||||||
| 					</button> |           :end="state.today" | ||||||
| 				</uni-datetime-picker> |         > | ||||||
|  |           <button class="ss-reset-button date-btn"> | ||||||
|  |             <text>{{ dateFilterText }}</text> | ||||||
|  |             <text class="cicon-drop-down ss-seldate-icon" /> | ||||||
|  |           </button> | ||||||
|  |         </uni-datetime-picker> | ||||||
| 
 | 
 | ||||||
| 				<view class="total-box"> |         <view class="total-box"> | ||||||
|           <!-- TODO 芋艿:这里暂时不考虑做 --> |           <!-- TODO 芋艿:这里暂时不考虑做 --> | ||||||
| 					<!-- <view class="ss-m-b-10">总收入¥{{ state.pagination.income.toFixed(2) }}</view> --> |           <!-- <view class="ss-m-b-10">总收入¥{{ state.pagination.income.toFixed(2) }}</view> --> | ||||||
| 					<!-- <view>总支出¥{{ (-state.pagination.expense).toFixed(2) }}</view> --> |           <!-- <view>总支出¥{{ (-state.pagination.expense).toFixed(2) }}</view> --> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 			<su-tabs :list="tabMaps" @change="onChangeTab" :scrollable="false" :current="state.currentTab" /> |       <su-tabs | ||||||
| 		</su-sticky> |         :list="tabMaps" | ||||||
| 		<s-empty v-if="state.pagination.total === 0" icon="/static/data-empty.png" text="暂无数据"></s-empty> |         @change="onChangeTab" | ||||||
|  |         :scrollable="false" | ||||||
|  |         :current="state.currentTab" | ||||||
|  |       /> | ||||||
|  |     </su-sticky> | ||||||
|  |     <s-empty | ||||||
|  |       v-if="state.pagination.total === 0" | ||||||
|  |       icon="/static/data-empty.png" | ||||||
|  |       text="暂无数据" | ||||||
|  |     ></s-empty> | ||||||
| 
 | 
 | ||||||
|     <!-- 转余额弹框 --> |     <!-- 转余额弹框 --> | ||||||
| 		<su-popup :show="state.showModal" type="bottom" round="20" @close="state.showModal = false" showClose> |     <su-popup | ||||||
| 			<view class="ss-p-x-20 ss-p-y-30"> |       :show="state.showModal" | ||||||
| 				<view class="model-title ss-m-b-30 ss-m-l-20">转余额</view> |       type="bottom" | ||||||
| 				<view class="model-subtitle ss-m-b-100 ss-m-l-20">将您的佣金转到余额中继续消费</view> |       round="20" | ||||||
| 				<view class="input-box ss-flex ss-col-center border-bottom ss-m-b-70 ss-m-x-20"> |       @close="state.showModal = false" | ||||||
| 					<view class="unit">¥</view> |       showClose | ||||||
| 					<uni-easyinput :inputBorder="false" class="ss-flex-1 ss-p-l-10" v-model="state.price" type="number" |     > | ||||||
|                          placeholder="请输入金额" /> |       <view class="ss-p-x-20 ss-p-y-30"> | ||||||
| 				</view> |         <view class="model-title ss-m-b-30 ss-m-l-20">转余额</view> | ||||||
| 				<button class="ss-reset-button model-btn ui-BG-Main-Gradient ui-Shadow-Main" @tap="onConfirm"> |         <view class="model-subtitle ss-m-b-100 ss-m-l-20">将您的佣金转到余额中继续消费</view> | ||||||
| 					确定 |         <view class="input-box ss-flex ss-col-center border-bottom ss-m-b-70 ss-m-x-20"> | ||||||
| 				</button> |           <view class="unit">¥</view> | ||||||
| 			</view> |           <uni-easyinput | ||||||
| 		</su-popup> |             :inputBorder="false" | ||||||
|  |             class="ss-flex-1 ss-p-l-10" | ||||||
|  |             v-model="state.price" | ||||||
|  |             type="number" | ||||||
|  |             placeholder="请输入金额" | ||||||
|  |           /> | ||||||
|  |         </view> | ||||||
|  |         <button | ||||||
|  |           class="ss-reset-button model-btn ui-BG-Main-Gradient ui-Shadow-Main" | ||||||
|  |           @tap="onConfirm" | ||||||
|  |         > | ||||||
|  |           确定 | ||||||
|  |         </button> | ||||||
|  |       </view> | ||||||
|  |     </su-popup> | ||||||
| 
 | 
 | ||||||
| 		<!-- 钱包记录 --> |     <!-- 钱包记录 --> | ||||||
| 		<view v-if="state.pagination.total > 0"> |     <view v-if="state.pagination.total > 0"> | ||||||
| 			<view class="wallet-list ss-flex border-bottom" v-for="item in state.pagination.list" :key="item.id"> |       <view | ||||||
| 				<view class="list-content"> |         class="wallet-list ss-flex border-bottom" | ||||||
| 					<view class="title-box ss-flex ss-row-between ss-m-b-20"> |         v-for="item in state.pagination.list" | ||||||
| 						<text class="title ss-line-1">{{ item.title }}</text> |         :key="item.id" | ||||||
| 						<view class="money"> |       > | ||||||
| 							<text v-if="item.price >= 0" class="add">+{{ fen2yuan(item.price) }}</text> |         <view class="list-content"> | ||||||
| 							<text v-else class="minus">{{ fen2yuan(item.price) }}</text> |           <view class="title-box ss-flex ss-row-between ss-m-b-20"> | ||||||
| 						</view> |             <text class="title ss-line-1">{{ item.title }}</text> | ||||||
| 					</view> |             <view class="money"> | ||||||
| 					<text class="time">{{ sheep.$helper.timeFormat(item.createTime, 'yyyy-mm-dd hh:MM:ss') }}</text> |               <text v-if="item.price >= 0" class="add">+{{ fen2yuan(item.price) }}</text> | ||||||
| 				</view> |               <text v-else class="minus">{{ fen2yuan(item.price) }}</text> | ||||||
| 			</view> |             </view> | ||||||
| 		</view> |           </view> | ||||||
|  |           <text class="time">{{ | ||||||
|  |             sheep.$helper.timeFormat(item.createTime, 'yyyy-mm-dd hh:MM:ss') | ||||||
|  |           }}</text> | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
|  |     </view> | ||||||
| 
 | 
 | ||||||
| 		<!-- <u-gap></u-gap> --> |     <!-- <u-gap></u-gap> --> | ||||||
| 		<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{ |     <uni-load-more | ||||||
|  |       v-if="state.pagination.total > 0" | ||||||
|  |       :status="state.loadStatus" | ||||||
|  |       :content-text="{ | ||||||
|         contentdown: '上拉加载更多', |         contentdown: '上拉加载更多', | ||||||
|       }" /> |       }" | ||||||
| 	</s-layout> |     /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { computed, reactive } from 'vue'; |   import { computed, reactive } from 'vue'; | ||||||
| 	import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import dayjs from 'dayjs'; |   import dayjs from 'dayjs'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import BrokerageApi from '@/sheep/api/trade/brokerage'; |   import BrokerageApi from '@/sheep/api/trade/brokerage'; | ||||||
|   import { fen2yuan } from '@/sheep/hooks/useGoods'; |   import { fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
| 
 | 
 | ||||||
| 	const headerBg = sheep.$url.css('/static/img/shop/user/wallet_card_bg.png'); |   const headerBg = sheep.$url.css('/static/img/shop/user/wallet_card_bg.png'); | ||||||
| 
 | 
 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
|     showMoney: false, |     showMoney: false, | ||||||
|     summary: {}, // 分销信息 |     summary: {}, // 分销信息 | ||||||
| 
 | 
 | ||||||
|     today: '', |     today: '', | ||||||
|     date: [], |     date: [], | ||||||
| 		currentTab: 0, |     currentTab: 0, | ||||||
| 		pagination: { |     pagination: { | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 1, |       pageSize: 1, | ||||||
|     }, |     }, | ||||||
| 		loadStatus: '', |     loadStatus: '', | ||||||
| 
 | 
 | ||||||
|     price: undefined, |     price: undefined, | ||||||
| 		showModal: false, |     showModal: false, | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	const tabMaps = [{ |   const tabMaps = [ | ||||||
| 			name: '分佣', |     { | ||||||
| 			value: '1', // BrokerageRecordBizTypeEnum.ORDER |       name: '分佣', | ||||||
| 		}, |       value: '1', // BrokerageRecordBizTypeEnum.ORDER | ||||||
| 		{ |     }, | ||||||
| 			name: '提现', |     { | ||||||
| 			value: '2', // BrokerageRecordBizTypeEnum.WITHDRAW |       name: '提现', | ||||||
| 		} |       value: '2', // BrokerageRecordBizTypeEnum.WITHDRAW | ||||||
| 	]; |     }, | ||||||
|  |   ]; | ||||||
| 
 | 
 | ||||||
| 	const dateFilterText = computed(() => { |   const dateFilterText = computed(() => { | ||||||
| 		if (state.date[0] === state.date[1]) { |     if (state.date[0] === state.date[1]) { | ||||||
| 			return state.date[0]; |       return state.date[0]; | ||||||
| 		} else { |     } else { | ||||||
| 			return state.date.join('~'); |       return state.date.join('~'); | ||||||
| 		} |     } | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	async function getLogList() { |   async function getLogList() { | ||||||
| 		state.loadStatus = 'loading'; |     state.loadStatus = 'loading'; | ||||||
| 		let { code, data } = await BrokerageApi.getBrokerageRecordPage({ |     let { code, data } = await BrokerageApi.getBrokerageRecordPage({ | ||||||
| 			pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
| 			pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       bizType: tabMaps[state.currentTab].value, |       bizType: tabMaps[state.currentTab].value, | ||||||
|       'createTime[0]': state.date[0] + ' 00:00:00', |       'createTime[0]': state.date[0] + ' 00:00:00', | ||||||
|       'createTime[1]': state.date[1] + ' 23:59:59', |       'createTime[1]': state.date[1] + ' 23:59:59', | ||||||
| 		}); |     }); | ||||||
| 		if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
| 		} |     } | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list); |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	function onChangeTab(e) { |   function onChangeTab(e) { | ||||||
| 		resetPagination(state.pagination); |  | ||||||
| 		state.currentTab = e.index; |  | ||||||
| 		getLogList(); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	function onChangeTime(e) { |  | ||||||
| 		state.date[0] = e[0]; |  | ||||||
| 		state.date[1] = e[e.length - 1]; |  | ||||||
|     resetPagination(state.pagination); |     resetPagination(state.pagination); | ||||||
| 		getLogList(); |     state.currentTab = e.index; | ||||||
| 	} |     getLogList(); | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
| 	// 确认操作(转账到余额) |   function onChangeTime(e) { | ||||||
| 	async function onConfirm() { |     state.date[0] = e[0]; | ||||||
| 		if (state.price <= 0) { |     state.date[1] = e[e.length - 1]; | ||||||
| 			sheep.$helper.toast('请输入正确的金额'); |     resetPagination(state.pagination); | ||||||
| 			return; |     getLogList(); | ||||||
| 		} |   } | ||||||
| 		uni.showModal({ | 
 | ||||||
| 			title: '提示', |   // 确认操作(转账到余额) | ||||||
| 			content: '确认把您的佣金转入到余额钱包中?', |   async function onConfirm() { | ||||||
| 			success: async function(res) { |     if (state.price <= 0) { | ||||||
| 				if (!res.confirm) { |       sheep.$helper.toast('请输入正确的金额'); | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  |     uni.showModal({ | ||||||
|  |       title: '提示', | ||||||
|  |       content: '确认把您的佣金转入到余额钱包中?', | ||||||
|  |       success: async function (res) { | ||||||
|  |         if (!res.confirm) { | ||||||
|           return; |           return; | ||||||
| 				} |         } | ||||||
|         const { code } = await BrokerageApi.createBrokerageWithdraw({ |         const { code } = await BrokerageApi.createBrokerageWithdraw({ | ||||||
|           type: 1, // 钱包 |           type: 1, // 钱包 | ||||||
|           price: state.price * 100, |           price: state.price * 100, | ||||||
|  | @ -199,272 +246,273 @@ | ||||||
|           state.showModal = false; |           state.showModal = false; | ||||||
|           await getAgentInfo(); |           await getAgentInfo(); | ||||||
|           onChangeTab({ |           onChangeTab({ | ||||||
|             index: 1 |             index: 1, | ||||||
|           }); |           }); | ||||||
|         } |         } | ||||||
| 			} |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	async function getAgentInfo() { |   async function getAgentInfo() { | ||||||
| 		const { code, data } = await BrokerageApi.getBrokerageUserSummary(); |     const { code, data } = await BrokerageApi.getBrokerageUserSummary(); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.summary = data; |     state.summary = data; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad(async (options) => { |   onLoad(async (options) => { | ||||||
| 		state.today = dayjs().format('YYYY-MM-DD'); |     state.today = dayjs().format('YYYY-MM-DD'); | ||||||
| 		state.date = [state.today, state.today]; |     state.date = [state.today, state.today]; | ||||||
|     if (options.type === 2) { // 切换到“提现” tab 下 |     if (options.type === 2) { | ||||||
|  |       // 切换到“提现” tab 下 | ||||||
|       state.currentTab = 1; |       state.currentTab = 1; | ||||||
|     } |     } | ||||||
| 		getLogList(); |     getLogList(); | ||||||
| 		getAgentInfo(); |     getAgentInfo(); | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	onReachBottom(() => { |   onReachBottom(() => { | ||||||
| 		if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
|     state.pagination.pageNo++; |     state.pagination.pageNo++; | ||||||
|     getLogList(); |     getLogList(); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	// 钱包 |   // 钱包 | ||||||
| 	.header-box { |   .header-box { | ||||||
| 		background-color: $white; |     background-color: $white; | ||||||
| 		padding: 30rpx; |     padding: 30rpx; | ||||||
| 
 | 
 | ||||||
| 		.card-box { |     .card-box { | ||||||
| 			width: 100%; |       width: 100%; | ||||||
| 			min-height: 300rpx; |       min-height: 300rpx; | ||||||
| 			padding: 40rpx; |       padding: 40rpx; | ||||||
| 			background-size: 100% 100%; |       background-size: 100% 100%; | ||||||
| 			border-radius: 30rpx; |       border-radius: 30rpx; | ||||||
| 			overflow: hidden; |       overflow: hidden; | ||||||
| 			position: relative; |       position: relative; | ||||||
| 			z-index: 1; |       z-index: 1; | ||||||
| 			box-sizing: border-box; |       box-sizing: border-box; | ||||||
| 
 | 
 | ||||||
| 			&::after { |       &::after { | ||||||
| 				content: ''; |         content: ''; | ||||||
| 				display: block; |         display: block; | ||||||
| 				width: 100%; |         width: 100%; | ||||||
| 				height: 100%; |         height: 100%; | ||||||
| 				z-index: 2; |         z-index: 2; | ||||||
| 				position: absolute; |         position: absolute; | ||||||
| 				top: 0; |         top: 0; | ||||||
| 				left: 0; |         left: 0; | ||||||
| 				background: v-bind(headerBg) no-repeat; |         background: v-bind(headerBg) no-repeat; | ||||||
| 				pointer-events: none; |         pointer-events: none; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.card-head { |       .card-head { | ||||||
| 				color: $white; |         color: $white; | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.ss-eye-icon { |       .ss-eye-icon { | ||||||
| 				font-size: 40rpx; |         font-size: 40rpx; | ||||||
| 				color: $white; |         color: $white; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.money-num { |       .money-num { | ||||||
| 				font-size: 40rpx; |         font-size: 40rpx; | ||||||
| 				line-height: normal; |         line-height: normal; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				color: $white; |         color: $white; | ||||||
| 				font-family: OPPOSANS; |         font-family: OPPOSANS; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.reduce-num { |       .reduce-num { | ||||||
| 				font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 				font-weight: 400; |         font-weight: 400; | ||||||
| 				color: $white; |         color: $white; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.withdraw-btn { |       .withdraw-btn { | ||||||
| 				width: 120rpx; |         width: 120rpx; | ||||||
| 				height: 60rpx; |         height: 60rpx; | ||||||
| 				line-height: 60rpx; |         line-height: 60rpx; | ||||||
| 				border-radius: 30px; |         border-radius: 30px; | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				background-color: $white; |         background-color: $white; | ||||||
| 				color: var(--ui-BG-Main); |         color: var(--ui-BG-Main); | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.balance-btn { |       .balance-btn { | ||||||
| 				width: 120rpx; |         width: 120rpx; | ||||||
| 				height: 60rpx; |         height: 60rpx; | ||||||
| 				line-height: 60rpx; |         line-height: 60rpx; | ||||||
| 				border-radius: 30px; |         border-radius: 30px; | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				color: $white; |         color: $white; | ||||||
| 				border: 1px solid $white; |         border: 1px solid $white; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.loading-money { |   .loading-money { | ||||||
| 		margin-top: 56rpx; |     margin-top: 56rpx; | ||||||
| 
 | 
 | ||||||
| 		.loading-money-title { |     .loading-money-title { | ||||||
| 			font-size: 24rpx; |       font-size: 24rpx; | ||||||
| 			font-weight: 400; |       font-weight: 400; | ||||||
| 			color: #ffffff; |       color: #ffffff; | ||||||
| 			line-height: normal; |       line-height: normal; | ||||||
| 			margin-bottom: 30rpx; |       margin-bottom: 30rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.loading-money-num { |     .loading-money-num { | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 			font-family: OPPOSANS; |       font-family: OPPOSANS; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: #fefefe; |       color: #fefefe; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 筛选 |   // 筛选 | ||||||
| 
 | 
 | ||||||
| 	.filter-box { |   .filter-box { | ||||||
| 		height: 120rpx; |     height: 120rpx; | ||||||
| 		padding: 0 30rpx; |     padding: 0 30rpx; | ||||||
| 		background-color: $bg-page; |     background-color: $bg-page; | ||||||
| 
 | 
 | ||||||
| 		.total-box { |     .total-box { | ||||||
| 			font-size: 24rpx; |       font-size: 24rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: $dark-9; |       color: $dark-9; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.date-btn { |     .date-btn { | ||||||
| 			background-color: $white; |       background-color: $white; | ||||||
| 			line-height: 54rpx; |       line-height: 54rpx; | ||||||
| 			border-radius: 27rpx; |       border-radius: 27rpx; | ||||||
| 			padding: 0 20rpx; |       padding: 0 20rpx; | ||||||
| 			font-size: 24rpx; |       font-size: 24rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: $dark-6; |       color: $dark-6; | ||||||
| 
 | 
 | ||||||
| 			.ss-seldate-icon { |       .ss-seldate-icon { | ||||||
| 				font-size: 50rpx; |         font-size: 50rpx; | ||||||
| 				color: $dark-9; |         color: $dark-9; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// tab |   // tab | ||||||
| 	.wallet-tab-card { |   .wallet-tab-card { | ||||||
| 		.tab-item { |     .tab-item { | ||||||
| 			height: 80rpx; |       height: 80rpx; | ||||||
| 			position: relative; |       position: relative; | ||||||
| 
 | 
 | ||||||
| 			.tab-title { |       .tab-title { | ||||||
| 				font-size: 30rpx; |         font-size: 30rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.cur-tab-title { |       .cur-tab-title { | ||||||
| 				font-weight: $font-weight-bold; |         font-weight: $font-weight-bold; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.tab-line { |       .tab-line { | ||||||
| 				width: 60rpx; |         width: 60rpx; | ||||||
| 				height: 6rpx; |         height: 6rpx; | ||||||
| 				border-radius: 6rpx; |         border-radius: 6rpx; | ||||||
| 				position: absolute; |         position: absolute; | ||||||
| 				left: 50%; |         left: 50%; | ||||||
| 				transform: translateX(-50%); |         transform: translateX(-50%); | ||||||
| 				bottom: 2rpx; |         bottom: 2rpx; | ||||||
| 				background-color: var(--ui-BG-Main); |         background-color: var(--ui-BG-Main); | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 钱包记录 |   // 钱包记录 | ||||||
| 	.wallet-list { |   .wallet-list { | ||||||
| 		padding: 30rpx; |     padding: 30rpx; | ||||||
| 		background-color: #ffff; |     background-color: #ffff; | ||||||
| 
 | 
 | ||||||
| 		.head-img { |     .head-img { | ||||||
| 			width: 70rpx; |       width: 70rpx; | ||||||
| 			height: 70rpx; |       height: 70rpx; | ||||||
| 			border-radius: 50%; |       border-radius: 50%; | ||||||
| 			background: $gray-c; |       background: $gray-c; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.list-content { |     .list-content { | ||||||
| 			justify-content: space-between; |       justify-content: space-between; | ||||||
| 			align-items: flex-start; |       align-items: flex-start; | ||||||
| 			flex: 1; |       flex: 1; | ||||||
| 
 | 
 | ||||||
| 			.title { |       .title { | ||||||
| 				font-size: 28rpx; |         font-size: 28rpx; | ||||||
| 				color: $dark-3; |         color: $dark-3; | ||||||
| 				width: 400rpx; |         width: 400rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.time { |       .time { | ||||||
| 				color: $gray-c; |         color: $gray-c; | ||||||
| 				font-size: 22rpx; |         font-size: 22rpx; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.money { |     .money { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 			font-weight: bold; |       font-weight: bold; | ||||||
| 			font-family: OPPOSANS; |       font-family: OPPOSANS; | ||||||
| 
 | 
 | ||||||
| 			.add { |       .add { | ||||||
| 				color: var(--ui-BG-Main); |         color: var(--ui-BG-Main); | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.minus { |       .minus { | ||||||
| 				color: $dark-3; |         color: $dark-3; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.model-title { |   .model-title { | ||||||
| 		font-size: 36rpx; |     font-size: 36rpx; | ||||||
| 		font-weight: bold; |     font-weight: bold; | ||||||
| 		color: #333333; |     color: #333333; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.model-subtitle { |   .model-subtitle { | ||||||
| 		font-size: 26rpx; |     font-size: 26rpx; | ||||||
| 		color: #c2c7cf; |     color: #c2c7cf; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.model-btn { |   .model-btn { | ||||||
| 		width: 100%; |     width: 100%; | ||||||
| 		height: 80rpx; |     height: 80rpx; | ||||||
| 		border-radius: 40rpx; |     border-radius: 40rpx; | ||||||
| 		font-size: 28rpx; |     font-size: 28rpx; | ||||||
| 		font-weight: 500; |     font-weight: 500; | ||||||
| 		color: #ffffff; |     color: #ffffff; | ||||||
| 		line-height: normal; |     line-height: normal; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.input-box { |   .input-box { | ||||||
| 		height: 100rpx; |     height: 100rpx; | ||||||
| 
 | 
 | ||||||
| 		.unit { |     .unit { | ||||||
| 			font-size: 48rpx; |       font-size: 48rpx; | ||||||
| 			color: #333; |       color: #333; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			line-height: normal; |       line-height: normal; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.uni-easyinput__placeholder-class { |     .uni-easyinput__placeholder-class { | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 			height: 40rpx; |       height: 40rpx; | ||||||
| 			line-height: normal; |       line-height: normal; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -16,13 +16,16 @@ | ||||||
|             <view class="title ss-m-t-50 ss-m-b-20 ss-m-x-20">{{ state.coupon.name }}</view> |             <view class="title ss-m-t-50 ss-m-b-20 ss-m-x-20">{{ state.coupon.name }}</view> | ||||||
|             <view class="subtitle ss-m-b-50"> |             <view class="subtitle ss-m-b-50"> | ||||||
|               满 {{ fen2yuan(state.coupon.usePrice) }} 元, |               满 {{ fen2yuan(state.coupon.usePrice) }} 元, | ||||||
|               {{ state.coupon.discountType === 1 |               {{ | ||||||
|                 ? '减 ' + fen2yuan(state.coupon.discountPrice) + ' 元' |                 state.coupon.discountType === 1 | ||||||
|                 : '打 ' + state.coupon.discountPercent / 10.0 + ' 折' }} |                   ? '减 ' + fen2yuan(state.coupon.discountPrice) + ' 元' | ||||||
|  |                   : '打 ' + state.coupon.discountPercent / 10.0 + ' 折' | ||||||
|  |               }} | ||||||
|             </view> |             </view> | ||||||
|             <button |             <button | ||||||
|               class="ss-reset-button ss-m-b-30" |               class="ss-reset-button ss-m-b-30" | ||||||
|               :class="state.coupon.canTake || state.coupon.status === 1 |               :class=" | ||||||
|  |                 state.coupon.canTake || state.coupon.status === 1 | ||||||
|                   ? 'use-btn' // 优惠劵模版(可领取)、优惠劵(可使用) |                   ? 'use-btn' // 优惠劵模版(可领取)、优惠劵(可使用) | ||||||
|                   : 'disable-btn' |                   : 'disable-btn' | ||||||
|               " |               " | ||||||
|  | @ -31,7 +34,13 @@ | ||||||
|             > |             > | ||||||
|               <text v-if="state.id > 0">{{ state.coupon.canTake ? '立即领取' : '已领取' }}</text> |               <text v-if="state.id > 0">{{ state.coupon.canTake ? '立即领取' : '已领取' }}</text> | ||||||
|               <text v-else> |               <text v-else> | ||||||
|                 {{ state.coupon.status === 1 ? '立即使用' : state.coupon.status === 2 ? '已使用' : '已过期' }} |                 {{ | ||||||
|  |                   state.coupon.status === 1 | ||||||
|  |                     ? '立即使用' | ||||||
|  |                     : state.coupon.status === 2 | ||||||
|  |                     ? '已使用' | ||||||
|  |                     : '已过期' | ||||||
|  |                 }} | ||||||
|               </text> |               </text> | ||||||
|             </button> |             </button> | ||||||
|             <view class="time ss-m-y-30" v-if="state.coupon.validityType === 2"> |             <view class="time ss-m-y-30" v-if="state.coupon.validityType === 2"> | ||||||
|  | @ -140,7 +149,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import CouponApi from '@/sheep/api/promotion/coupon'; |   import CouponApi from '@/sheep/api/promotion/coupon'; | ||||||
|   import { fen2yuan } from '@/sheep/hooks/useGoods'; |   import { fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
|  | @ -176,7 +185,7 @@ | ||||||
|     const { code, data } = await SpuApi.getSpuPage({ |     const { code, data } = await SpuApi.getSpuPage({ | ||||||
|       categoryId: state.categoryId, |       categoryId: state.categoryId, | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize |       pageSize: state.pagination.pageSize, | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  | @ -197,7 +206,9 @@ | ||||||
| 
 | 
 | ||||||
|   // 获得分类列表 |   // 获得分类列表 | ||||||
|   async function getCategoryList() { |   async function getCategoryList() { | ||||||
|     const { data, code } = await CategoryApi.getCategoryListByIds(state.coupon.productScopeValues.join(',')); |     const { data, code } = await CategoryApi.getCategoryListByIds( | ||||||
|  |       state.coupon.productScopeValues.join(','), | ||||||
|  |     ); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  | @ -225,8 +236,10 @@ | ||||||
| 
 | 
 | ||||||
|   // 加载优惠劵信息 |   // 加载优惠劵信息 | ||||||
|   async function getCouponContent() { |   async function getCouponContent() { | ||||||
|     const { code, data } = state.id > 0 ? await CouponApi.getCouponTemplate(state.id) |     const { code, data } = | ||||||
|       : await CouponApi.getCoupon(state.couponId); |       state.id > 0 | ||||||
|  |         ? await CouponApi.getCouponTemplate(state.id) | ||||||
|  |         : await CouponApi.getCoupon(state.couponId); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -45,7 +45,7 @@ | ||||||
|           <template #default> |           <template #default> | ||||||
|             <button |             <button | ||||||
|               class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center" |               class="ss-reset-button card-btn ss-flex ss-row-center ss-col-center" | ||||||
|               :class=" item.status !== 1 ? 'disabled-btn': ''" |               :class="item.status !== 1 ? 'disabled-btn' : ''" | ||||||
|               :disabled="item.status !== 1" |               :disabled="item.status !== 1" | ||||||
|               @click.stop="sheep.$router.go('/pages/coupon/detail', { couponId: item.id })" |               @click.stop="sheep.$router.go('/pages/coupon/detail', { couponId: item.id })" | ||||||
|             > |             > | ||||||
|  | @ -56,9 +56,14 @@ | ||||||
|       </view> |       </view> | ||||||
|     </template> |     </template> | ||||||
| 
 | 
 | ||||||
|     <uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{ |     <uni-load-more | ||||||
|  |       v-if="state.pagination.total > 0" | ||||||
|  |       :status="state.loadStatus" | ||||||
|  |       :content-text="{ | ||||||
|         contentdown: '上拉加载更多', |         contentdown: '上拉加载更多', | ||||||
|       }" @tap="loadMore" /> |       }" | ||||||
|  |       @tap="loadMore" | ||||||
|  |     /> | ||||||
|   </s-layout> |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
|  | @ -66,7 +71,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|   import CouponApi from '@/sheep/api/promotion/coupon'; |   import CouponApi from '@/sheep/api/promotion/coupon'; | ||||||
| 
 | 
 | ||||||
|  | @ -78,7 +83,7 @@ | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 5 |       pageSize: 5, | ||||||
|     }, |     }, | ||||||
|     loadStatus: '', |     loadStatus: '', | ||||||
|   }); |   }); | ||||||
|  | @ -106,9 +111,9 @@ | ||||||
|   function onTabsChange(e) { |   function onTabsChange(e) { | ||||||
|     state.currentTab = e.index; |     state.currentTab = e.index; | ||||||
|     state.type = e.value; |     state.type = e.value; | ||||||
|     resetPagination(state.pagination) |     resetPagination(state.pagination); | ||||||
|     if (state.currentTab === 0) { |     if (state.currentTab === 0) { | ||||||
|     	getData(); |       getData(); | ||||||
|     } else { |     } else { | ||||||
|       getCoupon(); |       getCoupon(); | ||||||
|     } |     } | ||||||
|  | @ -135,7 +140,7 @@ | ||||||
|     const { data, code } = await CouponApi.getCouponPage({ |     const { data, code } = await CouponApi.getCouponPage({ | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
|       status: state.type |       status: state.type, | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  | @ -177,13 +182,13 @@ | ||||||
|     // 领劵中心 |     // 领劵中心 | ||||||
|     if (Option.type === 'all' || !Option.type) { |     if (Option.type === 'all' || !Option.type) { | ||||||
|       getData(); |       getData(); | ||||||
|     // 我的优惠劵 |       // 我的优惠劵 | ||||||
|     } else { |     } else { | ||||||
|       Option.type === 'geted' |       Option.type === 'geted' | ||||||
|         ? (state.currentTab = 1) |         ? (state.currentTab = 1) | ||||||
|         : Option.type === 'used' |         : Option.type === 'used' | ||||||
|           ? (state.currentTab = 2) |         ? (state.currentTab = 2) | ||||||
|           : (state.currentTab = 3); |         : (state.currentTab = 3); | ||||||
|       state.type = state.currentTab; |       state.type = state.currentTab; | ||||||
|       getCoupon(); |       getCoupon(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -30,7 +30,7 @@ | ||||||
|   import CommentApi from '@/sheep/api/product/comment'; |   import CommentApi from '@/sheep/api/product/comment'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import commentItem from '../components/detail/comment-item.vue'; |   import commentItem from '../components/detail/comment-item.vue'; | ||||||
| 
 | 
 | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|  |  | ||||||
|  | @ -7,12 +7,16 @@ | ||||||
|     <detailSkeleton v-if="state.skeletonLoading" /> |     <detailSkeleton v-if="state.skeletonLoading" /> | ||||||
|     <!-- 下架/售罄提醒 --> |     <!-- 下架/售罄提醒 --> | ||||||
|     <s-empty |     <s-empty | ||||||
|         v-else-if="state.goodsInfo === null || state.activity.status !== 0 || state.activity.endTime < new Date().getTime()" |       v-else-if=" | ||||||
|         text="活动不存在或已结束" |         state.goodsInfo === null || | ||||||
|         icon="/static/soldout-empty.png" |         state.activity.status !== 0 || | ||||||
|         showAction |         state.activity.endTime < new Date().getTime() | ||||||
|         actionText="返回上一页" |       " | ||||||
|         @clickAction="sheep.$router.back()" |       text="活动不存在或已结束" | ||||||
|  |       icon="/static/soldout-empty.png" | ||||||
|  |       showAction | ||||||
|  |       actionText="返回上一页" | ||||||
|  |       @clickAction="sheep.$router.back()" | ||||||
|     /> |     /> | ||||||
|     <block v-else> |     <block v-else> | ||||||
|       <view class="detail-swiper-selector"> |       <view class="detail-swiper-selector"> | ||||||
|  | @ -47,10 +51,7 @@ | ||||||
|                 </view> |                 </view> | ||||||
|               </view> |               </view> | ||||||
|               <view class="ss-flex ss-row-between"> |               <view class="ss-flex ss-row-between"> | ||||||
|                 <view |                 <view class="origin-price ss-flex ss-col-center" v-if="state.goodsInfo.price"> | ||||||
|                   class="origin-price ss-flex ss-col-center" |  | ||||||
|                   v-if="state.goodsInfo.price" |  | ||||||
|                 > |  | ||||||
|                   单买价: |                   单买价: | ||||||
|                   <view class="origin-price-text"> |                   <view class="origin-price-text"> | ||||||
|                     {{ fen2yuan(state.goodsInfo.price) }} |                     {{ fen2yuan(state.goodsInfo.price) }} | ||||||
|  | @ -123,7 +124,9 @@ | ||||||
|             " |             " | ||||||
|             :disabled="state.goodsInfo.stock === 0 || state.activity.status !== 0" |             :disabled="state.goodsInfo.stock === 0 || state.activity.status !== 0" | ||||||
|           > |           > | ||||||
|             <view class="btn-price">{{ fen2yuan(state.activity.price || state.goodsInfo.price) }}</view> |             <view class="btn-price">{{ | ||||||
|  |               fen2yuan(state.activity.price || state.goodsInfo.price) | ||||||
|  |             }}</view> | ||||||
|             <view v-if="state.activity.startTime > new Date().getTime()">未开始</view> |             <view v-if="state.activity.startTime > new Date().getTime()">未开始</view> | ||||||
|             <view v-else-if="state.activity.endTime <= new Date().getTime()">已结束</view> |             <view v-else-if="state.activity.endTime <= new Date().getTime()">已结束</view> | ||||||
|             <view v-else> |             <view v-else> | ||||||
|  | @ -141,7 +144,7 @@ | ||||||
|   import { reactive, computed } from 'vue'; |   import { reactive, computed } from 'vue'; | ||||||
|   import { onLoad, onPageScroll } from '@dcloudio/uni-app'; |   import { onLoad, onPageScroll } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import detailNavbar from './components/detail/detail-navbar.vue'; |   import detailNavbar from './components/detail/detail-navbar.vue'; | ||||||
|   import detailCellSku from './components/detail/detail-cell-sku.vue'; |   import detailCellSku from './components/detail/detail-cell-sku.vue'; | ||||||
|   import detailTabbar from './components/detail/detail-tabbar.vue'; |   import detailTabbar from './components/detail/detail-tabbar.vue'; | ||||||
|  | @ -149,29 +152,27 @@ | ||||||
|   import detailCommentCard from './components/detail/detail-comment-card.vue'; |   import detailCommentCard from './components/detail/detail-comment-card.vue'; | ||||||
|   import detailContentCard from './components/detail/detail-content-card.vue'; |   import detailContentCard from './components/detail/detail-content-card.vue'; | ||||||
|   import grouponCardList from './components/groupon/groupon-card-list.vue'; |   import grouponCardList from './components/groupon/groupon-card-list.vue'; | ||||||
|   import {useDurationTime, formatGoodsSwiper, fen2yuan} from '@/sheep/hooks/useGoods'; |   import { useDurationTime, formatGoodsSwiper, fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import CombinationApi from "@/sheep/api/promotion/combination"; |   import CombinationApi from '@/sheep/api/promotion/combination'; | ||||||
|   import SpuApi from "@/sheep/api/product/spu"; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
| 
 | 
 | ||||||
|   const headerBg = sheep.$url.css('/static/img/shop/goods/groupon-bg.png'); |   const headerBg = sheep.$url.css('/static/img/shop/goods/groupon-bg.png'); | ||||||
|   const btnBg = sheep.$url.css('/static/img/shop/goods/groupon-btn.png'); |   const btnBg = sheep.$url.css('/static/img/shop/goods/groupon-btn.png'); | ||||||
|   const disabledBtnBg = sheep.$url.css( |   const disabledBtnBg = sheep.$url.css('/static/img/shop/goods/activity-btn-disabled.png'); | ||||||
|     '/static/img/shop/goods/activity-btn-disabled.png', |  | ||||||
|   ); |  | ||||||
|   const grouponBg = sheep.$url.css('/static/img/shop/goods/groupon-tip-bg.png'); |   const grouponBg = sheep.$url.css('/static/img/shop/goods/groupon-tip-bg.png'); | ||||||
| 
 | 
 | ||||||
|   onPageScroll(() => {}); |   onPageScroll(() => {}); | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|     skeletonLoading: true,  // 骨架屏 |     skeletonLoading: true, // 骨架屏 | ||||||
|     goodsId: 0,             // 商品ID |     goodsId: 0, // 商品ID | ||||||
|     goodsInfo: {},          // 商品信息 |     goodsInfo: {}, // 商品信息 | ||||||
|     goodsSwiper: [],        // 商品轮播图 |     goodsSwiper: [], // 商品轮播图 | ||||||
|     showSelectSku: false,   // 显示规格弹框 |     showSelectSku: false, // 显示规格弹框 | ||||||
|     selectedSkuPrice: {},   // 选中的规格价格 |     selectedSkuPrice: {}, // 选中的规格价格 | ||||||
|     activity: {},           // 团购活动 |     activity: {}, // 团购活动 | ||||||
|     grouponId: 0,           // 团购ID |     grouponId: 0, // 团购ID | ||||||
|     grouponNum: 0,          // 团购人数 |     grouponNum: 0, // 团购人数 | ||||||
|     grouponAction: 'create',  // 团购操作 |     grouponAction: 'create', // 团购操作 | ||||||
|     combinationHeadId: null, // 拼团团长编号 |     combinationHeadId: null, // 拼团团长编号 | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|  | @ -261,7 +262,7 @@ | ||||||
|     // 加载商品信息 |     // 加载商品信息 | ||||||
|     const { data: spu } = await SpuApi.getSpuDetail(activity.spuId); |     const { data: spu } = await SpuApi.getSpuDetail(activity.spuId); | ||||||
|     state.goodsId = spu.id; |     state.goodsId = spu.id; | ||||||
|     activity.products.forEach(product => { |     activity.products.forEach((product) => { | ||||||
|       spu.price = Math.min(spu.price, product.combinationPrice); // 设置 SPU 的最低价格 |       spu.price = Math.min(spu.price, product.combinationPrice); // 设置 SPU 的最低价格 | ||||||
|     }); |     }); | ||||||
|     // 关闭骨架屏 |     // 关闭骨架屏 | ||||||
|  | @ -475,8 +476,7 @@ | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   .groupon-box { |   .groupon-box { | ||||||
|     background: v-bind(grouponBg) |     background: v-bind(grouponBg) no-repeat; | ||||||
|       no-repeat; |  | ||||||
|     background-size: 100% 100%; |     background-size: 100% 100%; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,177 +1,227 @@ | ||||||
| <template> | <template> | ||||||
| 	<view> |   <view> | ||||||
| 		<s-layout :onShareAppMessage="shareInfo" navbar="goods"> |     <s-layout :onShareAppMessage="shareInfo" navbar="goods"> | ||||||
| 			<!-- 标题栏 --> |       <!-- 标题栏 --> | ||||||
| 			<detailNavbar /> |       <detailNavbar /> | ||||||
| 
 | 
 | ||||||
| 			<!-- 骨架屏 --> |       <!-- 骨架屏 --> | ||||||
| 			<detailSkeleton v-if="state.skeletonLoading" /> |       <detailSkeleton v-if="state.skeletonLoading" /> | ||||||
| 			<!-- 下架/售罄提醒 --> |       <!-- 下架/售罄提醒 --> | ||||||
| 			<s-empty v-else-if="state.goodsInfo === null" text="商品不存在或已下架" icon="/static/soldout-empty.png" showAction |       <s-empty | ||||||
|                actionText="再逛逛" actionUrl="/pages/goods/list" /> |         v-else-if="state.goodsInfo === null" | ||||||
| 			<block v-else> |         text="商品不存在或已下架" | ||||||
| 				<view class="detail-swiper-selector"> |         icon="/static/soldout-empty.png" | ||||||
| 					<!-- 商品轮播图  --> |         showAction | ||||||
| 					<su-swiper class="ss-m-b-14" isPreview :list="formatGoodsSwiper(state.goodsInfo.sliderPicUrls)" |         actionText="再逛逛" | ||||||
|                      otStyle="tag" imageMode="widthFix" dotCur="bg-mask-40" :seizeHeight="750" /> |         actionUrl="/pages/goods/list" | ||||||
|  |       /> | ||||||
|  |       <block v-else> | ||||||
|  |         <view class="detail-swiper-selector"> | ||||||
|  |           <!-- 商品轮播图  --> | ||||||
|  |           <su-swiper | ||||||
|  |             class="ss-m-b-14" | ||||||
|  |             isPreview | ||||||
|  |             :list="formatGoodsSwiper(state.goodsInfo.sliderPicUrls)" | ||||||
|  |             otStyle="tag" | ||||||
|  |             imageMode="widthFix" | ||||||
|  |             dotCur="bg-mask-40" | ||||||
|  |             :seizeHeight="750" | ||||||
|  |           /> | ||||||
| 
 | 
 | ||||||
| 					<!-- 价格+标题 --> |           <!-- 价格+标题 --> | ||||||
| 					<view class="title-card detail-card ss-p-y-40 ss-p-x-20"> |           <view class="title-card detail-card ss-p-y-40 ss-p-x-20"> | ||||||
| 						<view class="ss-flex ss-row-between ss-col-center ss-m-b-26"> |             <view class="ss-flex ss-row-between ss-col-center ss-m-b-26"> | ||||||
| 							<view class="price-box ss-flex ss-col-bottom"> |               <view class="price-box ss-flex ss-col-bottom"> | ||||||
| 								<view class="price-text ss-m-r-16"> |                 <view class="price-text ss-m-r-16"> | ||||||
| 									{{ fen2yuan(state.selectedSku.price || state.goodsInfo.price) }} |                   {{ fen2yuan(state.selectedSku.price || state.goodsInfo.price) }} | ||||||
| 								</view> |                 </view> | ||||||
| 								<view class="origin-price-text" v-if="state.goodsInfo.marketPrice > 0"> |                 <view class="origin-price-text" v-if="state.goodsInfo.marketPrice > 0"> | ||||||
| 									{{ fen2yuan(state.selectedSku.marketPrice || state.goodsInfo.marketPrice) }} |                   {{ fen2yuan(state.selectedSku.marketPrice || state.goodsInfo.marketPrice) }} | ||||||
| 								</view> |                 </view> | ||||||
| 							</view> |               </view> | ||||||
| 							<view class="sales-text"> |               <view class="sales-text"> | ||||||
| 								{{ formatSales('exact', state.goodsInfo.salesCount) }} |                 {{ formatSales('exact', state.goodsInfo.salesCount) }} | ||||||
| 							</view> |               </view> | ||||||
| 						</view> |             </view> | ||||||
| 						<view class="discounts-box ss-flex ss-row-between ss-m-b-28"> |             <view class="discounts-box ss-flex ss-row-between ss-m-b-28"> | ||||||
| 							<!-- 满减送/限时折扣活动的提示 --> |               <!-- 满减送/限时折扣活动的提示 --> | ||||||
| 							<div class="tag-content"> |               <div class="tag-content"> | ||||||
| 								<view class="tag-box ss-flex"> |                 <view class="tag-box ss-flex"> | ||||||
| 									<view class="tag ss-m-r-10" v-for="promos in state.activityInfo" |                   <view | ||||||
|                         :key="promos.id" @tap="onActivity"> |                     class="tag ss-m-r-10" | ||||||
| 										{{ promos.name }} |                     v-for="promos in state.activityInfo" | ||||||
| 									</view> |                     :key="promos.id" | ||||||
| 								</view> |                     @tap="onActivity" | ||||||
| 							</div> |                   > | ||||||
|  |                     {{ promos.name }} | ||||||
|  |                   </view> | ||||||
|  |                 </view> | ||||||
|  |               </div> | ||||||
| 
 | 
 | ||||||
| 							<!-- 优惠劵 --> |               <!-- 优惠劵 --> | ||||||
| 							<view class="get-coupon-box ss-flex ss-col-center ss-m-l-20" @tap="state.showModel = true" |               <view | ||||||
| 								v-if="state.couponInfo.length"> |                 class="get-coupon-box ss-flex ss-col-center ss-m-l-20" | ||||||
| 								<view class="discounts-title ss-m-r-8">领券</view> |                 @tap="state.showModel = true" | ||||||
| 								<text class="cicon-forward"></text> |                 v-if="state.couponInfo.length" | ||||||
| 							</view> |               > | ||||||
| 						</view> |                 <view class="discounts-title ss-m-r-8">领券</view> | ||||||
| 						<view class="title-text ss-line-2 ss-m-b-6">{{ state.goodsInfo.name }}</view> |                 <text class="cicon-forward"></text> | ||||||
| 						<view class="subtitle-text ss-line-1">{{ state.goodsInfo.introduction }}</view> |               </view> | ||||||
| 					</view> |             </view> | ||||||
|  |             <view class="title-text ss-line-2 ss-m-b-6">{{ state.goodsInfo.name }}</view> | ||||||
|  |             <view class="subtitle-text ss-line-1">{{ state.goodsInfo.introduction }}</view> | ||||||
|  |           </view> | ||||||
| 
 | 
 | ||||||
| 					<!-- 功能卡片 --> |           <!-- 功能卡片 --> | ||||||
| 					<view class="detail-cell-card detail-card ss-flex-col"> |           <view class="detail-cell-card detail-card ss-flex-col"> | ||||||
| 						<detail-cell-sku v-model="state.selectedSku.goods_sku_text" :sku="state.selectedSku" |             <detail-cell-sku | ||||||
|                              @tap="state.showSelectSku = true" /> |               v-model="state.selectedSku.goods_sku_text" | ||||||
| 					</view> |               :sku="state.selectedSku" | ||||||
|  |               @tap="state.showSelectSku = true" | ||||||
|  |             /> | ||||||
|  |           </view> | ||||||
| 
 | 
 | ||||||
| 					<!-- 规格与数量弹框 --> |           <!-- 规格与数量弹框 --> | ||||||
| 					<s-select-sku :goodsInfo="state.goodsInfo" :show="state.showSelectSku" @addCart="onAddCart" |           <s-select-sku | ||||||
|                         @buy="onBuy" @change="onSkuChange" @close="state.showSelectSku = false" /> |             :goodsInfo="state.goodsInfo" | ||||||
| 				</view> |             :show="state.showSelectSku" | ||||||
|  |             @addCart="onAddCart" | ||||||
|  |             @buy="onBuy" | ||||||
|  |             @change="onSkuChange" | ||||||
|  |             @close="state.showSelectSku = false" | ||||||
|  |           /> | ||||||
|  |         </view> | ||||||
| 
 | 
 | ||||||
| 				<!-- 评价 --> |         <!-- 评价 --> | ||||||
| 				<detail-comment-card class="detail-comment-selector" :goodsId="state.goodsId" /> |         <detail-comment-card class="detail-comment-selector" :goodsId="state.goodsId" /> | ||||||
| 				<!-- 详情 --> |         <!-- 详情 --> | ||||||
| 				<detail-content-card class="detail-content-selector" :content="state.goodsInfo.description" /> |         <detail-content-card | ||||||
|  |           class="detail-content-selector" | ||||||
|  |           :content="state.goodsInfo.description" | ||||||
|  |         /> | ||||||
| 
 | 
 | ||||||
| 				<!-- 活动跳转:拼团/秒杀/砍价活动 --> |         <!-- 活动跳转:拼团/秒杀/砍价活动 --> | ||||||
| 				<detail-activity-tip v-if="state.activityList.length > 0" :activity-list="state.activityList" /> |         <detail-activity-tip | ||||||
|  |           v-if="state.activityList.length > 0" | ||||||
|  |           :activity-list="state.activityList" | ||||||
|  |         /> | ||||||
| 
 | 
 | ||||||
| 				<!-- 详情 tabbar --> |         <!-- 详情 tabbar --> | ||||||
| 				<detail-tabbar v-model="state.goodsInfo"> |         <detail-tabbar v-model="state.goodsInfo"> | ||||||
| 					<view class="buy-box ss-flex ss-col-center ss-p-r-20" v-if="state.goodsInfo.stock > 0"> |           <view class="buy-box ss-flex ss-col-center ss-p-r-20" v-if="state.goodsInfo.stock > 0"> | ||||||
| 						<button class="ss-reset-button add-btn ui-Shadow-Main" @tap="state.showSelectSku = true"> |             <button | ||||||
| 							加入购物车 |               class="ss-reset-button add-btn ui-Shadow-Main" | ||||||
| 						</button> |               @tap="state.showSelectSku = true" | ||||||
| 						<button class="ss-reset-button buy-btn ui-Shadow-Main" @tap="state.showSelectSku = true"> |             > | ||||||
| 							立即购买 |               加入购物车 | ||||||
| 						</button> |             </button> | ||||||
| 					</view> |             <button | ||||||
| 					<view class="buy-box ss-flex ss-col-center ss-p-r-20" v-else> |               class="ss-reset-button buy-btn ui-Shadow-Main" | ||||||
| 						<button class="ss-reset-button disabled-btn" disabled> 已售罄 </button> |               @tap="state.showSelectSku = true" | ||||||
| 					</view> |             > | ||||||
| 				</detail-tabbar> |               立即购买 | ||||||
|  |             </button> | ||||||
|  |           </view> | ||||||
|  |           <view class="buy-box ss-flex ss-col-center ss-p-r-20" v-else> | ||||||
|  |             <button class="ss-reset-button disabled-btn" disabled> 已售罄 </button> | ||||||
|  |           </view> | ||||||
|  |         </detail-tabbar> | ||||||
| 
 | 
 | ||||||
| 				<!-- 优惠劵弹窗 --> |         <!-- 优惠劵弹窗 --> | ||||||
| 				<s-coupon-get v-model="state.couponInfo" :show="state.showModel" @close="state.showModel = false" |         <s-coupon-get | ||||||
|                       @get="onGet" /> |           v-model="state.couponInfo" | ||||||
|  |           :show="state.showModel" | ||||||
|  |           @close="state.showModel = false" | ||||||
|  |           @get="onGet" | ||||||
|  |         /> | ||||||
| 
 | 
 | ||||||
| 				<!-- 满减送/限时折扣活动弹窗 --> |         <!-- 满减送/限时折扣活动弹窗 --> | ||||||
| 				<s-activity-pop v-model="state.activityInfo" :show="state.showActivityModel" |         <s-activity-pop | ||||||
|                         @close="state.showActivityModel = false" /> |           v-model="state.activityInfo" | ||||||
| 			</block> |           :show="state.showActivityModel" | ||||||
| 		</s-layout> |           @close="state.showActivityModel = false" | ||||||
| 	</view> |         /> | ||||||
|  |       </block> | ||||||
|  |     </s-layout> | ||||||
|  |   </view> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { reactive, computed } from 'vue'; |   import { reactive, computed } from 'vue'; | ||||||
| 	import { onLoad, onPageScroll } from '@dcloudio/uni-app'; |   import { onLoad, onPageScroll } from '@dcloudio/uni-app'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import CouponApi from '@/sheep/api/promotion/coupon'; |   import CouponApi from '@/sheep/api/promotion/coupon'; | ||||||
| 	import ActivityApi from '@/sheep/api/promotion/activity'; |   import ActivityApi from '@/sheep/api/promotion/activity'; | ||||||
|   import FavoriteApi from '@/sheep/api/product/favorite'; |   import FavoriteApi from '@/sheep/api/product/favorite'; | ||||||
|   import { formatSales, formatGoodsSwiper, fen2yuan } from '@/sheep/hooks/useGoods'; |   import { formatSales, formatGoodsSwiper, fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
| 	import detailNavbar from './components/detail/detail-navbar.vue'; |   import detailNavbar from './components/detail/detail-navbar.vue'; | ||||||
| 	import detailCellSku from './components/detail/detail-cell-sku.vue'; |   import detailCellSku from './components/detail/detail-cell-sku.vue'; | ||||||
| 	import detailTabbar from './components/detail/detail-tabbar.vue'; |   import detailTabbar from './components/detail/detail-tabbar.vue'; | ||||||
| 	import detailSkeleton from './components/detail/detail-skeleton.vue'; |   import detailSkeleton from './components/detail/detail-skeleton.vue'; | ||||||
| 	import detailCommentCard from './components/detail/detail-comment-card.vue'; |   import detailCommentCard from './components/detail/detail-comment-card.vue'; | ||||||
| 	import detailContentCard from './components/detail/detail-content-card.vue'; |   import detailContentCard from './components/detail/detail-content-card.vue'; | ||||||
| 	import detailActivityTip from './components/detail/detail-activity-tip.vue'; |   import detailActivityTip from './components/detail/detail-activity-tip.vue'; | ||||||
| 	import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
| 
 | 
 | ||||||
| 	onPageScroll(() => {}); |   onPageScroll(() => {}); | ||||||
| 
 | 
 | ||||||
|   const isLogin = computed(() => sheep.$store('user').isLogin); |   const isLogin = computed(() => sheep.$store('user').isLogin); | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
| 		goodsId: 0, |     goodsId: 0, | ||||||
| 		skeletonLoading: true, // SPU 加载中 |     skeletonLoading: true, // SPU 加载中 | ||||||
| 		goodsInfo: {}, // SPU 信息 |     goodsInfo: {}, // SPU 信息 | ||||||
| 		showSelectSku: false, // 是否展示 SKU 选择弹窗 |     showSelectSku: false, // 是否展示 SKU 选择弹窗 | ||||||
| 		selectedSku: {}, // 选中的 SKU |     selectedSku: {}, // 选中的 SKU | ||||||
| 		showModel: false, // 是否展示 Coupon 优惠劵的弹窗 |     showModel: false, // 是否展示 Coupon 优惠劵的弹窗 | ||||||
| 		couponInfo: [], // 可领取的 Coupon 优惠劵的列表 |     couponInfo: [], // 可领取的 Coupon 优惠劵的列表 | ||||||
| 		showActivityModel: false, // 【满减送/限时折扣】是否展示 Activity 营销活动的弹窗 |     showActivityModel: false, // 【满减送/限时折扣】是否展示 Activity 营销活动的弹窗 | ||||||
| 		activityInfo: [], // 【满减送/限时折扣】可参与的 Activity 营销活动的列表 |     activityInfo: [], // 【满减送/限时折扣】可参与的 Activity 营销活动的列表 | ||||||
| 		activityList: [], // 【秒杀/拼团/砍价】可参与的 Activity 营销活动的列表 |     activityList: [], // 【秒杀/拼团/砍价】可参与的 Activity 营销活动的列表 | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 规格变更 |   // 规格变更 | ||||||
| 	function onSkuChange(e) { |   function onSkuChange(e) { | ||||||
| 		state.selectedSku = e; |     state.selectedSku = e; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 添加购物车 |   // 添加购物车 | ||||||
| 	function onAddCart(e) { |   function onAddCart(e) { | ||||||
|     if (!e.id) { |     if (!e.id) { | ||||||
|       sheep.$helper.toast('请选择商品规格'); |       sheep.$helper.toast('请选择商品规格'); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| 		sheep.$store('cart').add(e); |     sheep.$store('cart').add(e); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 立即购买 |   // 立即购买 | ||||||
| 	function onBuy(e) { |   function onBuy(e) { | ||||||
|     if (!state.selectedSku.id) { |     if (!state.selectedSku.id) { | ||||||
|       sheep.$helper.toast('请选择商品规格'); |       sheep.$helper.toast('请选择商品规格'); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     sheep.$router.go('/pages/order/confirm', { |     sheep.$router.go('/pages/order/confirm', { | ||||||
|       data: JSON.stringify({ |       data: JSON.stringify({ | ||||||
|         items: [{ |         items: [ | ||||||
|           skuId: e.id, |           { | ||||||
|           count: e.goods_num |             skuId: e.id, | ||||||
|         }], |             count: e.goods_num, | ||||||
|  |           }, | ||||||
|  |         ], | ||||||
|         // TODO 芋艿:后续清理掉这 2 参数 |         // TODO 芋艿:后续清理掉这 2 参数 | ||||||
|         deliveryType: 1, |         deliveryType: 1, | ||||||
|         pointStatus: false, |         pointStatus: false, | ||||||
|       }), |       }), | ||||||
|     }); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 营销活动 |   // 营销活动 | ||||||
| 	function onActivity() { |   function onActivity() { | ||||||
| 		state.showActivityModel = true; |     state.showActivityModel = true; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 立即领取 |   // 立即领取 | ||||||
| 	async function onGet(id) { |   async function onGet(id) { | ||||||
|     const { code } = await CouponApi.takeCoupon(id); |     const { code } = await CouponApi.takeCoupon(id); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  | @ -182,27 +232,30 @@ | ||||||
|     setTimeout(() => { |     setTimeout(() => { | ||||||
|       getCoupon(); |       getCoupon(); | ||||||
|     }, 1000); |     }, 1000); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	//  TODO 芋艿:待测试 |   //  TODO 芋艿:待测试 | ||||||
| 	const shareInfo = computed(() => { |   const shareInfo = computed(() => { | ||||||
| 		if (isEmpty(state.goodsInfo)) return {}; |     if (isEmpty(state.goodsInfo)) return {}; | ||||||
| 		return sheep.$platform.share.getShareInfo({ |     return sheep.$platform.share.getShareInfo( | ||||||
| 			title: state.goodsInfo.name, |       { | ||||||
| 			image: sheep.$url.cdn(state.goodsInfo.picUrl), |         title: state.goodsInfo.name, | ||||||
| 			desc: state.goodsInfo.introduction, |         image: sheep.$url.cdn(state.goodsInfo.picUrl), | ||||||
| 			params: { |         desc: state.goodsInfo.introduction, | ||||||
| 				page: '2', |         params: { | ||||||
| 				query: state.goodsInfo.id, |           page: '2', | ||||||
| 			}, |           query: state.goodsInfo.id, | ||||||
| 		}, { |         }, | ||||||
| 			type: 'goods', // 商品海报 |       }, | ||||||
| 			title: state.goodsInfo.name, // 商品名称 |       { | ||||||
| 			image: sheep.$url.cdn(state.goodsInfo.picUrl), // 商品主图 |         type: 'goods', // 商品海报 | ||||||
| 			price: fen2yuan(state.goodsInfo.price), // 商品价格 |         title: state.goodsInfo.name, // 商品名称 | ||||||
| 			original_price: fen2yuan(state.goodsInfo.marketPrice), // 商品原价 |         image: sheep.$url.cdn(state.goodsInfo.picUrl), // 商品主图 | ||||||
| 		}); |         price: fen2yuan(state.goodsInfo.price), // 商品价格 | ||||||
| 	}); |         original_price: fen2yuan(state.goodsInfo.marketPrice), // 商品原价 | ||||||
|  |       }, | ||||||
|  |     ); | ||||||
|  |   }); | ||||||
| 
 | 
 | ||||||
|   async function getCoupon() { |   async function getCoupon() { | ||||||
|     const { code, data } = await CouponApi.getCouponTemplateList(state.goodsId, 2, 10); |     const { code, data } = await CouponApi.getCouponTemplateList(state.goodsId, 2, 10); | ||||||
|  | @ -211,23 +264,23 @@ | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad((options) => { |   onLoad((options) => { | ||||||
| 		// 非法参数 |     // 非法参数 | ||||||
| 		if (!options.id) { |     if (!options.id) { | ||||||
| 			state.goodsInfo = null; |       state.goodsInfo = null; | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
| 		state.goodsId = options.id; |     state.goodsId = options.id; | ||||||
| 		// 1. 加载商品信息 |     // 1. 加载商品信息 | ||||||
| 		SpuApi.getSpuDetail(state.goodsId).then((res) => { |     SpuApi.getSpuDetail(state.goodsId).then((res) => { | ||||||
| 			// 未找到商品 |       // 未找到商品 | ||||||
| 			if (res.code !== 0 || !res.data) { |       if (res.code !== 0 || !res.data) { | ||||||
| 				state.goodsInfo = null; |         state.goodsInfo = null; | ||||||
| 				return; |         return; | ||||||
| 			} |       } | ||||||
| 			// 加载到商品 |       // 加载到商品 | ||||||
| 			state.skeletonLoading = false; |       state.skeletonLoading = false; | ||||||
| 			state.goodsInfo = res.data; |       state.goodsInfo = res.data; | ||||||
| 
 | 
 | ||||||
|       // 加载是否收藏 |       // 加载是否收藏 | ||||||
|       if (isLogin.value) { |       if (isLogin.value) { | ||||||
|  | @ -238,172 +291,175 @@ | ||||||
|           state.goodsInfo.favorite = res.data; |           state.goodsInfo.favorite = res.data; | ||||||
|         }); |         }); | ||||||
|       } |       } | ||||||
| 		}); |     }); | ||||||
| 
 | 
 | ||||||
| 		// 2. 加载优惠劵信息 |     // 2. 加载优惠劵信息 | ||||||
|     getCoupon(); |     getCoupon(); | ||||||
| 
 | 
 | ||||||
| 		// 3. 加载营销活动信息 |     // 3. 加载营销活动信息 | ||||||
| 		ActivityApi.getActivityListBySpuId(state.goodsId).then((res) => { |     ActivityApi.getActivityListBySpuId(state.goodsId).then((res) => { | ||||||
| 			if (res.code !== 0) { |       if (res.code !== 0) { | ||||||
| 				return; |         return; | ||||||
| 			} |       } | ||||||
|       res.data.forEach(activity => { |       res.data.forEach((activity) => { | ||||||
|         if ([1, 2, 3].includes(activity.type)) { // 情况一:拼团/秒杀/砍价 |         if ([1, 2, 3].includes(activity.type)) { | ||||||
|  |           // 情况一:拼团/秒杀/砍价 | ||||||
|           state.activityList.push(activity); |           state.activityList.push(activity); | ||||||
|         } else if (activity.type === 5) { // 情况二:满减送 |         } else if (activity.type === 5) { | ||||||
|  |           // 情况二:满减送 | ||||||
|           state.activityInfo.push(activity); |           state.activityInfo.push(activity); | ||||||
|         } else { // 情况三:限时折扣 TODO 芋艿 |         } else { | ||||||
|  |           // 情况三:限时折扣 TODO 芋艿 | ||||||
|           console.log('待实现!优先级不高'); |           console.log('待实现!优先级不高'); | ||||||
|         } |         } | ||||||
|       }) |       }); | ||||||
| 		}); |     }); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.detail-card { |   .detail-card { | ||||||
| 		background-color: #ffff; |     background-color: #ffff; | ||||||
| 		margin: 14rpx 20rpx; |     margin: 14rpx 20rpx; | ||||||
| 		border-radius: 10rpx; |     border-radius: 10rpx; | ||||||
| 		overflow: hidden; |     overflow: hidden; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 价格标题卡片 |   // 价格标题卡片 | ||||||
| 	.title-card { |   .title-card { | ||||||
| 		.price-box { |     .price-box { | ||||||
| 			.price-text { |       .price-text { | ||||||
| 				font-size: 42rpx; |         font-size: 42rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				color: #ff3000; |         color: #ff3000; | ||||||
| 				line-height: 30rpx; |         line-height: 30rpx; | ||||||
| 				font-family: OPPOSANS; |         font-family: OPPOSANS; | ||||||
| 
 | 
 | ||||||
| 				&::before { |         &::before { | ||||||
| 					content: '¥'; |           content: '¥'; | ||||||
| 					font-size: 30rpx; |           font-size: 30rpx; | ||||||
| 				} |         } | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.origin-price-text { |       .origin-price-text { | ||||||
| 				font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 				font-weight: 400; |         font-weight: 400; | ||||||
| 				text-decoration: line-through; |         text-decoration: line-through; | ||||||
| 				color: $gray-c; |         color: $gray-c; | ||||||
| 				font-family: OPPOSANS; |         font-family: OPPOSANS; | ||||||
| 
 | 
 | ||||||
| 				&::before { |         &::before { | ||||||
| 					content: '¥'; |           content: '¥'; | ||||||
| 				} |         } | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.sales-text { |     .sales-text { | ||||||
| 			font-size: 26rpx; |       font-size: 26rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: $gray-c; |       color: $gray-c; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.discounts-box { |     .discounts-box { | ||||||
| 			.tag-content { |       .tag-content { | ||||||
| 				flex: 1; |         flex: 1; | ||||||
| 				min-width: 0; |         min-width: 0; | ||||||
| 				white-space: nowrap; |         white-space: nowrap; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.tag-box { |       .tag-box { | ||||||
| 				overflow: hidden; |         overflow: hidden; | ||||||
| 				text-overflow: ellipsis; |         text-overflow: ellipsis; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.tag { |       .tag { | ||||||
| 				flex-shrink: 0; |         flex-shrink: 0; | ||||||
| 				padding: 4rpx 10rpx; |         padding: 4rpx 10rpx; | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				border-radius: 4rpx; |         border-radius: 4rpx; | ||||||
| 				color: var(--ui-BG-Main); |         color: var(--ui-BG-Main); | ||||||
| 				background: var(--ui-BG-Main-tag); |         background: var(--ui-BG-Main-tag); | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.discounts-title { |       .discounts-title { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 				color: var(--ui-BG-Main); |         color: var(--ui-BG-Main); | ||||||
| 				line-height: normal; |         line-height: normal; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.cicon-forward { |       .cicon-forward { | ||||||
| 				color: var(--ui-BG-Main); |         color: var(--ui-BG-Main); | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				line-height: normal; |         line-height: normal; | ||||||
| 				margin-top: 4rpx; |         margin-top: 4rpx; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.title-text { |     .title-text { | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 			font-weight: bold; |       font-weight: bold; | ||||||
| 			line-height: 42rpx; |       line-height: 42rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.subtitle-text { |     .subtitle-text { | ||||||
| 			font-size: 26rpx; |       font-size: 26rpx; | ||||||
| 			font-weight: 400; |       font-weight: 400; | ||||||
| 			color: $dark-9; |       color: $dark-9; | ||||||
| 			line-height: 42rpx; |       line-height: 42rpx; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 购买 |   // 购买 | ||||||
| 	.buy-box { |   .buy-box { | ||||||
| 		.add-btn { |     .add-btn { | ||||||
| 			width: 214rpx; |       width: 214rpx; | ||||||
| 			height: 72rpx; |       height: 72rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 			border-radius: 40rpx 0 0 40rpx; |       border-radius: 40rpx 0 0 40rpx; | ||||||
| 			background-color: var(--ui-BG-Main-light); |       background-color: var(--ui-BG-Main-light); | ||||||
| 			color: var(--ui-BG-Main); |       color: var(--ui-BG-Main); | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.buy-btn { |     .buy-btn { | ||||||
| 			width: 214rpx; |       width: 214rpx; | ||||||
| 			height: 72rpx; |       height: 72rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 
 | 
 | ||||||
| 			border-radius: 0 40rpx 40rpx 0; |       border-radius: 0 40rpx 40rpx 0; | ||||||
| 			background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); |       background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); | ||||||
| 			color: $white; |       color: $white; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.disabled-btn { |     .disabled-btn { | ||||||
| 			width: 428rpx; |       width: 428rpx; | ||||||
| 			height: 72rpx; |       height: 72rpx; | ||||||
| 			border-radius: 40rpx; |       border-radius: 40rpx; | ||||||
| 			background: #999999; |       background: #999999; | ||||||
| 			color: $white; |       color: $white; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.model-box { |   .model-box { | ||||||
| 		height: 60vh; |     height: 60vh; | ||||||
| 
 | 
 | ||||||
| 		.model-content { |     .model-content { | ||||||
| 			height: 56vh; |       height: 56vh; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.title { |     .title { | ||||||
| 			font-size: 36rpx; |       font-size: 36rpx; | ||||||
| 			font-weight: bold; |       font-weight: bold; | ||||||
| 			color: #333333; |       color: #333333; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.subtitle { |     .subtitle { | ||||||
| 			font-size: 26rpx; |       font-size: 26rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: #333333; |       color: #333333; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -1,362 +1,398 @@ | ||||||
| <template> | <template> | ||||||
| 	<s-layout navbar="normal" :leftWidth="0" :rightWidth="0" tools="search" :defaultSearch="state.keyword" |   <s-layout | ||||||
| 		@search="onSearch"> |     navbar="normal" | ||||||
| 		<!-- 筛选 --> |     :leftWidth="0" | ||||||
| 		<su-sticky bgColor="#fff"> |     :rightWidth="0" | ||||||
| 			<view class="ss-flex"> |     tools="search" | ||||||
| 				<view class="ss-flex-1"> |     :defaultSearch="state.keyword" | ||||||
| 					<su-tabs :list="state.tabList" :scrollable="false" @change="onTabsChange" |     @search="onSearch" | ||||||
|                    :current="state.currentTab" /> |   > | ||||||
| 				</view> |     <!-- 筛选 --> | ||||||
| 				<view class="list-icon" @tap="state.iconStatus = !state.iconStatus"> |     <su-sticky bgColor="#fff"> | ||||||
| 					<text v-if="state.iconStatus" class="sicon-goods-list" /> |       <view class="ss-flex"> | ||||||
| 					<text v-else class="sicon-goods-card" /> |         <view class="ss-flex-1"> | ||||||
| 				</view> |           <su-tabs | ||||||
| 			</view> |             :list="state.tabList" | ||||||
| 		</su-sticky> |             :scrollable="false" | ||||||
|  |             @change="onTabsChange" | ||||||
|  |             :current="state.currentTab" | ||||||
|  |           /> | ||||||
|  |         </view> | ||||||
|  |         <view class="list-icon" @tap="state.iconStatus = !state.iconStatus"> | ||||||
|  |           <text v-if="state.iconStatus" class="sicon-goods-list" /> | ||||||
|  |           <text v-else class="sicon-goods-card" /> | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
|  |     </su-sticky> | ||||||
| 
 | 
 | ||||||
| 		<!-- 弹窗 --> |     <!-- 弹窗 --> | ||||||
| 		<su-popup :show="state.showFilter" type="top" round="10" :space="sys_navBar + 38" backgroundColor="#F6F6F6" |     <su-popup | ||||||
| 			:zIndex="10" @close="state.showFilter = false"> |       :show="state.showFilter" | ||||||
| 			<view class="filter-list-box"> |       type="top" | ||||||
| 				<view class="filter-item" v-for="(item, index) in state.tabList[state.currentTab].list" |       round="10" | ||||||
| 					:key="item.value" :class="[{ 'filter-item-active': index === state.curFilter }]" |       :space="sys_navBar + 38" | ||||||
| 					@tap="onFilterItem(index)"> |       backgroundColor="#F6F6F6" | ||||||
| 					{{ item.label }} |       :zIndex="10" | ||||||
| 				</view> |       @close="state.showFilter = false" | ||||||
| 			</view> |     > | ||||||
| 		</su-popup> |       <view class="filter-list-box"> | ||||||
|  |         <view | ||||||
|  |           class="filter-item" | ||||||
|  |           v-for="(item, index) in state.tabList[state.currentTab].list" | ||||||
|  |           :key="item.value" | ||||||
|  |           :class="[{ 'filter-item-active': index === state.curFilter }]" | ||||||
|  |           @tap="onFilterItem(index)" | ||||||
|  |         > | ||||||
|  |           {{ item.label }} | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
|  |     </su-popup> | ||||||
| 
 | 
 | ||||||
|     <!-- 情况一:单列布局 --> |     <!-- 情况一:单列布局 --> | ||||||
| 		<view v-if="state.iconStatus && state.pagination.total > 0" class="goods-list ss-m-t-20"> |     <view v-if="state.iconStatus && state.pagination.total > 0" class="goods-list ss-m-t-20"> | ||||||
| 			<view class="ss-p-l-20 ss-p-r-20 ss-m-b-20" v-for="item in state.pagination.list" :key="item.id"> |       <view | ||||||
| 				<s-goods-column |         class="ss-p-l-20 ss-p-r-20 ss-m-b-20" | ||||||
|  |         v-for="item in state.pagination.list" | ||||||
|  |         :key="item.id" | ||||||
|  |       > | ||||||
|  |         <s-goods-column | ||||||
|           class="" |           class="" | ||||||
|           size="lg" |           size="lg" | ||||||
|           :data="item" |           :data="item" | ||||||
|           :topRadius="10" |           :topRadius="10" | ||||||
|           :bottomRadius="10" |           :bottomRadius="10" | ||||||
| 					@click="sheep.$router.go('/pages/goods/index', { id: item.id })" |           @click="sheep.$router.go('/pages/goods/index', { id: item.id })" | ||||||
|         /> |         /> | ||||||
| 			</view> |       </view> | ||||||
| 		</view> |     </view> | ||||||
|     <!-- 情况二:双列布局 --> |     <!-- 情况二:双列布局 --> | ||||||
|     <view v-if="!state.iconStatus && state.pagination.total > 0" |     <view | ||||||
| 			class="ss-flex ss-flex-wrap ss-p-x-20 ss-m-t-20 ss-col-top"> |       v-if="!state.iconStatus && state.pagination.total > 0" | ||||||
| 			<view class="goods-list-box"> |       class="ss-flex ss-flex-wrap ss-p-x-20 ss-m-t-20 ss-col-top" | ||||||
| 				<view class="left-list" v-for="item in state.leftGoodsList" :key="item.id"> |     > | ||||||
| 					<s-goods-column |       <view class="goods-list-box"> | ||||||
|  |         <view class="left-list" v-for="item in state.leftGoodsList" :key="item.id"> | ||||||
|  |           <s-goods-column | ||||||
|             class="goods-md-box" |             class="goods-md-box" | ||||||
|             size="md" |             size="md" | ||||||
|             :data="item" |             :data="item" | ||||||
|             :topRadius="10" |             :topRadius="10" | ||||||
|             :bottomRadius="10" |             :bottomRadius="10" | ||||||
| 						@click="sheep.$router.go('/pages/goods/index', { id: item.id })" |             @click="sheep.$router.go('/pages/goods/index', { id: item.id })" | ||||||
| 						@getHeight="mountMasonry($event, 'left')" |             @getHeight="mountMasonry($event, 'left')" | ||||||
|           > |           > | ||||||
| 						<template v-slot:cart> |             <template v-slot:cart> | ||||||
| 							<button class="ss-reset-button cart-btn" /> |               <button class="ss-reset-button cart-btn" /> | ||||||
| 						</template> |             </template> | ||||||
| 					</s-goods-column> |           </s-goods-column> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 			<view class="goods-list-box"> |       <view class="goods-list-box"> | ||||||
| 				<view class="right-list" v-for="item in state.rightGoodsList" :key="item.id"> |         <view class="right-list" v-for="item in state.rightGoodsList" :key="item.id"> | ||||||
| 					<s-goods-column |           <s-goods-column | ||||||
|             class="goods-md-box" |             class="goods-md-box" | ||||||
|             size="md" |             size="md" | ||||||
|             :topRadius="10" |             :topRadius="10" | ||||||
|             :bottomRadius="10" |             :bottomRadius="10" | ||||||
|             :data="item" |             :data="item" | ||||||
| 						@click="sheep.$router.go('/pages/goods/index', { id: item.id })" |             @click="sheep.$router.go('/pages/goods/index', { id: item.id })" | ||||||
| 						@getHeight="mountMasonry($event, 'right')" |             @getHeight="mountMasonry($event, 'right')" | ||||||
|           > |           > | ||||||
| 						<template v-slot:cart> |             <template v-slot:cart> | ||||||
| 							<button class="ss-reset-button cart-btn" /> |               <button class="ss-reset-button cart-btn" /> | ||||||
| 						</template> |             </template> | ||||||
| 					</s-goods-column> |           </s-goods-column> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 		</view> |     </view> | ||||||
| 		<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{ |     <uni-load-more | ||||||
|  |       v-if="state.pagination.total > 0" | ||||||
|  |       :status="state.loadStatus" | ||||||
|  |       :content-text="{ | ||||||
|         contentdown: '上拉加载更多', |         contentdown: '上拉加载更多', | ||||||
|       }" @tap="loadMore" /> |       }" | ||||||
| 		<s-empty v-if="state.pagination.total === 0" icon="/static/soldout-empty.png" text="暂无商品" /> |       @tap="loadMore" | ||||||
| 	</s-layout> |     /> | ||||||
|  |     <s-empty v-if="state.pagination.total === 0" icon="/static/soldout-empty.png" text="暂无商品" /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
| 	import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
| 
 | 
 | ||||||
| 	const sys_navBar = sheep.$platform.navbar; |   const sys_navBar = sheep.$platform.navbar; | ||||||
| 	const emits = defineEmits(['close', 'change']); |   const emits = defineEmits(['close', 'change']); | ||||||
| 
 | 
 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		pagination: { |     pagination: { | ||||||
| 			list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
| 			pageSize: 6, |       pageSize: 6, | ||||||
| 		}, |     }, | ||||||
| 		currentSort: undefined, |     currentSort: undefined, | ||||||
| 		currentOrder: undefined, |     currentOrder: undefined, | ||||||
| 		currentTab: 0, // 当前选中的 tab |     currentTab: 0, // 当前选中的 tab | ||||||
| 		curFilter: 0, // 当前选中的 list 筛选项 |     curFilter: 0, // 当前选中的 list 筛选项 | ||||||
| 		showFilter: false, |     showFilter: false, | ||||||
| 		iconStatus: false, // true - 单列布局;false - 双列布局 |     iconStatus: false, // true - 单列布局;false - 双列布局 | ||||||
|     keyword: '', |     keyword: '', | ||||||
|     categoryId: 0, |     categoryId: 0, | ||||||
| 		tabList: [{ |     tabList: [ | ||||||
| 				name: '综合推荐', |       { | ||||||
| 				list: [{ |         name: '综合推荐', | ||||||
| 						label: '综合推荐' |         list: [ | ||||||
| 					}, |           { | ||||||
| 					{ |             label: '综合推荐', | ||||||
| 						label: '价格升序', |           }, | ||||||
| 						sort: 'price', |           { | ||||||
| 						order: true, |             label: '价格升序', | ||||||
| 					}, |             sort: 'price', | ||||||
| 					{ |             order: true, | ||||||
| 						label: '价格降序', |           }, | ||||||
| 						sort: 'price', |           { | ||||||
| 						order: false, |             label: '价格降序', | ||||||
| 					}, |             sort: 'price', | ||||||
| 				], |             order: false, | ||||||
| 			}, |           }, | ||||||
| 			{ |         ], | ||||||
| 				name: '销量', |       }, | ||||||
| 				sort: 'salesCount', |       { | ||||||
| 				order: false |         name: '销量', | ||||||
| 			}, |         sort: 'salesCount', | ||||||
| 			{ |         order: false, | ||||||
| 				name: '新品优先', |       }, | ||||||
| 				value: 'createTime', |       { | ||||||
|         order: false |         name: '新品优先', | ||||||
| 			}, |         value: 'createTime', | ||||||
| 		], |         order: false, | ||||||
| 		loadStatus: '', |       }, | ||||||
| 		leftGoodsList: [], // 双列布局 - 左侧商品 |     ], | ||||||
| 		rightGoodsList: [], // 双列布局 - 右侧商品 |     loadStatus: '', | ||||||
| 	}); |     leftGoodsList: [], // 双列布局 - 左侧商品 | ||||||
|  |     rightGoodsList: [], // 双列布局 - 右侧商品 | ||||||
|  |   }); | ||||||
| 
 | 
 | ||||||
| 	// 加载瀑布流 |   // 加载瀑布流 | ||||||
| 	let count = 0; |   let count = 0; | ||||||
| 	let leftHeight = 0; |   let leftHeight = 0; | ||||||
| 	let rightHeight = 0; |   let rightHeight = 0; | ||||||
| 
 | 
 | ||||||
|   // 处理双列布局 leftGoodsList + rightGoodsList |   // 处理双列布局 leftGoodsList + rightGoodsList | ||||||
| 	function mountMasonry(height = 0, where = 'left') { |   function mountMasonry(height = 0, where = 'left') { | ||||||
| 		if (!state.pagination.list[count]) { |     if (!state.pagination.list[count]) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 		if (where === 'left') { |     if (where === 'left') { | ||||||
| 			leftHeight += height; |       leftHeight += height; | ||||||
| 		} else { |     } else { | ||||||
| 			rightHeight += height; |       rightHeight += height; | ||||||
| 		} |     } | ||||||
| 		if (leftHeight <= rightHeight) { |     if (leftHeight <= rightHeight) { | ||||||
| 			state.leftGoodsList.push(state.pagination.list[count]); |       state.leftGoodsList.push(state.pagination.list[count]); | ||||||
| 		} else { |     } else { | ||||||
| 			state.rightGoodsList.push(state.pagination.list[count]); |       state.rightGoodsList.push(state.pagination.list[count]); | ||||||
| 		} |     } | ||||||
| 		count++; |     count++; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
|   // 清空列表 |   // 清空列表 | ||||||
| 	function emptyList() { |   function emptyList() { | ||||||
|     resetPagination(state.pagination); |     resetPagination(state.pagination); | ||||||
|     state.leftGoodsList = []; |     state.leftGoodsList = []; | ||||||
| 		state.rightGoodsList = []; |     state.rightGoodsList = []; | ||||||
| 		count = 0; |     count = 0; | ||||||
| 		leftHeight = 0; |     leftHeight = 0; | ||||||
| 		rightHeight = 0; |     rightHeight = 0; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 搜索 |   // 搜索 | ||||||
| 	function onSearch(e) { |   function onSearch(e) { | ||||||
| 		state.keyword = e; |     state.keyword = e; | ||||||
| 		emptyList(); |     emptyList(); | ||||||
| 		getList(state.currentSort, state.currentOrder); |     getList(state.currentSort, state.currentOrder); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 点击 |   // 点击 | ||||||
| 	function onTabsChange(e) { |   function onTabsChange(e) { | ||||||
|     // 如果点击的是【综合推荐】,则直接展开或者收起筛选项 |     // 如果点击的是【综合推荐】,则直接展开或者收起筛选项 | ||||||
| 		if (state.tabList[e.index].list) { |     if (state.tabList[e.index].list) { | ||||||
| 			state.currentTab = e.index; |       state.currentTab = e.index; | ||||||
| 			state.showFilter = !state.showFilter; |       state.showFilter = !state.showFilter; | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
|     state.showFilter = false; |     state.showFilter = false; | ||||||
| 
 | 
 | ||||||
|     // 如果点击的是【销量】或者【新品优先】,则直接切换 tab |     // 如果点击的是【销量】或者【新品优先】,则直接切换 tab | ||||||
| 		if (e.index === state.currentTab) { |     if (e.index === state.currentTab) { | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
|     state.currentTab = e.index; |     state.currentTab = e.index; | ||||||
|     state.currentSort = e.sort; |     state.currentSort = e.sort; | ||||||
|     state.currentOrder = e.order; |     state.currentOrder = e.order; | ||||||
| 		emptyList(); |     emptyList(); | ||||||
| 		getList(e.sort, e.order); |     getList(e.sort, e.order); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 点击 tab 的 list 筛选项 |   // 点击 tab 的 list 筛选项 | ||||||
| 	const onFilterItem = (val) => { |   const onFilterItem = (val) => { | ||||||
|     // 如果点击的是当前的筛选项,则直接收起筛选项,不要加载数据 |     // 如果点击的是当前的筛选项,则直接收起筛选项,不要加载数据 | ||||||
|     // 这里选择 tabList[0] 的原因,是目前只有它有 list |     // 这里选择 tabList[0] 的原因,是目前只有它有 list | ||||||
| 		if (state.currentSort === state.tabList[0].list[val].sort |     if ( | ||||||
|       && state.currentOrder === state.tabList[0].list[val].order) { |       state.currentSort === state.tabList[0].list[val].sort && | ||||||
| 			state.showFilter = false; |       state.currentOrder === state.tabList[0].list[val].order | ||||||
| 			return; |     ) { | ||||||
| 		} |       state.showFilter = false; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|     state.showFilter = false; |     state.showFilter = false; | ||||||
| 
 | 
 | ||||||
|     // 设置筛选条件 |     // 设置筛选条件 | ||||||
| 		state.curFilter = val; |     state.curFilter = val; | ||||||
| 		state.tabList[0].name = state.tabList[0].list[val].label; |     state.tabList[0].name = state.tabList[0].list[val].label; | ||||||
| 		state.currentSort = state.tabList[0].list[val].sort; |     state.currentSort = state.tabList[0].list[val].sort; | ||||||
| 		state.currentOrder = state.tabList[0].list[val].order; |     state.currentOrder = state.tabList[0].list[val].order; | ||||||
| 		// 清空 + 加载数据 |     // 清空 + 加载数据 | ||||||
|     emptyList(); |     emptyList(); | ||||||
| 		getList(); |     getList(); | ||||||
| 	} |   }; | ||||||
| 
 | 
 | ||||||
| 	async function getList() { |   async function getList() { | ||||||
| 		state.loadStatus = 'loading'; |     state.loadStatus = 'loading'; | ||||||
| 		const { code, data } = await SpuApi.getSpuPage({ |     const { code, data } = await SpuApi.getSpuPage({ | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
| 			sortField: state.currentSort, |       sortField: state.currentSort, | ||||||
| 			sortAsc: state.currentOrder, |       sortAsc: state.currentOrder, | ||||||
| 			categoryId: state.categoryId, |       categoryId: state.categoryId, | ||||||
| 			keyword: state.keyword, |       keyword: state.keyword, | ||||||
| 		}); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list) |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
|     mountMasonry(); |     mountMasonry(); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 加载更多 |   // 加载更多 | ||||||
| 	function loadMore() { |   function loadMore() { | ||||||
|     if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.pageNo++; |     state.pagination.pageNo++; | ||||||
|     getList(state.currentSort, state.currentOrder); |     getList(state.currentSort, state.currentOrder); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad((options) => { |   onLoad((options) => { | ||||||
| 		state.categoryId = options.categoryId; |     state.categoryId = options.categoryId; | ||||||
| 		state.keyword = options.keyword; |     state.keyword = options.keyword; | ||||||
| 		getList(state.currentSort, state.currentOrder); |     getList(state.currentSort, state.currentOrder); | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 上拉加载更多 |   // 上拉加载更多 | ||||||
| 	onReachBottom(() => { |   onReachBottom(() => { | ||||||
| 		loadMore(); |     loadMore(); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.goods-list-box { |   .goods-list-box { | ||||||
| 		width: 50%; |     width: 50%; | ||||||
| 		box-sizing: border-box; |     box-sizing: border-box; | ||||||
| 
 | 
 | ||||||
| 		.left-list { |     .left-list { | ||||||
| 			margin-right: 10rpx; |       margin-right: 10rpx; | ||||||
| 			margin-bottom: 20rpx; |       margin-bottom: 20rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.right-list { |     .right-list { | ||||||
| 			margin-left: 10rpx; |       margin-left: 10rpx; | ||||||
| 			margin-bottom: 20rpx; |       margin-bottom: 20rpx; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.goods-box { |   .goods-box { | ||||||
| 		&:nth-last-of-type(1) { |     &:nth-last-of-type(1) { | ||||||
| 			margin-bottom: 0 !important; |       margin-bottom: 0 !important; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		&:nth-child(2n) { |     &:nth-child(2n) { | ||||||
| 			margin-right: 0; |       margin-right: 0; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.list-icon { |   .list-icon { | ||||||
| 		width: 80rpx; |     width: 80rpx; | ||||||
| 
 | 
 | ||||||
| 		.sicon-goods-card { |     .sicon-goods-card { | ||||||
| 			font-size: 40rpx; |       font-size: 40rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.sicon-goods-list { |     .sicon-goods-list { | ||||||
| 			font-size: 40rpx; |       font-size: 40rpx; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.goods-card { |   .goods-card { | ||||||
| 		margin-left: 20rpx; |     margin-left: 20rpx; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.list-filter-tabs { |   .list-filter-tabs { | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.filter-list-box { |   .filter-list-box { | ||||||
| 		padding: 28rpx 52rpx; |     padding: 28rpx 52rpx; | ||||||
| 
 | 
 | ||||||
| 		.filter-item { |     .filter-item { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: #333333; |       color: #333333; | ||||||
| 			line-height: normal; |       line-height: normal; | ||||||
| 			margin-bottom: 24rpx; |       margin-bottom: 24rpx; | ||||||
| 
 | 
 | ||||||
| 			&:nth-last-child(1) { |       &:nth-last-child(1) { | ||||||
| 				margin-bottom: 0; |         margin-bottom: 0; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.filter-item-active { |     .filter-item-active { | ||||||
| 			color: var(--ui-BG-Main); |       color: var(--ui-BG-Main); | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.tab-item { |   .tab-item { | ||||||
| 		height: 50px; |     height: 50px; | ||||||
| 		position: relative; |     position: relative; | ||||||
| 		z-index: 11; |     z-index: 11; | ||||||
| 
 | 
 | ||||||
| 		.tab-title { |     .tab-title { | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.cur-tab-title { |     .cur-tab-title { | ||||||
| 			font-weight: $font-weight-bold; |       font-weight: $font-weight-bold; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.tab-line { |     .tab-line { | ||||||
| 			width: 60rpx; |       width: 60rpx; | ||||||
| 			height: 6rpx; |       height: 6rpx; | ||||||
| 			border-radius: 6rpx; |       border-radius: 6rpx; | ||||||
| 			position: absolute; |       position: absolute; | ||||||
| 			left: 50%; |       left: 50%; | ||||||
| 			transform: translateX(-50%); |       transform: translateX(-50%); | ||||||
| 			bottom: 10rpx; |       bottom: 10rpx; | ||||||
| 			background-color: var(--ui-BG-Main); |       background-color: var(--ui-BG-Main); | ||||||
| 			z-index: 12; |       z-index: 12; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -69,10 +69,7 @@ | ||||||
| 
 | 
 | ||||||
|         <!-- 功能卡片 --> |         <!-- 功能卡片 --> | ||||||
|         <view class="detail-cell-card detail-card ss-flex-col"> |         <view class="detail-cell-card detail-card ss-flex-col"> | ||||||
|           <detail-cell-sku |           <detail-cell-sku :sku="state.selectedSku" @tap="state.showSelectSku = true" /> | ||||||
|             :sku="state.selectedSku" |  | ||||||
|             @tap="state.showSelectSku = true" |  | ||||||
|           /> |  | ||||||
|         </view> |         </view> | ||||||
|         <!-- 规格与数量弹框 --> |         <!-- 规格与数量弹框 --> | ||||||
|         <s-select-seckill-sku |         <s-select-seckill-sku | ||||||
|  | @ -107,7 +104,9 @@ | ||||||
|           <button v-else class="ss-reset-button origin-price-btn ss-flex-col"> |           <button v-else class="ss-reset-button origin-price-btn ss-flex-col"> | ||||||
|             <view |             <view | ||||||
|               class="no-original" |               class="no-original" | ||||||
|               :class="state.goodsInfo.stock === 0 || timeStatusEnum !== TimeStatusEnum.STARTED ? '' : ''" |               :class=" | ||||||
|  |                 state.goodsInfo.stock === 0 || timeStatusEnum !== TimeStatusEnum.STARTED ? '' : '' | ||||||
|  |               " | ||||||
|             > |             > | ||||||
|               秒杀价 |               秒杀价 | ||||||
|             </view> |             </view> | ||||||
|  | @ -136,11 +135,11 @@ | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
|   import {reactive, computed, ref} from 'vue'; |   import { reactive, computed, ref } from 'vue'; | ||||||
|   import { onLoad, onPageScroll } from '@dcloudio/uni-app'; |   import { onLoad, onPageScroll } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import {isEmpty, min} from 'lodash'; |   import { isEmpty, min } from 'lodash-es'; | ||||||
|   import {useDurationTime, formatGoodsSwiper, fen2yuan} from '@/sheep/hooks/useGoods'; |   import { useDurationTime, formatGoodsSwiper, fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import detailNavbar from './components/detail/detail-navbar.vue'; |   import detailNavbar from './components/detail/detail-navbar.vue'; | ||||||
|   import detailCellSku from './components/detail/detail-cell-sku.vue'; |   import detailCellSku from './components/detail/detail-cell-sku.vue'; | ||||||
|   import detailTabbar from './components/detail/detail-tabbar.vue'; |   import detailTabbar from './components/detail/detail-tabbar.vue'; | ||||||
|  | @ -148,15 +147,13 @@ | ||||||
|   import detailCommentCard from './components/detail/detail-comment-card.vue'; |   import detailCommentCard from './components/detail/detail-comment-card.vue'; | ||||||
|   import detailContentCard from './components/detail/detail-content-card.vue'; |   import detailContentCard from './components/detail/detail-content-card.vue'; | ||||||
|   import detailProgress from './components/detail/detail-progress.vue'; |   import detailProgress from './components/detail/detail-progress.vue'; | ||||||
|   import SeckillApi from "@/sheep/api/promotion/seckill"; |   import SeckillApi from '@/sheep/api/promotion/seckill'; | ||||||
|   import SpuApi from "@/sheep/api/product/spu"; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
|   import {getTimeStatusEnum, TimeStatusEnum} from "@/sheep/util/const"; |   import { getTimeStatusEnum, TimeStatusEnum } from '@/sheep/util/const'; | ||||||
| 
 | 
 | ||||||
|   const headerBg = sheep.$url.css('/static/img/shop/goods/seckill-bg.png'); |   const headerBg = sheep.$url.css('/static/img/shop/goods/seckill-bg.png'); | ||||||
|   const btnBg = sheep.$url.css('/static/img/shop/goods/seckill-btn.png'); |   const btnBg = sheep.$url.css('/static/img/shop/goods/seckill-btn.png'); | ||||||
|   const disabledBtnBg = sheep.$url.css( |   const disabledBtnBg = sheep.$url.css('/static/img/shop/goods/activity-btn-disabled.png'); | ||||||
|     '/static/img/shop/goods/activity-btn-disabled.png', |  | ||||||
|   ); |  | ||||||
|   const seckillBg = sheep.$url.css('/static/img/shop/goods/seckill-tip-bg.png'); |   const seckillBg = sheep.$url.css('/static/img/shop/goods/seckill-tip-bg.png'); | ||||||
|   const grouponBg = sheep.$url.css('/static/img/shop/goods/groupon-tip-bg.png'); |   const grouponBg = sheep.$url.css('/static/img/shop/goods/groupon-tip-bg.png'); | ||||||
| 
 | 
 | ||||||
|  | @ -221,36 +218,40 @@ | ||||||
|     ); |     ); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   const activity = ref() |   const activity = ref(); | ||||||
|   const timeStatusEnum = ref('') |   const timeStatusEnum = ref(''); | ||||||
|   // 查询活动 |   // 查询活动 | ||||||
|   const getActivity = async (id) => { |   const getActivity = async (id) => { | ||||||
|     const { data } = await SeckillApi.getSeckillActivity(id) |     const { data } = await SeckillApi.getSeckillActivity(id); | ||||||
|     activity.value = data |     activity.value = data; | ||||||
|     timeStatusEnum.value = getTimeStatusEnum(activity.startTime, activity.endTime) |     timeStatusEnum.value = getTimeStatusEnum(activity.startTime, activity.endTime); | ||||||
| 
 | 
 | ||||||
|     // 查询商品 |     // 查询商品 | ||||||
|     await getSpu(data.spuId) |     await getSpu(data.spuId); | ||||||
|   } |   }; | ||||||
| 
 | 
 | ||||||
|   const getSpu = async (id) => { |   const getSpu = async (id) => { | ||||||
|     const { data } = await SpuApi.getSpuDetail(id) |     const { data } = await SpuApi.getSpuDetail(id); | ||||||
|     // 模拟 |     // 模拟 | ||||||
|     data.activity_type = 'seckill' |     data.activity_type = 'seckill'; | ||||||
|     state.goodsInfo = data |     state.goodsInfo = data; | ||||||
|     // 处理轮播图 |     // 处理轮播图 | ||||||
|     state.goodsSwiper = formatGoodsSwiper(state.goodsInfo.sliderPicUrls); |     state.goodsSwiper = formatGoodsSwiper(state.goodsInfo.sliderPicUrls); | ||||||
| 
 | 
 | ||||||
|     // 默认显示最低价 |     // 默认显示最低价 | ||||||
|     state.goodsInfo.price = min([state.goodsInfo.price, ...activity.value.products.map(spu => spu.seckillPrice)]) |     state.goodsInfo.price = min([ | ||||||
|  |       state.goodsInfo.price, | ||||||
|  |       ...activity.value.products.map((spu) => spu.seckillPrice), | ||||||
|  |     ]); | ||||||
| 
 | 
 | ||||||
|     // 价格、库存使用活动的 |     // 价格、库存使用活动的 | ||||||
|     data.skus.forEach(sku => { |     data.skus.forEach((sku) => { | ||||||
|       const product = activity.value.products.find(product => product.skuId === sku.id); |       const product = activity.value.products.find((product) => product.skuId === sku.id); | ||||||
|       if (product) { |       if (product) { | ||||||
|         sku.price = product.seckillPrice; |         sku.price = product.seckillPrice; | ||||||
|         sku.stock = Math.min(sku.stock, product.stock); |         sku.stock = Math.min(sku.stock, product.stock); | ||||||
|       } else { // 找不到可能是没配置,则不能发起秒杀 |       } else { | ||||||
|  |         // 找不到可能是没配置,则不能发起秒杀 | ||||||
|         sku.stock = 0; |         sku.stock = 0; | ||||||
|       } |       } | ||||||
|       // 设置限购数量 |       // 设置限购数量 | ||||||
|  | @ -264,7 +265,7 @@ | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     state.skeletonLoading = false; |     state.skeletonLoading = false; | ||||||
|   } |   }; | ||||||
| 
 | 
 | ||||||
|   onLoad((options) => { |   onLoad((options) => { | ||||||
|     // 非法参数 |     // 非法参数 | ||||||
|  | @ -274,7 +275,7 @@ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // 查询活动 |     // 查询活动 | ||||||
|     getActivity(options.id) |     getActivity(options.id); | ||||||
|   }); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -63,7 +63,7 @@ | ||||||
|   import SpuApi from '@/sheep/api/product/spu'; |   import SpuApi from '@/sheep/api/product/spu'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { computed, reactive } from 'vue'; |   import { computed, reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { handleTree } from '@/sheep/util'; |   import { handleTree } from '@/sheep/util'; | ||||||
| 
 | 
 | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|  |  | ||||||
|  | @ -98,11 +98,7 @@ | ||||||
|         </view> |         </view> | ||||||
|         <view class="modal-content content_box"> |         <view class="modal-content content_box"> | ||||||
|           <radio-group @change="onChange"> |           <radio-group @change="onChange"> | ||||||
|             <label |             <label class="radio ss-flex ss-col-center" v-for="item in state.reasonList" :key="item"> | ||||||
|               class="radio ss-flex ss-col-center" |  | ||||||
|               v-for="item in state.reasonList" |  | ||||||
|               :key="item" |  | ||||||
|             > |  | ||||||
|               <view class="ss-flex-1 ss-p-20">{{ item }}</view> |               <view class="ss-flex-1 ss-p-20">{{ item }}</view> | ||||||
|               <radio |               <radio | ||||||
|                 :value="item" |                 :value="item" | ||||||
|  | @ -153,9 +149,9 @@ | ||||||
|     ], |     ], | ||||||
|     reasonList: [], // 可选的申请原因数组 |     reasonList: [], // 可选的申请原因数组 | ||||||
|     showModal: false, // 是否显示申请原因弹窗 |     showModal: false, // 是否显示申请原因弹窗 | ||||||
|     currentValue: '' // 当前选择的售后原因 |     currentValue: '', // 当前选择的售后原因 | ||||||
|   }); |   }); | ||||||
|   const formData = reactive({ |   let formData = reactive({ | ||||||
|     way: '', |     way: '', | ||||||
|     applyReason: '', |     applyReason: '', | ||||||
|     applyDescription: '', |     applyDescription: '', | ||||||
|  |  | ||||||
|  | @ -1,156 +1,193 @@ | ||||||
| <!-- 售后详情 --> | <!-- 售后详情 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout title="售后详情" :navbar="!isEmpty(state.info) && state.loading ? 'inner' : 'normal'"> |   <s-layout title="售后详情" :navbar="!isEmpty(state.info) && state.loading ? 'inner' : 'normal'"> | ||||||
| 		<view class="content_box" v-if="!isEmpty(state.info) && state.loading"> |     <view class="content_box" v-if="!isEmpty(state.info) && state.loading"> | ||||||
| 			<!-- 步骤条 --> |       <!-- 步骤条 --> | ||||||
| 			<view class="steps-box ss-flex" :style="[ |       <view | ||||||
|  |         class="steps-box ss-flex" | ||||||
|  |         :style="[ | ||||||
|           { |           { | ||||||
|             marginTop: '-' + Number(statusBarHeight + 88) + 'rpx', |             marginTop: '-' + Number(statusBarHeight + 88) + 'rpx', | ||||||
|             paddingTop: Number(statusBarHeight + 88) + 'rpx', |             paddingTop: Number(statusBarHeight + 88) + 'rpx', | ||||||
|           }, |           }, | ||||||
|         ]"> |         ]" | ||||||
| 				<view class="ss-flex"> |       > | ||||||
| 					<view class="steps-item" v-for="(item, index) in state.list" :key="index"> |         <view class="ss-flex"> | ||||||
| 						<view class="ss-flex"> |           <view class="steps-item" v-for="(item, index) in state.list" :key="index"> | ||||||
| 							<text class="sicon-circleclose" |             <view class="ss-flex"> | ||||||
|                     v-if="state.list.length - 1 === index && [61, 62, 63].includes(state.info.status)" /> |               <text | ||||||
| 							<text class="sicon-circlecheck" v-else |                 class="sicon-circleclose" | ||||||
|                     :class="state.active >= index ? 'activity-color' : 'info-color'" /> |                 v-if="state.list.length - 1 === index && [61, 62, 63].includes(state.info.status)" | ||||||
|  |               /> | ||||||
|  |               <text | ||||||
|  |                 class="sicon-circlecheck" | ||||||
|  |                 v-else | ||||||
|  |                 :class="state.active >= index ? 'activity-color' : 'info-color'" | ||||||
|  |               /> | ||||||
| 
 | 
 | ||||||
| 							<view v-if="state.list.length - 1 !== index" class="line" |               <view | ||||||
|                     :class="state.active >= index ? 'activity-bg' : 'info-bg'" /> |                 v-if="state.list.length - 1 !== index" | ||||||
| 						</view> |                 class="line" | ||||||
| 						<view class="steps-item-title" :class="state.active >= index ? 'activity-color' : 'info-color'"> |                 :class="state.active >= index ? 'activity-bg' : 'info-bg'" | ||||||
| 							{{ item.title }} |               /> | ||||||
| 						</view> |             </view> | ||||||
| 					</view> |             <view | ||||||
| 				</view> |               class="steps-item-title" | ||||||
| 			</view> |               :class="state.active >= index ? 'activity-color' : 'info-color'" | ||||||
|  |             > | ||||||
|  |               {{ item.title }} | ||||||
|  |             </view> | ||||||
|  |           </view> | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
| 
 | 
 | ||||||
| 			<!-- 服务状态 --> |       <!-- 服务状态 --> | ||||||
| 			<view class="status-box ss-flex ss-col-center ss-row-between ss-m-x-20" |       <view | ||||||
|             @tap="sheep.$router.go('/pages/order/aftersale/log', { id: state.id })"> |         class="status-box ss-flex ss-col-center ss-row-between ss-m-x-20" | ||||||
| 				<view class=""> |         @tap="sheep.$router.go('/pages/order/aftersale/log', { id: state.id })" | ||||||
| 					<view class="status-text"> |       > | ||||||
|  |         <view class=""> | ||||||
|  |           <view class="status-text"> | ||||||
|             {{ formatAfterSaleStatusDescription(state.info) }} |             {{ formatAfterSaleStatusDescription(state.info) }} | ||||||
|           </view> |           </view> | ||||||
| 					<view class="status-time"> |           <view class="status-time"> | ||||||
|             {{ sheep.$helper.timeFormat(state.info.updateTime, 'yyyy-mm-dd hh:MM:ss') }} |             {{ sheep.$helper.timeFormat(state.info.updateTime, 'yyyy-mm-dd hh:MM:ss') }} | ||||||
|           </view> |           </view> | ||||||
| 				</view> |         </view> | ||||||
| 				<text class="ss-iconfont _icon-forward" style="color: #666" /> |         <text class="ss-iconfont _icon-forward" style="color: #666" /> | ||||||
| 			</view> |       </view> | ||||||
| 
 | 
 | ||||||
| 			<!-- 退款金额 --> |       <!-- 退款金额 --> | ||||||
| 			<view class="aftersale-money ss-flex ss-col-center ss-row-between"> |       <view class="aftersale-money ss-flex ss-col-center ss-row-between"> | ||||||
| 				<view class="aftersale-money--title">退款总额</view> |         <view class="aftersale-money--title">退款总额</view> | ||||||
| 				<view class="aftersale-money--num">¥{{ fen2yuan(state.info.refundPrice) }}</view> |         <view class="aftersale-money--num">¥{{ fen2yuan(state.info.refundPrice) }}</view> | ||||||
| 			</view> |       </view> | ||||||
| 			<!-- 服务商品 --> |       <!-- 服务商品 --> | ||||||
| 			<view class="order-shop"> |       <view class="order-shop"> | ||||||
| 				<s-goods-item |         <s-goods-item | ||||||
|           :img=" state.info.picUrl" |           :img="state.info.picUrl" | ||||||
|           :title=" state.info.spuName" |           :title="state.info.spuName" | ||||||
| 					:titleWidth="480" |           :titleWidth="480" | ||||||
|           :skuText="state.info.properties.map((property) => property.valueName).join(' ')" |           :skuText="state.info.properties.map((property) => property.valueName).join(' ')" | ||||||
|           :num=" state.info.count" |           :num="state.info.count" | ||||||
|         /> |         /> | ||||||
| 			</view> |       </view> | ||||||
| 
 | 
 | ||||||
| 			<!-- 服务内容 --> |       <!-- 服务内容 --> | ||||||
| 			<view class="aftersale-content"> |       <view class="aftersale-content"> | ||||||
| 				<view class="aftersale-item ss-flex ss-col-center"> |         <view class="aftersale-item ss-flex ss-col-center"> | ||||||
| 					<view class="item-title">服务单号:</view> |           <view class="item-title">服务单号:</view> | ||||||
| 					<view class="item-content ss-m-r-16">{{ state.info.no }}</view> |           <view class="item-content ss-m-r-16">{{ state.info.no }}</view> | ||||||
| 					<button class="ss-reset-button copy-btn" @tap="onCopy">复制</button> |           <button class="ss-reset-button copy-btn" @tap="onCopy">复制</button> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="aftersale-item ss-flex ss-col-center"> |         <view class="aftersale-item ss-flex ss-col-center"> | ||||||
| 					<view class="item-title">申请时间:</view> |           <view class="item-title">申请时间:</view> | ||||||
| 					<view class="item-content"> |           <view class="item-content"> | ||||||
| 						{{ sheep.$helper.timeFormat(state.info.createTime, 'yyyy-mm-dd hh:MM:ss') }} |             {{ sheep.$helper.timeFormat(state.info.createTime, 'yyyy-mm-dd hh:MM:ss') }} | ||||||
| 					</view> |           </view> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="aftersale-item ss-flex ss-col-center"> |         <view class="aftersale-item ss-flex ss-col-center"> | ||||||
| 					<view class="item-title">售后类型:</view> |           <view class="item-title">售后类型:</view> | ||||||
| 					<view class="item-content">{{ state.info.way === 10 ? '仅退款' : '退款退货' }}</view> |           <view class="item-content">{{ state.info.way === 10 ? '仅退款' : '退款退货' }}</view> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="aftersale-item ss-flex ss-col-center"> |         <view class="aftersale-item ss-flex ss-col-center"> | ||||||
| 					<view class="item-title">申请原因:</view> |           <view class="item-title">申请原因:</view> | ||||||
| 					<view class="item-content">{{ state.info.applyReason }}</view> |           <view class="item-content">{{ state.info.applyReason }}</view> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="aftersale-item ss-flex ss-col-center"> |         <view class="aftersale-item ss-flex ss-col-center"> | ||||||
| 					<view class="item-title">相关描述:</view> |           <view class="item-title">相关描述:</view> | ||||||
| 					<view class="item-content">{{ state.info.applyDescription }}</view> |           <view class="item-content">{{ state.info.applyDescription }}</view> | ||||||
| 				</view> |         </view> | ||||||
| 			</view> |       </view> | ||||||
| 		</view> |     </view> | ||||||
| 
 | 
 | ||||||
|     <!-- 操作区 --> |     <!-- 操作区 --> | ||||||
| 		<s-empty v-if="isEmpty(state.info) && state.loading" icon="/static/order-empty.png" text="暂无该订单售后详情" /> |     <s-empty | ||||||
| 		<su-fixed bottom placeholder bg="bg-white" v-if="!isEmpty(state.info)"> |       v-if="isEmpty(state.info) && state.loading" | ||||||
| 			<view class="foot_box"> |       icon="/static/order-empty.png" | ||||||
|         <button class="ss-reset-button btn" v-if="state.info.buttons?.includes('cancel')" |       text="暂无该订单售后详情" | ||||||
|                 @tap="onApply(state.info.id)"> |     /> | ||||||
|  |     <su-fixed bottom placeholder bg="bg-white" v-if="!isEmpty(state.info)"> | ||||||
|  |       <view class="foot_box"> | ||||||
|  |         <button | ||||||
|  |           class="ss-reset-button btn" | ||||||
|  |           v-if="state.info.buttons?.includes('cancel')" | ||||||
|  |           @tap="onApply(state.info.id)" | ||||||
|  |         > | ||||||
|           取消申请 |           取消申请 | ||||||
|         </button> |         </button> | ||||||
|         <button class="ss-reset-button btn" v-if="state.info.buttons?.includes('delivery')" |         <button | ||||||
|                 @tap="sheep.$router.go('/pages/order/aftersale/return-delivery', { id: state.info.id })"> |           class="ss-reset-button btn" | ||||||
|  |           v-if="state.info.buttons?.includes('delivery')" | ||||||
|  |           @tap="sheep.$router.go('/pages/order/aftersale/return-delivery', { id: state.info.id })" | ||||||
|  |         > | ||||||
|           填写退货 |           填写退货 | ||||||
|         </button> |         </button> | ||||||
| 				<button class="ss-reset-button contcat-btn btn" @tap="sheep.$router.go('/pages/chat/index')"> |         <button | ||||||
|  |           class="ss-reset-button contcat-btn btn" | ||||||
|  |           @tap="sheep.$router.go('/pages/chat/index')" | ||||||
|  |         > | ||||||
|           联系客服 |           联系客服 | ||||||
|         </button> |         </button> | ||||||
| 			</view> |       </view> | ||||||
| 		</su-fixed> |     </su-fixed> | ||||||
| 	</s-layout> |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import { onLoad } from '@dcloudio/uni-app'; |   import { onLoad } from '@dcloudio/uni-app'; | ||||||
| 	import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
| 	import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import { fen2yuan, formatAfterSaleStatusDescription, handleAfterSaleButtons } from '@/sheep/hooks/useGoods'; |   import { | ||||||
|  |     fen2yuan, | ||||||
|  |     formatAfterSaleStatusDescription, | ||||||
|  |     handleAfterSaleButtons, | ||||||
|  |   } from '@/sheep/hooks/useGoods'; | ||||||
|   import AfterSaleApi from '@/sheep/api/trade/afterSale'; |   import AfterSaleApi from '@/sheep/api/trade/afterSale'; | ||||||
| 
 | 
 | ||||||
| 	const statusBarHeight = sheep.$platform.device.statusBarHeight * 2; |   const statusBarHeight = sheep.$platform.device.statusBarHeight * 2; | ||||||
| 	const headerBg = sheep.$url.css('/static/img/shop/order/order_bg.png'); |   const headerBg = sheep.$url.css('/static/img/shop/order/order_bg.png'); | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
|     id: 0, // 售后编号 |     id: 0, // 售后编号 | ||||||
|     info: {}, // 收货信息 |     info: {}, // 收货信息 | ||||||
| 		loading: false, |     loading: false, | ||||||
|     active: 0, // 在 list 的激活位置 |     active: 0, // 在 list 的激活位置 | ||||||
|     list: [{ |     list: [ | ||||||
|       title: '提交申请', |       { | ||||||
|     }, { |         title: '提交申请', | ||||||
|       title: '处理中', |       }, | ||||||
|     }, { |       { | ||||||
|       title: '完成' |         title: '处理中', | ||||||
|     }], // 时间轴 |       }, | ||||||
| 	}); |       { | ||||||
|  |         title: '完成', | ||||||
|  |       }, | ||||||
|  |     ], // 时间轴 | ||||||
|  |   }); | ||||||
| 
 | 
 | ||||||
| 	function onApply(id) { |   function onApply(id) { | ||||||
| 		uni.showModal({ |     uni.showModal({ | ||||||
| 			title: '提示', |       title: '提示', | ||||||
| 			content: '确定要取消此申请吗?', |       content: '确定要取消此申请吗?', | ||||||
| 			success: async function(res) { |       success: async function (res) { | ||||||
| 				if (!res.confirm) { |         if (!res.confirm) { | ||||||
| 					return; |           return; | ||||||
| 				} |         } | ||||||
|         const { code } = await AfterSaleApi.cancelAfterSale(id); |         const { code } = await AfterSaleApi.cancelAfterSale(id); | ||||||
|         if (code === 0) { |         if (code === 0) { | ||||||
|           await getDetail(id); |           await getDetail(id); | ||||||
|         } |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
|   // 复制 |   // 复制 | ||||||
|   const onCopy = () => { |   const onCopy = () => { | ||||||
| 		sheep.$helper.copyText(state.info.no); |     sheep.$helper.copyText(state.info.no); | ||||||
| 	}; |   }; | ||||||
| 
 | 
 | ||||||
| 	async function getDetail(id) { |   async function getDetail(id) { | ||||||
|     state.loading = true; |     state.loading = true; | ||||||
|     const { code, data } = await AfterSaleApi.getAfterSale(id); |     const { code, data } = await AfterSaleApi.getAfterSale(id); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|  | @ -170,173 +207,173 @@ | ||||||
|     } else if ([61, 62, 63].includes(state.info.status)) { |     } else if ([61, 62, 63].includes(state.info.status)) { | ||||||
|       state.active = 2; |       state.active = 2; | ||||||
|     } |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad((options) => { |   onLoad((options) => { | ||||||
|     if (!options.id) { |     if (!options.id) { | ||||||
|       sheep.$helper.toast(`缺少订单信息,请检查`); |       sheep.$helper.toast(`缺少订单信息,请检查`); | ||||||
|       return |       return; | ||||||
|     } |     } | ||||||
| 		state.id = options.id; |     state.id = options.id; | ||||||
| 		getDetail(options.id); |     getDetail(options.id); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	// 步骤条 |   // 步骤条 | ||||||
| 	.steps-box { |   .steps-box { | ||||||
| 		width: 100%; |     width: 100%; | ||||||
| 		height: 190rpx; |     height: 190rpx; | ||||||
| 		background: v-bind(headerBg) no-repeat, |     background: v-bind(headerBg) no-repeat, | ||||||
| 			linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); |       linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); | ||||||
| 		background-size: 750rpx 100%; |     background-size: 750rpx 100%; | ||||||
| 		padding-left: 72rpx; |     padding-left: 72rpx; | ||||||
| 
 | 
 | ||||||
| 		.steps-item { |     .steps-item { | ||||||
| 			.sicon-circleclose { |       .sicon-circleclose { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				color: #fff; |         color: #fff; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.sicon-circlecheck { |       .sicon-circlecheck { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.steps-item-title { |       .steps-item-title { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				font-weight: 400; |         font-weight: 400; | ||||||
| 				margin-top: 16rpx; |         margin-top: 16rpx; | ||||||
| 				margin-left: -36rpx; |         margin-left: -36rpx; | ||||||
| 				width: 100rpx; |         width: 100rpx; | ||||||
| 				text-align: center; |         text-align: center; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.activity-color { |   .activity-color { | ||||||
| 		color: #fff; |     color: #fff; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.info-color { |   .info-color { | ||||||
| 		color: rgba(#fff, 0.4); |     color: rgba(#fff, 0.4); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.activity-bg { |   .activity-bg { | ||||||
| 		background: #fff; |     background: #fff; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.info-bg { |   .info-bg { | ||||||
| 		background: rgba(#fff, 0.4); |     background: rgba(#fff, 0.4); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.line { |   .line { | ||||||
| 		width: 270rpx; |     width: 270rpx; | ||||||
| 		height: 4rpx; |     height: 4rpx; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 服务状态 |   // 服务状态 | ||||||
| 	.status-box { |   .status-box { | ||||||
| 		position: relative; |     position: relative; | ||||||
| 		z-index: 3; |     z-index: 3; | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 		border-radius: 20rpx 20rpx 0px 0px; |     border-radius: 20rpx 20rpx 0px 0px; | ||||||
| 		padding: 20rpx; |     padding: 20rpx; | ||||||
| 		margin-top: -20rpx; |     margin-top: -20rpx; | ||||||
| 
 | 
 | ||||||
| 		.status-text { |     .status-text { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 
 | 
 | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: rgba(51, 51, 51, 1); |       color: rgba(51, 51, 51, 1); | ||||||
| 			margin-bottom: 20rpx; |       margin-bottom: 20rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.status-time { |     .status-time { | ||||||
| 			font-size: 24rpx; |       font-size: 24rpx; | ||||||
| 
 | 
 | ||||||
| 			font-weight: 400; |       font-weight: 400; | ||||||
| 			color: rgba(153, 153, 153, 1); |       color: rgba(153, 153, 153, 1); | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 退款金额 |   // 退款金额 | ||||||
| 	.aftersale-money { |   .aftersale-money { | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 		height: 98rpx; |     height: 98rpx; | ||||||
| 		padding: 0 20rpx; |     padding: 0 20rpx; | ||||||
| 		margin: 20rpx; |     margin: 20rpx; | ||||||
| 
 | 
 | ||||||
| 		.aftersale-money--title { |     .aftersale-money--title { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 
 | 
 | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: rgba(51, 51, 51, 1); |       color: rgba(51, 51, 51, 1); | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.aftersale-money--num { |     .aftersale-money--num { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 			font-family: OPPOSANS; |       font-family: OPPOSANS; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: #ff3000; |       color: #ff3000; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// order-shop |   // order-shop | ||||||
| 	.order-shop { |   .order-shop { | ||||||
| 		padding: 20rpx; |     padding: 20rpx; | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 		margin: 0 20rpx 20rpx 20rpx; |     margin: 0 20rpx 20rpx 20rpx; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 服务内容 |   // 服务内容 | ||||||
| 	.aftersale-content { |   .aftersale-content { | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 		padding: 20rpx; |     padding: 20rpx; | ||||||
| 		margin: 0 20rpx; |     margin: 0 20rpx; | ||||||
| 
 | 
 | ||||||
| 		.aftersale-item { |     .aftersale-item { | ||||||
| 			height: 60rpx; |       height: 60rpx; | ||||||
| 
 | 
 | ||||||
| 			.copy-btn { |       .copy-btn { | ||||||
| 				background: #eeeeee; |         background: #eeeeee; | ||||||
| 				color: #333; |         color: #333; | ||||||
| 				border-radius: 20rpx; |         border-radius: 20rpx; | ||||||
| 				width: 75rpx; |         width: 75rpx; | ||||||
| 				height: 40rpx; |         height: 40rpx; | ||||||
| 				font-size: 22rpx; |         font-size: 22rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.item-title { |       .item-title { | ||||||
| 				color: #999; |         color: #999; | ||||||
| 				font-size: 28rpx; |         font-size: 28rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.item-content { |       .item-content { | ||||||
| 				color: #333; |         color: #333; | ||||||
| 				font-size: 28rpx; |         font-size: 28rpx; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 底部功能 |   // 底部功能 | ||||||
| 	.foot_box { |   .foot_box { | ||||||
| 		height: 100rpx; |     height: 100rpx; | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 		display: flex; |     display: flex; | ||||||
| 		align-items: center; |     align-items: center; | ||||||
| 		justify-content: flex-end; |     justify-content: flex-end; | ||||||
| 
 | 
 | ||||||
| 		.btn { |     .btn { | ||||||
| 			width: 160rpx; |       width: 160rpx; | ||||||
| 			line-height: 60rpx; |       line-height: 60rpx; | ||||||
| 			background: rgba(238, 238, 238, 1); |       background: rgba(238, 238, 238, 1); | ||||||
| 			border-radius: 30rpx; |       border-radius: 30rpx; | ||||||
| 			padding: 0; |       padding: 0; | ||||||
| 			margin-right: 20rpx; |       margin-right: 20rpx; | ||||||
| 			font-size: 26rpx; |       font-size: 26rpx; | ||||||
| 
 | 
 | ||||||
| 			font-weight: 400; |       font-weight: 400; | ||||||
| 			color: rgba(51, 51, 51, 1); |       color: rgba(51, 51, 51, 1); | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -1,187 +1,210 @@ | ||||||
| <!-- 售后列表 --> | <!-- 售后列表 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout title="售后列表"> |   <s-layout title="售后列表"> | ||||||
| 		<!-- tab --> |     <!-- tab --> | ||||||
| 		<su-sticky bgColor="#fff"> |     <su-sticky bgColor="#fff"> | ||||||
| 			<su-tabs :list="tabMaps" :scrollable="false" @change="onTabsChange" :current="state.currentTab" /> |       <su-tabs | ||||||
| 		</su-sticky> |         :list="tabMaps" | ||||||
| 		<s-empty v-if="state.pagination.total === 0" icon="/static/data-empty.png" text="暂无数据" /> |         :scrollable="false" | ||||||
| 		<!-- 列表 --> |         @change="onTabsChange" | ||||||
| 		<view v-if="state.pagination.total > 0"> |         :current="state.currentTab" | ||||||
| 			<view class="list-box ss-m-y-20" v-for="order in state.pagination.list" :key="order.id" |       /> | ||||||
| 				@tap="sheep.$router.go('/pages/order/aftersale/detail', { id: order.id })"> |     </su-sticky> | ||||||
| 				<view class="order-head ss-flex ss-col-center ss-row-between"> |     <s-empty v-if="state.pagination.total === 0" icon="/static/data-empty.png" text="暂无数据" /> | ||||||
| 					<text class="no">服务单号:{{ order.no }}</text> |     <!-- 列表 --> | ||||||
| 					<text class="state">{{ formatAfterSaleStatus(order) }}</text> |     <view v-if="state.pagination.total > 0"> | ||||||
| 				</view> |       <view | ||||||
| 				<s-goods-item |         class="list-box ss-m-y-20" | ||||||
|  |         v-for="order in state.pagination.list" | ||||||
|  |         :key="order.id" | ||||||
|  |         @tap="sheep.$router.go('/pages/order/aftersale/detail', { id: order.id })" | ||||||
|  |       > | ||||||
|  |         <view class="order-head ss-flex ss-col-center ss-row-between"> | ||||||
|  |           <text class="no">服务单号:{{ order.no }}</text> | ||||||
|  |           <text class="state">{{ formatAfterSaleStatus(order) }}</text> | ||||||
|  |         </view> | ||||||
|  |         <s-goods-item | ||||||
|           :img="order.picUrl" |           :img="order.picUrl" | ||||||
|           :title="order.spuName" |           :title="order.spuName" | ||||||
| 					:skuText="order.properties.map((property) => property.valueName).join(' ')" |           :skuText="order.properties.map((property) => property.valueName).join(' ')" | ||||||
|           :price="order.refundPrice" |           :price="order.refundPrice" | ||||||
|         /> |         /> | ||||||
| 				<view class="apply-box ss-flex ss-col-center ss-row-between border-bottom ss-p-x-20"> |         <view class="apply-box ss-flex ss-col-center ss-row-between border-bottom ss-p-x-20"> | ||||||
| 					<view class="ss-flex ss-col-center"> |           <view class="ss-flex ss-col-center"> | ||||||
| 						<view class="title ss-m-r-20">{{ order.way === 10 ? '仅退款' : '退款退货' }}</view> |             <view class="title ss-m-r-20">{{ order.way === 10 ? '仅退款' : '退款退货' }}</view> | ||||||
| 						 <view class="value">{{ formatAfterSaleStatusDescription(order) }}</view> |             <view class="value">{{ formatAfterSaleStatusDescription(order) }}</view> | ||||||
| 					</view> |           </view> | ||||||
| 					<text class="_icon-forward"></text> |           <text class="_icon-forward"></text> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="tool-btn-box ss-flex ss-col-center ss-row-right ss-p-r-20"> |         <view class="tool-btn-box ss-flex ss-col-center ss-row-right ss-p-r-20"> | ||||||
|           <!-- TODO 功能缺失:填写退货信息 --> |           <!-- TODO 功能缺失:填写退货信息 --> | ||||||
| 					<view> |           <view> | ||||||
| 						<button class="ss-reset-button tool-btn" @tap.stop="onApply(order.id)" |             <button | ||||||
| 							v-if="order?.buttons.includes('cancel')">取消申请</button> |               class="ss-reset-button tool-btn" | ||||||
| 					</view> |               @tap.stop="onApply(order.id)" | ||||||
| 				</view> |               v-if="order?.buttons.includes('cancel')" | ||||||
| 			</view> |               >取消申请</button | ||||||
| 		</view> |             > | ||||||
| 		<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{ |           </view> | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
|  |     </view> | ||||||
|  |     <uni-load-more | ||||||
|  |       v-if="state.pagination.total > 0" | ||||||
|  |       :status="state.loadStatus" | ||||||
|  |       :content-text="{ | ||||||
|         contentdown: '上拉加载更多', |         contentdown: '上拉加载更多', | ||||||
|       }" @tap="loadMore" /> |       }" | ||||||
| 	</s-layout> |       @tap="loadMore" | ||||||
|  |     /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
| 	import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import { formatAfterSaleStatus, formatAfterSaleStatusDescription, handleAfterSaleButtons } from '@/sheep/hooks/useGoods'; |   import { | ||||||
|  |     formatAfterSaleStatus, | ||||||
|  |     formatAfterSaleStatusDescription, | ||||||
|  |     handleAfterSaleButtons, | ||||||
|  |   } from '@/sheep/hooks/useGoods'; | ||||||
|   import AfterSaleApi from '@/sheep/api/trade/afterSale'; |   import AfterSaleApi from '@/sheep/api/trade/afterSale'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
| 
 | 
 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		currentTab: 0, |     currentTab: 0, | ||||||
| 		showApply: false, |     showApply: false, | ||||||
| 		pagination: { |     pagination: { | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 10 |       pageSize: 10, | ||||||
| 		}, |     }, | ||||||
| 		loadStatus: '', |     loadStatus: '', | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
|   // TODO 芋艿:优化点,增加筛选 |   // TODO 芋艿:优化点,增加筛选 | ||||||
| 	const tabMaps = [{ |   const tabMaps = [ | ||||||
| 			name: '全部', |     { | ||||||
| 			value: 'all', |       name: '全部', | ||||||
| 		}, |       value: 'all', | ||||||
| 		// { |     }, | ||||||
| 		//   name: '申请中', |     // { | ||||||
| 		//   value: 'nooper', |     //   name: '申请中', | ||||||
| 		// }, |     //   value: 'nooper', | ||||||
| 		// { |     // }, | ||||||
| 		//   name: '处理中', |     // { | ||||||
| 		//   value: 'ing', |     //   name: '处理中', | ||||||
| 		// }, |     //   value: 'ing', | ||||||
| 		// { |     // }, | ||||||
| 		//   name: '已完成', |     // { | ||||||
| 		//   value: 'completed', |     //   name: '已完成', | ||||||
| 		// }, |     //   value: 'completed', | ||||||
| 		// { |     // }, | ||||||
| 		//   name: '已拒绝', |     // { | ||||||
| 		//   value: 'refuse', |     //   name: '已拒绝', | ||||||
| 		// }, |     //   value: 'refuse', | ||||||
| 	]; |     // }, | ||||||
|  |   ]; | ||||||
| 
 | 
 | ||||||
| 	// 切换选项卡 |   // 切换选项卡 | ||||||
| 	function onTabsChange(e) { |   function onTabsChange(e) { | ||||||
|     resetPagination(state.pagination); |     resetPagination(state.pagination); | ||||||
| 		state.currentTab = e.index; |     state.currentTab = e.index; | ||||||
| 		getOrderList(); |     getOrderList(); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 获取售后列表 |   // 获取售后列表 | ||||||
| 	async function getOrderList() { |   async function getOrderList() { | ||||||
| 		state.loadStatus = 'loading'; |     state.loadStatus = 'loading'; | ||||||
| 		let { data, code } = await AfterSaleApi.getAfterSalePage({ |     let { data, code } = await AfterSaleApi.getAfterSalePage({ | ||||||
| 			// type: tabMaps[state.currentTab].value, |       // type: tabMaps[state.currentTab].value, | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
| 		}); |     }); | ||||||
| 		if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
| 		} |     } | ||||||
|     data.list.forEach(order => handleAfterSaleButtons(order)); |     data.list.forEach((order) => handleAfterSaleButtons(order)); | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list); |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	function onApply(orderId) { |   function onApply(orderId) { | ||||||
| 		uni.showModal({ |     uni.showModal({ | ||||||
| 			title: '提示', |       title: '提示', | ||||||
| 			content: '确定要取消此申请吗?', |       content: '确定要取消此申请吗?', | ||||||
| 			success: async function(res) { |       success: async function (res) { | ||||||
| 				if (!res.confirm) { |         if (!res.confirm) { | ||||||
|           return; |           return; | ||||||
| 				} |         } | ||||||
|         const { code } = await AfterSaleApi.cancelAfterSale(orderId); |         const { code } = await AfterSaleApi.cancelAfterSale(orderId); | ||||||
|         if (code === 0) { |         if (code === 0) { | ||||||
|           resetPagination(state.pagination); |           resetPagination(state.pagination); | ||||||
|           await getOrderList(); |           await getOrderList(); | ||||||
|         } |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad(async (options) => { |   onLoad(async (options) => { | ||||||
| 		if (options.type) { |     if (options.type) { | ||||||
| 			state.currentTab = options.type; |       state.currentTab = options.type; | ||||||
| 		} |     } | ||||||
| 		await getOrderList(); |     await getOrderList(); | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 加载更多 |   // 加载更多 | ||||||
| 	function loadMore() { |   function loadMore() { | ||||||
|     if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
|       return |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.pageNo++; |     state.pagination.pageNo++; | ||||||
|     getOrderList(); |     getOrderList(); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 上拉加载更多 |   // 上拉加载更多 | ||||||
| 	onReachBottom(() => { |   onReachBottom(() => { | ||||||
| 		loadMore(); |     loadMore(); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.list-box { |   .list-box { | ||||||
| 		background-color: #fff; |     background-color: #fff; | ||||||
| 
 | 
 | ||||||
| 		.order-head { |     .order-head { | ||||||
| 			padding: 0 25rpx; |       padding: 0 25rpx; | ||||||
| 			height: 77rpx; |       height: 77rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.apply-box { |     .apply-box { | ||||||
| 			height: 82rpx; |       height: 82rpx; | ||||||
| 
 | 
 | ||||||
| 			.title { |       .title { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.value { |       .value { | ||||||
| 				font-size: 22rpx; |         font-size: 22rpx; | ||||||
| 				color: $dark-6; |         color: $dark-6; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.tool-btn-box { |     .tool-btn-box { | ||||||
| 			height: 100rpx; |       height: 100rpx; | ||||||
| 
 | 
 | ||||||
| 			.tool-btn { |       .tool-btn { | ||||||
| 				width: 160rpx; |         width: 160rpx; | ||||||
| 				height: 60rpx; |         height: 60rpx; | ||||||
| 				background: #f6f6f6; |         background: #f6f6f6; | ||||||
| 				border-radius: 30rpx; |         border-radius: 30rpx; | ||||||
| 				font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 				font-weight: 400; |         font-weight: 400; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -162,7 +162,7 @@ | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad } from '@dcloudio/uni-app'; |   import { onLoad } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import OrderApi from '@/sheep/api/trade/order'; |   import OrderApi from '@/sheep/api/trade/order'; | ||||||
|   import CouponApi from '@/sheep/api/promotion/coupon'; |   import CouponApi from '@/sheep/api/promotion/coupon'; | ||||||
|   import { fen2yuan } from '@/sheep/hooks/useGoods'; |   import { fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|  | @ -223,7 +223,7 @@ | ||||||
|       pointStatus: false, // TODO 芋艿:需要支持【积分选择】 |       pointStatus: false, // TODO 芋艿:需要支持【积分选择】 | ||||||
|       combinationActivityId: state.orderPayload.combinationActivityId, |       combinationActivityId: state.orderPayload.combinationActivityId, | ||||||
|       combinationHeadId: state.orderPayload.combinationHeadId, |       combinationHeadId: state.orderPayload.combinationHeadId, | ||||||
|       seckillActivityId: state.orderPayload.seckillActivityId |       seckillActivityId: state.orderPayload.seckillActivityId, | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  | @ -250,7 +250,7 @@ | ||||||
|       pointStatus: false, // TODO 芋艿:需要支持【积分选择】 |       pointStatus: false, // TODO 芋艿:需要支持【积分选择】 | ||||||
|       combinationActivityId: state.orderPayload.combinationActivityId, |       combinationActivityId: state.orderPayload.combinationActivityId, | ||||||
|       combinationHeadId: state.orderPayload.combinationHeadId, |       combinationHeadId: state.orderPayload.combinationHeadId, | ||||||
|       seckillActivityId: state.orderPayload.seckillActivityId |       seckillActivityId: state.orderPayload.seckillActivityId, | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  |  | ||||||
|  | @ -252,7 +252,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad } from '@dcloudio/uni-app'; |   import { onLoad } from '@dcloudio/uni-app'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import { |   import { | ||||||
|     fen2yuan, |     fen2yuan, | ||||||
|     formatOrderStatus, |     formatOrderStatus, | ||||||
|  | @ -371,7 +371,7 @@ | ||||||
|   // 评价 |   // 评价 | ||||||
|   function onComment(id) { |   function onComment(id) { | ||||||
|     sheep.$router.go('/pages/goods/comment/add', { |     sheep.$router.go('/pages/goods/comment/add', { | ||||||
|       id |       id, | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,243 +1,284 @@ | ||||||
| <!-- 订单列表 --> | <!-- 订单列表 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout title="我的订单"> |   <s-layout title="我的订单"> | ||||||
| 		<su-sticky bgColor="#fff"> |     <su-sticky bgColor="#fff"> | ||||||
| 			<su-tabs :list="tabMaps" :scrollable="false" @change="onTabsChange" :current="state.currentTab" /> |       <su-tabs | ||||||
| 		</su-sticky> |         :list="tabMaps" | ||||||
| 		<s-empty v-if="state.pagination.total === 0" icon="/static/order-empty.png" text="暂无订单" /> |         :scrollable="false" | ||||||
| 		<view v-if="state.pagination.total > 0"> |         @change="onTabsChange" | ||||||
| 			<view class="bg-white order-list-card-box ss-r-10 ss-m-t-14 ss-m-20" v-for="order in state.pagination.list" |         :current="state.currentTab" | ||||||
|             :key="order.id" @tap="onOrderDetail(order.id)"> |       /> | ||||||
| 				<view class="order-card-header ss-flex ss-col-center ss-row-between ss-p-x-20"> |     </su-sticky> | ||||||
| 					<view class="order-no">订单号:{{ order.no }}</view> |     <s-empty v-if="state.pagination.total === 0" icon="/static/order-empty.png" text="暂无订单" /> | ||||||
| 					<view class="order-state ss-font-26" :class="formatOrderColor(order)"> |     <view v-if="state.pagination.total > 0"> | ||||||
|  |       <view | ||||||
|  |         class="bg-white order-list-card-box ss-r-10 ss-m-t-14 ss-m-20" | ||||||
|  |         v-for="order in state.pagination.list" | ||||||
|  |         :key="order.id" | ||||||
|  |         @tap="onOrderDetail(order.id)" | ||||||
|  |       > | ||||||
|  |         <view class="order-card-header ss-flex ss-col-center ss-row-between ss-p-x-20"> | ||||||
|  |           <view class="order-no">订单号:{{ order.no }}</view> | ||||||
|  |           <view class="order-state ss-font-26" :class="formatOrderColor(order)"> | ||||||
|             {{ formatOrderStatus(order) }} |             {{ formatOrderStatus(order) }} | ||||||
|           </view> |           </view> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="border-bottom" v-for="item in order.items" :key="item.id"> |         <view class="border-bottom" v-for="item in order.items" :key="item.id"> | ||||||
| 					<s-goods-item |           <s-goods-item | ||||||
|             :img="item.picUrl" |             :img="item.picUrl" | ||||||
|             :title="item.spuName" |             :title="item.spuName" | ||||||
| 						:skuText="item.properties.map((property) => property.valueName).join(' ')" |             :skuText="item.properties.map((property) => property.valueName).join(' ')" | ||||||
| 						:price="item.price" |             :price="item.price" | ||||||
|             :num="item.count" |             :num="item.count" | ||||||
|           /> |           /> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="pay-box ss-m-t-30 ss-flex ss-row-right ss-p-r-20"> |         <view class="pay-box ss-m-t-30 ss-flex ss-row-right ss-p-r-20"> | ||||||
| 					<view class="ss-flex ss-col-center"> |           <view class="ss-flex ss-col-center"> | ||||||
| 						<view class="discounts-title pay-color">共 {{ order.productCount }} 件商品,总金额:</view> |             <view class="discounts-title pay-color" | ||||||
| 						<view class="discounts-money pay-color"> |               >共 {{ order.productCount }} 件商品,总金额:</view | ||||||
| 							¥{{ fen2yuan(order.payPrice) }} |             > | ||||||
|             </view> |             <view class="discounts-money pay-color"> ¥{{ fen2yuan(order.payPrice) }} </view> | ||||||
| 					</view> |           </view> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="order-card-footer ss-flex ss-col-center ss-p-x-20" |         <view | ||||||
|               :class="order.buttons.length > 3 ? 'ss-row-between' : 'ss-row-right'"> |           class="order-card-footer ss-flex ss-col-center ss-p-x-20" | ||||||
| 					<view class="ss-flex ss-col-center"> |           :class="order.buttons.length > 3 ? 'ss-row-between' : 'ss-row-right'" | ||||||
| 						<button v-if="order.buttons.includes('combination')" class="tool-btn ss-reset-button" |         > | ||||||
| 							@tap.stop="onOrderGroupon(order)"> |           <view class="ss-flex ss-col-center"> | ||||||
|  |             <button | ||||||
|  |               v-if="order.buttons.includes('combination')" | ||||||
|  |               class="tool-btn ss-reset-button" | ||||||
|  |               @tap.stop="onOrderGroupon(order)" | ||||||
|  |             > | ||||||
|               拼团详情 |               拼团详情 | ||||||
| 						</button> |             </button> | ||||||
| 						<button v-if="order.buttons.length === 0" class="tool-btn ss-reset-button" |             <button | ||||||
|                     @tap.stop="onOrderDetail(order.id)"> |               v-if="order.buttons.length === 0" | ||||||
|  |               class="tool-btn ss-reset-button" | ||||||
|  |               @tap.stop="onOrderDetail(order.id)" | ||||||
|  |             > | ||||||
|               查看详情 |               查看详情 | ||||||
| 						</button> |             </button> | ||||||
| 						<button v-if="order.buttons.includes('confirm')" class="tool-btn ss-reset-button" |             <button | ||||||
|                     @tap.stop="onConfirm(order)"> |               v-if="order.buttons.includes('confirm')" | ||||||
|  |               class="tool-btn ss-reset-button" | ||||||
|  |               @tap.stop="onConfirm(order)" | ||||||
|  |             > | ||||||
|               确认收货 |               确认收货 | ||||||
| 						</button> |             </button> | ||||||
| 						<button v-if="order.buttons.includes('express')" class="tool-btn ss-reset-button" |             <button | ||||||
|                     @tap.stop="onExpress(order.id)"> |               v-if="order.buttons.includes('express')" | ||||||
| 							查看物流 |               class="tool-btn ss-reset-button" | ||||||
| 						</button> |               @tap.stop="onExpress(order.id)" | ||||||
| 						<button v-if="order.buttons.includes('cancel')" class="tool-btn ss-reset-button" |             > | ||||||
|                     @tap.stop="onCancel(order.id)"> |               查看物流 | ||||||
| 							取消订单 |             </button> | ||||||
| 						</button> |             <button | ||||||
| 						<button v-if="order.buttons.includes('comment')" class="tool-btn ss-reset-button" |               v-if="order.buttons.includes('cancel')" | ||||||
|                     @tap.stop="onComment(order.id)"> |               class="tool-btn ss-reset-button" | ||||||
| 							评价 |               @tap.stop="onCancel(order.id)" | ||||||
| 						</button> |             > | ||||||
| 						<button v-if="order.buttons.includes('delete')" class="delete-btn ss-reset-button" |               取消订单 | ||||||
|                     @tap.stop="onDelete(order.id)"> |             </button> | ||||||
| 							删除订单 |             <button | ||||||
| 						</button> |               v-if="order.buttons.includes('comment')" | ||||||
| 						<button v-if="order.buttons.includes('pay')" class="tool-btn ss-reset-button ui-BG-Main-Gradient" |               class="tool-btn ss-reset-button" | ||||||
|                     @tap.stop="onPay(order.payOrderId)"> |               @tap.stop="onComment(order.id)" | ||||||
| 							继续支付 |             > | ||||||
| 						</button> |               评价 | ||||||
| 					</view> |             </button> | ||||||
| 				</view> |             <button | ||||||
| 			</view> |               v-if="order.buttons.includes('delete')" | ||||||
| 		</view> |               class="delete-btn ss-reset-button" | ||||||
|  |               @tap.stop="onDelete(order.id)" | ||||||
|  |             > | ||||||
|  |               删除订单 | ||||||
|  |             </button> | ||||||
|  |             <button | ||||||
|  |               v-if="order.buttons.includes('pay')" | ||||||
|  |               class="tool-btn ss-reset-button ui-BG-Main-Gradient" | ||||||
|  |               @tap.stop="onPay(order.payOrderId)" | ||||||
|  |             > | ||||||
|  |               继续支付 | ||||||
|  |             </button> | ||||||
|  |           </view> | ||||||
|  |         </view> | ||||||
|  |       </view> | ||||||
|  |     </view> | ||||||
| 
 | 
 | ||||||
| 		<!-- 加载更多 --> |     <!-- 加载更多 --> | ||||||
| 		<uni-load-more v-if="state.pagination.total > 0" :status="state.loadStatus" :content-text="{ |     <uni-load-more | ||||||
|  |       v-if="state.pagination.total > 0" | ||||||
|  |       :status="state.loadStatus" | ||||||
|  |       :content-text="{ | ||||||
|         contentdown: '上拉加载更多', |         contentdown: '上拉加载更多', | ||||||
|       }" @tap="loadMore" /> |       }" | ||||||
| 	</s-layout> |       @tap="loadMore" | ||||||
|  |     /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
| 	import { onLoad, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom, onPullDownRefresh } from '@dcloudio/uni-app'; | ||||||
|   import { |   import { | ||||||
|     fen2yuan, |     fen2yuan, | ||||||
|     formatOrderColor, formatOrderStatus, handleOrderButtons, |     formatOrderColor, | ||||||
|  |     formatOrderStatus, | ||||||
|  |     handleOrderButtons, | ||||||
|   } from '@/sheep/hooks/useGoods'; |   } from '@/sheep/hooks/useGoods'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
| 	import { |   import { isEmpty } from 'lodash-es'; | ||||||
| 		isEmpty |  | ||||||
| 	} from 'lodash'; |  | ||||||
|   import OrderApi from '@/sheep/api/trade/order'; |   import OrderApi from '@/sheep/api/trade/order'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
| 
 | 
 | ||||||
| 	// 数据 |   // 数据 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		currentTab: 0, // 选中的 tabMaps 下标 |     currentTab: 0, // 选中的 tabMaps 下标 | ||||||
| 		pagination: { |     pagination: { | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 5, |       pageSize: 5, | ||||||
| 		}, |     }, | ||||||
| 		loadStatus: '' |     loadStatus: '', | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	const tabMaps = [{ |   const tabMaps = [ | ||||||
| 			name: '全部' |     { | ||||||
| 		}, |       name: '全部', | ||||||
| 		{ |     }, | ||||||
| 			name: '待付款', |     { | ||||||
| 			value: 0, |       name: '待付款', | ||||||
| 		}, |       value: 0, | ||||||
| 		{ |     }, | ||||||
| 			name: '待发货', |     { | ||||||
| 			value: 10, |       name: '待发货', | ||||||
| 		}, |       value: 10, | ||||||
| 		{ |     }, | ||||||
| 			name: '待收货', |     { | ||||||
| 			value: 20, |       name: '待收货', | ||||||
| 		}, |       value: 20, | ||||||
| 		{ |     }, | ||||||
| 			name: '待评价', |     { | ||||||
| 			value: 30, |       name: '待评价', | ||||||
| 		}, |       value: 30, | ||||||
| 	]; |     }, | ||||||
|  |   ]; | ||||||
| 
 | 
 | ||||||
| 	// 切换选项卡 |   // 切换选项卡 | ||||||
| 	function onTabsChange(e) { |   function onTabsChange(e) { | ||||||
| 		if (state.currentTab === e.index) { |     if (state.currentTab === e.index) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     // 重头加载代码 |     // 重头加载代码 | ||||||
| 		resetPagination(state.pagination); |     resetPagination(state.pagination); | ||||||
| 		state.currentTab = e.index; |     state.currentTab = e.index; | ||||||
| 		getOrderList(); |     getOrderList(); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 订单详情 |   // 订单详情 | ||||||
| 	function onOrderDetail(id) { |   function onOrderDetail(id) { | ||||||
| 		sheep.$router.go('/pages/order/detail', { |     sheep.$router.go('/pages/order/detail', { | ||||||
| 			id, |       id, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 跳转拼团记录的详情 |   // 跳转拼团记录的详情 | ||||||
| 	function onOrderGroupon(order) { |   function onOrderGroupon(order) { | ||||||
| 		sheep.$router.go('/pages/activity/groupon/detail', { |     sheep.$router.go('/pages/activity/groupon/detail', { | ||||||
| 			id: order.combinationRecordId, |       id: order.combinationRecordId, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 继续支付 |   // 继续支付 | ||||||
| 	function onPay(payOrderId) { |   function onPay(payOrderId) { | ||||||
| 		sheep.$router.go('/pages/pay/index', { |     sheep.$router.go('/pages/pay/index', { | ||||||
| 			id: payOrderId, |       id: payOrderId, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 评价 |   // 评价 | ||||||
| 	function onComment(id) { |   function onComment(id) { | ||||||
| 		sheep.$router.go('/pages/goods/comment/add', { |     sheep.$router.go('/pages/goods/comment/add', { | ||||||
| 			id, |       id, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 确认收货 TODO 芋艿:待测试 |   // 确认收货 TODO 芋艿:待测试 | ||||||
| 	async function onConfirm(order, ignore = false) { |   async function onConfirm(order, ignore = false) { | ||||||
| 		// 需开启确认收货组件 |     // 需开启确认收货组件 | ||||||
| 		// todo: 芋艿:需要后续接入微信收货组件 |     // todo: 芋艿:需要后续接入微信收货组件 | ||||||
| 		// 1.怎么检测是否开启了发货组件功能?如果没有开启的话就不能在这里return出去 |     // 1.怎么检测是否开启了发货组件功能?如果没有开启的话就不能在这里return出去 | ||||||
| 		// 2.如果开启了走mpConfirm方法,需要在App.vue的show方法中拿到确认收货结果 |     // 2.如果开启了走mpConfirm方法,需要在App.vue的show方法中拿到确认收货结果 | ||||||
| 		let isOpenBusinessView = true; |     let isOpenBusinessView = true; | ||||||
| 		if ( |     if ( | ||||||
| 			sheep.$platform.name === 'WechatMiniProgram' && |       sheep.$platform.name === 'WechatMiniProgram' && | ||||||
| 			!isEmpty(order.wechat_extra_data) && |       !isEmpty(order.wechat_extra_data) && | ||||||
| 			isOpenBusinessView && |       isOpenBusinessView && | ||||||
| 			!ignore |       !ignore | ||||||
| 		) { |     ) { | ||||||
| 			mpConfirm(order); |       mpConfirm(order); | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		// 正常的确认收货流程 |     // 正常的确认收货流程 | ||||||
| 		const { code } = await OrderApi.receiveOrder(order.id); |     const { code } = await OrderApi.receiveOrder(order.id); | ||||||
| 		if (code === 0) { |     if (code === 0) { | ||||||
|       resetPagination(state.pagination); |       resetPagination(state.pagination); | ||||||
|       await getOrderList(); |       await getOrderList(); | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// #ifdef MP-WEIXIN |   // #ifdef MP-WEIXIN | ||||||
| 	// 小程序确认收货组件 TODO 芋艿:后续再接入 |   // 小程序确认收货组件 TODO 芋艿:后续再接入 | ||||||
| 	function mpConfirm(order) { |   function mpConfirm(order) { | ||||||
| 		if (!wx.openBusinessView) { |     if (!wx.openBusinessView) { | ||||||
| 			sheep.$helper.toast(`请升级微信版本`); |       sheep.$helper.toast(`请升级微信版本`); | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
| 		wx.openBusinessView({ |     wx.openBusinessView({ | ||||||
| 			businessType: 'weappOrderConfirm', |       businessType: 'weappOrderConfirm', | ||||||
| 			extraData: { |       extraData: { | ||||||
| 				merchant_id: '1481069012', |         merchant_id: '1481069012', | ||||||
| 				merchant_trade_no: order.wechat_extra_data.merchant_trade_no, |         merchant_trade_no: order.wechat_extra_data.merchant_trade_no, | ||||||
| 				transaction_id: order.wechat_extra_data.transaction_id, |         transaction_id: order.wechat_extra_data.transaction_id, | ||||||
| 			}, |       }, | ||||||
| 			success(response) { |       success(response) { | ||||||
| 				console.log('success:', response); |         console.log('success:', response); | ||||||
| 				if (response.errMsg === 'openBusinessView:ok') { |         if (response.errMsg === 'openBusinessView:ok') { | ||||||
| 					if (response.extraData.status === 'success') { |           if (response.extraData.status === 'success') { | ||||||
| 						onConfirm(order, true); |             onConfirm(order, true); | ||||||
| 					} |           } | ||||||
| 				} |         } | ||||||
| 			}, |       }, | ||||||
| 			fail(error) { |       fail(error) { | ||||||
| 				console.log('error:', error); |         console.log('error:', error); | ||||||
| 			}, |       }, | ||||||
| 			complete(result) { |       complete(result) { | ||||||
| 				console.log('result:', result); |         console.log('result:', result); | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 	// #endif |   // #endif | ||||||
| 
 | 
 | ||||||
| 	// 查看物流 |   // 查看物流 | ||||||
| 	async function onExpress(id) { |   async function onExpress(id) { | ||||||
| 		sheep.$router.go('/pages/order/express/log', { |     sheep.$router.go('/pages/order/express/log', { | ||||||
|       id, |       id, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 取消订单 |   // 取消订单 | ||||||
| 	async function onCancel(orderId) { |   async function onCancel(orderId) { | ||||||
| 		uni.showModal({ |     uni.showModal({ | ||||||
| 			title: '提示', |       title: '提示', | ||||||
| 			content: '确定要取消订单吗?', |       content: '确定要取消订单吗?', | ||||||
| 			success: async function(res) { |       success: async function (res) { | ||||||
| 				if (!res.confirm) { |         if (!res.confirm) { | ||||||
|           return; |           return; | ||||||
| 				} |         } | ||||||
|         const { code } = await OrderApi.cancelOrder(orderId); |         const { code } = await OrderApi.cancelOrder(orderId); | ||||||
|         if (code === 0) { |         if (code === 0) { | ||||||
|           // 修改数据的状态 |           // 修改数据的状态 | ||||||
|  | @ -246,208 +287,209 @@ | ||||||
|           orderInfo.status = 40; |           orderInfo.status = 40; | ||||||
|           handleOrderButtons(orderInfo); |           handleOrderButtons(orderInfo); | ||||||
|         } |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 删除订单 |   // 删除订单 | ||||||
| 	function onDelete(orderId) { |   function onDelete(orderId) { | ||||||
| 		uni.showModal({ |     uni.showModal({ | ||||||
| 			title: '提示', |       title: '提示', | ||||||
| 			content: '确定要删除订单吗?', |       content: '确定要删除订单吗?', | ||||||
| 			success: async function(res) { |       success: async function (res) { | ||||||
| 				if (res.confirm) { |         if (res.confirm) { | ||||||
| 					const { code } = await OrderApi.deleteOrder(orderId); |           const { code } = await OrderApi.deleteOrder(orderId); | ||||||
| 					if (code === 0) { |           if (code === 0) { | ||||||
|             // 删除数据 |             // 删除数据 | ||||||
| 						let index = state.pagination.list.findIndex((order) => order.id === orderId); |             let index = state.pagination.list.findIndex((order) => order.id === orderId); | ||||||
| 						state.pagination.list.splice(index, 1); |             state.pagination.list.splice(index, 1); | ||||||
| 					} |           } | ||||||
| 				} |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	// 获取订单列表 |   // 获取订单列表 | ||||||
| 	async function getOrderList() { |   async function getOrderList() { | ||||||
| 		state.loadStatus = 'loading'; |     state.loadStatus = 'loading'; | ||||||
| 		let { code, data } = await OrderApi.getOrderPage({ |     let { code, data } = await OrderApi.getOrderPage({ | ||||||
|       pageNo: state.pagination.pageNo, |       pageNo: state.pagination.pageNo, | ||||||
|       pageSize: state.pagination.pageSize, |       pageSize: state.pagination.pageSize, | ||||||
|       status: tabMaps[state.currentTab].value, |       status: tabMaps[state.currentTab].value, | ||||||
| 			commentStatus: tabMaps[state.currentTab].value === 30 ? false : null |       commentStatus: tabMaps[state.currentTab].value === 30 ? false : null, | ||||||
| 		}); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     data.list.forEach(order => handleOrderButtons(order)); |     data.list.forEach((order) => handleOrderButtons(order)); | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list) |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 	onLoad(async (options) => { |   onLoad(async (options) => { | ||||||
| 		if (options.type) { |     if (options.type) { | ||||||
| 			state.currentTab = options.type; |       state.currentTab = options.type; | ||||||
| 		} |     } | ||||||
| 		await getOrderList(); |     await getOrderList(); | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 加载更多 |   // 加载更多 | ||||||
| 	function loadMore() { |   function loadMore() { | ||||||
| 		if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
|       return |       return; | ||||||
| 		} |     } | ||||||
|     state.pagination.pageNo++; |     state.pagination.pageNo++; | ||||||
|     getOrderList(); |     getOrderList(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 	// 上拉加载更多 |   // 上拉加载更多 | ||||||
| 	onReachBottom(() => { |   onReachBottom(() => { | ||||||
| 		loadMore(); |     loadMore(); | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 下拉刷新 |   // 下拉刷新 | ||||||
| 	onPullDownRefresh(() => { |   onPullDownRefresh(() => { | ||||||
|     resetPagination(state.pagination); |     resetPagination(state.pagination); | ||||||
| 		getOrderList(); |     getOrderList(); | ||||||
| 		setTimeout(function() { |     setTimeout(function () { | ||||||
| 			uni.stopPullDownRefresh(); |       uni.stopPullDownRefresh(); | ||||||
| 		}, 800); |     }, 800); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.score-img { |   .score-img { | ||||||
| 		width: 36rpx; |     width: 36rpx; | ||||||
| 		height: 36rpx; |     height: 36rpx; | ||||||
| 		margin: 0 4rpx; |     margin: 0 4rpx; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.tool-btn { |   .tool-btn { | ||||||
| 		width: 160rpx; |     width: 160rpx; | ||||||
| 		height: 60rpx; |     height: 60rpx; | ||||||
| 		background: #f6f6f6; |     background: #f6f6f6; | ||||||
| 		font-size: 26rpx; |     font-size: 26rpx; | ||||||
| 		border-radius: 30rpx; |     border-radius: 30rpx; | ||||||
| 		margin-right: 10rpx; |     margin-right: 10rpx; | ||||||
| 
 | 
 | ||||||
| 		&:last-of-type { |     &:last-of-type { | ||||||
| 			margin-right: 0; |       margin-right: 0; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.delete-btn { |   .delete-btn { | ||||||
| 		width: 160rpx; |     width: 160rpx; | ||||||
| 		height: 56rpx; |     height: 56rpx; | ||||||
| 		color: #ff3000; |     color: #ff3000; | ||||||
| 		background: #fee; |     background: #fee; | ||||||
| 		border-radius: 28rpx; |     border-radius: 28rpx; | ||||||
| 		font-size: 26rpx; |     font-size: 26rpx; | ||||||
| 		margin-right: 10rpx; |     margin-right: 10rpx; | ||||||
| 		line-height: normal; |     line-height: normal; | ||||||
| 
 | 
 | ||||||
| 		&:last-of-type { |     &:last-of-type { | ||||||
| 			margin-right: 0; |       margin-right: 0; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.apply-btn { |   .apply-btn { | ||||||
| 		width: 140rpx; |     width: 140rpx; | ||||||
| 		height: 50rpx; |     height: 50rpx; | ||||||
| 		border-radius: 25rpx; |     border-radius: 25rpx; | ||||||
| 		font-size: 24rpx; |     font-size: 24rpx; | ||||||
| 		border: 2rpx solid #dcdcdc; |     border: 2rpx solid #dcdcdc; | ||||||
| 		line-height: normal; |     line-height: normal; | ||||||
| 		margin-left: 16rpx; |     margin-left: 16rpx; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.swiper-box { |   .swiper-box { | ||||||
| 		flex: 1; |     flex: 1; | ||||||
| 
 | 
 | ||||||
| 		.swiper-item { |     .swiper-item { | ||||||
| 			height: 100%; |       height: 100%; | ||||||
| 			width: 100%; |       width: 100%; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.order-list-card-box { |   .order-list-card-box { | ||||||
| 		.order-card-header { |     .order-card-header { | ||||||
| 			height: 80rpx; |       height: 80rpx; | ||||||
| 
 | 
 | ||||||
| 			.order-no { |       .order-no { | ||||||
| 				font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.order-state {} |       .order-state { | ||||||
| 		} |       } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
| 		.pay-box { |     .pay-box { | ||||||
| 			.discounts-title { |       .discounts-title { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				line-height: normal; |         line-height: normal; | ||||||
| 				color: #999999; |         color: #999999; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.discounts-money { |       .discounts-money { | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 				line-height: normal; |         line-height: normal; | ||||||
| 				color: #999; |         color: #999; | ||||||
| 				font-family: OPPOSANS; |         font-family: OPPOSANS; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.pay-color { |       .pay-color { | ||||||
| 				color: #333; |         color: #333; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.order-card-footer { |     .order-card-footer { | ||||||
| 			height: 100rpx; |       height: 100rpx; | ||||||
| 
 | 
 | ||||||
| 			.more-item-box { |       .more-item-box { | ||||||
| 				padding: 20rpx; |         padding: 20rpx; | ||||||
| 
 | 
 | ||||||
| 				.more-item { |         .more-item { | ||||||
| 					height: 60rpx; |           height: 60rpx; | ||||||
| 
 | 
 | ||||||
| 					.title { |           .title { | ||||||
| 						font-size: 26rpx; |             font-size: 26rpx; | ||||||
| 					} |           } | ||||||
| 				} |         } | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.more-btn { |       .more-btn { | ||||||
| 				color: $dark-9; |         color: $dark-9; | ||||||
| 				font-size: 24rpx; |         font-size: 24rpx; | ||||||
| 			} |       } | ||||||
| 
 | 
 | ||||||
| 			.content { |       .content { | ||||||
| 				width: 154rpx; |         width: 154rpx; | ||||||
| 				color: #333333; |         color: #333333; | ||||||
| 				font-size: 26rpx; |         font-size: 26rpx; | ||||||
| 				font-weight: 500; |         font-weight: 500; | ||||||
| 			} |       } | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	:deep(.uni-tooltip-popup) { |   :deep(.uni-tooltip-popup) { | ||||||
| 		background: var(--ui-BG); |     background: var(--ui-BG); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.warning-color { |   .warning-color { | ||||||
| 		color: #faad14; |     color: #faad14; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.danger-color { |   .danger-color { | ||||||
| 		color: #ff3000; |     color: #ff3000; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.success-color { |   .success-color { | ||||||
| 		color: #52c41a; |     color: #52c41a; | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.info-color { |   .info-color { | ||||||
| 		color: #999999; |     color: #999999; | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -8,7 +8,7 @@ | ||||||
|           <view class="title">充值金额</view> |           <view class="title">充值金额</view> | ||||||
|           <view class="num" :class="item.refundStatus === 10 ? 'danger-color' : 'success-color'"> |           <view class="num" :class="item.refundStatus === 10 ? 'danger-color' : 'success-color'"> | ||||||
|             {{ fen2yuan(item.payPrice) }} 元 |             {{ fen2yuan(item.payPrice) }} 元 | ||||||
|             <text v-if="item.bonusPrice > 0">(赠送 {{ fen2yuan(item.bonusPrice)}} 元)</text> |             <text v-if="item.bonusPrice > 0">(赠送 {{ fen2yuan(item.bonusPrice) }} 元)</text> | ||||||
|           </view> |           </view> | ||||||
|         </view> |         </view> | ||||||
|         <view class="status-box item ss-flex ss-col-center ss-row-between"> |         <view class="status-box item ss-flex ss-col-center ss-row-between"> | ||||||
|  | @ -30,7 +30,9 @@ | ||||||
|         </view> |         </view> | ||||||
|         <view class="time-box item ss-flex ss-col-center ss-row-between"> |         <view class="time-box item ss-flex ss-col-center ss-row-between"> | ||||||
|           <text class="item-title">充值时间</text> |           <text class="item-title">充值时间</text> | ||||||
|           <view class="time"> {{ sheep.$helper.timeFormat(item.payTime, 'yyyy-mm-dd hh:MM:ss') }}</view> |           <view class="time"> | ||||||
|  |             {{ sheep.$helper.timeFormat(item.payTime, 'yyyy-mm-dd hh:MM:ss') }}</view | ||||||
|  |           > | ||||||
|         </view> |         </view> | ||||||
|       </view> |       </view> | ||||||
|     </view> |     </view> | ||||||
|  | @ -53,7 +55,7 @@ | ||||||
| <script setup> | <script setup> | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import PayWalletApi from '@/sheep/api/pay/wallet'; |   import PayWalletApi from '@/sheep/api/pay/wallet'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { fen2yuan } from '../../sheep/hooks/useGoods'; |   import { fen2yuan } from '../../sheep/hooks/useGoods'; | ||||||
|  |  | ||||||
|  | @ -50,7 +50,10 @@ | ||||||
|       </view> |       </view> | ||||||
| 
 | 
 | ||||||
|       <!-- #ifdef MP --> |       <!-- #ifdef MP --> | ||||||
|       <view class="subscribe-box ss-flex ss-m-t-44" v-if="showSubscribeBtn && state.orderType === 'goods'"> |       <view | ||||||
|  |         class="subscribe-box ss-flex ss-m-t-44" | ||||||
|  |         v-if="showSubscribeBtn && state.orderType === 'goods'" | ||||||
|  |       > | ||||||
|         <image class="subscribe-img" :src="sheep.$url.static('/static/img/shop/order/cargo.png')" /> |         <image class="subscribe-img" :src="sheep.$url.static('/static/img/shop/order/cargo.png')" /> | ||||||
|         <view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view> |         <view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view> | ||||||
|         <view class="subscribe-start" @tap="subscribeMessage">立即订阅</view> |         <view class="subscribe-start" @tap="subscribeMessage">立即订阅</view> | ||||||
|  | @ -63,7 +66,7 @@ | ||||||
| <script setup> | <script setup> | ||||||
|   import { onLoad, onHide, onShow } from '@dcloudio/uni-app'; |   import { onLoad, onHide, onShow } from '@dcloudio/uni-app'; | ||||||
|   import { reactive, computed, ref } from 'vue'; |   import { reactive, computed, ref } from 'vue'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import PayOrderApi from '@/sheep/api/pay/order'; |   import PayOrderApi from '@/sheep/api/pay/order'; | ||||||
|   import { fen2yuan } from '@/sheep/hooks/useGoods'; |   import { fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|  | @ -114,12 +117,12 @@ | ||||||
|         uni.showModal({ |         uni.showModal({ | ||||||
|           title: '支付结果', |           title: '支付结果', | ||||||
|           showCancel: false, // 不要取消按钮 |           showCancel: false, // 不要取消按钮 | ||||||
|           content: "支付成功", |           content: '支付成功', | ||||||
|           success: () => { |           success: () => { | ||||||
|             // 订阅只能由用户主动触发,只能包一层 showModal 诱导用户点击 |             // 订阅只能由用户主动触发,只能包一层 showModal 诱导用户点击 | ||||||
|             autoSubscribeMessage(); |             autoSubscribeMessage(); | ||||||
|           } |           }, | ||||||
|         }) |         }); | ||||||
| 
 | 
 | ||||||
|         // #endif |         // #endif | ||||||
|         // 特殊:获得商品订单信息 |         // 特殊:获得商品订单信息 | ||||||
|  | @ -153,8 +156,8 @@ | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // #ifdef MP |   // #ifdef MP | ||||||
|   const showSubscribeBtn = ref(false) // 默认隐藏 |   const showSubscribeBtn = ref(false); // 默认隐藏 | ||||||
|   const SUBSCRIBE_BTN_STATUS_STORAGE_KEY = "subscribe_btn_status" |   const SUBSCRIBE_BTN_STATUS_STORAGE_KEY = 'subscribe_btn_status'; | ||||||
|   function subscribeMessage() { |   function subscribeMessage() { | ||||||
|     if (state.orderType !== 'goods') { |     if (state.orderType !== 'goods') { | ||||||
|       return; |       return; | ||||||
|  | @ -176,11 +179,11 @@ | ||||||
|     const subscribeBtnStatus = uni.getStorageSync(SUBSCRIBE_BTN_STATUS_STORAGE_KEY); |     const subscribeBtnStatus = uni.getStorageSync(SUBSCRIBE_BTN_STATUS_STORAGE_KEY); | ||||||
|     if (!subscribeBtnStatus) { |     if (!subscribeBtnStatus) { | ||||||
|       showSubscribeBtn.value = true; |       showSubscribeBtn.value = true; | ||||||
|       return |       return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // 2. 订阅消息 |     // 2. 订阅消息 | ||||||
|     subscribeMessage() |     subscribeMessage(); | ||||||
|   } |   } | ||||||
|   // #endif |   // #endif | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,78 +1,118 @@ | ||||||
| <!-- 收货地址的新增/编辑 --> | <!-- 收货地址的新增/编辑 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout :title="state.model.id ? '编辑地址' : '新增地址'"> |   <s-layout :title="state.model.id ? '编辑地址' : '新增地址'"> | ||||||
| 		<uni-forms ref="addressFormRef" v-model="state.model" :rules="rules" validateTrigger="bind" |     <uni-forms | ||||||
| 			labelWidth="160" labelAlign="left" border :labelStyle="{ fontWeight: 'bold' }"> |       ref="addressFormRef" | ||||||
| 			<view class="bg-white form-box ss-p-x-30"> |       v-model="state.model" | ||||||
| 				<uni-forms-item name="name" label="收货人" class="form-item"> |       :rules="rules" | ||||||
| 					<uni-easyinput v-model="state.model.name" placeholder="请填写收货人姓名" :inputBorder="false" |       validateTrigger="bind" | ||||||
| 						placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" /> |       labelWidth="160" | ||||||
| 				</uni-forms-item> |       labelAlign="left" | ||||||
|  |       border | ||||||
|  |       :labelStyle="{ fontWeight: 'bold' }" | ||||||
|  |     > | ||||||
|  |       <view class="bg-white form-box ss-p-x-30"> | ||||||
|  |         <uni-forms-item name="name" label="收货人" class="form-item"> | ||||||
|  |           <uni-easyinput | ||||||
|  |             v-model="state.model.name" | ||||||
|  |             placeholder="请填写收货人姓名" | ||||||
|  |             :inputBorder="false" | ||||||
|  |             placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" | ||||||
|  |           /> | ||||||
|  |         </uni-forms-item> | ||||||
| 
 | 
 | ||||||
| 				<uni-forms-item name="mobile" label="手机号" class="form-item"> |         <uni-forms-item name="mobile" label="手机号" class="form-item"> | ||||||
| 					<uni-easyinput v-model="state.model.mobile" type="number" placeholder="请输入手机号" :inputBorder="false" |           <uni-easyinput | ||||||
| 						placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal"> |             v-model="state.model.mobile" | ||||||
| 					</uni-easyinput> |             type="number" | ||||||
| 				</uni-forms-item> |             placeholder="请输入手机号" | ||||||
| 				<uni-forms-item name="areaName" label="省市区" @tap="state.showRegion = true" class="form-item"> |             :inputBorder="false" | ||||||
| 					<uni-easyinput v-model="state.model.areaName" disabled :inputBorder="false" |             placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" | ||||||
| 						:styles="{ disableColor: '#fff', color: '#333' }" |           > | ||||||
| 						placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" |           </uni-easyinput> | ||||||
| 						placeholder="请选择省市区"> |         </uni-forms-item> | ||||||
| 						<template v-slot:right> |         <uni-forms-item | ||||||
| 							<uni-icons type="right" /> |           name="areaName" | ||||||
| 						</template> |           label="省市区" | ||||||
| 					</uni-easyinput> |           @tap="state.showRegion = true" | ||||||
| 				</uni-forms-item> |           class="form-item" | ||||||
| 				<uni-forms-item name="detailAddress" label="详细地址" :formItemStyle="{ alignItems: 'flex-start' }" |         > | ||||||
| 					:labelStyle="{ lineHeight: '5em' }" class="textarea-item"> |           <uni-easyinput | ||||||
| 					<uni-easyinput :inputBorder="false" type="textarea" v-model="state.model.detailAddress" |             v-model="state.model.areaName" | ||||||
| 						placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" |             disabled | ||||||
| 						placeholder="请输入详细地址" clearable /> |             :inputBorder="false" | ||||||
| 				</uni-forms-item> |             :styles="{ disableColor: '#fff', color: '#333' }" | ||||||
| 			</view> |             placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" | ||||||
| 			<view class="ss-m-y-20 bg-white ss-p-x-30 ss-flex ss-row-between ss-col-center default-box"> |             placeholder="请选择省市区" | ||||||
| 				<view class="default-box-title"> 设为默认地址 </view> |           > | ||||||
| 				<su-switch style="transform: scale(0.8)" v-model="state.model.defaultStatus" /> |             <template v-slot:right> | ||||||
| 			</view> |               <uni-icons type="right" /> | ||||||
| 		</uni-forms> |             </template> | ||||||
| 		<su-fixed bottom :opacity="false" bg="" placeholder :noFixed="false" :index="10"> |           </uni-easyinput> | ||||||
| 			<view class="footer-box ss-flex-col ss-row-between ss-p-20"> |         </uni-forms-item> | ||||||
| 				<view class="ss-m-b-20"> |         <uni-forms-item | ||||||
|  |           name="detailAddress" | ||||||
|  |           label="详细地址" | ||||||
|  |           :formItemStyle="{ alignItems: 'flex-start' }" | ||||||
|  |           :labelStyle="{ lineHeight: '5em' }" | ||||||
|  |           class="textarea-item" | ||||||
|  |         > | ||||||
|  |           <uni-easyinput | ||||||
|  |             :inputBorder="false" | ||||||
|  |             type="textarea" | ||||||
|  |             v-model="state.model.detailAddress" | ||||||
|  |             placeholderStyle="color:#BBBBBB;font-size:30rpx;font-weight:400;line-height:normal" | ||||||
|  |             placeholder="请输入详细地址" | ||||||
|  |             clearable | ||||||
|  |           /> | ||||||
|  |         </uni-forms-item> | ||||||
|  |       </view> | ||||||
|  |       <view class="ss-m-y-20 bg-white ss-p-x-30 ss-flex ss-row-between ss-col-center default-box"> | ||||||
|  |         <view class="default-box-title"> 设为默认地址 </view> | ||||||
|  |         <su-switch style="transform: scale(0.8)" v-model="state.model.defaultStatus" /> | ||||||
|  |       </view> | ||||||
|  |     </uni-forms> | ||||||
|  |     <su-fixed bottom :opacity="false" bg="" placeholder :noFixed="false" :index="10"> | ||||||
|  |       <view class="footer-box ss-flex-col ss-row-between ss-p-20"> | ||||||
|  |         <view class="ss-m-b-20"> | ||||||
|           <button class="ss-reset-button save-btn ui-Shadow-Main" @tap="onSave">保存</button> |           <button class="ss-reset-button save-btn ui-Shadow-Main" @tap="onSave">保存</button> | ||||||
|         </view> |         </view> | ||||||
| 				<button v-if="state.model.id" class="ss-reset-button cancel-btn" @tap="onDelete"> |         <button v-if="state.model.id" class="ss-reset-button cancel-btn" @tap="onDelete"> | ||||||
| 					删除 |           删除 | ||||||
| 				</button> |         </button> | ||||||
| 			</view> |       </view> | ||||||
| 		</su-fixed> |     </su-fixed> | ||||||
| 
 | 
 | ||||||
| 		<!-- 省市区弹窗 --> |     <!-- 省市区弹窗 --> | ||||||
| 		<su-region-picker :show="state.showRegion" @cancel="state.showRegion = false" @confirm="onRegionConfirm" /> |     <su-region-picker | ||||||
| 	</s-layout> |       :show="state.showRegion" | ||||||
|  |       @cancel="state.showRegion = false" | ||||||
|  |       @confirm="onRegionConfirm" | ||||||
|  |     /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { ref, reactive, unref } from 'vue'; |   import { ref, reactive, unref } from 'vue'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import { onLoad } from '@dcloudio/uni-app'; |   import { onLoad } from '@dcloudio/uni-app'; | ||||||
| 	import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
| 	import { mobile } from '@/sheep/validate/form'; |   import { mobile } from '@/sheep/validate/form'; | ||||||
|   import AreaApi from '@/sheep/api/system/area'; |   import AreaApi from '@/sheep/api/system/area'; | ||||||
|   import AddressApi from '@/sheep/api/member/address'; |   import AddressApi from '@/sheep/api/member/address'; | ||||||
| 
 | 
 | ||||||
| 	const addressFormRef = ref(null); |   const addressFormRef = ref(null); | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		showRegion: false, |     showRegion: false, | ||||||
| 		model: { |     model: { | ||||||
| 			name: '', |       name: '', | ||||||
| 			mobile: '', |       mobile: '', | ||||||
|       detailAddress: '', |       detailAddress: '', | ||||||
| 			defaultStatus: false, |       defaultStatus: false, | ||||||
|       areaName: '', |       areaName: '', | ||||||
| 		}, |     }, | ||||||
|     rules: {}, |     rules: {}, | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
|   const rules = { |   const rules = { | ||||||
|     name: { |     name: { | ||||||
|  | @ -85,93 +125,99 @@ | ||||||
|     }, |     }, | ||||||
|     mobile, |     mobile, | ||||||
|     detailAddress: { |     detailAddress: { | ||||||
|       rules: [{ |       rules: [ | ||||||
|         required: true, |         { | ||||||
|         errorMessage: '请输入详细地址', |           required: true, | ||||||
|       }] |           errorMessage: '请输入详细地址', | ||||||
|  |         }, | ||||||
|  |       ], | ||||||
|     }, |     }, | ||||||
|     areaName: { |     areaName: { | ||||||
|       rules: [{ |       rules: [ | ||||||
|         required: true, |         { | ||||||
|         errorMessage: '请选择您的位置' |           required: true, | ||||||
|       }] |           errorMessage: '请选择您的位置', | ||||||
|  |         }, | ||||||
|  |       ], | ||||||
|     }, |     }, | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   // 确认选择地区 |   // 确认选择地区 | ||||||
| 	const onRegionConfirm = (e) => { |   const onRegionConfirm = (e) => { | ||||||
|     state.model.areaName = `${e.province_name} ${e.city_name} ${e.district_name}` |     state.model.areaName = `${e.province_name} ${e.city_name} ${e.district_name}`; | ||||||
|     state.model.areaId = e.district_id; |     state.model.areaId = e.district_id; | ||||||
| 		state.showRegion = false; |     state.showRegion = false; | ||||||
| 	}; |   }; | ||||||
| 
 | 
 | ||||||
|   // 获得地区数据 |   // 获得地区数据 | ||||||
| 	const getAreaData = () => { |   const getAreaData = () => { | ||||||
| 		if (_.isEmpty(uni.getStorageSync('areaData'))) { |     if (_.isEmpty(uni.getStorageSync('areaData'))) { | ||||||
|       AreaApi.getAreaTree().then((res) => { |       AreaApi.getAreaTree().then((res) => { | ||||||
|         if (res.code === 0) { |         if (res.code === 0) { | ||||||
|           uni.setStorageSync('areaData', res.data); |           uni.setStorageSync('areaData', res.data); | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
| 		} |     } | ||||||
| 	}; |   }; | ||||||
| 
 | 
 | ||||||
|   // 保存收货地址 |   // 保存收货地址 | ||||||
| 	const onSave = async () => { |   const onSave = async () => { | ||||||
|     // 参数校验 |     // 参数校验 | ||||||
| 		const validate = await unref(addressFormRef) |     const validate = await unref(addressFormRef) | ||||||
| 			.validate() |       .validate() | ||||||
| 			.catch((error) => { |       .catch((error) => { | ||||||
| 				console.log('error: ', error); |         console.log('error: ', error); | ||||||
| 			}); |       }); | ||||||
| 		if (!validate) { |     if (!validate) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // 提交请求 |     // 提交请求 | ||||||
|     const formData = { |     const formData = { | ||||||
|       ...state.model |       ...state.model, | ||||||
|  |     }; | ||||||
|  |     const { code } = | ||||||
|  |       state.model.id > 0 | ||||||
|  |         ? await AddressApi.updateAddress(formData) | ||||||
|  |         : await AddressApi.createAddress(formData); | ||||||
|  |     if (code === 0) { | ||||||
|  |       sheep.$router.back(); | ||||||
|     } |     } | ||||||
|     const {code } = state.model.id > 0 ? await AddressApi.updateAddress(formData) |   }; | ||||||
|       : await AddressApi.createAddress(formData); |  | ||||||
| 		if (code === 0) { |  | ||||||
| 			sheep.$router.back(); |  | ||||||
| 		} |  | ||||||
| 	}; |  | ||||||
| 
 | 
 | ||||||
|   // 删除收货地址 |   // 删除收货地址 | ||||||
| 	const onDelete = () => { |   const onDelete = () => { | ||||||
| 		uni.showModal({ |     uni.showModal({ | ||||||
| 			title: '提示', |       title: '提示', | ||||||
| 			content: '确认删除此收货地址吗?', |       content: '确认删除此收货地址吗?', | ||||||
| 			success: async function(res) { |       success: async function (res) { | ||||||
| 				if (!res.confirm) { |         if (!res.confirm) { | ||||||
| 					return; |           return; | ||||||
| 				} |         } | ||||||
|         const { code } = await AddressApi.deleteAddress(state.model.id); |         const { code } = await AddressApi.deleteAddress(state.model.id); | ||||||
|         if (code === 0) { |         if (code === 0) { | ||||||
|           sheep.$router.back(); |           sheep.$router.back(); | ||||||
|         } |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 	}; |   }; | ||||||
| 
 | 
 | ||||||
| 	onLoad(async (options) => { |   onLoad(async (options) => { | ||||||
|     // 获得地区数据 |     // 获得地区数据 | ||||||
| 		getAreaData(); |     getAreaData(); | ||||||
|     // 情况一:基于 id 获得收件地址 |     // 情况一:基于 id 获得收件地址 | ||||||
| 		if (options.id) { |     if (options.id) { | ||||||
| 			let { code, data} = await AddressApi.getAddress(options.id); |       let { code, data } = await AddressApi.getAddress(options.id); | ||||||
|       if (code !== 0) { |       if (code !== 0) { | ||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|       state.model = data; |       state.model = data; | ||||||
| 		} |     } | ||||||
|      // 情况二:微信导入 |     // 情况二:微信导入 | ||||||
|     if (options.data) { |     if (options.data) { | ||||||
|       let data = JSON.parse(options.data); |       let data = JSON.parse(options.data); | ||||||
|       const areaData = uni.getStorageSync('areaData'); |       const areaData = uni.getStorageSync('areaData'); | ||||||
|       const findAreaByName = (areas, name) => areas.find(item => item.name === name); |       const findAreaByName = (areas, name) => areas.find((item) => item.name === name); | ||||||
| 
 | 
 | ||||||
|       let provinceObj = findAreaByName(areaData, data.province_name); |       let provinceObj = findAreaByName(areaData, data.province_name); | ||||||
|       let cityObj = provinceObj ? findAreaByName(provinceObj.children, data.city_name) : undefined; |       let cityObj = provinceObj ? findAreaByName(provinceObj.children, data.city_name) : undefined; | ||||||
|  | @ -181,77 +227,79 @@ | ||||||
|       state.model = { |       state.model = { | ||||||
|         ...state.model, |         ...state.model, | ||||||
|         areaId, |         areaId, | ||||||
|         areaName: [data.province_name, data.city_name, data.district_name].filter(Boolean).join(" "), |         areaName: [data.province_name, data.city_name, data.district_name] | ||||||
|  |           .filter(Boolean) | ||||||
|  |           .join(' '), | ||||||
|         defaultStatus: false, |         defaultStatus: false, | ||||||
|         detailAddress: data.address, |         detailAddress: data.address, | ||||||
|         mobile: data.mobile, |         mobile: data.mobile, | ||||||
|         name: data.consignee, |         name: data.consignee, | ||||||
|       }; |       }; | ||||||
| 		} |     } | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	:deep() { |   :deep() { | ||||||
| 		.uni-forms-item__label .label-text { |     .uni-forms-item__label .label-text { | ||||||
| 			font-size: 28rpx !important; |       font-size: 28rpx !important; | ||||||
| 			color: #333333 !important; |       color: #333333 !important; | ||||||
| 			line-height: normal !important; |       line-height: normal !important; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.uni-easyinput__content-input { |     .uni-easyinput__content-input { | ||||||
| 			font-size: 28rpx !important; |       font-size: 28rpx !important; | ||||||
| 			color: #333333 !important; |       color: #333333 !important; | ||||||
| 			line-height: normal !important; |       line-height: normal !important; | ||||||
| 			padding-left: 0 !important; |       padding-left: 0 !important; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.uni-easyinput__content-textarea { |     .uni-easyinput__content-textarea { | ||||||
| 			font-size: 28rpx !important; |       font-size: 28rpx !important; | ||||||
| 			color: #333333 !important; |       color: #333333 !important; | ||||||
| 			line-height: normal !important; |       line-height: normal !important; | ||||||
| 			margin-top: 8rpx !important; |       margin-top: 8rpx !important; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.uni-icons { |     .uni-icons { | ||||||
| 			font-size: 40rpx !important; |       font-size: 40rpx !important; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.is-textarea-icon { |     .is-textarea-icon { | ||||||
| 			margin-top: 22rpx; |       margin-top: 22rpx; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.is-disabled { |     .is-disabled { | ||||||
| 			color: #333333; |       color: #333333; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.default-box { |   .default-box { | ||||||
| 		width: 100%; |     width: 100%; | ||||||
| 		box-sizing: border-box; |     box-sizing: border-box; | ||||||
| 		height: 100rpx; |     height: 100rpx; | ||||||
| 
 | 
 | ||||||
| 		.default-box-title { |     .default-box-title { | ||||||
| 			font-size: 28rpx; |       font-size: 28rpx; | ||||||
| 			color: #333333; |       color: #333333; | ||||||
| 			line-height: normal; |       line-height: normal; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	.footer-box { |   .footer-box { | ||||||
| 		.save-btn { |     .save-btn { | ||||||
| 			width: 710rpx; |       width: 710rpx; | ||||||
| 			height: 80rpx; |       height: 80rpx; | ||||||
| 			border-radius: 40rpx; |       border-radius: 40rpx; | ||||||
| 			background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); |       background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); | ||||||
| 			color: $white; |       color: $white; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.cancel-btn { |     .cancel-btn { | ||||||
| 			width: 710rpx; |       width: 710rpx; | ||||||
| 			height: 80rpx; |       height: 80rpx; | ||||||
| 			border-radius: 40rpx; |       border-radius: 40rpx; | ||||||
| 			background: var(--ui-BG); |       background: var(--ui-BG); | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -1,143 +1,156 @@ | ||||||
| <!-- 收件地址列表 --> | <!-- 收件地址列表 --> | ||||||
| <template> | <template> | ||||||
| 	<s-layout title="收货地址" :bgStyle="{ color: '#FFF' }"> |   <s-layout title="收货地址" :bgStyle="{ color: '#FFF' }"> | ||||||
| 		<view v-if="state.list.length"> |     <view v-if="state.list.length"> | ||||||
| 			<s-address-item hasBorderBottom v-for="item in state.list" :key="item.id" :item="item" |       <s-address-item | ||||||
|                       @tap="onSelect(item)" /> |         hasBorderBottom | ||||||
| 		</view> |         v-for="item in state.list" | ||||||
|  |         :key="item.id" | ||||||
|  |         :item="item" | ||||||
|  |         @tap="onSelect(item)" | ||||||
|  |       /> | ||||||
|  |     </view> | ||||||
| 
 | 
 | ||||||
| 		<su-fixed bottom placeholder> |     <su-fixed bottom placeholder> | ||||||
| 			<view class="footer-box ss-flex ss-row-between ss-p-20"> |       <view class="footer-box ss-flex ss-row-between ss-p-20"> | ||||||
| 				<!-- 微信小程序和微信H5 --> |         <!-- 微信小程序和微信H5 --> | ||||||
| 				<button v-if="['WechatMiniProgram', 'WechatOfficialAccount'].includes(sheep.$platform.name)" |         <button | ||||||
| 					@tap="importWechatAddress" |           v-if="['WechatMiniProgram', 'WechatOfficialAccount'].includes(sheep.$platform.name)" | ||||||
| 					class="border ss-reset-button sync-wxaddress ss-m-20 ss-flex ss-row-center ss-col-center"> |           @tap="importWechatAddress" | ||||||
| 					<text class="cicon-weixin ss-p-r-10" style="color: #09bb07; font-size: 40rpx"></text> |           class="border ss-reset-button sync-wxaddress ss-m-20 ss-flex ss-row-center ss-col-center" | ||||||
| 					导入微信地址 |         > | ||||||
| 				</button> |           <text class="cicon-weixin ss-p-r-10" style="color: #09bb07; font-size: 40rpx"></text> | ||||||
| 				<button class="add-btn ss-reset-button ui-Shadow-Main" |           导入微信地址 | ||||||
| 					@tap="sheep.$router.go('/pages/user/address/edit')"> |         </button> | ||||||
| 					新增收货地址 |         <button | ||||||
| 				</button> |           class="add-btn ss-reset-button ui-Shadow-Main" | ||||||
| 			</view> |           @tap="sheep.$router.go('/pages/user/address/edit')" | ||||||
| 		</su-fixed> |         > | ||||||
| 		<s-empty v-if="state.list.length === 0 && !state.loading" text="暂无收货地址" icon="/static/data-empty.png" /> |           新增收货地址 | ||||||
| 	</s-layout> |         </button> | ||||||
|  |       </view> | ||||||
|  |     </su-fixed> | ||||||
|  |     <s-empty | ||||||
|  |       v-if="state.list.length === 0 && !state.loading" | ||||||
|  |       text="暂无收货地址" | ||||||
|  |       icon="/static/data-empty.png" | ||||||
|  |     /> | ||||||
|  |   </s-layout> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script setup> | <script setup> | ||||||
| 	import { reactive, onBeforeMount } from 'vue'; |   import { reactive, onBeforeMount } from 'vue'; | ||||||
| 	import { onShow } from '@dcloudio/uni-app'; |   import { onShow } from '@dcloudio/uni-app'; | ||||||
| 	import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
| 	import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import AreaApi from '@/sheep/api/system/area'; |   import AreaApi from '@/sheep/api/system/area'; | ||||||
|   import AddressApi from '@/sheep/api/member/address'; |   import AddressApi from '@/sheep/api/member/address'; | ||||||
| 
 | 
 | ||||||
| 	const state = reactive({ |   const state = reactive({ | ||||||
| 		list: [], // 地址列表 |     list: [], // 地址列表 | ||||||
| 		loading: true, |     loading: true, | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	// 选择收货地址 |   // 选择收货地址 | ||||||
| 	const onSelect = (addressInfo) => { |   const onSelect = (addressInfo) => { | ||||||
| 		uni.$emit('SELECT_ADDRESS', { |     uni.$emit('SELECT_ADDRESS', { | ||||||
| 			addressInfo, |       addressInfo, | ||||||
| 		}); |     }); | ||||||
| 		sheep.$router.back(); |     sheep.$router.back(); | ||||||
| 	}; |   }; | ||||||
| 
 | 
 | ||||||
| 	// 导入微信地址 |   // 导入微信地址 | ||||||
|   // TODO 芋艿:未测试 |   // TODO 芋艿:未测试 | ||||||
| 	function importWechatAddress() { |   function importWechatAddress() { | ||||||
| 		let wechatAddress = {}; |     let wechatAddress = {}; | ||||||
| 		// #ifdef MP |     // #ifdef MP | ||||||
| 		uni.chooseAddress({ |     uni.chooseAddress({ | ||||||
| 			success: (res) => { |       success: (res) => { | ||||||
| 				wechatAddress = { |         wechatAddress = { | ||||||
| 					consignee: res.userName, |           consignee: res.userName, | ||||||
| 					mobile: res.telNumber, |           mobile: res.telNumber, | ||||||
| 					province_name: res.provinceName, |           province_name: res.provinceName, | ||||||
| 					city_name: res.cityName, |           city_name: res.cityName, | ||||||
| 					district_name: res.countyName, |           district_name: res.countyName, | ||||||
| 					address: res.detailInfo, |           address: res.detailInfo, | ||||||
| 					region: '', |           region: '', | ||||||
| 					is_default: false, |           is_default: false, | ||||||
| 				}; |         }; | ||||||
| 				if (!isEmpty(wechatAddress)) { |         if (!isEmpty(wechatAddress)) { | ||||||
| 					sheep.$router.go('/pages/user/address/edit', { |           sheep.$router.go('/pages/user/address/edit', { | ||||||
| 						data: JSON.stringify(wechatAddress), |             data: JSON.stringify(wechatAddress), | ||||||
| 					}); |           }); | ||||||
| 				} |         } | ||||||
| 			}, |       }, | ||||||
| 			fail: (err) => { |       fail: (err) => { | ||||||
| 				console.log('%cuni.chooseAddress,调用失败', 'color:green;background:yellow'); |         console.log('%cuni.chooseAddress,调用失败', 'color:green;background:yellow'); | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 		// #endif |     // #endif | ||||||
| 		// #ifdef H5 |     // #ifdef H5 | ||||||
| 		sheep.$platform.useProvider('wechat').jssdk.openAddress({ |     sheep.$platform.useProvider('wechat').jssdk.openAddress({ | ||||||
| 			success: (res) => { |       success: (res) => { | ||||||
| 				wechatAddress = { |         wechatAddress = { | ||||||
| 					consignee: res.userName, |           consignee: res.userName, | ||||||
| 					mobile: res.telNumber, |           mobile: res.telNumber, | ||||||
| 					province_name: res.provinceName, |           province_name: res.provinceName, | ||||||
| 					city_name: res.cityName, |           city_name: res.cityName, | ||||||
| 					district_name: res.countryName, |           district_name: res.countryName, | ||||||
| 					address: res.detailInfo, |           address: res.detailInfo, | ||||||
| 					region: '', |           region: '', | ||||||
| 					is_default: false, |           is_default: false, | ||||||
| 				}; |         }; | ||||||
| 				if (!isEmpty(wechatAddress)) { |         if (!isEmpty(wechatAddress)) { | ||||||
| 					sheep.$router.go('/pages/user/address/edit', { |           sheep.$router.go('/pages/user/address/edit', { | ||||||
| 						data: JSON.stringify(wechatAddress), |             data: JSON.stringify(wechatAddress), | ||||||
| 					}); |           }); | ||||||
| 				} |         } | ||||||
| 			}, |       }, | ||||||
| 		}); |     }); | ||||||
| 		// #endif |     // #endif | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	onShow(async () => { |   onShow(async () => { | ||||||
| 		state.list = (await AddressApi.getAddressList()).data; |     state.list = (await AddressApi.getAddressList()).data; | ||||||
| 		state.loading = false; |     state.loading = false; | ||||||
| 	}); |   }); | ||||||
| 
 | 
 | ||||||
| 	onBeforeMount(() => { |   onBeforeMount(() => { | ||||||
| 		if (!!uni.getStorageSync('areaData')) { |     if (!!uni.getStorageSync('areaData')) { | ||||||
| 			return; |       return; | ||||||
| 		} |     } | ||||||
| 		// 提前加载省市区数据 |     // 提前加载省市区数据 | ||||||
|     AreaApi.getAreaTree().then((res) => { |     AreaApi.getAreaTree().then((res) => { | ||||||
| 			if (res.code === 0) { |       if (res.code === 0) { | ||||||
| 				uni.setStorageSync('areaData', res.data); |         uni.setStorageSync('areaData', res.data); | ||||||
| 			} |       } | ||||||
| 		}); |     }); | ||||||
| 	}); |   }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| 	.footer-box { |   .footer-box { | ||||||
| 		.add-btn { |     .add-btn { | ||||||
| 			flex: 1; |       flex: 1; | ||||||
| 			background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); |       background: linear-gradient(90deg, var(--ui-BG-Main), var(--ui-BG-Main-gradient)); | ||||||
| 			border-radius: 80rpx; |       border-radius: 80rpx; | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			line-height: 80rpx; |       line-height: 80rpx; | ||||||
| 			color: $white; |       color: $white; | ||||||
| 			position: relative; |       position: relative; | ||||||
| 			z-index: 1; |       z-index: 1; | ||||||
| 		} |     } | ||||||
| 
 | 
 | ||||||
| 		.sync-wxaddress { |     .sync-wxaddress { | ||||||
| 			flex: 1; |       flex: 1; | ||||||
| 			line-height: 80rpx; |       line-height: 80rpx; | ||||||
| 			background: $white; |       background: $white; | ||||||
| 			border-radius: 80rpx; |       border-radius: 80rpx; | ||||||
| 			font-size: 30rpx; |       font-size: 30rpx; | ||||||
| 			font-weight: 500; |       font-weight: 500; | ||||||
| 			color: $dark-6; |       color: $dark-6; | ||||||
| 			margin-right: 18rpx; |       margin-right: 18rpx; | ||||||
| 		} |     } | ||||||
| 	} |   } | ||||||
| </style> | </style> | ||||||
|  | @ -5,7 +5,8 @@ | ||||||
|       <!-- 头部 --> |       <!-- 头部 --> | ||||||
|       <view class="cart-header ss-flex ss-col-center ss-row-between ss-p-x-30"> |       <view class="cart-header ss-flex ss-col-center ss-row-between ss-p-x-30"> | ||||||
|         <view class="header-left ss-flex ss-col-center ss-font-26"> |         <view class="header-left ss-flex ss-col-center ss-font-26"> | ||||||
|           共 <text class="goods-number ui-TC-Main ss-flex">{{ state.pagination.total }}</text> 件商品 |           共 | ||||||
|  |           <text class="goods-number ui-TC-Main ss-flex">{{ state.pagination.total }}</text> 件商品 | ||||||
|         </view> |         </view> | ||||||
|         <view class="header-right"> |         <view class="header-right"> | ||||||
|           <button |           <button | ||||||
|  | @ -77,7 +78,8 @@ | ||||||
|           <view class="footer-right"> |           <view class="footer-right"> | ||||||
|             <button |             <button | ||||||
|               class="ss-reset-button ui-BG-Main-Gradient pay-btn ss-font-28 ui-Shadow-Main" |               class="ss-reset-button ui-BG-Main-Gradient pay-btn ss-font-28 ui-Shadow-Main" | ||||||
|               @tap="onCancel"> |               @tap="onCancel" | ||||||
|  |             > | ||||||
|               取消收藏 |               取消收藏 | ||||||
|             </button> |             </button> | ||||||
|           </view> |           </view> | ||||||
|  | @ -100,7 +102,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import FavoriteApi from '@/sheep/api/product/favorite'; |   import FavoriteApi from '@/sheep/api/product/favorite'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
| 
 | 
 | ||||||
|  | @ -129,7 +131,7 @@ | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.list = _.concat(state.pagination.list, data.list) |     state.pagination.list = _.concat(state.pagination.list, data.list); | ||||||
|     state.pagination.total = data.total; |     state.pagination.total = data.total; | ||||||
|     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; |     state.loadStatus = state.pagination.list.length < state.pagination.total ? 'more' : 'noMore'; | ||||||
|   } |   } | ||||||
|  | @ -174,7 +176,7 @@ | ||||||
|   // 加载更多 |   // 加载更多 | ||||||
|   function loadMore() { |   function loadMore() { | ||||||
|     if (state.loadStatus === 'noMore') { |     if (state.loadStatus === 'noMore') { | ||||||
|       return |       return; | ||||||
|     } |     } | ||||||
|     state.pagination.pageNo++; |     state.pagination.pageNo++; | ||||||
|     getData(); |     getData(); | ||||||
|  |  | ||||||
|  | @ -81,11 +81,13 @@ | ||||||
|           </view> |           </view> | ||||||
|           <view class="footer-right ss-flex"> |           <view class="footer-right ss-flex"> | ||||||
|             <button |             <button | ||||||
|               :class="['ss-reset-button  pay-btn ss-font-28 ', |               :class="[ | ||||||
|                   { |                 'ss-reset-button  pay-btn ss-font-28 ', | ||||||
|                     'ui-BG-Main-Gradient': state.selectedSpuIdList.length > 0, |                 { | ||||||
|                     'ui-Shadow-Main': state.selectedSpuIdList.length > 0 |                   'ui-BG-Main-Gradient': state.selectedSpuIdList.length > 0, | ||||||
|                   }]" |                   'ui-Shadow-Main': state.selectedSpuIdList.length > 0, | ||||||
|  |                 }, | ||||||
|  |               ]" | ||||||
|               @tap="onDelete" |               @tap="onDelete" | ||||||
|             > |             > | ||||||
|               删除足迹 |               删除足迹 | ||||||
|  | @ -120,9 +122,9 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { reactive } from 'vue'; |   import { reactive } from 'vue'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import SpuHistoryApi from "@/sheep/api/product/history"; |   import SpuHistoryApi from '@/sheep/api/product/history'; | ||||||
|   import {cloneDeep} from "@/sheep/helper/utils"; |   import { cloneDeep } from '@/sheep/helper/utils'; | ||||||
| 
 | 
 | ||||||
|   const sys_navBar = sheep.$platform.navbar; |   const sys_navBar = sheep.$platform.navbar; | ||||||
|   const pagination = { |   const pagination = { | ||||||
|  |  | ||||||
|  | @ -26,7 +26,8 @@ | ||||||
|             <button |             <button | ||||||
|               class="ss-reset-button avatar-action-btn" |               class="ss-reset-button avatar-action-btn" | ||||||
|               open-type="chooseAvatar" |               open-type="chooseAvatar" | ||||||
|               @chooseavatar="onChooseAvatar"> |               @chooseavatar="onChooseAvatar" | ||||||
|  |             > | ||||||
|               修改 |               修改 | ||||||
|             </button> |             </button> | ||||||
|             <!-- #endif --> |             <!-- #endif --> | ||||||
|  | @ -154,10 +155,7 @@ | ||||||
|         </view> |         </view> | ||||||
|         <view class="ss-flex ss-col-center"> |         <view class="ss-flex ss-col-center"> | ||||||
|           <view class="info ss-flex ss-col-center" v-if="state.thirdInfo"> |           <view class="info ss-flex ss-col-center" v-if="state.thirdInfo"> | ||||||
|             <image |             <image class="avatar ss-m-r-20" :src="sheep.$url.cdn(state.thirdInfo.avatar)" /> | ||||||
|               class="avatar ss-m-r-20" |  | ||||||
|               :src="sheep.$url.cdn(state.thirdInfo.avatar)" |  | ||||||
|             /> |  | ||||||
|             <text class="name">{{ state.thirdInfo.nickname }}</text> |             <text class="name">{{ state.thirdInfo.nickname }}</text> | ||||||
|           </view> |           </view> | ||||||
|           <view class="bind-box ss-m-l-20"> |           <view class="bind-box ss-m-l-20"> | ||||||
|  | @ -185,7 +183,7 @@ | ||||||
| <script setup> | <script setup> | ||||||
|   import { computed, reactive, onBeforeMount } from 'vue'; |   import { computed, reactive, onBeforeMount } from 'vue'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { clone } from 'lodash'; |   import { clone } from 'lodash-es'; | ||||||
|   import { showAuthModal } from '@/sheep/hooks/useModal'; |   import { showAuthModal } from '@/sheep/hooks/useModal'; | ||||||
|   import FileApi from '@/sheep/api/infra/file'; |   import FileApi from '@/sheep/api/infra/file'; | ||||||
|   import UserApi from '@/sheep/api/member/user'; |   import UserApi from '@/sheep/api/member/user'; | ||||||
|  | @ -198,14 +196,15 @@ | ||||||
| 
 | 
 | ||||||
|   const placeholderStyle = 'color:#BBBBBB;font-size:28rpx;line-height:normal'; |   const placeholderStyle = 'color:#BBBBBB;font-size:28rpx;line-height:normal'; | ||||||
| 
 | 
 | ||||||
|   const sexRadioMap = [{ |   const sexRadioMap = [ | ||||||
|  |     { | ||||||
|       name: '男', |       name: '男', | ||||||
|       value: '1', |       value: '1', | ||||||
|     }, |     }, | ||||||
|     { |     { | ||||||
|       name: '女', |       name: '女', | ||||||
|       value: '2', |       value: '2', | ||||||
|     } |     }, | ||||||
|   ]; |   ]; | ||||||
| 
 | 
 | ||||||
|   const userInfo = computed(() => sheep.$store('user').userInfo); |   const userInfo = computed(() => sheep.$store('user').userInfo); | ||||||
|  | @ -279,7 +278,7 @@ | ||||||
| 
 | 
 | ||||||
|   // 保存信息 |   // 保存信息 | ||||||
|   async function onSubmit() { |   async function onSubmit() { | ||||||
| 	 const { code } = await UserApi.updateUser({ |     const { code } = await UserApi.updateUser({ | ||||||
|       avatar: state.model.avatar, |       avatar: state.model.avatar, | ||||||
|       nickname: state.model.nickname, |       nickname: state.model.nickname, | ||||||
|       sex: state.model.sex, |       sex: state.model.sex, | ||||||
|  |  | ||||||
|  | @ -13,7 +13,9 @@ | ||||||
|           /> |           /> | ||||||
|         </view> |         </view> | ||||||
|         <view class="ss-flex ss-row-between ss-col-center ss-m-t-64"> |         <view class="ss-flex ss-row-between ss-col-center ss-m-t-64"> | ||||||
|           <view class="money-num">{{ state.showMoney ? fen2yuan(userWallet.balance) : '*****' }}</view> |           <view class="money-num">{{ | ||||||
|  |             state.showMoney ? fen2yuan(userWallet.balance) : '*****' | ||||||
|  |           }}</view> | ||||||
|           <button class="ss-reset-button topup-btn" @tap="sheep.$router.go('/pages/pay/recharge')"> |           <button class="ss-reset-button topup-btn" @tap="sheep.$router.go('/pages/pay/recharge')"> | ||||||
|             充值 |             充值 | ||||||
|           </button> |           </button> | ||||||
|  | @ -24,7 +26,12 @@ | ||||||
|     <su-sticky> |     <su-sticky> | ||||||
|       <!-- 统计 --> |       <!-- 统计 --> | ||||||
|       <view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> |       <view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> | ||||||
|         <uni-datetime-picker v-model="state.data" type="daterange" @change="onChangeTime" :end="state.today"> |         <uni-datetime-picker | ||||||
|  |           v-model="state.data" | ||||||
|  |           type="daterange" | ||||||
|  |           @change="onChangeTime" | ||||||
|  |           :end="state.today" | ||||||
|  |         > | ||||||
|           <button class="ss-reset-button date-btn"> |           <button class="ss-reset-button date-btn"> | ||||||
|             <text>{{ dateFilterText }}</text> |             <text>{{ dateFilterText }}</text> | ||||||
|             <text class="cicon-drop-down ss-seldate-icon"></text> |             <text class="cicon-drop-down ss-seldate-icon"></text> | ||||||
|  | @ -82,7 +89,7 @@ | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import dayjs from 'dayjs'; |   import dayjs from 'dayjs'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import PayWalletApi from '@/sheep/api/pay/wallet'; |   import PayWalletApi from '@/sheep/api/pay/wallet'; | ||||||
|   import { fen2yuan } from '@/sheep/hooks/useGoods'; |   import { fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|  | @ -98,7 +105,7 @@ | ||||||
|       list: [], |       list: [], | ||||||
|       total: 0, |       total: 0, | ||||||
|       pageNo: 1, |       pageNo: 1, | ||||||
|       pageSize: 8 |       pageSize: 8, | ||||||
|     }, |     }, | ||||||
|     summary: { |     summary: { | ||||||
|       totalIncome: 0, |       totalIncome: 0, | ||||||
|  | @ -155,7 +162,7 @@ | ||||||
|   // 获得钱包统计 |   // 获得钱包统计 | ||||||
|   async function getSummary() { |   async function getSummary() { | ||||||
|     const { data, code } = await PayWalletApi.getWalletTransactionSummary({ |     const { data, code } = await PayWalletApi.getWalletTransactionSummary({ | ||||||
|       'createTime': [state.date[0] + ' 00:00:00', state.date[1] + ' 23:59:59'], |       createTime: [state.date[0] + ' 00:00:00', state.date[1] + ' 23:59:59'], | ||||||
|     }); |     }); | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return; | ||||||
|  | @ -226,8 +233,7 @@ | ||||||
|         position: absolute; |         position: absolute; | ||||||
|         top: 0; |         top: 0; | ||||||
|         left: 0; |         left: 0; | ||||||
|         background: v-bind(headerBg) |         background: v-bind(headerBg) no-repeat; | ||||||
|           no-repeat; |  | ||||||
|         pointer-events: none; |         pointer-events: none; | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -24,19 +24,24 @@ | ||||||
|     <su-sticky :customNavHeight="sys_navBar"> |     <su-sticky :customNavHeight="sys_navBar"> | ||||||
|       <!-- 统计 --> |       <!-- 统计 --> | ||||||
|       <view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> |       <view class="filter-box ss-p-x-30 ss-flex ss-col-center ss-row-between"> | ||||||
| 				<uni-datetime-picker v-model="state.date" type="daterange" @change="onChangeTime" :end="state.today"> |         <uni-datetime-picker | ||||||
| 					<button class="ss-reset-button date-btn"> |           v-model="state.date" | ||||||
| 						<text>{{ dateFilterText }}</text> |           type="daterange" | ||||||
| 						<text class="cicon-drop-down ss-seldate-icon"></text> |           @change="onChangeTime" | ||||||
| 					</button> |           :end="state.today" | ||||||
| 				</uni-datetime-picker> |         > | ||||||
|  |           <button class="ss-reset-button date-btn"> | ||||||
|  |             <text>{{ dateFilterText }}</text> | ||||||
|  |             <text class="cicon-drop-down ss-seldate-icon"></text> | ||||||
|  |           </button> | ||||||
|  |         </uni-datetime-picker> | ||||||
| 
 | 
 | ||||||
|         <!-- TODO 芋艿:优化 --> |         <!-- TODO 芋艿:优化 --> | ||||||
| <!--				<view class="total-box">--> |         <!--				<view class="total-box">--> | ||||||
| <!--					<view class="ss-m-b-10">总收入¥{{ state.pagination.income }}</view>--> |         <!--					<view class="ss-m-b-10">总收入¥{{ state.pagination.income }}</view>--> | ||||||
| <!--					<view>总支出¥{{ -state.pagination.expense }}</view>--> |         <!--					<view>总支出¥{{ -state.pagination.expense }}</view>--> | ||||||
| <!--				</view>--> |         <!--				</view>--> | ||||||
| 			</view> |       </view> | ||||||
|       <su-tabs |       <su-tabs | ||||||
|         :list="tabMaps" |         :list="tabMaps" | ||||||
|         @change="onChange" |         @change="onChange" | ||||||
|  | @ -83,7 +88,7 @@ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; |   import { onLoad, onReachBottom } from '@dcloudio/uni-app'; | ||||||
|   import { computed, reactive } from 'vue'; |   import { computed, reactive } from 'vue'; | ||||||
|   import _ from 'lodash'; |   import _ from 'lodash-es'; | ||||||
|   import dayjs from 'dayjs'; |   import dayjs from 'dayjs'; | ||||||
|   import PointApi from '@/sheep/api/member/point'; |   import PointApi from '@/sheep/api/member/point'; | ||||||
|   import { resetPagination } from '@/sheep/util'; |   import { resetPagination } from '@/sheep/util'; | ||||||
|  |  | ||||||
|  | @ -18,9 +18,7 @@ | ||||||
|       <view class="address-text"> |       <view class="address-text"> | ||||||
|         {{ props.item.detailAddress }} |         {{ props.item.detailAddress }} | ||||||
|       </view> |       </view> | ||||||
|       <view class="person-text"> |       <view class="person-text"> {{ props.item.name }} {{ props.item.mobile }} </view> | ||||||
|         {{ props.item.name }} {{ props.item.mobile }} |  | ||||||
|       </view> |  | ||||||
|     </view> |     </view> | ||||||
|     <view v-else> |     <view v-else> | ||||||
|       <view class="address-text ss-m-b-10">请选择收货地址</view> |       <view class="address-text ss-m-b-10">请选择收货地址</view> | ||||||
|  | @ -47,7 +45,7 @@ | ||||||
|    * @slot 								 - 默认插槽 |    * @slot 								 - 默认插槽 | ||||||
|    */ |    */ | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   const props = defineProps({ |   const props = defineProps({ | ||||||
|     item: { |     item: { | ||||||
|       type: Object, |       type: Object, | ||||||
|  |  | ||||||
|  | @ -11,7 +11,11 @@ | ||||||
|       <view v-if="tagStyle.show" class="tag-icon-box"> |       <view v-if="tagStyle.show" class="tag-icon-box"> | ||||||
|         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> |         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> | ||||||
|       </view> |       </view> | ||||||
|       <image class="xs-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="aspectFit"></image> |       <image | ||||||
|  |         class="xs-img-box" | ||||||
|  |         :src="sheep.$url.cdn(data.image || data.picUrl)" | ||||||
|  |         mode="aspectFit" | ||||||
|  |       ></image> | ||||||
|       <view |       <view | ||||||
|         v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show" |         v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show" | ||||||
|         class="xs-goods-content ss-flex-col ss-row-around" |         class="xs-goods-content ss-flex-col ss-row-around" | ||||||
|  | @ -39,14 +43,21 @@ | ||||||
|       <view v-if="tagStyle.show" class="tag-icon-box"> |       <view v-if="tagStyle.show" class="tag-icon-box"> | ||||||
|         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> |         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> | ||||||
|       </view> |       </view> | ||||||
|       <image class="sm-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="aspectFill"></image> |       <image | ||||||
|  |         class="sm-img-box" | ||||||
|  |         :src="sheep.$url.cdn(data.image || data.picUrl)" | ||||||
|  |         mode="aspectFill" | ||||||
|  |       ></image> | ||||||
| 
 | 
 | ||||||
|       <view |       <view | ||||||
|         v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show" |         v-if="goodsFields.title?.show || goodsFields.name?.show || goodsFields.price?.show" | ||||||
|         class="sm-goods-content" |         class="sm-goods-content" | ||||||
|         :style="[{ color: titleColor, width: titleWidth ? titleWidth + 'rpx' : '' }]" |         :style="[{ color: titleColor, width: titleWidth ? titleWidth + 'rpx' : '' }]" | ||||||
|       > |       > | ||||||
|         <view v-if="goodsFields.title?.show || goodsFields.name?.show" class="sm-goods-title ss-line-1 ss-m-b-16"> |         <view | ||||||
|  |           v-if="goodsFields.title?.show || goodsFields.name?.show" | ||||||
|  |           class="sm-goods-title ss-line-1 ss-m-b-16" | ||||||
|  |         > | ||||||
|           {{ data.title || data.name }} |           {{ data.title || data.name }} | ||||||
|         </view> |         </view> | ||||||
|         <view |         <view | ||||||
|  | @ -65,7 +76,11 @@ | ||||||
|       <view v-if="tagStyle.show" class="tag-icon-box"> |       <view v-if="tagStyle.show" class="tag-icon-box"> | ||||||
|         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> |         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> | ||||||
|       </view> |       </view> | ||||||
|       <image class="md-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="widthFix"></image> |       <image | ||||||
|  |         class="md-img-box" | ||||||
|  |         :src="sheep.$url.cdn(data.image || data.picUrl)" | ||||||
|  |         mode="widthFix" | ||||||
|  |       ></image> | ||||||
|       <view |       <view | ||||||
|         class="md-goods-content ss-flex-col ss-row-around ss-p-b-20 ss-p-t-20 ss-p-x-16" |         class="md-goods-content ss-flex-col ss-row-around ss-p-b-20 ss-p-t-20 ss-p-x-16" | ||||||
|         :id="elId" |         :id="elId" | ||||||
|  | @ -106,7 +121,10 @@ | ||||||
|           </view> |           </view> | ||||||
| 
 | 
 | ||||||
|           <view |           <view | ||||||
|             v-if="(goodsFields.original_price?.show||goodsFields.marketPrice?.show) &&( data.original_price > 0|| data.marketPrice > 0)" |             v-if=" | ||||||
|  |               (goodsFields.original_price?.show || goodsFields.marketPrice?.show) && | ||||||
|  |               (data.original_price > 0 || data.marketPrice > 0) | ||||||
|  |             " | ||||||
|             class="goods-origin-price ss-m-t-16 font-OPPOSANS ss-flex" |             class="goods-origin-price ss-m-t-16 font-OPPOSANS ss-flex" | ||||||
|             :style="[{ color: originPriceColor }]" |             :style="[{ color: originPriceColor }]" | ||||||
|           > |           > | ||||||
|  | @ -141,7 +159,11 @@ | ||||||
|       <view v-if="grouponTag" class="groupon-tag ss-flex ss-row-center"> |       <view v-if="grouponTag" class="groupon-tag ss-flex ss-row-center"> | ||||||
|         <view class="tag-icon">拼团</view> |         <view class="tag-icon">拼团</view> | ||||||
|       </view> |       </view> | ||||||
|       <image class="lg-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="aspectFill"></image> |       <image | ||||||
|  |         class="lg-img-box" | ||||||
|  |         :src="sheep.$url.cdn(data.image || data.picUrl)" | ||||||
|  |         mode="aspectFill" | ||||||
|  |       ></image> | ||||||
|       <view class="lg-goods-content ss-flex-1 ss-flex-col ss-row-between ss-p-b-10 ss-p-t-20"> |       <view class="lg-goods-content ss-flex-1 ss-flex-col ss-row-between ss-p-b-10 ss-p-t-20"> | ||||||
|         <view> |         <view> | ||||||
|           <view |           <view | ||||||
|  | @ -177,7 +199,10 @@ | ||||||
|               {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }} |               {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }} | ||||||
|             </view> |             </view> | ||||||
|             <view |             <view | ||||||
|               v-if="(goodsFields.original_price?.show||goodsFields.marketPrice?.show) &&( data.original_price > 0|| data.marketPrice > 0)" |               v-if=" | ||||||
|  |                 (goodsFields.original_price?.show || goodsFields.marketPrice?.show) && | ||||||
|  |                 (data.original_price > 0 || data.marketPrice > 0) | ||||||
|  |               " | ||||||
|               class="goods-origin-price ss-flex ss-col-bottom font-OPPOSANS" |               class="goods-origin-price ss-flex ss-col-bottom font-OPPOSANS" | ||||||
|               :style="[{ color: originPriceColor }]" |               :style="[{ color: originPriceColor }]" | ||||||
|             > |             > | ||||||
|  | @ -192,9 +217,7 @@ | ||||||
|       </view> |       </view> | ||||||
| 
 | 
 | ||||||
|       <slot name="cart"> |       <slot name="cart"> | ||||||
|         <view class="buy-box ss-flex ss-col-center ss-row-center" v-if="buttonShow"> |         <view class="buy-box ss-flex ss-col-center ss-row-center" v-if="buttonShow"> 去购买 </view> | ||||||
|           去购买 |  | ||||||
|         </view> |  | ||||||
|       </slot> |       </slot> | ||||||
|     </view> |     </view> | ||||||
| 
 | 
 | ||||||
|  | @ -204,7 +227,11 @@ | ||||||
|         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> |         <image class="tag-icon" :src="sheep.$url.cdn(tagStyle.src || tagStyle.imgUrl)"></image> | ||||||
|       </view> |       </view> | ||||||
| 
 | 
 | ||||||
|       <image class="sl-img-box" :src="sheep.$url.cdn(data.image || data.picUrl)" mode="aspectFill"></image> |       <image | ||||||
|  |         class="sl-img-box" | ||||||
|  |         :src="sheep.$url.cdn(data.image || data.picUrl)" | ||||||
|  |         mode="aspectFill" | ||||||
|  |       ></image> | ||||||
| 
 | 
 | ||||||
|       <view class="sl-goods-content"> |       <view class="sl-goods-content"> | ||||||
|         <view> |         <view> | ||||||
|  | @ -241,7 +268,10 @@ | ||||||
|               {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }} |               {{ isArray(data.price) ? fen2yuan(data.price[0]) : fen2yuan(data.price) }} | ||||||
|             </view> |             </view> | ||||||
|             <view |             <view | ||||||
|               v-if="(goodsFields.original_price?.show||goodsFields.marketPrice?.show) &&( data.original_price > 0|| data.marketPrice > 0)" |               v-if=" | ||||||
|  |                 (goodsFields.original_price?.show || goodsFields.marketPrice?.show) && | ||||||
|  |                 (data.original_price > 0 || data.marketPrice > 0) | ||||||
|  |               " | ||||||
|               class="goods-origin-price ss-m-t-16 font-OPPOSANS ss-flex" |               class="goods-origin-price ss-m-t-16 font-OPPOSANS ss-flex" | ||||||
|               :style="[{ color: originPriceColor }]" |               :style="[{ color: originPriceColor }]" | ||||||
|             > |             > | ||||||
|  | @ -296,7 +326,7 @@ | ||||||
|   import { fen2yuan, formatSales } from '@/sheep/hooks/useGoods'; |   import { fen2yuan, formatSales } from '@/sheep/hooks/useGoods'; | ||||||
|   import { formatStock } from '@/sheep/hooks/useGoods'; |   import { formatStock } from '@/sheep/hooks/useGoods'; | ||||||
|   import goodsCollectVue from '@/pages/user/goods-collect.vue'; |   import goodsCollectVue from '@/pages/user/goods-collect.vue'; | ||||||
|   import { isArray } from 'lodash'; |   import { isArray } from 'lodash-es'; | ||||||
| 
 | 
 | ||||||
|   // 数据 |   // 数据 | ||||||
|   const state = reactive({}); |   const state = reactive({}); | ||||||
|  |  | ||||||
|  | @ -31,7 +31,11 @@ | ||||||
|         ></view> |         ></view> | ||||||
| 
 | 
 | ||||||
|         <!-- 顶部导航栏-情况4:装修组件导航栏-沉浸式 --> |         <!-- 顶部导航栏-情况4:装修组件导航栏-沉浸式 --> | ||||||
|         <s-custom-navbar v-if="navbar === 'custom' && navbarMode === 'inner'" :data="navbarStyle" :showLeftButton="showLeftButton" /> |         <s-custom-navbar | ||||||
|  |           v-if="navbar === 'custom' && navbarMode === 'inner'" | ||||||
|  |           :data="navbarStyle" | ||||||
|  |           :showLeftButton="showLeftButton" | ||||||
|  |         /> | ||||||
| 
 | 
 | ||||||
|         <!-- 页面内容插槽 --> |         <!-- 页面内容插槽 --> | ||||||
|         <slot /> |         <slot /> | ||||||
|  | @ -58,7 +62,7 @@ | ||||||
|    */ |    */ | ||||||
|   import { computed, reactive, ref } from 'vue'; |   import { computed, reactive, ref } from 'vue'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash-es'; | ||||||
|   import { onShow } from '@dcloudio/uni-app'; |   import { onShow } from '@dcloudio/uni-app'; | ||||||
|   // #ifdef MP-WEIXIN |   // #ifdef MP-WEIXIN | ||||||
|   import { onShareAppMessage } from '@dcloudio/uni-app'; |   import { onShareAppMessage } from '@dcloudio/uni-app'; | ||||||
|  |  | ||||||
|  | @ -1,31 +1,31 @@ | ||||||
| <!-- 秒杀商品的 SKU 选择,和 s-select-sku.vue 类似 --> | <!-- 秒杀商品的 SKU 选择,和 s-select-sku.vue 类似 --> | ||||||
| <template> | <template> | ||||||
| 	<!-- 规格弹窗 --> |   <!-- 规格弹窗 --> | ||||||
| 	<su-popup :show="show" round="10" @close="emits('close')"> |   <su-popup :show="show" round="10" @close="emits('close')"> | ||||||
| 		<!-- SKU 信息 --> |     <!-- SKU 信息 --> | ||||||
| 		<view class="ss-modal-box bg-white ss-flex-col"> |     <view class="ss-modal-box bg-white ss-flex-col"> | ||||||
| 			<view class="modal-header ss-flex ss-col-center"> |       <view class="modal-header ss-flex ss-col-center"> | ||||||
| 				<!-- 规格图 --> |         <!-- 规格图 --> | ||||||
| 				<view class="header-left ss-m-r-30"> |         <view class="header-left ss-m-r-30"> | ||||||
| 					<image |           <image | ||||||
| 						class="sku-image" |             class="sku-image" | ||||||
| 						:src="sheep.$url.cdn(state.selectedSku.picUrl || state.goodsInfo.picUrl)" |             :src="sheep.$url.cdn(state.selectedSku.picUrl || state.goodsInfo.picUrl)" | ||||||
| 						mode="aspectFill" |             mode="aspectFill" | ||||||
| 					> |           > | ||||||
| 					</image> |           </image> | ||||||
| 				</view> |         </view> | ||||||
| 				<view class="header-right ss-flex-col ss-row-between ss-flex-1"> |         <view class="header-right ss-flex-col ss-row-between ss-flex-1"> | ||||||
| 					<!-- 名称 --> |           <!-- 名称 --> | ||||||
| 					<view class="goods-title ss-line-2">{{ state.goodsInfo.name }}</view> |           <view class="goods-title ss-line-2">{{ state.goodsInfo.name }}</view> | ||||||
| 					<view class="header-right-bottom ss-flex ss-col-center ss-row-between"> |           <view class="header-right-bottom ss-flex ss-col-center ss-row-between"> | ||||||
| 						<!-- 价格 --> |             <!-- 价格 --> | ||||||
| 						<view class="price-text"> |             <view class="price-text"> | ||||||
| 							{{ fen2yuan(state.selectedSku.price || state.goodsInfo.price) }} |               {{ fen2yuan(state.selectedSku.price || state.goodsInfo.price) }} | ||||||
| 						</view> |             </view> | ||||||
| 						<!-- 秒杀价格标签 --> |             <!-- 秒杀价格标签 --> | ||||||
| 						<view class="tig ss-flex ss-col-center"> |             <view class="tig ss-flex ss-col-center"> | ||||||
| 							<view class="tig-icon ss-flex ss-col-center ss-row-center"> |               <view class="tig-icon ss-flex ss-col-center ss-row-center"> | ||||||
| 	              <text class="cicon-alarm"></text> |                 <text class="cicon-alarm"></text> | ||||||
|               </view> |               </view> | ||||||
|               <view class="tig-title">秒杀价</view> |               <view class="tig-title">秒杀价</view> | ||||||
|             </view> |             </view> | ||||||
|  | @ -91,8 +91,8 @@ | ||||||
|   // 按钮状态: active,nostock |   // 按钮状态: active,nostock | ||||||
|   import { computed, reactive, watch } from 'vue'; |   import { computed, reactive, watch } from 'vue'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import {convertProductPropertyList, fen2yuan} from "@/sheep/hooks/useGoods"; |   import { convertProductPropertyList, fen2yuan } from '@/sheep/hooks/useGoods'; | ||||||
|   import {min} from "lodash"; |   import { min } from 'lodash-es'; | ||||||
|   const emits = defineEmits(['change', 'addCart', 'buy', 'close']); |   const emits = defineEmits(['change', 'addCart', 'buy', 'close']); | ||||||
|   const props = defineProps({ |   const props = defineProps({ | ||||||
|     modelValue: { |     modelValue: { | ||||||
|  | @ -107,7 +107,7 @@ | ||||||
|     singleLimitCount: { |     singleLimitCount: { | ||||||
|       type: Number, |       type: Number, | ||||||
|       default: 1, |       default: 1, | ||||||
|     } |     }, | ||||||
|   }); |   }); | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|     goodsInfo: computed(() => props.modelValue), |     goodsInfo: computed(() => props.modelValue), | ||||||
|  | @ -120,7 +120,7 @@ | ||||||
|   const skuList = computed(() => { |   const skuList = computed(() => { | ||||||
|     let skuPrices = state.goodsInfo.skus; |     let skuPrices = state.goodsInfo.skus; | ||||||
|     for (let price of skuPrices) { |     for (let price of skuPrices) { | ||||||
|       price.value_id_array = price.properties.map((item) => item.valueId) |       price.value_id_array = price.properties.map((item) => item.valueId); | ||||||
|     } |     } | ||||||
|     return skuPrices; |     return skuPrices; | ||||||
|   }); |   }); | ||||||
|  | @ -228,7 +228,7 @@ | ||||||
|       // 如果当前 property id 不存在于有库存的 SKU 中,则禁用 |       // 如果当前 property id 不存在于有库存的 SKU 中,则禁用 | ||||||
|       for (let valueIndex in propertyList[propertyIndex]['values']) { |       for (let valueIndex in propertyList[propertyIndex]['values']) { | ||||||
|         propertyList[propertyIndex]['values'][valueIndex]['disabled'] = |         propertyList[propertyIndex]['values'][valueIndex]['disabled'] = | ||||||
|             noChooseValueIds.indexOf(propertyList[propertyIndex]['values'][valueIndex]['id']) < 0; // true 禁用 or false 不禁用 |           noChooseValueIds.indexOf(propertyList[propertyIndex]['values'][valueIndex]['id']) < 0; // true 禁用 or false 不禁用 | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|  | @ -258,7 +258,10 @@ | ||||||
|   const onSelectSku = (propertyId, valueId) => { |   const onSelectSku = (propertyId, valueId) => { | ||||||
|     // 清空已选择 |     // 清空已选择 | ||||||
|     let isChecked = true; // 选中 or 取消选中 |     let isChecked = true; // 选中 or 取消选中 | ||||||
|     if (state.currentPropertyArray[propertyId] !== undefined && state.currentPropertyArray[propertyId] === valueId) { |     if ( | ||||||
|  |       state.currentPropertyArray[propertyId] !== undefined && | ||||||
|  |       state.currentPropertyArray[propertyId] === valueId | ||||||
|  |     ) { | ||||||
|       // 点击已被选中的,删除并填充 '' |       // 点击已被选中的,删除并填充 '' | ||||||
|       isChecked = false; |       isChecked = false; | ||||||
|       state.currentPropertyArray.splice(propertyId, 1, ''); |       state.currentPropertyArray.splice(propertyId, 1, ''); | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ | ||||||
|  * @param {Object} device - 设备信息 |  * @param {Object} device - 设备信息 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| import { isEmpty } from 'lodash'; | import { isEmpty } from 'lodash-es'; | ||||||
| // #ifdef H5
 | // #ifdef H5
 | ||||||
| import { isWxBrowser } from '@/sheep/helper/utils'; | import { isWxBrowser } from '@/sheep/helper/utils'; | ||||||
| // #endif
 | // #endif
 | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| import $store from '@/sheep/store'; | import $store from '@/sheep/store'; | ||||||
| import { showAuthModal, showShareModal } from '@/sheep/hooks/useModal'; | import { showAuthModal, showShareModal } from '@/sheep/hooks/useModal'; | ||||||
| import { isNumber, isString, isEmpty, startsWith, isObject, isNil, clone } from 'lodash'; | import { isNumber, isString, isEmpty, startsWith, isObject, isNil, clone } from 'lodash-es'; | ||||||
| import throttle from '@/sheep/helper/throttle'; | import throttle from '@/sheep/helper/throttle'; | ||||||
| 
 | 
 | ||||||
| const _go = ( | const _go = ( | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| import { defineStore } from 'pinia'; | import { defineStore } from 'pinia'; | ||||||
| import $share from '@/sheep/platform/share'; | import $share from '@/sheep/platform/share'; | ||||||
| import { clone, cloneDeep } from 'lodash'; | import { clone, cloneDeep } from 'lodash-es'; | ||||||
| import cart from './cart'; | import cart from './cart'; | ||||||
| import app from './app'; | import app from './app'; | ||||||
| import { showAuthModal } from '@/sheep/hooks/useModal'; | import { showAuthModal } from '@/sheep/hooks/useModal'; | ||||||
|  | @ -68,12 +68,12 @@ const user = defineStore({ | ||||||
| 
 | 
 | ||||||
|     // 获取订单、优惠券等其他资产信息
 |     // 获取订单、优惠券等其他资产信息
 | ||||||
|     getNumData() { |     getNumData() { | ||||||
|       OrderApi.getOrderCount().then(res => { |       OrderApi.getOrderCount().then((res) => { | ||||||
|         if (res.code === 0) { |         if (res.code === 0) { | ||||||
|           this.numData.orderCount = res.data; |           this.numData.orderCount = res.data; | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|       CouponApi.getUnusedCouponCount().then(res => { |       CouponApi.getUnusedCouponCount().then((res) => { | ||||||
|         if (res.code === 0) { |         if (res.code === 0) { | ||||||
|           this.numData.unusedCouponCount = res.data; |           this.numData.unusedCouponCount = res.data; | ||||||
|         } |         } | ||||||
|  | @ -143,20 +143,22 @@ const user = defineStore({ | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       // 绑定推广员
 |       // 绑定推广员
 | ||||||
|       $share.bindBrokerageUser() |       $share.bindBrokerageUser(); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     // 登出系统
 |     // 登出系统
 | ||||||
|     async logout() { |     async logout() { | ||||||
|       this.resetUserData(); |       this.resetUserData(); | ||||||
|       return !this.isLogin; |       return !this.isLogin; | ||||||
|     } |     }, | ||||||
|   }, |   }, | ||||||
|   persist: { |   persist: { | ||||||
|     enabled: true, |     enabled: true, | ||||||
|     strategies: [{ |     strategies: [ | ||||||
|       key: 'user-store', |       { | ||||||
|     }] |         key: 'user-store', | ||||||
|  |       }, | ||||||
|  |     ], | ||||||
|   }, |   }, | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -88,7 +88,7 @@ | ||||||
| 
 | 
 | ||||||
|   import { reactive, computed } from 'vue'; |   import { reactive, computed } from 'vue'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|   import { clone } from 'lodash'; |   import { clone } from 'lodash-es'; | ||||||
| 
 | 
 | ||||||
|   // 数据 |   // 数据 | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|  | @ -196,11 +196,11 @@ | ||||||
|   const onPreview = () => { |   const onPreview = () => { | ||||||
|     if (!props.isPreview) return; |     if (!props.isPreview) return; | ||||||
|     let previewImage = clone(props.list); |     let previewImage = clone(props.list); | ||||||
|     previewImage.forEach((item,index) => { |     previewImage.forEach((item, index) => { | ||||||
|       if(item.type === 'video') { |       if (item.type === 'video') { | ||||||
|         previewImage.splice(index, 1); |         previewImage.splice(index, 1); | ||||||
|       } |       } | ||||||
|     }) |     }); | ||||||
|     uni.previewImage({ |     uni.previewImage({ | ||||||
|       urls: |       urls: | ||||||
|         previewImage.length < 1 |         previewImage.length < 1 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 芋道源码
						芋道源码